Greasy Fork is available in English.

pops

纯JavaScript编写的弹窗,内置方法confirm、alert、prompt、loading、iframe、isPhone、tooltip、folder、panel、rightClickMenu。

Ten skrypt nie powinien być instalowany bezpośrednio. Jest to biblioteka dla innych skyptów do włączenia dyrektywą meta // @require https://update.greasyfork.org/scripts/456485/1360571/pops.js

/// <reference path="../DOMUtils/core.d.ts" />
(function (global, factory) {
  /**
   * 不使用define
   * typeof define === "function" && define.amd
   * define(factory)
   */
  if (typeof exports === "object" && typeof module !== "undefined") {
    /* 适用于NodeJs或typeScript */
    module.exports = factory();
  } else {
    global = typeof globalThis !== "undefined" ? globalThis : global || self;
    /* 适用于浏览器中,且this对象是window,如果this是其它,那么会在其它对象下注册对象 */
    global.pops = factory(global.pops);
  }
})(typeof window !== "undefined" ? window : this, function (AnotherPops) {
  "use strict";

  const OriginPrototype = {
    Object: {
      defineProperty: Object.defineProperty,
    },
  };

  /** 工具类 */
  const PopsUtils = {
    /** .on绑定的事件 @type {unique symbol} */
    SymbolEvents: Symbol(
      "events_" +
        (((1 + Math.random()) * 0x10000) | 0).toString(16).substring(1)
    ),
    assignJSON(target, source) {
      /* JSON数据存在即替换 */
      if (source == null) {
        return target;
      }
      for (var target_key in target) {
        if (typeof source[target_key] !== "undefined") {
          if (
            typeof source[target_key] === "object" &&
            !(source[target_key] instanceof Node)
          ) {
            target[target_key] = this.assignJSON(
              target[target_key],
              source[target_key]
            );
          } else {
            target[target_key] = source[target_key];
          }
        }
      }
      return target;
    },
    /**
     * 字符串转HTMLElement
     * @param {string} elementString
     * @returns {HTMLElement}
     */
    parseTextToDOM(elementString) {
      /* 去除前后的换行和空格 */
      elementString = elementString
        .replace(/^[\n|\s]*/g, "")
        .replace(/[\n|\s]*$/g, "");
      let targetElement = PopsDOMUtils.createElement("div", {
        innerHTML: elementString,
      });
      return targetElement.firstChild;
    },
    /**
     * 生成随机GUID
     * @returns {string}
     */
    getRandomGUID() {
      function randomId() {
        return (((1 + Math.random()) * 0x10000) | 0).toString(16).substring(1);
      }
      return `${randomId()}${randomId()}-${randomId()}-${randomId()}-${randomId()}-${randomId()}${randomId()}${randomId()}`;
    },
    /**
     * 判断元素/页面中是否包含该元素
     * @param {HTMLElement} target (可选)
     * @param {HTMLElement[]|HTMLElement} sourceList
     */
    contains(target, sourceList) {
      if (arguments.length === 1) {
        return this.contains(
          document.body || document.documentElement,
          arguments[0]
        );
      }
      if (typeof sourceList[Symbol.iterator] === "function") {
        let flag = true;
        for (const sourceNode of sourceList) {
          if (!target.contains(sourceNode)) {
            flag = false;
            break;
          }
        }
        return flag;
      } else {
        return this.contains(target, [sourceList]);
      }
    },
    /**
     * 元素后追加元素
     * @param {HTMLElement} target (可选)
     * @param {HTMLElement[]|HTMLElement} sourceList
     */
    appendChild(target, sourceList) {
      if (arguments.length === 1) {
        this.appendChild(
          document.body || document.documentElement,
          arguments[0]
        );
        return;
      }
      if (typeof sourceList[Symbol.iterator] === "function") {
        sourceList.forEach((item) => {
          this.appendChild(target, item);
        });
        return;
      }

      target.appendChild(sourceList);
    },
    /**
     * 删除配置中对应的对象
     * @param {any[]} targets
     * @param {string} guid
     * @param {boolean} removeAll 是否全部删除
     * @returns
     */
    configRemove(targets, guid, removeAll = false) {
      /**
       *
       * @param {PopsLayerCommonConfig} item
       */
      function removeItem(item) {
        item?.animElement?.remove();
        item?.popsElement?.remove();
        item?.maskElement?.remove();
        item?.$shadowContainer?.remove();
      }
      targets.forEach((target) => {
        target.forEach(
          /**
           * @param {PopsLayerCommonConfig} item
           * @param {number} index
           */
          (item, index) => {
            if (removeAll || item["guid"] === guid) {
              if (
                pops.config.animation.hasOwnProperty(
                  item.animElement.getAttribute("anim")
                )
              ) {
                item.animElement.style.width = "100%";
                item.animElement.style.height = "100%";
                item.animElement.style["animation-name"] =
                  item.animElement.getAttribute("anim") + "-reverse";
                if (
                  pops.config.animation.hasOwnProperty(
                    item.animElement.style["animation-name"]
                  )
                ) {
                  PopsDOMUtils.on(
                    item.animElement,
                    PopsDOMUtils.getAnimationEndNameList(),
                    void 0,
                    function () {
                      removeItem(item);
                    },
                    {
                      capture: true,
                    }
                  );
                } else {
                  removeItem(item);
                }
              } else {
                removeItem(item);
              }
              target.splice(index, 1);
            }
          }
        );
      });

      return targets;
    },
    /**
     * 隐藏
     * @param {"alert"|"confirm"|"prompt"|"loading"|"iframe"|"drawer"} popsType
     * @param {any[]} source
     * @param {string} guid
     * @param {PopsAlertDetails|PopsDrawerDetails|PopsPromptDetails|PopsConfirmDetails|PopsIframeDetails|PopsLoadingDetails|PopsPanelDetails|PopsFolderDetails} config
     * @param {HTMLElement} animElement
     * @param {HTMLElement} maskElement
     */
    hide(popsType, source, guid, config, animElement, maskElement) {
      let popsElement = animElement.querySelector(".pops[type-value]");
      if (popsType === "drawer") {
        setTimeout(() => {
          maskElement.style.setProperty("display", "none");
          if (["top", "bottom"].includes(config.direction)) {
            popsElement.style.setProperty("height", 0);
          } else if (["left", "right"].includes(config.direction)) {
            popsElement.style.setProperty("width", 0);
          } else {
            console.error("未知direction:", config.direction);
          }
        }, config.closeDelay);
      } else {
        source.forEach((item) => {
          if (item.guid === guid) {
            /* 存在动画 */
            item.animElement.style.width = "100%";
            item.animElement.style.height = "100%";
            item.animElement.style["animation-name"] =
              item.animElement.getAttribute("anim") + "-reverse";
            if (
              pops.config.animation.hasOwnProperty(
                item.animElement.style["animation-name"]
              )
            ) {
              function animationendCallBack() {
                item.animElement.style.display = "none";
                if (item.maskElement) {
                  item.maskElement.style.display = "none";
                }
                PopsDOMUtils.off(
                  item.animElement,
                  PopsDOMUtils.getAnimationEndNameList(),
                  void 0,
                  animationendCallBack,
                  {
                    capture: true,
                  }
                );
              }
              PopsDOMUtils.on(
                item.animElement,
                PopsDOMUtils.getAnimationEndNameList(),
                void 0,
                animationendCallBack,
                {
                  capture: true,
                }
              );
            } else {
              item.animElement.style.display = "none";
              if (item.maskElement) {
                item.maskElement.style.display = "none";
              }
            }

            return;
          }
        });
      }
    },
    /**
     * 显示
     * @param {"alert"|"confirm"|"prompt"|"loading"|"iframe"|"drawer"} popsType
     * @param {any[]} source
     * @param {string} guid
     * @param {PopsAlertDetails|PopsDrawerDetails|PopsPromptDetails|PopsConfirmDetails|PopsIframeDetails|PopsLoadingDetails|PopsPanelDetails|PopsFolderDetails} config
     * @param {HTMLElement} animElement
     * @param {HTMLElement} maskElement
     */
    show(popsType, source, guid, config, animElement, maskElement) {
      let popsElement = animElement.querySelector(".pops[type-value]");
      if (popsType === "drawer") {
        setTimeout(() => {
          maskElement.style.setProperty("display", "");
          if (["top", "bottom"].includes(config.direction)) {
            popsElement.style.setProperty("height", config.size);
          } else if (["left", "right"].includes(config.direction)) {
            popsElement.style.setProperty("width", config.size);
          } else {
            console.error("未知direction:", config.direction);
          }
        }, config.openDelay);
      } else {
        source.forEach((item) => {
          if (item.guid === guid) {
            item.animElement.style.width = "";
            item.animElement.style.height = "";
            item.animElement.style["animation-name"] = item.animElement
              .getAttribute("anim")
              .replace("-reverse", "");
            if (
              pops.config.animation.hasOwnProperty(
                item.animElement.style["animation-name"]
              )
            ) {
              item.animElement.style.display = "";
              if (item.maskElement) {
                item.maskElement.style.display = "";
              }
              function animationendCallBack() {
                PopsDOMUtils.off(
                  item.animElement,
                  PopsDOMUtils.getAnimationEndNameList(),
                  void 0,
                  animationendCallBack,
                  {
                    capture: true,
                  }
                );
              }
              PopsDOMUtils.on(
                item.animElement,
                PopsDOMUtils.getAnimationEndNameList(),
                void 0,
                animationendCallBack,
                {
                  capture: true,
                }
              );
            } else {
              item.animElement.style.display = "";
              if (item.maskElement) {
                item.maskElement.style.display = "";
              }
            }
          }
          return;
        });
      }
    },
    /**
     * 关闭
     * @param {string} popsType
     * @param {any} source
     * @param {string} guid
     * @param {PopsAlertDetails|PopsDrawerDetails|PopsPromptDetails|PopsConfirmDetails|PopsIframeDetails|PopsLoadingDetails|PopsPanelDetails|PopsFolderDetails} config
     * @param {HTMLElement} animElement
     */
    close(popsType, source, guid, config, animElement) {
      let popsElement = animElement.querySelector(".pops[type-value]");
      /**
       * 动画结束事件
       */
      function transitionendEvent() {
        /**
         *
         * @param {TransitionEvent} event
         */
        function closeCallBack(event) {
          if (event.propertyName !== "transform") {
            return;
          }
          PopsDOMUtils.off(
            popsElement,
            PopsDOMUtils.getTransitionEndNameList(),
            void 0,
            closeCallBack
          );
          PopsUtils.configRemove([source], guid);
        }
        /* 监听过渡结束 */
        PopsDOMUtils.on(
          popsElement,
          PopsDOMUtils.getTransitionEndNameList(),
          void 0,
          closeCallBack
        );
        let popsTransForm = getComputedStyle(popsElement).transform;
        if (popsTransForm !== "none") {
          PopsDOMUtils.trigger(
            popsElement,
            PopsDOMUtils.getTransitionEndNameList(),
            void 0,
            true
          );
          return;
        }
        if (["top"].includes(config.direction)) {
          popsElement.style.setProperty("transform", "translateY(-100%)");
        } else if (["bottom"].includes(config.direction)) {
          popsElement.style.setProperty("transform", "translateY(100%)");
        } else if (["left"].includes(config.direction)) {
          popsElement.style.setProperty("transform", "translateX(-100%)");
        } else if (["right"].includes(config.direction)) {
          popsElement.style.setProperty("transform", "translateX(100%)");
        } else {
          console.error("未知direction:", config.direction);
        }
      }

      if (popsType === "drawer") {
        setTimeout(() => {
          transitionendEvent();
        }, config.closeDelay);
      } else {
        PopsUtils.configRemove([source], guid);
      }
    },
    /**
     * 获取所有弹窗中的最大的z-index
     * @param {number} defaultValue
     */
    getPopsMaxZIndex(defaultValue) {
      let maxZIndex = 0;
      let maxZIndexElement = null;

      Object.keys(pops.config.layer).forEach((item) => {
        pops.config.layer[item].forEach(
          /**
           * @param {PopsLayerCommonConfig} item2
           */
          (item2) => {
            let itemZIndex = parseInt(
              getComputedStyle(item2["animElement"]).zIndex
            );
            maxZIndexElement =
              itemZIndex > maxZIndex ? item2["animElement"] : maxZIndexElement;
            maxZIndex = itemZIndex > maxZIndex ? itemZIndex : maxZIndex;
          }
        );
      });
      maxZIndex = maxZIndex === 0 ? defaultValue : maxZIndex;
      return { zIndex: maxZIndex, animElement: maxZIndexElement };
    },
    /**
     * 获取CSS Rule
     * @param {StyleSheet} sheet
     * @returns
     */
    getKeyFrames(sheet) {
      let result = {};
      Object.keys(sheet.cssRules).forEach((key) => {
        if (
          sheet.cssRules[key].type === 7 &&
          sheet.cssRules[key].name.startsWith("pops-anim-")
        ) {
          result[sheet.cssRules[key].name] = sheet.cssRules[key];
        }
      });
      return result;
    },
    /**
     * 拖拽元素
     * 说明:
     * + 元素的position为absolute或者fixed
     * + 会为元素的
     * @param {HTMLElement} moveElement
     * @param {{
     * dragElement: HTMLElement,
     * limit: boolean,
     * extraDistance: number,
     * container: Element|Window,
     * moveCallBack?: (moveElement: HTMLElement,left: number,top: number) => void,
     * endCallBack?: (moveElement: HTMLElement,left: number,top: number) => void,
     * preventEvent?: (event: TouchEvent|PointerEvent) => boolean;
     * }} options
     */
    drag(moveElement, options = {}) {
      options = Object.assign(
        {
          limit: true,
          extraDistance: 3,
          container: globalThis,
        },
        options
      );
      let isMove = false;
      /* 点击元素,left偏移 */
      let clickElementLeftOffset = 0;
      /* 点击元素,top偏移 */
      let clickElementTopOffset = 0;
      let AnyTouch = PopsUtils.AnyTouch();
      let anyTouchElement = new AnyTouch(options.dragElement, {
        preventEvent(event) {
          if (typeof options.preventEvent === "function") {
            return options.preventEvent(event);
          } else {
            return false;
          }
        },
      });
      PopsDOMUtils.css(options.dragElement, {
        cursor: "move",
      });
      /**
       * 获取移动元素的transform偏移
       */
      function getTransform(element) {
        let transform_left = 0;
        let transform_top = 0;
        let elementTransform = globalThis.getComputedStyle(element).transform;
        if (
          elementTransform !== "none" &&
          elementTransform != null &&
          elementTransform !== ""
        ) {
          let elementTransformSplit = elementTransform
            .match(/\((.+)\)/)[1]
            .split(",");
          transform_left = Math.abs(parseInt(elementTransformSplit[4]));
          transform_top = Math.abs(parseInt(elementTransformSplit[5]));
        }
        return {
          transformLeft: transform_left,
          transformTop: transform_top,
        };
      }
      /**
       * 修改移动的元素的style
       */
      function changeMoveElementStyle(element) {
        let old_transitionDuration = element.style.transitionDuration;
        if (globalThis.getComputedStyle(element).transitionDuration !== "0s") {
          element.style.transitionDuration = "0s";
        }
        return () => {
          element.style.transitionDuration = old_transitionDuration;
        };
      }
      /**
       * 获取容器的高度、宽度,一般是window为容器
       */
      function getContainerWidthOrHeight(container) {
        container = container ?? globalThis;
        return {
          width: PopsDOMUtils.width(container),
          height: PopsDOMUtils.height(container),
        };
      }
      /**
       * 获取容器的最小left、top偏移
       */
      function getContainerTopOrLeft(container) {
        container = container ?? globalThis;
        if (PopsUtils.isWin(container)) {
          return {
            left: 0,
            top: 0,
          };
        } else {
          let rect = container.getBoundingClientRect();
          return {
            left: rect.left,
            top: rect.top,
          };
        }
      }
      let transformInfo = getTransform(moveElement);
      let transformLeft = transformInfo.transformLeft;
      let transformTop = transformInfo.transformTop;
      let resumeMoveElementStyle = null;
      anyTouchElement.on("pan", function (event) {
        if (!isMove) {
          isMove = true;
          let rect = options.dragElement.getBoundingClientRect();
          clickElementLeftOffset = event.x - rect.left;
          clickElementTopOffset = event.y - rect.top;
          transformInfo = getTransform(moveElement);
          transformLeft = transformInfo.transformLeft;
          transformTop = transformInfo.transformTop;
          //if (event.nativeEvent.offsetX) {
          //  clickElementLeftOffset = parseInt(event.nativeEvent.offsetX);
          //} else {
          //  clickElementLeftOffset = parseInt(event.getOffset().x);
          //}
          //if (event.nativeEvent.offsetY) {
          //  clickElementTopOffset = parseInt(event.nativeEvent.offsetY);
          //} else {
          //  clickElementTopOffset = parseInt(event.getOffset().y);
          //}
          resumeMoveElementStyle = changeMoveElementStyle(moveElement);
        }

        /** 当前移动的left偏移 */
        let currentMoveLeftOffset =
          event.x - clickElementLeftOffset + transformLeft;
        /** 当前移动的top偏移 */
        let currentMoveTopOffset =
          event.y - clickElementTopOffset + transformTop;
        /* 拖拽移动 */
        if (event.phase === "move") {
          if (options.limit) {
            /* 限制在容器内移动 */
            /* left偏移最大值 */
            let maxLeftOffset =
              getContainerWidthOrHeight(options.container).width -
              PopsDOMUtils.width(moveElement) +
              transformLeft;
            let { left: minLeftOffset, top: minTopOffset } =
              getContainerTopOrLeft(options.container);
            /* top偏移的最大值 */
            let maxTopOffset =
              getContainerWidthOrHeight(options.container).height -
              PopsDOMUtils.height(moveElement) +
              transformTop;
            if (currentMoveLeftOffset > maxLeftOffset) {
              /* 不允许超过容器的最大宽度 */
              currentMoveLeftOffset = maxLeftOffset;
            }
            if (currentMoveTopOffset > maxTopOffset) {
              /* 不允许超过容器的最大高度 */
              currentMoveTopOffset = maxTopOffset;
            }
            if (
              currentMoveLeftOffset - options.extraDistance * 2 <
              minLeftOffset + transformLeft
            ) {
              /* 不允许left偏移小于容器最小值 */
              currentMoveLeftOffset = minLeftOffset + transformLeft;
              /* 最左边 +额外距离 */
              currentMoveLeftOffset += options.extraDistance;
            } else {
              /* 最右边 -额外距离 */
              currentMoveLeftOffset -= options.extraDistance;
            }
            if (
              currentMoveTopOffset - options.extraDistance * 2 <
              minTopOffset + transformTop
            ) {
              /* 不允许top偏移小于容器最小值 */
              currentMoveTopOffset = minTopOffset + transformTop;
              /* 最上面 +额外距离 */
              currentMoveTopOffset += options.extraDistance;
            } else {
              /* 最下面 -额外距离 */
              currentMoveTopOffset -= options.extraDistance;
            }
          }
          if (typeof options.moveCallBack === "function") {
            options.moveCallBack(
              moveElement,
              currentMoveLeftOffset,
              currentMoveTopOffset
            );
          }
          PopsDOMUtils.css(moveElement, {
            left: currentMoveLeftOffset + "px",
            top: currentMoveTopOffset + "px",
          });
        }

        /* 停止拖拽 */
        if (event.phase === "end") {
          isMove = false;
          if (typeof resumeMoveElementStyle === "function") {
            resumeMoveElementStyle();
            resumeMoveElementStyle = null;
          }
          if (typeof options.endCallBack === "function") {
            options.endCallBack(
              moveElement,
              currentMoveLeftOffset,
              currentMoveTopOffset
            );
          }
        }
      });
      /* 因为会覆盖上面的点击事件,主动触发一下 */
      anyTouchElement.on(["click", "tap"], function (event) {
        event.changedPoints.forEach((item) => {
          PopsDOMUtils.trigger(item.target, "click", void 0, transformLeft);
        });
      });
    },
    /**
     * AnyTouch
     * + https://fastly.jsdelivr.net/npm/any-touch@2.2.0/dist/any-touch.umd.min.js
     * + https://github.com/any86/any-touch/blob/master/README.CN.md
     */
    AnyTouch() {
      let anyTouch = null;
      (function (global, factory) {
        anyTouch = factory();
      })(this, function () {
        "use strict";

        /*! *****************************************************************************
        Copyright (c) Microsoft Corporation.
    
        Permission to use, copy, modify, and/or distribute this software for any
        purpose with or without fee is hereby granted.
    
        THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
        REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
        AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
        INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
        LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
        OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
        PERFORMANCE OF THIS SOFTWARE.
        ***************************************************************************** */
        /* global Reflect, Promise */

        var extendStatics = function (d, b) {
          extendStatics =
            Object.setPrototypeOf ||
            ({ __proto__: [] } instanceof Array &&
              function (d, b) {
                d.__proto__ = b;
              }) ||
            function (d, b) {
              for (var p in b)
                if (Object.hasOwnProperty.call(b, p)) d[p] = b[p];
            };
          return extendStatics(d, b);
        };

        function __extends(d, b) {
          if (typeof b !== "function" && b !== null)
            throw new TypeError(
              "Class extends value " +
                String(b) +
                " is not a constructor or null"
            );
          extendStatics(d, b);
          function __() {
            this.constructor = d;
          }
          d.prototype =
            b === null
              ? Object.create(b)
              : ((__.prototype = b.prototype), new __());
        }

        var __assign = function () {
          __assign =
            Object.assign ||
            function __assign(t) {
              for (var s, i = 1, n = arguments.length; i < n; i++) {
                s = arguments[i];
                for (var p in s)
                  if (Object.hasOwnProperty.call(s, p)) t[p] = s[p];
              }
              return t;
            };
          return __assign.apply(this, arguments);
        };

        function __values(o) {
          var s = typeof Symbol === "function" && Symbol.iterator,
            m = s && o[s],
            i = 0;
          if (m) return m.call(o);
          if (o && typeof o.length === "number")
            return {
              next: function () {
                if (o && i >= o.length) o = void 0;
                return { value: o && o[i++], done: !o };
              },
            };
          throw new TypeError(
            s ? "Object is not iterable." : "Symbol.iterator is not defined."
          );
        }

        var AnyEvent = (function () {
          function AnyEvent() {
            this.__map = {};
          }
          AnyEvent.prototype.beforeEach = function (interceptor) {
            this.__interceptor = interceptor;
          };
          AnyEvent.prototype.on = function (typeOrTypes, listener) {
            var e_1, _a;
            var types = Array.isArray(typeOrTypes)
              ? typeOrTypes
              : [typeOrTypes];
            try {
              for (
                var types_1 = __values(types), types_1_1 = types_1.next();
                !types_1_1.done;
                types_1_1 = types_1.next()
              ) {
                var type = types_1_1.value;
                this.__map[type] = this.__map[type] || [];
                var listeners = this.__map[type];
                if (listeners) {
                  listeners.push(listener);
                }
              }
            } catch (e_1_1) {
              e_1 = { error: e_1_1 };
            } finally {
              try {
                if (types_1_1 && !types_1_1.done && (_a = types_1.return))
                  _a.call(types_1);
              } finally {
                if (e_1) throw e_1.error;
              }
            }
            return this;
          };
          AnyEvent.prototype.emit = function (type, payload, callback) {
            var _this = this;
            if (void 0 !== this.__interceptor) {
              this.__interceptor(type, function () {
                _this.__emit(type, payload);
                callback && callback();
              });
            } else {
              this.__emit(type, payload);
              callback && callback();
            }
          };
          AnyEvent.prototype.__emit = function (type, event) {
            var e_2, _a;
            var listeners = this.__map[type];
            if (
              Array.isArray(listeners) &&
              (listeners === null || listeners === void 0
                ? void 0
                : listeners.length)
            ) {
              try {
                for (
                  var listeners_1 = __values(listeners),
                    listeners_1_1 = listeners_1.next();
                  !listeners_1_1.done;
                  listeners_1_1 = listeners_1.next()
                ) {
                  var listener = listeners_1_1.value;
                  listener(event, type);
                }
              } catch (e_2_1) {
                e_2 = { error: e_2_1 };
              } finally {
                try {
                  if (
                    listeners_1_1 &&
                    !listeners_1_1.done &&
                    (_a = listeners_1.return)
                  )
                    _a.call(listeners_1);
                } finally {
                  if (e_2) throw e_2.error;
                }
              }
            }
            this.event = event;
          };
          AnyEvent.prototype.off = function (type, listener) {
            var listeners = this.__map[type];
            if (void 0 !== listeners) {
              if (void 0 === listener) {
                delete this.__map[type];
              } else {
                var index = listeners.findIndex(function (cb) {
                  return cb === listener;
                });
                listeners.splice(index, 1);
              }
            }
          };
          AnyEvent.prototype.destroy = function () {
            this.__map = {};
          };
          return AnyEvent;
        })();

        var TOUCH_START = "touchstart";
        var TOUCH_MOVE = "touchmove";
        var TOUCH_END = "touchend";
        var TOUCH_CANCEL = "touchcancel";
        var MOUSE_UP = "mouseup";
        var MOUSE_MOVE = "mousemove";
        var MOUSE_DOWN = "mousedown";
        var TYPE_START$1 = "start";
        var TYPE_MOVE$1 = "move";
        var TYPE_END$1 = "end";
        function isFunction(input) {
          return "[object Function]" === Object.prototype.toString.call(input);
        }

        var CLIENT_X = "clientX";
        var CLIENT_Y = "clientY";
        var COMPUTE_INTERVAL = 16;
        var TYPE_START = "start";
        var TYPE_MOVE = "move";
        var TYPE_CANCEL = "cancel";
        var TYPE_END = "end";
        var DIRECTION_LEFT = "left";
        var DIRECTION_RIGHT = "right";
        var DIRECTION_UP = "up";
        var DIRECTION_DOWN = "down";

        var _a;
        var STATUS_CODE_AND_NAME_MAP =
          ((_a = {}),
          (_a[4] = TYPE_START),
          (_a[5] = TYPE_MOVE),
          (_a[1] = TYPE_END),
          (_a[3] = TYPE_CANCEL),
          _a);
        function getStatusName(code) {
          return STATUS_CODE_AND_NAME_MAP[code];
        }
        function flow(isVaild, lastStatus, phase) {
          var _a, _b, _c, _d, _e, _f, _g;
          var STATE_MAP = {
            1:
              ((_a = {}),
              (_a[0] = ((_b = {}), (_b[TYPE_MOVE] = 4), _b)),
              (_a[4] =
                ((_c = {}),
                (_c[TYPE_MOVE] = 5),
                (_c[TYPE_END] = 1),
                (_c[TYPE_CANCEL] = 3),
                _c)),
              (_a[5] =
                ((_d = {}),
                (_d[TYPE_MOVE] = 5),
                (_d[TYPE_END] = 1),
                (_d[TYPE_CANCEL] = 3),
                _d)),
              _a),
            0:
              ((_e = {}),
              (_e[4] =
                ((_f = {}),
                (_f[TYPE_MOVE] = 2),
                (_f[TYPE_END] = 1),
                (_f[TYPE_CANCEL] = 3),
                _f)),
              (_e[5] =
                ((_g = {}),
                (_g[TYPE_START] = 2),
                (_g[TYPE_MOVE] = 2),
                (_g[TYPE_END] = 1),
                (_g[TYPE_CANCEL] = 3),
                _g)),
              _e),
          };
          var map = STATE_MAP[Number(isVaild)][lastStatus];
          return (void 0 !== map && map[phase]) || 0;
        }
        function resetState(context) {
          if ([1, 3, 2].includes(context.state)) {
            context.state = 0;
          }
        }
        function isMoveOrEndOrCancel(state) {
          return [5, 1, 3].includes(state);
        }
        function isDisabled(context) {
          if (context.disabled) {
            context.state = 0;
            return true;
          }
        }

        function createPluginContext(defaultOptions, options) {
          return __assign(__assign(__assign({}, defaultOptions), options), {
            state: 0,
            disabled: false,
          });
        }

        function round2(n) {
          return Math.round(n * 100) / 100;
        }

        function inputCreator() {
          var id = 0;
          var prevInput;
          var activeInput;
          var startInput;
          var startMultiInput;
          return function (basicsInput) {
            prevInput = activeInput;
            if (void 0 !== basicsInput) {
              id = Number.MAX_SAFE_INTEGER > id ? ++id : 1;
              var pureInput = extendInput(basicsInput, id);
              activeInput = pureInput;
              var isStart = pureInput.isStart,
                pointLength = pureInput.pointLength;
              if (isStart) {
                startInput = pureInput;
                prevInput = void 0;
                if (1 < pointLength) {
                  startMultiInput = pureInput;
                } else {
                  startMultiInput = void 0;
                }
              }
              return __assign(__assign({}, pureInput), {
                prevInput: prevInput,
                startMultiInput: startMultiInput,
                startInput: startInput,
              });
            }
          };
        }
        function getCenter(points) {
          var length = points.length;
          if (0 < length) {
            if (1 === length) {
              var _a = points[0],
                clientX = _a.clientX,
                clientY = _a.clientY;
              return { x: Math.round(clientX), y: Math.round(clientY) };
            }
            var countPoint = points.reduce(
              function (countPoint, point) {
                countPoint.x += point[CLIENT_X];
                countPoint.y += point[CLIENT_Y];
                return countPoint;
              },
              { x: 0, y: 0 }
            );
            return {
              x: Math.round(countPoint.x / length),
              y: Math.round(countPoint.y / length),
            };
          }
        }
        function extendInput(basicsInput, id) {
          var phase = basicsInput.phase,
            points = basicsInput.points,
            changedPoints = basicsInput.changedPoints,
            nativeEvent = basicsInput.nativeEvent;
          var pointLength = points.length;
          var isStart = TYPE_START === phase;
          var isEnd =
            (TYPE_END === phase && 0 === pointLength) || TYPE_CANCEL === phase;
          var timestamp = Date.now();
          var _a = getCenter(points) || getCenter(changedPoints),
            x = _a.x,
            y = _a.y;
          var currentTarget = nativeEvent.currentTarget;
          return Object.assign(basicsInput, {
            id: id,
            x: x,
            y: y,
            timestamp: timestamp,
            isStart: isStart,
            isEnd: isEnd,
            pointLength: pointLength,
            currentTarget: currentTarget,
            getOffset: function (el) {
              if (el === void 0) {
                el = currentTarget;
              }
              var rect = el.getBoundingClientRect();
              return {
                x: x - Math.round(rect.left),
                y: y - Math.round(rect.top),
              };
            },
          });
        }

        function mouse() {
          var prevPoints;
          var isPressed = false;
          var _target = null;
          var createInput = inputCreator();
          return function (event) {
            var clientX = event.clientX,
              clientY = event.clientY,
              type = event.type,
              button = event.button,
              target = event.target;
            var points = [
              { clientX: clientX, clientY: clientY, target: target },
            ];
            var phase;
            if (MOUSE_DOWN === type && 0 === button) {
              _target = target;
              isPressed = true;
              phase = TYPE_START$1;
            } else if (isPressed) {
              if (MOUSE_MOVE === type) {
                phase = TYPE_MOVE$1;
              } else if (MOUSE_UP === type) {
                points = [];
                phase = TYPE_END$1;
                isPressed = false;
              }
            } else {
              return;
            }
            var changedPoints = prevPoints || [
              { clientX: clientX, clientY: clientY, target: target },
            ];
            prevPoints = [
              { clientX: clientX, clientY: clientY, target: target },
            ];
            if (void 0 !== phase) {
              return createInput({
                phase: phase,
                changedPoints: changedPoints,
                points: points,
                target: _target,
                targets: [_target],
                nativeEvent: event,
              });
            }
          };
        }

        function touch(el) {
          var createInput = inputCreator();
          return function (event) {
            var targets = [];
            var points = [];
            Array.from(event.touches).forEach(function (_a) {
              var clientX = _a.clientX,
                clientY = _a.clientY,
                target = _a.target;
              if (el === null || el === void 0 ? void 0 : el.contains(target)) {
                targets.push(target);
                points.push({
                  clientX: clientX,
                  clientY: clientY,
                  target: target,
                });
              }
            });
            var changedPoints = Array.from(event.changedTouches).map(function (
              _a
            ) {
              var clientX = _a.clientX,
                clientY = _a.clientY,
                target = _a.target;
              return { clientX: clientX, clientY: clientY, target: target };
            });
            return createInput({
              phase: event.type.replace("touch", ""),
              changedPoints: changedPoints,
              points: points,
              nativeEvent: event,
              target: event.target,
              targets: targets,
            });
          };
        }

        function dispatchDomEvent(typeName, el, payload, eventInit) {
          var data = {};
          for (var key in payload) {
            if (!["target", "currentTarget", "type"].includes(key)) {
              data[key] = payload[key];
            }
          }
          var event;
          if (document.createEvent) {
            event = document.createEvent("HTMLEvents");
            event.initEvent(
              typeName,
              eventInit === null || eventInit === void 0
                ? void 0
                : eventInit.bubbles,
              eventInit === null || eventInit === void 0
                ? void 0
                : eventInit.cancelable
            );
          } else {
            event = new Event(typeName, eventInit);
          }
          Object.assign(event, data, {
            match: function () {
              return (
                payload.targets &&
                0 < payload.targets.length &&
                payload.targets.every(function (target) {
                  return event.currentTarget.contains(target);
                })
              );
            },
          });
          return el.dispatchEvent(event);
        }

        function canPreventDefault(event, options) {
          var preventDefault = options.preventDefault;
          if (isFunction(preventDefault)) {
            return preventDefault(event);
          } else {
            return !!preventDefault;
          }
        }

        var ELEMENT_TYPES = [
          TOUCH_START,
          TOUCH_MOVE,
          TOUCH_END,
          TOUCH_CANCEL,
          MOUSE_DOWN,
        ];
        var WINDOW_TYPES = [MOUSE_MOVE, MOUSE_UP];
        function bindElement(el, catchEvent, options) {
          ELEMENT_TYPES.forEach(function (type) {
            el.addEventListener(type, catchEvent, options);
          });
          WINDOW_TYPES.forEach(function (type) {
            window.addEventListener(type, catchEvent, options);
          });
          return function () {
            ELEMENT_TYPES.forEach(function (types) {
              el.removeEventListener(types, catchEvent);
            });
            WINDOW_TYPES.forEach(function (type) {
              window.removeEventListener(type, catchEvent);
            });
          };
        }

        var TYPE_COMPUTED = "computed";
        var DEFAULT_OPTIONS$6 = {
          domEvents: { bubbles: true, cancelable: true },
          preventDefault: function (event) {
            if (event.target && "tagName" in event.target) {
              var tagName = event.target.tagName;
              return !/^(?:INPUT|TEXTAREA|BUTTON|SELECT)$/.test(tagName);
            }
            return false;
          },
        };
        var TYPE_UNBIND = "u";
        var TYPE_INPUT = "input";
        var TYPE_AT_AFTER = "at:after";
        var default_1$1 = (function (_super) {
          __extends(default_1, _super);
          function default_1(el, options) {
            var _a;
            var _this = _super.call(this) || this;
            _this.v = "2.1.3";
            _this.__computeFunctionList = [];
            _this.__computeFunctionCreatorList = [];
            _this.__pluginContexts = [];
            _this.__isIgnoreMouse = false;
            _this.el = el;
            _this.c = {};
            _this.__options = __assign(
              __assign({}, DEFAULT_OPTIONS$6),
              options
            );
            var createInputFromTouch = touch(_this.el);
            var createInputFromMouse = mouse();
            _this.__inputCreatorMap =
              ((_a = {}),
              (_a[TOUCH_START] = createInputFromTouch),
              (_a[TOUCH_MOVE] = createInputFromTouch),
              (_a[TOUCH_END] = createInputFromTouch),
              (_a[TOUCH_CANCEL] = createInputFromTouch),
              (_a[MOUSE_DOWN] = createInputFromMouse),
              (_a[MOUSE_MOVE] = createInputFromMouse),
              (_a[MOUSE_UP] = createInputFromMouse),
              _a);
            _this.on(TYPE_AT_AFTER, function (payload) {
              var target = payload.target,
                __type = payload.__type;
              var domEvents = _this.__options.domEvents;
              if (!!domEvents && void 0 !== _this.el && !!target) {
                dispatchDomEvent(__type, target, payload, domEvents);
                dispatchDomEvent(TYPE_AT_AFTER, target, payload, domEvents);
              }
            });
            if (void 0 !== el) {
              el.style.webkitTapHighlightColor = "rgba(0,0,0,0)";
              var supportsPassive_1 = false;
              try {
                var opts = {};
                OriginPrototype.Object.defineProperty(opts, "passive", {
                  get: function () {
                    supportsPassive_1 = true;
                  },
                });
                window.addEventListener(
                  "_",
                  function () {
                    return void 0;
                  },
                  opts
                );
              } catch (_b) {}
              _this.on(
                TYPE_UNBIND,
                bindElement(
                  el,
                  _this.catchEvent.bind(_this),
                  false === _this.__options.preventDefault && supportsPassive_1
                    ? { passive: true }
                    : { passive: false }
                )
              );
            }
            return _this;
          }
          default_1.prototype.use = function (plugin, pluginOptions) {
            this.__pluginContexts.push(plugin(this, pluginOptions));
          };
          default_1.prototype.catchEvent = function (event) {
            var input = this.__inputCreatorMap[event.type](event);
            if (void 0 !== input) {
              var stopPropagation = function () {
                return event.stopPropagation();
              };
              var stopImmediatePropagation = function () {
                return event.stopImmediatePropagation();
              };
              var preventDefault = function () {
                return event.preventDefault();
              };
              if (canPreventDefault(event, this.__options)) {
                preventDefault();
              } else {
                if ("touchstart" === event.type) {
                  this.__isIgnoreMouse = true;
                } else if ("touchmove" === event.type) {
                  this.__isIgnoreMouse = false;
                }
                if (this.__isIgnoreMouse && event.type.startsWith("mouse")) {
                  if ("mouseup" === event.type) {
                    this.__isIgnoreMouse = false;
                  }
                  return;
                }
              }
              this.emit(TYPE_INPUT, input);
              this.emit2("at:".concat(input.phase), input, {});
              var computed_1 = {};
              this.__computeFunctionList.forEach(function (compute) {
                var result = compute(input, computed_1);
                if (void 0 !== result) {
                  for (var key in result) {
                    computed_1[key] = result[key];
                  }
                }
              });
              this.emit(
                TYPE_COMPUTED,
                __assign(__assign(__assign({}, input), computed_1), {
                  stopPropagation: stopPropagation,
                  stopImmediatePropagation: stopImmediatePropagation,
                  preventDefault: preventDefault,
                })
              );
            }
          };
          default_1.prototype.compute = function (
            computeFunctionCreatorList,
            callback
          ) {
            var e_1, _a;
            try {
              for (
                var computeFunctionCreatorList_1 = __values(
                    computeFunctionCreatorList
                  ),
                  computeFunctionCreatorList_1_1 =
                    computeFunctionCreatorList_1.next();
                !computeFunctionCreatorList_1_1.done;
                computeFunctionCreatorList_1_1 =
                  computeFunctionCreatorList_1.next()
              ) {
                var computeFunctionCreator =
                  computeFunctionCreatorList_1_1.value;
                if (
                  !this.__computeFunctionCreatorList.includes(
                    computeFunctionCreator
                  )
                ) {
                  this.__computeFunctionCreatorList.push(
                    computeFunctionCreator
                  );
                  this.__computeFunctionList.push(computeFunctionCreator());
                }
              }
            } catch (e_1_1) {
              e_1 = { error: e_1_1 };
            } finally {
              try {
                if (
                  computeFunctionCreatorList_1_1 &&
                  !computeFunctionCreatorList_1_1.done &&
                  (_a = computeFunctionCreatorList_1.return)
                )
                  _a.call(computeFunctionCreatorList_1);
              } finally {
                if (e_1) throw e_1.error;
              }
            }
            this.on(TYPE_COMPUTED, callback);
          };
          default_1.prototype.beforeEach = function (interceptor) {
            var _this = this;
            _super.prototype.beforeEach.call(this, function (type, next) {
              var _a;
              if ((_a = _this.c) === null || _a === void 0 ? void 0 : _a.name) {
                interceptor(type, next);
              } else {
                next();
              }
            });
          };
          default_1.prototype.get = function (name) {
            return this.__pluginContexts.find(function (pluginContext) {
              return name === pluginContext.name;
            });
          };
          default_1.prototype.set = function (newOptions) {
            this.__options = __assign(__assign({}, this.__options), newOptions);
          };
          default_1.prototype.emit2 = function (type, payload, pluginContext) {
            var _this = this;
            this.c = pluginContext;
            this.emit(
              type,
              __assign(__assign({}, payload), { type: type }),
              function () {
                _this.emit(
                  TYPE_AT_AFTER,
                  __assign(__assign({}, payload), { name: type, __type: type })
                );
              }
            );
          };
          default_1.prototype.destroy = function () {
            this.emit(TYPE_UNBIND);
            _super.prototype.destroy.call(this);
          };
          return default_1;
        })(AnyEvent);

        var getVLength = function (v) {
          return Math.sqrt(v.x * v.x + v.y * v.y);
        };

        var getDotProduct = function (v1, v2) {
          return v1.x * v2.x + v1.y * v2.y;
        };

        var getRadian = function (v1, v2) {
          var mr = getVLength(v1) * getVLength(v2);
          if (mr === 0) return 0;
          var r = getDotProduct(v1, v2) / mr;
          if (r > 1) r = 1;
          return Math.acos(r);
        };

        var getCross = function (v1, v2) {
          return v1.x * v2.y - v2.x * v1.y;
        };

        var radianToAngle = function (radian) {
          return (radian / Math.PI) * 180;
        };

        var getAngle = function (v1, v2) {
          var angle = getRadian(v1, v2);
          if (getCross(v1, v2) > 0) {
            angle *= -1;
          }
          return radianToAngle(angle);
        };

        var getDirection = function (x, y) {
          if (0 === x && 0 === y) {
            return;
          }
          if (Math.abs(x) >= Math.abs(y)) {
            return 0 < x ? DIRECTION_RIGHT : DIRECTION_LEFT;
          } else {
            return 0 < y ? DIRECTION_DOWN : DIRECTION_UP;
          }
        };

        function ComputeAngle() {
          var angle = 0;
          var deltaAngle = 0;
          return function (input, computed) {
            var prevVecotr = computed.prevVecotr,
              startVecotr = computed.startVecotr,
              activeVecotr = computed.activeVecotr;
            if (activeVecotr) {
              deltaAngle = Math.round(getAngle(activeVecotr, prevVecotr));
              angle = Math.round(getAngle(activeVecotr, startVecotr));
            }
            return { angle: angle, deltaAngle: deltaAngle };
          };
        }

        function ComputeDeltaXY() {
          return function (input) {
            var prevInput = input.prevInput;
            var deltaX = 0;
            var deltaY = 0;
            var deltaXYAngle = 0;
            if (void 0 !== prevInput) {
              deltaX = input.x - prevInput.x;
              deltaY = input.y - prevInput.y;
              if (0 !== deltaX || 0 !== deltaY) {
                var deltaXY = Math.sqrt(
                  Math.pow(deltaX, 2) + Math.pow(deltaY, 2)
                );
                deltaXYAngle = Math.round(
                  radianToAngle(Math.acos(Math.abs(deltaX) / deltaXY))
                );
              }
            }
            return {
              deltaX: deltaX,
              deltaY: deltaY,
              deltaXYAngle: deltaXYAngle,
            };
          };
        }

        function ComputeDistance() {
          var displacementX = 0;
          var displacementY = 0;
          var distanceX = 0;
          var distanceY = 0;
          var distance = 0;
          var overallDirection;
          return function (input) {
            var phase = input.phase,
              startInput = input.startInput;
            if (TYPE_START === phase) {
              displacementX = 0;
              displacementY = 0;
              distanceX = 0;
              distanceY = 0;
              distance = 0;
            } else if (TYPE_MOVE === phase) {
              displacementX = Math.round(
                input.points[0][CLIENT_X] - startInput.points[0][CLIENT_X]
              );
              displacementY = Math.round(
                input.points[0][CLIENT_Y] - startInput.points[0][CLIENT_Y]
              );
              distanceX = Math.abs(displacementX);
              distanceY = Math.abs(displacementY);
              distance = Math.round(getVLength({ x: distanceX, y: distanceY }));
              overallDirection = getDirection(displacementX, displacementY);
            }
            return {
              displacementX: displacementX,
              displacementY: displacementY,
              distanceX: distanceX,
              distanceY: distanceY,
              distance: distance,
              overallDirection: overallDirection,
            };
          };
        }

        function ComputeScale() {
          var scale = 1;
          return function (input, computed) {
            var deltaScale = 1;
            var prevVecotr = computed.prevVecotr,
              startVecotr = computed.startVecotr,
              activeVecotr = computed.activeVecotr;
            if (activeVecotr) {
              deltaScale = round2(
                getVLength(activeVecotr) / getVLength(prevVecotr)
              );
              scale = round2(
                getVLength(activeVecotr) / getVLength(startVecotr)
              );
            }
            return { scale: scale, deltaScale: deltaScale };
          };
        }

        function ComputeVAndDir() {
          var velocityX = 0;
          var velocityY = 0;
          var speedX = 0;
          var speedY = 0;
          var direction;
          var lastValidInput;
          return function (input) {
            if (void 0 !== input) {
              lastValidInput = lastValidInput || input.startInput;
              var deltaTime = input.timestamp - lastValidInput.timestamp;
              if (COMPUTE_INTERVAL < deltaTime) {
                var deltaX = input.x - lastValidInput.x;
                var deltaY = input.y - lastValidInput.y;
                speedX = Math.round((deltaX / deltaTime) * 100) / 100;
                speedY = Math.round((deltaY / deltaTime) * 100) / 100;
                velocityX = Math.abs(speedX);
                velocityY = Math.abs(speedY);
                direction = getDirection(deltaX, deltaY);
                lastValidInput = input;
              }
            }
            return {
              velocityX: velocityX,
              velocityY: velocityY,
              speedX: speedX,
              speedY: speedY,
              direction: direction,
            };
          };
        }

        function ComputeMaxLength() {
          var maxPointLength = 0;
          return function (input) {
            var phase = input.phase;
            if (TYPE_START === phase) {
              maxPointLength = input.pointLength;
            }
            return { maxPointLength: maxPointLength };
          };
        }

        function computeVector(input) {
          return {
            x: input.points[1][CLIENT_X] - input.points[0][CLIENT_X],
            y: input.points[1][CLIENT_Y] - input.points[0][CLIENT_Y],
          };
        }
        function ComputeVectorForMutli() {
          var startVecotr;
          var prevVecotr;
          var activeVecotr;
          return function (input) {
            var prevInput = input.prevInput,
              startMultiInput = input.startMultiInput;
            if (
              void 0 !== startMultiInput &&
              void 0 !== prevInput &&
              input.id !== startMultiInput.id &&
              1 < prevInput.pointLength &&
              1 < input.pointLength
            ) {
              startVecotr = computeVector(startMultiInput);
              prevVecotr = computeVector(prevInput);
              activeVecotr = computeVector(input);
            } else {
              activeVecotr = void 0;
            }
            return {
              startVecotr: startVecotr,
              prevVecotr: prevVecotr,
              activeVecotr: activeVecotr,
            };
          };
        }

        var DEFAULT_OPTIONS$5 = {
          name: "tap",
          pointLength: 1,
          tapTimes: 1,
          waitNextTapTime: 300,
          maxDistance: 2,
          maxDistanceFromPrevTap: 9,
          maxPressTime: 250,
        };
        function tap(at, options) {
          var context = createPluginContext(DEFAULT_OPTIONS$5, options);
          var tapCount = 0;
          var prevTapPoint;
          var prevTapTime;
          var countDownToFailTimer;
          function reset() {
            tapCount = 0;
            prevTapPoint = void 0;
            prevTapTime = void 0;
          }
          function countDownToFail() {
            countDownToFailTimer = setTimeout(function () {
              context.state = 2;
              reset();
            }, context.waitNextTapTime);
          }
          function isValidDistanceFromPrevTap(center, options) {
            if (void 0 !== prevTapPoint) {
              var distanceFromPreviousTap = getVLength({
                x: center.x - prevTapPoint.x,
                y: center.y - prevTapPoint.y,
              });
              prevTapPoint = center;
              return options.maxDistanceFromPrevTap >= distanceFromPreviousTap;
            } else {
              prevTapPoint = center;
              return true;
            }
          }
          function isValidInterval(waitNextTapTime) {
            var now = performance.now();
            if (void 0 === prevTapTime) {
              prevTapTime = now;
              return true;
            } else {
              var interval = now - prevTapTime;
              prevTapTime = now;
              return interval < waitNextTapTime;
            }
          }
          at.compute([ComputeDistance, ComputeMaxLength], function (computed) {
            if (isDisabled(context)) return;
            var phase = computed.phase,
              x = computed.x,
              y = computed.y;
            if (TYPE_END !== phase) return;
            context.state = 0;
            if (test()) {
              clearTimeout(countDownToFailTimer);
              if (
                isValidDistanceFromPrevTap({ x: x, y: y }, context) &&
                isValidInterval(context.waitNextTapTime)
              ) {
                tapCount++;
              } else {
                tapCount = 1;
              }
              if (0 === tapCount % context.tapTimes) {
                context.state = 1;
                at.emit2(context.name, computed, context);
                reset();
              } else {
                countDownToFail();
              }
            } else {
              reset();
              context.state = 2;
            }
            function test() {
              var startInput = computed.startInput,
                pointLength = computed.pointLength,
                timestamp = computed.timestamp;
              var deltaTime = timestamp - startInput.timestamp;
              var distance = computed.distance,
                maxPointLength = computed.maxPointLength;
              return (
                maxPointLength === context.pointLength &&
                0 === pointLength &&
                context.maxDistance >= distance &&
                context.maxPressTime > deltaTime
              );
            }
          });
          return context;
        }

        var DEFAULT_OPTIONS$4 = { name: "pan", threshold: 10, pointLength: 1 };
        function pan(at, options) {
          var context = createPluginContext(DEFAULT_OPTIONS$4, options);
          at.compute(
            [ComputeVAndDir, ComputeDistance, ComputeDeltaXY],
            function (computed) {
              resetState(context);
              if (isDisabled(context)) return;
              var isValid = test();
              context.state = flow(isValid, context.state, computed.phase);
              if (isValid || isMoveOrEndOrCancel(context.state)) {
                var name_1 = context.name;
                at.emit2(name_1, computed, context);
                at.emit2(
                  name_1 + getStatusName(context.state),
                  computed,
                  context
                );
                if (
                  ![TYPE_END, TYPE_CANCEL].includes(computed.phase) &&
                  computed.direction
                ) {
                  at.emit2(name_1 + computed.direction, computed, context);
                }
              }
              function test() {
                var pointLength = computed.pointLength,
                  distance = computed.distance;
                return (
                  context.pointLength === pointLength &&
                  context.threshold <= distance
                );
              }
            }
          );
          return context;
        }

        var DEFAULT_OPTIONS$3 = {
          name: "swipe",
          threshold: 10,
          velocity: 0.3,
          pointLength: 1,
        };
        function swipe(at, options) {
          var context = createPluginContext(DEFAULT_OPTIONS$3, options);
          at.compute(
            [ComputeDistance, ComputeVAndDir, ComputeMaxLength],
            function (computed) {
              context.state = 0;
              if (context.disabled) return;
              if (test()) {
                var name_1 = context.name;
                context.state = 1;
                at.emit2(name_1, computed, context);
                at.emit2(name_1 + computed.direction, computed, context);
              }
              function test() {
                if (TYPE_END !== computed.phase) return false;
                var velocityX = computed.velocityX,
                  velocityY = computed.velocityY,
                  distance = computed.distance,
                  maxPointLength = computed.maxPointLength;
                return (
                  maxPointLength === context.pointLength &&
                  0 === computed.points.length &&
                  context.threshold < distance &&
                  context.velocity < Math.max(velocityX, velocityY)
                );
              }
            }
          );
          return context;
        }

        var DEFAULT_OPTIONS$2 = {
          name: "press",
          pointLength: 1,
          maxDistance: 9,
          minPressTime: 251,
        };
        function press(at, options) {
          var context = createPluginContext(DEFAULT_OPTIONS$2, options);
          var timeoutId = 0;
          at.compute([ComputeDistance], function (computed) {
            if (isDisabled(context)) return;
            var phase = computed.phase,
              startInput = computed.startInput,
              pointLength = computed.pointLength;
            if (TYPE_START === phase && context.pointLength === pointLength) {
              resetState(context);
              clearTimeout(timeoutId);
              timeoutId = setTimeout(function () {
                context.state = 1;
                at.emit2(context.name, computed, context);
              }, context.minPressTime);
            } else if (TYPE_END === phase && 1 === context.state) {
              at.emit2(
                "".concat(context.name).concat(DIRECTION_UP),
                computed,
                context
              );
            } else if (1 !== context.state) {
              var deltaTime = computed.timestamp - startInput.timestamp;
              if (
                !test() ||
                (context.minPressTime > deltaTime &&
                  [TYPE_END, TYPE_CANCEL].includes(phase))
              ) {
                clearTimeout(timeoutId);
                context.state = 2;
              }
            }
            function test() {
              var distance = computed.distance;
              return distance && context.maxDistance > distance;
            }
          });
          return context;
        }

        var DEFAULT_OPTIONS$1 = {
          name: "pinch",
          threshold: 0,
          pointLength: 2,
        };
        function pinch(at, options) {
          var context = createPluginContext(DEFAULT_OPTIONS$1, options);
          at.compute(
            [ComputeVectorForMutli, ComputeScale],
            function (computed) {
              resetState(context);
              if (isDisabled(context)) return;
              var isValid = test();
              context.state = flow(isValid, context.state, computed.phase);
              var name = context.name;
              if (isValid || isMoveOrEndOrCancel(context.state)) {
                at.emit2(name, computed, context);
                var deltaScale = computed.deltaScale;
                if (1 !== deltaScale) {
                  at.emit2(
                    name + (1 < deltaScale ? "in" : "out"),
                    computed,
                    context
                  );
                }
              }
              var stateName = getStatusName(context.state);
              if (stateName) {
                at.emit2(name + stateName, computed, context);
              }
              function test() {
                var pointLength = computed.pointLength,
                  scale = computed.scale;
                computed.deltaScale;
                computed.phase;
                return (
                  context.pointLength === pointLength &&
                  context.threshold < Math.abs(scale - 1)
                );
              }
            }
          );
          return context;
        }

        var DEFAULT_OPTIONS = {
          name: "rotate",
          threshold: 0,
          pointLength: 2,
        };
        function rotate(at, options) {
          var context = createPluginContext(DEFAULT_OPTIONS, options);
          at.compute(
            [ComputeVectorForMutli, ComputeAngle],
            function (computed) {
              if (isDisabled(context)) return;
              resetState(context);
              var isValid = test();
              context.state = flow(isValid, context.state, computed.phase);
              var name = context.name;
              if (isValid || isMoveOrEndOrCancel(context.state)) {
                at.emit2(name, computed, context);
              }
              var stateName = getStatusName(context.state);
              if (stateName) {
                at.emit2(name + stateName, computed, context);
              }
              function test() {
                var pointLength = computed.pointLength,
                  angle = computed.angle;
                return (
                  context.pointLength === pointLength &&
                  context.threshold < Math.abs(angle)
                );
              }
            }
          );
          return context;
        }

        function doubletap(at) {
          at.use(tap, { name: "doubletap", tapTimes: 2 });
          var doubleTapContext = at.get("doubletap");
          var timeID;
          at.beforeEach(function (type, next) {
            if ("tap" === type) {
              clearTimeout(timeID);
              timeID = setTimeout(function () {
                if ([0, 2].includes(doubleTapContext.state)) {
                  next();
                }
              }, 300);
            } else {
              next();
            }
          });
          return doubleTapContext;
        }

        var default_1 = (function (_super) {
          __extends(default_1, _super);
          function default_1(el, options) {
            var _this = _super.call(this, el, options) || this;
            _this.use(tap);
            _this.use(pan);
            _this.use(swipe);
            _this.use(press);
            _this.use(pinch);
            _this.use(rotate);
            return _this;
          }
          default_1.STATE_POSSIBLE = 0;
          default_1.STATE_START = 4;
          default_1.STATE_MOVE = 5;
          default_1.STATE_END = 1;
          default_1.STATE_CANCELLED = 3;
          default_1.STATE_FAILED = 2;
          default_1.STATE_RECOGNIZED = 1;
          default_1.tap = tap;
          default_1.pan = pan;
          default_1.swipe = swipe;
          default_1.press = press;
          default_1.rotate = rotate;
          default_1.pinch = pinch;
          default_1.doubletap = doubletap;
          return default_1;
        })(default_1$1);

        return default_1;
      });
      //# sourceMappingURL=any-touch.umd.js.map
      return anyTouch;
    },
    /**
     * 排序数组
     * @param {(value: any)=>any} getBeforeValueFun
     * @param {(value: any)=>any} getAfterValueFun
     * @param {boolean} sortByDesc 排序是否降序,默认降序
     * @returns
     */
    sortElementListByProperty(
      getBeforeValueFun,
      getAfterValueFun,
      sortByDesc = true
    ) {
      if (typeof sortByDesc !== "boolean") {
        throw "参数 sortByDesc 必须为boolean类型";
      }
      if (getBeforeValueFun == null || getAfterValueFun == null) {
        throw "获取前面的值或后面的值的方法不能为空";
      }
      return function (after_obj, before_obj) {
        var beforeValue = getBeforeValueFun(before_obj); /*  前 */
        var afterValue = getAfterValueFun(after_obj); /* 后 */
        if (sortByDesc) {
          if (afterValue > beforeValue) {
            return -1;
          } else if (afterValue < beforeValue) {
            return 1;
          } else {
            return 0;
          }
        } else {
          if (afterValue < beforeValue) {
            return -1;
          } else if (afterValue > beforeValue) {
            return 1;
          } else {
            return 0;
          }
        }
      };
    },
    /**
     * 获取格式化后的时间
     * @param {string|number} [text= new Date()]	需要格式化的字符串或者时间戳
     * @param {string} [formatType = "yyyy-MM-dd HH:mm:ss"]	格式化成的显示类型
     * + yyyy 年
     * + MM 月
     * + dd 天
     * + HH 时 (24小时制)
     * + hh 时 (12小时制)
     * + mm 分
     * + ss 秒
     * @returns {string}	返回格式化后的时间
     * @example
     * Utils.formatTime("2022-08-21 23:59:00","HH:mm:ss");
     * > '23:59:00'
     * @example
     * Utils.formatTime(1899187424988,"HH:mm:ss");
     * > '15:10:13'
     * @example
     * Utils.formatTime()
     * > '2023-1-1 00:00:00'
     **/
    formatTime: function (
      text = new Date(),
      formatType = "yyyy-MM-dd HH:mm:ss"
    ) {
      let time = text == null ? new Date() : new Date(text);
      /**
       * 校验时间补0
       * @param {number} timeNum
       * @returns
       */
      function checkTime(timeNum) {
        if (timeNum < 10) return "0" + timeNum;
        return timeNum;
      }

      /**
       * 时间制修改 24小时制转12小时制
       * @param {number} hourNum 小时
       * @returns
       */
      function timeSystemChange(hourNum) {
        return hourNum > 12 ? hourNum - 12 : hourNum;
      }

      let timeRegexp = {
        yyyy: time.getFullYear(),
        /* 年 */
        MM: checkTime(time.getMonth() + 1),
        /* 月 */
        dd: checkTime(time.getDate()),
        /* 日 */
        HH: checkTime(time.getHours()),
        /* 时 (24小时制) */
        hh: checkTime(timeSystemChange(time.getHours())),
        /* 时 (12小时制) */
        mm: checkTime(time.getMinutes()),
        /* 分 */
        ss: checkTime(time.getSeconds()),
        /* 秒 */
      };
      Object.keys(timeRegexp).forEach(function (key) {
        let replaecRegexp = new RegExp(key, "g");
        formatType = formatType.replace(replaecRegexp, timeRegexp[key]);
      });
      return formatType;
    },
    /**
     * 格式化byte为KB、MB、GB、TB、PB、EB、ZB、YB、BB、NB、DB
     * @param {number|string} byteSize 字节
     * @param {boolean} [addType=true]
     * + true (默认) 添加单位
     * + false 不添加单位
     * @returns {string|number}
     * + {string} 当addType为true时,且保留小数点末尾2位
     * + {number} 当addType为false时,且保留小数点末尾2位
     * @example
     * Utils.formatByteToSize("812304");
     * > '793.27KB'
     * @example
     * Utils.formatByteToSize("812304",false);
     * > 793.27
     **/
    formatByteToSize: function (byteSize, addType = true) {
      byteSize = parseInt(byteSize);
      if (isNaN(byteSize)) {
        throw new Error("Utils.formatByteToSize 参数 byteSize 格式不正确");
      }
      let result = 0;
      let resultType = "KB";
      let sizeData = {};
      sizeData.B = 1;
      sizeData.KB = 1024;
      sizeData.MB = sizeData.KB * sizeData.KB;
      sizeData.GB = sizeData.MB * sizeData.KB;
      sizeData.TB = sizeData.GB * sizeData.KB;
      sizeData.PB = sizeData.TB * sizeData.KB;
      sizeData.EB = sizeData.PB * sizeData.KB;
      sizeData.ZB = sizeData.EB * sizeData.KB;
      sizeData.YB = sizeData.ZB * sizeData.KB;
      sizeData.BB = sizeData.YB * sizeData.KB;
      sizeData.NB = sizeData.BB * sizeData.KB;
      sizeData.DB = sizeData.NB * sizeData.KB;
      for (let key in sizeData) {
        result = byteSize / sizeData[key];
        resultType = key;
        if (sizeData.KB >= result) {
          break;
        }
      }
      result = result.toFixed(2);
      result = addType ? result + resultType.toString() : parseFloat(result);
      return result;
    },
    /**
     * 判断元素是否已显示或已连接
     * @param {HTMLElement} element
     * @returns {boolean}
     */
    isShow(element) {
      return Boolean(element.getClientRects().length);
    },
    /**
     * 用于显示元素并获取它的高度宽度等其它属性
     * @param {HTMLElement} element
     * @returns {{recovery: ()=>void}} - 恢复
     */
    showElement(element) {
      let oldStyleAttribute = element.getAttribute("style");
      element.setAttribute(
        "style",
        "visibility: !important;display:block !important;"
      );
      return {
        recovery() {
          if (oldStyleAttribute) {
            element.setAttribute("style", oldStyleAttribute);
          } else {
            element.removeAttribute("style");
          }
        },
      };
    },
    /**
     * 获取元素上的Float格式的属性px
     * @param {HTMLElement|CSSStyleDeclaration} element
     * @param {string} styleName style名
     * @return {number}
     */
    getStyleValue(element, styleName) {
      let view = null;
      let styles = null;
      if (element instanceof CSSStyleDeclaration) {
        /* 直接就获取了style属性 */
        styles = element;
      } else {
        view = element.ownerDocument.defaultView;
        if (!view || !view.opener) {
          view = window;
        }
        styles = view.getComputedStyle(element);
      }
      let value = parseFloat(styles[styleName]);
      if (isNaN(value)) {
        return 0;
      } else {
        return value;
      }
    },
    /**
     * 判断是否是window,例如window、self、globalThis
     * @param {any} target
     * @returns {boolean}
     */
    isWin(target) {
      if (!typeof target === "object") {
        return false;
      }
      if (target instanceof Node) {
        return false;
      }
      if (target === globalThis) {
        return true;
      }
      if (target === window) {
        return true;
      }
      if (target === self) {
        return true;
      }
      if (target?.Math?.toString() !== "[object Math]") {
        return false;
      }
      return true;
    },
    /**
     * 阻止默认事件触发
     * @param {Event} event
     */
    preventEvent(event) {
      /* 阻止事件的默认行为发生。例如,当点击一个链接时,浏览器会默认打开链接的URL */
      event?.preventDefault();
      /* 停止事件的传播,阻止它继续向更上层的元素冒泡,事件将不会再传播给其他的元素 */
      event?.stopPropagation();
      /* 阻止事件传播,并且还能阻止元素上的其他事件处理程序被触发 */
      event?.stopImmediatePropagation();
    },
  };

  /**
   * 浮点数工具类
   */
  const MathFloatUtils = {
    /**
     * 判断数字是否是浮点数
     * @param {number} num
     * @returns
     */
    isFloat(num) {
      return Number(num) === num && num % 1 !== 0;
    },
    /**
     * 浮点数加法
     * @param {number} number1
     * @param {number} number2
     */
    add(number1, number2) {
      let number1length, number2length, powValue;
      try {
        number1length = number1.toString().split(".")[1].length;
      } catch (error) {
        number1length = 0;
      }
      try {
        number2length = number2.toString().split(".")[1].length;
      } catch (error) {
        number2length = 0;
      }
      powValue = Math.pow(10, Math.max(number1length, number2length));
      return Math.round(number1 * powValue + number2 * powValue) / powValue;
    },
    /**
     * 减法
     * @param {number} number1
     * @param {number} number2
     * @returns
     */
    sub(number1, number2) {
      let number1length, number2length, powValue;
      try {
        number1length = number1.toString().split(".")[1].length;
      } catch (error) {
        number1length = 0;
      }
      try {
        number2length = number2.toString().split(".")[1].length;
      } catch (error) {
        number2length = 0;
      }
      powValue = Math.pow(10, Math.max(number1length, number2length));
      let fixedValue =
        number1length >= number2length ? number1length : number2length;
      return (
        Math.round(number1 * powValue - number2 * powValue) / powValue
      ).toFixed(fixedValue);
    },
    /**
     * 除法
     * @param {number} number1
     * @param {number} number2
     */
    division(number1, number2) {
      let number1length,
        number2length,
        number1ReplaceValue,
        number2ReplaceValue;
      try {
        number1length = number1.toString().split(".")[1].length;
      } catch (error) {
        number1length = 0;
      }
      try {
        number2length = number2.toString().split(".")[1].length;
      } catch (error) {
        number2length = 0;
      }
      number1ReplaceValue = Number(number1.toString().replace(".", ""));
      number2ReplaceValue = Number(number2.toString().replace(".", ""));
      return (
        (number1ReplaceValue / number2ReplaceValue) *
        Math.pow(10, number2length - number1length)
      );
    },
  };

  /** 元素工具类 */
  const PopsDOMUtils = {
    /**
     * 获取animationend的在各个浏览器的兼容名
     */
    getAnimationEndNameList() {
      return [
        "webkitAnimationEnd",
        "mozAnimationEnd",
        "MSAnimationEnd",
        "oanimationend",
        "animationend",
      ];
    },
    /**
     * 获取 transitionend 的在各个浏览器的兼容名
     */
    getTransitionEndNameList() {
      return [
        "webkitTransitionEnd",
        "mozTransitionEnd",
        "MSTransitionEnd",
        "otransitionend",
        "transitionend",
      ];
    },
    /**
     * 绑定事件
     * @param {HTMLElement|string|NodeList|Array|Window} element 需要绑定的元素|元素数组|window
     * @param {DOMUtils_EventType|DOMUtils_EventType[]} eventType 需要监听的事件
     * @param {string|undefined} selector 子元素选择器
     * @param {((event: Event)=>void)|undefined} callback 绑定事件触发的回调函数
     * @param {boolean|AddEventListenerOptions|undefined} option
     * + capture 表示事件是否在捕获阶段触发。默认为false,即在冒泡阶段触发
     * + once 表示事件是否只触发一次。默认为false
     * + passive 表示事件监听器是否不会调用preventDefault()。默认为false
     */
    on(element, eventType, selector, callback, option) {
      /**
       * 获取option配置
       * @param {any[]} args
       * @param {number} startIndex
       * @param {AddEventListenerOptions} option
       * @returns {AddEventListenerOptions}
       */
      function getOption(args, startIndex, option) {
        if (typeof args[startIndex] === "boolean") {
          option.capture = args[startIndex];
          if (typeof args[startIndex + 1] === "boolean") {
            option.once = args[startIndex + 1];
          }
          if (typeof args[startIndex + 2] === "boolean") {
            option.passive = args[startIndex + 2];
          }
        } else if (
          typeof args[startIndex] === "object" &&
          ("capture" in args[startIndex] ||
            "once" in args[startIndex] ||
            "passive" in args[startIndex])
        ) {
          option.capture = args[startIndex].capture;
          option.once = args[startIndex].once;
          option.passive = args[startIndex].passive;
        }
        return option;
      }

      let args = arguments;
      if (typeof element === "string") {
        element = document.querySelectorAll(element);
      }
      if (element == void 0) {
        return;
      }
      /**
       * @type {HTMLElement[]}
       */
      let elementList = [];
      if (element instanceof NodeList || Array.isArray(element)) {
        elementList = [...element];
      } else {
        elementList.push(element);
      }
      /**
       * @type {string[]}
       */
      let eventTypeList = [];
      if (Array.isArray(eventType)) {
        eventTypeList = eventTypeList.concat(eventType);
      } else if (typeof eventType === "string") {
        eventTypeList = eventTypeList.concat(eventType.split(" "));
      }
      /**
       * @type {?string}
       */
      let _selector_ = selector;
      /**
       * @type {(event:Event)=>{}}
       */
      let _callback_ = callback;
      /**
       * @type {AddEventListenerOptions}
       */
      let _option_ = {
        capture: false,
        once: false,
        passive: false,
      };
      if (typeof selector === "function") {
        /* 这是为没有selector的情况 */
        _selector_ = void 0;
        _callback_ = selector;
        _option_ = getOption(args, 3, _option_);
      } else {
        /* 这是存在selector的情况 */
        _option_ = getOption(args, 4, _option_);
      }
      /**
       * 如果是once,那么删除该监听和元素上的事件和监听
       */
      function checkOptionOnceToRemoveEventListener() {
        if (_option_.once) {
          PopsDOMUtils.off(element, eventType, selector, callback, option);
        }
      }
      elementList.forEach((elementItem) => {
        let ownCallBack = function (event) {
          let target = event.target;
          if (_selector_) {
            /* 存在自定义子元素选择器 */
            let totalParent = PopsUtils.isWin(elementItem)
              ? document.documentElement
              : elementItem;
            if (target.matches(_selector_)) {
              /* 当前目标可以被selector所匹配到 */
              _callback_.call(target, event);
              checkOptionOnceToRemoveEventListener();
              return;
            } else if (
              target.closest(_selector_) &&
              totalParent.contains(target.closest(_selector_))
            ) {
              /* 在上层与主元素之间寻找可以被selector所匹配到的 */
              let closestElement = target.closest(_selector_);
              /* event的target值不能直接修改 */
              OriginPrototype.Object.defineProperty(event, "target", {
                get() {
                  return closestElement;
                },
              });
              _callback_.call(closestElement, event);
              checkOptionOnceToRemoveEventListener();
              return;
            }
          } else {
            _callback_.call(elementItem, event);
            checkOptionOnceToRemoveEventListener();
          }
        };

        /* 遍历事件名设置元素事件 */
        eventTypeList.forEach((eventName) => {
          elementItem.addEventListener(eventName, ownCallBack, _option_);

          if (_callback_ && _callback_.delegate) {
            elementItem.setAttribute("data-delegate", _selector_);
          }
          /* 获取对象上的事件 */
          let elementEvents = elementItem[PopsUtils.SymbolEvents] || {};
          /* 初始化对象上的xx事件 */
          elementEvents[eventName] = elementEvents[eventName] || [];
          elementEvents[eventName].push({
            selector: _selector_,
            option: _option_,
            callback: ownCallBack,
            originCallBack: _callback_,
          });
          /* 覆盖事件 */
          elementItem[PopsUtils.SymbolEvents] = elementEvents;
        });
      });
    },
    /**
     * 取消绑定事件
     * @param {HTMLElement|string|NodeList|Array|Window} element 需要取消绑定的元素|元素数组
     * @param {DOMUtils_EventType|DOMUtils_EventType[]} eventType 需要取消监听的事件
     * @param {string|undefined} selector 子元素选择器
     * @param {((event: Event)=>void)|undefined} callback 通过DOMUtils.on绑定的事件函数
     * @param {EventListenerOptions|boolean|undefined} option
     * + capture 如果在添加事件监听器时指定了useCapture为true,则在移除事件监听器时也必须指定为true
     */
    off(element, eventType, selector, callback, option) {
      /**
       * 获取option配置
       * @param {any[]} args
       * @param {number} startIndex
       * @param {EventListenerOptions} option
       * @returns {EventListenerOptions}
       */
      function getOption(args, startIndex, option) {
        if (typeof args[startIndex] === "boolean") {
          option.capture = args[startIndex];
        } else if (
          typeof args[startIndex] === "object" &&
          "capture" in args[startIndex]
        ) {
          option.capture = args[startIndex].capture;
        }
        return option;
      }

      let args = arguments;
      if (typeof element === "string") {
        element = document.querySelectorAll(element);
      }
      if (element == void 0) {
        return;
      }
      /**
       * @type {HTMLElement[]}
       */
      let elementList = [];
      if (element instanceof NodeList || Array.isArray(element)) {
        elementList = [...element];
      } else {
        elementList.push(element);
      }
      /**
       * @type {string[]}
       */
      let eventTypeList = [];
      if (Array.isArray(eventType)) {
        eventTypeList = eventTypeList.concat(eventType);
      } else if (typeof eventType === "string") {
        eventTypeList = eventTypeList.concat(eventType.split(" "));
      }
      /**
       * @type {?string}
       */
      let _selector_ = selector;
      /**
       * @type {(event:Event)=>{}}
       */
      let _callback_ = callback;

      /**
       * @type {EventListenerOptions}
       */
      let _option_ = {
        capture: false,
      };
      if (typeof selector === "function") {
        /* 这是为没有selector的情况 */
        _selector_ = void 0;
        _callback_ = selector;
        _option_ = getOption(args, 3, _option_);
      } else {
        _option_ = getOption(args, 4, _option_);
      }
      elementList.forEach((elementItem) => {
        /* 获取对象上的事件 */
        let elementEvents = elementItem[PopsUtils.SymbolEvents] || {};
        eventTypeList.forEach((eventName) => {
          /**
           * @type {DOMUtilsEventListenerOptionsAttribute[]}
           */
          let handlers = elementEvents[eventName] || [];
          if (typeof filter === "function") {
            handlers = handlers.filter(filter);
          }
          for (let index = 0; index < handlers.length; index++) {
            let handler = handlers[index];
            let flag = !1;
            if (!_selector_ || handler.selector === _selector_) {
              /* selector不为空,进行selector判断 */
              flag = !0;
            }
            if (
              !_callback_ ||
              handler.callback === _callback_ ||
              handler.originCallBack === _callback_
            ) {
              /* callback不为空,进行callback判断 */
              flag = !0;
            }

            if (flag) {
              elementItem.removeEventListener(
                eventName,
                handler.callback,
                _option_
              );
              handlers.splice(index--, 1);
            }
          }
          if (handlers.length === 0) {
            /* 如果没有任意的handler,那么删除该属性 */
            delete elementEvents[eventType];
          }
        });
        elementItem[PopsUtils.SymbolEvents] = elementEvents;
      });
    },
    /**
     * 主动触发事件
     * @param {HTMLElement|string|NodeList|Array|Window} element 需要触发的元素|元素数组|window
     * @param {DOMUtils_EventType|DOMUtils_EventType[]} eventType 需要触发的事件
     * @param {object|undefined} details 赋予触发的Event的额外属性
     * @param {boolean} [useDispatchToTriggerEvent=true] 是否使用dispatchEvent来触发事件,默认true
     */
    trigger(element, eventType, details, useDispatchToTriggerEvent = true) {
      if (typeof element === "string") {
        element = document.querySelector(element);
      }
      if (element == void 0) {
        return;
      }
      let elementList = [];
      if (element instanceof NodeList || Array.isArray(element)) {
        elementList = [...element];
      } else {
        elementList = [element];
      }
      let eventTypeList = [];
      if (Array.isArray(eventType)) {
        eventTypeList = eventType;
      } else if (typeof eventType === "string") {
        eventTypeList = eventType.split(" ");
      }
      elementList.forEach((elementItem) => {
        /* 获取对象上的事件 */
        let events = elementItem[PopsUtils.SymbolEvents] || {};
        eventTypeList.forEach((_eventType_) => {
          let event = new Event(_eventType_);
          if (details) {
            Object.keys(details).forEach((keyName) => {
              event[keyName] = details[keyName];
            });
          }
          if (useDispatchToTriggerEvent == false && _eventType_ in events) {
            events[_eventType_].forEach((eventsItem) => {
              eventsItem.callback(event);
            });
          } else {
            elementItem.dispatchEvent(event);
          }
        });
      });
    },
    /**
     * 实现jQuery中的$().offset();
     * @param {HTMLElement} element
     * @returns
     */
    offset(element) {
      let rect = element.getBoundingClientRect();
      let win = element.ownerDocument.defaultView;
      return {
        top: parseFloat(rect.top + win.pageYOffset),
        bottom: parseFloat(rect.bottom + win + pageYOffset),
        left: parseFloat(rect.left + win.pageXOffset),
        right: parseFloat(rect.right + win.pageXOffset),
        width: rect.width,
        height: rect.height,
      };
    },
    /**
     * 获取元素的宽度
     * @param {HTMLElement} element - 要获取宽度的元素
     * @param {boolean} [isShow=false] 是否已进行isShow,避免爆堆栈
     * @returns {number} - 元素的宽度,单位为像素
     */
    width(element, isShow = false) {
      if (PopsUtils.isWin(element)) {
        return window.document.documentElement.clientWidth;
      }
      if (typeof element === "string") {
        element = document.querySelector(element);
      }
      if (element == void 0) {
        return;
      }
      if (element.nodeType === 9) {
        /* 文档节点 */
        return Math.max(
          element.body.scrollWidth,
          element.documentElement.scrollWidth,
          element.body.offsetWidth,
          element.documentElement.offsetWidth,
          element.documentElement.clientWidth
        );
      }
      if (isShow || PopsUtils.isShow(element)) {
        /* 已显示 */
        /* 不从style中获取对应的宽度,因为可能使用了class定义了width !important */

        /* 如果element.style.width为空  则从css里面获取是否定义了width信息如果定义了 则读取css里面定义的宽度width */
        if (parseFloat(PopsUtils.getStyleValue(element, "width")) > 0) {
          return parseFloat(PopsUtils.getStyleValue(element, "width"));
        }

        /* 如果从css里获取到的值不是大于0  可能是auto 则通过offsetWidth来进行计算 */
        if (element.offsetWidth > 0) {
          let borderLeftWidth = PopsUtils.getStyleValue(
            element,
            "borderLeftWidth"
          );
          let borderRightWidth = PopsUtils.getStyleValue(
            element,
            "borderRightWidth"
          );
          let paddingLeft = PopsUtils.getStyleValue(element, "paddingLeft");
          let paddingRight = PopsUtils.getStyleValue(element, "paddingRight");
          let backHeight =
            parseFloat(element.offsetWidth) -
            parseFloat(borderLeftWidth) -
            parseFloat(borderRightWidth) -
            parseFloat(paddingLeft) -
            parseFloat(paddingRight);
          return parseFloat(backHeight);
        }
        return 0;
      } else {
        /* 未显示 */
        let { recovery } = PopsUtils.showElement(element);
        let width = PopsDOMUtils.width(element, true);
        recovery();
        return width;
      }
    },
    /**
     * 获取元素的高度
     * @param {HTMLElement} element - 要获取高度的元素
     * @param {boolean} [isShow=false] 是否已进行isShow,避免爆堆栈
     * @returns {number} - 元素的高度,单位为像素
     */
    height(element, isShow = false) {
      if (PopsUtils.isWin(element)) {
        return window.document.documentElement.clientHeight;
      }
      if (typeof element === "string") {
        element = document.querySelector(element);
      }
      if (element == void 0) {
        return;
      }
      if (element.nodeType === 9) {
        /* 文档节点 */
        return Math.max(
          element.body.scrollHeight,
          element.documentElement.scrollHeight,
          element.body.offsetHeight,
          element.documentElement.offsetHeight,
          element.documentElement.clientHeight
        );
      }
      if (isShow || PopsUtils.isShow(element)) {
        /* 已显示 */
        /* 从style中获取对应的高度,因为可能使用了class定义了width !important */
        /* 如果element.style.height为空  则从css里面获取是否定义了height信息如果定义了 则读取css里面定义的高度height */
        if (parseFloat(PopsUtils.getStyleValue(element, "height")) > 0) {
          return parseFloat(PopsUtils.getStyleValue(element, "height"));
        }

        /* 如果从css里获取到的值不是大于0  可能是auto 则通过offsetHeight来进行计算 */
        if (element.offsetHeight > 0) {
          let borderTopWidth = PopsUtils.getStyleValue(
            element,
            "borderTopWidth"
          );
          let borderBottomWidth = PopsUtils.getStyleValue(
            element,
            "borderBottomWidth"
          );
          let paddingTop = PopsUtils.getStyleValue(element, "paddingTop");
          let paddingBottom = PopsUtils.getStyleValue(element, "paddingBottom");
          let backHeight =
            parseFloat(element.offsetHeight) -
            parseFloat(borderTopWidth) -
            parseFloat(borderBottomWidth) -
            parseFloat(paddingTop) -
            parseFloat(paddingBottom);
          return parseFloat(backHeight);
        }
        return 0;
      } else {
        /* 未显示 */
        let { recovery } = PopsUtils.showElement(element);
        let height = PopsDOMUtils.height(element, true);
        recovery();
        return height;
      }
    },
    /**
     * 获取元素的外部宽度(包括边框和外边距)
     * @param {HTMLElement} element - 要获取外部宽度的元素
     * @param {boolean} [isShow=false] 是否已进行isShow,避免爆堆栈
     * @returns {number} - 元素的外部宽度,单位为像素
     */
    outerWidth(element, isShow = false) {
      if (PopsUtils.isWin(element)) {
        return window.innerWidth;
      }
      if (typeof element === "string") {
        element = document.querySelector(element);
      }
      if (element == void 0) {
        return;
      }
      if (isShow || PopsUtils.isShow(element)) {
        let style = getComputedStyle(element, null);
        let marginLeft = PopsUtils.getStyleValue(style, "marginLeft");
        let marginRight = PopsUtils.getStyleValue(style, "marginRight");
        return element.offsetWidth + marginLeft + marginRight;
      } else {
        let { recovery } = PopsUtils.showElement(element);
        let outerWidth = PopsDOMUtils.outerWidth(element, true);
        recovery();
        return outerWidth;
      }
    },
    /**
     * 获取元素的外部高度(包括边框和外边距)
     * @param {HTMLElement} element - 要获取外部高度的元素
     * @param {boolean} [isShow=false] 是否已进行isShow,避免爆堆栈
     * @returns {number} - 元素的外部高度,单位为像素
     */
    outerHeight(element, isShow = false) {
      if (PopsUtils.isWin(element)) {
        return window.innerHeight;
      }
      if (typeof element === "string") {
        element = document.querySelector(element);
      }
      if (element == void 0) {
        return;
      }
      if (isShow || PopsUtils.isShow(element)) {
        let style = getComputedStyle(element, null);
        let marginTop = PopsUtils.getStyleValue(style, "marginTop");
        let marginBottom = PopsUtils.getStyleValue(style, "marginBottom");
        return element.offsetHeight + marginTop + marginBottom;
      } else {
        let { recovery } = PopsUtils.showElement(element);
        let outerHeight = PopsDOMUtils.outerHeight(element, true);
        recovery();
        return outerHeight;
      }
    },
    /**
     * 添加className
     * @param {HTMLElement} element 目标元素
     * @param {string} className className属性
     */
    addClassName(element, className) {
      if (typeof className !== "string") {
        return;
      }
      if (className.trim() === "") {
        return;
      }
      element.classList.add(className);
    },
    /**
     * 删除className
     * @param {HTMLElement} element 目标元素
     * @param {string} className className属性
     */
    removeClassName(element, className) {
      if (typeof className !== "string") {
        return;
      }
      if (className.trim() === "") {
        return;
      }
      element.classList.remove(className);
    },
    /**
     * 判断元素是否包含某个className
     * @param {HTMLElement} element 目标元素
     * @param {string} className className属性
     */
    containsClassName(element, className) {
      if (typeof className !== "string") {
        return;
      }
      if (className.trim() === "") {
        return;
      }
      return element.classList.contains(className);
    },
    /**
     * 获取或设置元素的样式属性值
     * @param {HTMLElement|string} element 目标元素
     * @param {CSSStyleDeclaration|string} property 样式属性名或包含多个属性名和属性值的对象
     * @param {any} [value] 样式属性值(可选)
     * @returns {?string} 如果传入了value,则返回undefined;否则返回样式属性值
     **/
    css(element, property, value) {
      /**
       * 把纯数字没有px的加上
       */
      function handlePixe(propertyName, propertyValue) {
        let allowAddPixe = [
          "width",
          "height",
          "top",
          "left",
          "right",
          "bottom",
          "font-size",
        ];
        if (typeof propertyValue === "number") {
          propertyValue = propertyValue.toString();
        }
        if (
          typeof propertyValue === "string" &&
          allowAddPixe.includes(propertyName) &&
          propertyValue.match(/[0-9]$/gi)
        ) {
          propertyValue = propertyValue + "px";
        }
        return propertyValue;
      }
      if (typeof element === "string") {
        element = document.querySelector(element);
      }
      if (element == void 0) {
        return;
      }
      if (typeof property === "string") {
        if (value === void 0) {
          return getComputedStyle(element).getPropertyValue(property);
        } else {
          if (value === "string" && value.includes("!important")) {
            element.style.setProperty(property, value, "important");
          } else {
            value = handlePixe(property, value);
            element.style.setProperty(property, value);
          }
        }
      } else if (typeof property === "object") {
        for (let prop in property) {
          if (
            typeof property[prop] === "string" &&
            property[prop].includes("!important")
          ) {
            element.style.setProperty(prop, property[prop], "important");
          } else {
            property[prop] = handlePixe(prop, property[prop]);
            element.style.setProperty(prop, property[prop]);
          }
        }
      }
    },
    /**
     * 创建元素
     * @param {keyof HTMLElementTagNameMap} tagName 元素类型
     * @param {HTMLElement|undefined} property 元素属性,对已有元素上的属性或者自定义的属性赋值
     * @param {object|undefined} attributes 元素自定义属性,通过setAttribute赋值
     * @returns {HTMLElement}
     */
    createElement(tagName, property, attributes) {
      let tempElement = document.createElement(tagName);
      if (typeof property === "string") {
        tempElement.innerHTML = property;
        return tempElement;
      }
      if (property == void 0) {
        property = {};
      }
      if (attributes == void 0) {
        attributes = {};
      }
      Object.keys(property).forEach((key) => {
        let value = property[key];
        tempElement[key] = value;
      });
      Object.keys(attributes).forEach((key) => {
        let value = attributes[key];
        if (typeof value === "object") {
          /* object转字符串 */
          value = JSON.stringify(value);
        } else if (typeof value === "function") {
          /* function转字符串 */
          value = value.toString();
        }
        tempElement.setAttribute(key, value);
      });
      return tempElement;
    },
  };

  /** 弹窗 */
  const pops = {};

  /** 配置 */
  pops.config = {
    /** 版本号 */
    version: "2024.3.21",
    cssText: {
      /** 主CSS */
      index: `@charset "utf-8";
      * {
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        margin: 0;
        padding: 0;
        -webkit-tap-highlight-color: transparent;
        /* 代替::-webkit-scrollbar */
        scrollbar-width: thin;
      }
      .pops{
        --pops-bg-opacity: 1;
        --pops-bd-opacity: 1;
        --pops-font-size: 16px;
      }
      .pops-mask{
        --pops-mask-bg-opacity: 0.4;
      }
      .pops {
        background-color: rgb(255, 255, 255, var(--pops-bg-opacity));
        border-radius: 4px;
        border: 1px solid rgb(235, 238, 245, var(--pops-bd-opacity));
        font-size: var(--pops-font-size);
        box-shadow: 0 0 12px rgba(0,0,0,.12);
        box-sizing: border-box;
        overflow: hidden;
        transition: all .35s
      }
      .pops-anim{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;}
      .pops-anim[anim=""]{top:unset;right:unset;bottom:unset;left:unset;width:unset;height:unset;transition:none;}
      /* 底部图标动画和样式 */
      .pops i.pops-bottom-icon[is-loading="true"]{animation: rotating 2s linear infinite;}
      .pops i.pops-bottom-icon{height:1em;width:1em;line-height:1em;display:inline-flex;justify-content:center;align-items:center;position:relative;fill:currentColor;color:inherit;font-size:inherit}
    
      /* 遮罩层样式 */
      .pops-mask{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;border:0;border-radius:0;background-color:rgba(0,0,0,var(--pops-mask-bg-opacity));box-shadow:none;transition:none;}
    
    
      .pops-header-controls button.pops-header-control[type][data-header]{
        float: right;
        margin: 0 0;
        outline: 0;
        border: 0;
        border-color: rgb(136, 136, 136, var(--pops-bd-opacity));
        background-color: transparent;
        color: #888;
        cursor: pointer;
      }
      .pops-header-controls button.pops-header-control[type=max],
      .pops-header-controls button.pops-header-control[type=mise],
      .pops-header-controls button.pops-header-control[type=min]{position:relative;float:right;margin:0 2px;outline:0!important;border:0;border-color:rgb(136, 136, 136, var(--pops-bd-opacity));background-color:transparent;color:rgb(136, 136, 136);cursor:pointer;transition:all .3s ease-in-out;}
      button.pops-header-control i{color:rgb(144, 147, 153);font-size:inherit;display:inline-flex;justify-content:center;align-items:center;position:relative;fill:currentColor}
      button.pops-header-control svg{height:1.25em;width:1.25em}
      button.pops-header-control{right:15px;padding:0;border:none;outline:0;background:0 0;cursor:pointer;position:unset;line-height:1.15;}
      button.pops-header-control i:hover{color:rgb(64, 158, 255)}
      .pops-header-controls[data-margin] button.pops-header-control{margin:0 6px}
      .pops[type-value] .pops-header-controls{display: flex;}
      `,
      /** 九宫格位置CSS */
      ninePalaceGridPosition: `
      .pops[position=top_left]{position:fixed;top:0;left:0;}
      .pops[position=top]{position:fixed;top:0;left:50%;transform:translateX(-50%);}
      .pops[position=top_right]{position:fixed;top:0;right:0;}
      .pops[position=center_left]{position:fixed;top:50%;left:0;transform:translateY(-50%);}
      .pops[position=center]{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);}
      .pops[position=center_right]{position:fixed;top:50%;right:0;transform:translateY(-50%);}
      .pops[position=bottom_left]{position:fixed;bottom:0;left:0;}
      .pops[position=bottom]{position:fixed;bottom:0;left:50%;transform:translate(-50%,0);}
      .pops[position=bottom_right]{position:fixed;right:0;bottom:0;}
      
      `,
      /** 滚动条CSS */
      scrollbar: `
      /* firefox上暂不支持::-webkit-scrollbar */
      .pops ::-webkit-scrollbar{
        width:6px;
        height:0;
      }

      .pops ::-webkit-scrollbar-track{
        width:0;
      }
      .pops ::-webkit-scrollbar-thumb:hover{
        background: rgb(178, 178, 178, var(--pops-bg-opacity));
      }
      .pops ::-webkit-scrollbar-thumb{
        min-height: 28px;
        border-radius: 2em;
        background: rgb(204, 204, 204, var(--pops-bg-opacity));
        background-clip: padding-box;
      }
      `,
      /** 按钮CSS */
      button: `
      .pops {
        --button-font-size: 14px;
        --button-height: 32px;
        --button-color: rgb(51, 51, 51);
        --button-bd-color: rgb(220, 223, 230, var(--pops-bd-opacity));
        --button-bg-color: rgb(220, 223, 230, var(--pops-bg-opacity));
        --button-margin-top: 0px;
        --button-margin-bottom: 0px;
        --button-margin-left: 5px;
        --button-margin-right: 5px;
        --button-padding-top: 6px;
        --button-padding-bottom: 6px;
        --button-padding-left: 12px;
        --button-padding-right: 12px;
        --button-radius: 4px;
    
        --container-title-height: 55px;
        --container-bottom-btn-height: 55px;
      }
      .pops[data-bottom-btn="false"]{
        --container-bottom-btn-height: 0px;
      }
      .pops button {
        white-space: nowrap;
        float: right;
        display: inline-block;
        margin: var(--button-margin-top) var(--button-margin-right) var(--button-margin-bottom) var(--button-margin-left);
        padding: var(--button-padding-top) var(--button-padding-right) var(--button-padding-bottom) var(--button-padding-left);
        outline: 0;
      }
      .pops button {
        border-radius: var(--button-radius);
        box-shadow: none;
        font-weight: 400;
        font-size: var(--button-font-size);
        cursor: pointer;
        transition: all .3s ease-in-out;
      }
      .pops button {
        display: flex;
        align-items: center;
        height: var(--button-height);
        line-height: 1;
        box-sizing: border-box;
        user-select: none;
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        border: 1px solid var(--button-bd-color);
      }
      .pops button {
        color: var(--button-color);
        border-color: var(--button-bd-color);
        background-color: var(--button-bg-color);
      }
      .pops button:active{
        color: var(--button-color);
        border-color: var(--button-bd-color);
        background-color: var(--button-bg-color);
        outline: 0;
      }
      .pops button:hover{
        color: var(--button-color);
        border-color: var(--button-bd-color);
        background-color: var(--button-bg-color);
      }
      .pops button:focus-visible{
        color: var(--button-color);
        border-color: var(--button-bd-color);
        background-color: var(--button-bg-color);
      }
      .pops button:disabled {
        cursor: not-allowed;
        color: var(--button-color);
        border-color: var(--button-bd-color);
        background-color: var(--button-bg-color);
      }
      .pops button.pops-button-large {
        --button-height: 32px;
        --button-padding-top: 12px;
        --button-padding-bottom: 12px;
        --button-padding-left: 19px;
        --button-padding-right: 19px;
        --button-font-size: 14px;
        --button-border-radius: 4px;
      }
      
      .pops button.pops-button-small {
        --button-height: 24px;
        --button-padding-top: 5px;
        --button-padding-bottom: 5px;
        --button-padding-left: 11px;
        --button-padding-right: 11px;
        --button-font-size: 12px;
        --button-border-radius: 4px;
      }
      .pops-panel-button-no-icon .pops-panel-button_inner i{
        display: none;
      }
      .pops-panel-button-right-icon{
        
      }
      .pops-panel-button-right-icon .pops-panel-button_inner{
        flex-direction: row-reverse;
      }
      .pops-panel-button-right-icon .pops-panel-button_inner i{
    
      }
      .pops-panel-button .pops-panel-button_inner i:has(svg),
      .pops-panel-button-right-icon .pops-panel-button-text{
        margin-right: 6px;
      }
    
        
      .pops button[type=default]{--button-color:#333333;--button-bd-color:#dcdfe6;--button-bg-color:#ffffff;}
      .pops button[type=default]:active{--button-color:#409eff;--button-bd-color:#409eff;--button-bg-color:#ecf5ff;}
      .pops button[type=default]:hover{--button-color:#409eff;--button-bd-color:#c6e2ff;--button-bg-color:#ecf5ff;}
      .pops button[type=default]:focus-visible{outline:2px solid #a0cfff;outline-offset:1px;}
      .pops button[type=default]:disabled{--button-color:#a8abb2;--button-bd-color:#fff;--button-bg-color:#e4e7ed;}
    
      .pops button[type=primary]{--button-color:#ffffff;--button-bd-color:#409eff;--button-bg-color:#409eff;}
      .pops button[type=primary]:active{--button-color:#ffffff;--button-bd-color:#337ecc;--button-bg-color:#337ecc;}
      .pops button[type=primary]:hover{--button-color:#ffffff;--button-bd-color:#79bbff;--button-bg-color:#79bbff;}
      .pops button[type=primary]:focus-visible{outline:2px solid #a0cfff;outline-offset:1px;}
      .pops button[type=primary]:disabled{--button-color:#ffffff;--button-bd-color:#a0cfff;--button-bg-color:#a0cfff;}
      
      .pops button[type=success]{--button-color:#ffffff;--button-bd-color:#4cae4c;--button-bg-color:#5cb85c;}
      .pops button[type=success]:active{--button-color:#ffffff;--button-bd-color:#529b2e;--button-bg-color:#529b2e;}
      .pops button[type=success]:hover{--button-color:#ffffff;--button-bd-color:#95d475;--button-bg-color:#95d475;}
      .pops button[type=success]:focus-visible{outline:2px solid #b3e19d;outline-offset:1px;}
      .pops button[type=success]:disabled{--button-color:#ffffff;--button-bd-color:#b3e19d;--button-bg-color:#b3e19d;}
      
      .pops button[type=info]{--button-color:#ffffff;--button-bd-color:#909399;--button-bg-color:#909399;}
      .pops button[type=info]:active{--button-color:#ffffff;--button-bd-color:#73767a;--button-bg-color:#73767a;}
      .pops button[type=info]:hover{--button-color:#ffffff;--button-bd-color:#b1b3b8;--button-bg-color:#b1b3b8;}
      .pops button[type=info]:focus-visible{outline:2px solid #c8c9cc;outline-offset:1px;}
      .pops button[type=info]:disabled{--button-color:#ffffff;--button-bd-color:#c8c9cc;--button-bg-color:#c8c9cc;}
      
      .pops button[type=warning]{--button-color:#ffffff;--button-bd-color:#e6a23c;--button-bg-color:#e6a23c;}
      .pops button[type=warning]:active{--button-color:#ffffff;--button-bd-color:#b88230;--button-bg-color:#b88230;}
      .pops button[type=warning]:hover{--button-color:#ffffff;--button-bd-color:#eebe77;--button-bg-color:#eebe77;}
      .pops button[type=warning]:focus-visible{outline:2px solid #f3d19e;outline-offset:1px;}
      .pops button[type=warning]:disabled{--button-color:#ffffff;--button-bd-color:#f3d19e;--button-bg-color:#f3d19e;}
      
      .pops button[type=danger]{--button-color:#ffffff;--button-bd-color:#f56c6c;--button-bg-color:#f56c6c;}
      .pops button[type=danger]:active{--button-color:#ffffff;--button-bd-color:#c45656;--button-bg-color:#c45656;}
      .pops button[type=danger]:hover{--button-color:#ffffff;--button-bd-color:#f89898;--button-bg-color:#f89898;}
      .pops button[type=danger]:focus-visible{outline:2px solid #fab6b6;outline-offset:1px;}
      .pops button[type=danger]:disabled{--button-color:#ffffff;--button-bd-color:#fab6b6;--button-bg-color:#fab6b6;}
      
      .pops button[type=xiaomi-primary]{--button-color:#ffffff;--button-bd-color:#ff5c00;--button-bg-color:#ff5c00;}
      .pops button[type=xiaomi-primary]:active{--button-color:#ffffff;--button-bd-color:#da4f00;--button-bg-color:#da4f00;}
      .pops button[type=xiaomi-primary]:hover{--button-color:#ffffff;--button-bd-color:#ff7e29;--button-bg-color:#ff7e29;}
      .pops button[type=xiaomi-primary]:focus-visible{outline:2px solid #fab6b6;outline-offset:1px;}
      .pops button[type=xiaomi-primary]:disabled{--button-color:#ffffff;--button-bd-color:#fad5b6;--button-bg-color:#fad5b6;}
    
      `,
      /** 通用的CSS */
      common: `
      .pops-flex-items-center{display: flex;align-items: center;}
      .pops-flex-y-center{display: flex;justify-content: space-between;}
      .pops-flex-x-center{display: flex;align-content: center;}
      .pops-hide {display: none;}
      .pops-hide-important {display: none !important;}
      .pops-no-border{border: 0;}
      .pops-no-border-important{border: 0;}
      `,
      /** 动画 */
      anim: `
      @keyframes rotating{0%{transform:rotate(0)}
      to{transform:rotate(360deg)}
      }
      @keyframes iframeLoadingChange_85{0%{background:linear-gradient(to right,#4995dd,#fff,rgb(202 224 246));}
      20%{background:linear-gradient(to right,#4995dd,#ead0d0,rgb(123 185 246));}
      40%{background:linear-gradient(to right,#4995dd,#f4b7b7,rgb(112 178 244));}
      60%{background:linear-gradient(to right,#4995dd,#ec9393,rgb(80 163 246));}
      80%{background:linear-gradient(to right,#4995dd,#e87f7f,rgb(25 139 253));}
      100%{background:linear-gradient(to right,#4995dd,#ee2c2c,rgb(0 124 247));}
      from{width:75%;}
      to{width:100%;}
      }
      @keyframes iframeLoadingChange{0%{background:linear-gradient(to right,#4995dd,#fff,rgb(202 224 246));}
      20%{background:linear-gradient(to right,#4995dd,#ead0d0,rgb(123 185 246));}
      40%{background:linear-gradient(to right,#4995dd,#f4b7b7,rgb(112 178 244));}
      60%{background:linear-gradient(to right,#4995dd,#ec9393,rgb(80 163 246));}
      80%{background:linear-gradient(to right,#4995dd,#e87f7f,rgb(25 139 253));}
      100%{background:linear-gradient(to right,#4995dd,#ee2c2c,rgb(0 124 247));}
      from{width:0;}
      to{width:75%;}
      }
      @keyframes pops-anim-wait-rotate{form{transform:rotate(0);}
      to{transform:rotate(360deg);}
      }
      @keyframes pops-anim-spread{0%{opacity:0;transform:scaleX(0);}
      100%{opacity:1;transform:scaleX(1);}
      }
      @keyframes pops-anim-shake{0%,100%{transform:translateX(0);}
      10%,30%,50%,70%,90%{transform:translateX(-10px);}
      20%,40%,60%,80%{transform:translateX(10px);}
      }
      @keyframes pops-anim-rolling-left{0%{opacity:0;transform:translateX(-100%) rotate(-120deg);}
      100%{opacity:1;transform:translateX(0) rotate(0);}
      }
      @keyframes pops-anim-rolling-right{0%{opacity:0;transform:translateX(100%) rotate(120deg);}
      100%{opacity:1;transform:translateX(0) rotate(0);}
      }
      @keyframes pops-anim-slide-top{0%{opacity:0;transform:translateY(-200%);}
      100%{opacity:1;transform:translateY(0);}
      }
      @keyframes pops-anim-slide-bottom{0%{opacity:0;transform:translateY(200%);}
      100%{opacity:1;transform:translateY(0);}
      }
      @keyframes pops-anim-slide-left{0%{opacity:0;transform:translateX(-200%);}
      100%{opacity:1;transform:translateX(0);}
      }
      @keyframes pops-anim-slide-right{0%{transform:translateX(200%);}
      100%{opacity:1;transform:translateX(0);}
      }
      @keyframes pops-anim-fadein{0%{opacity:0;}
      100%{opacity:1;}
      }
      @keyframes pops-anim-fadein-zoom{0%{opacity:0;transform:scale(.5);}
      100%{opacity:1;transform:scale(1);}
      }
      @keyframes pops-anim-fadein-alert{0%{transform:scale(.5);}
      45%{transform:scale(1.05);}
      80%{transform:scale(.95);}
      100%{transform:scale(1);}
      }
      @keyframes pops-anim-don{0%{opacity:0;transform:matrix3d(.7,0,0,0,0,.7,0,0,0,0,1,0,0,0,0,1);}
      2.08333%{transform:matrix3d(.75266,0,0,0,0,.76342,0,0,0,0,1,0,0,0,0,1);}
      4.16667%{transform:matrix3d(.81071,0,0,0,0,.84545,0,0,0,0,1,0,0,0,0,1);}
      6.25%{transform:matrix3d(.86808,0,0,0,0,.9286,0,0,0,0,1,0,0,0,0,1);}
      8.33333%{transform:matrix3d(.92038,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);}
      10.4167%{transform:matrix3d(.96482,0,0,0,0,1.05202,0,0,0,0,1,0,0,0,0,1);}
      12.5%{transform:matrix3d(1,0,0,0,0,1.08204,0,0,0,0,1,0,0,0,0,1);}
      14.5833%{transform:matrix3d(1.02563,0,0,0,0,1.09149,0,0,0,0,1,0,0,0,0,1);}
      16.6667%{transform:matrix3d(1.04227,0,0,0,0,1.08453,0,0,0,0,1,0,0,0,0,1);}
      18.75%{transform:matrix3d(1.05102,0,0,0,0,1.06666,0,0,0,0,1,0,0,0,0,1);}
      20.8333%{transform:matrix3d(1.05334,0,0,0,0,1.04355,0,0,0,0,1,0,0,0,0,1);}
      22.9167%{transform:matrix3d(1.05078,0,0,0,0,1.02012,0,0,0,0,1,0,0,0,0,1);}
      25%{transform:matrix3d(1.04487,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);}
      27.0833%{transform:matrix3d(1.03699,0,0,0,0,.98534,0,0,0,0,1,0,0,0,0,1);}
      29.1667%{transform:matrix3d(1.02831,0,0,0,0,.97688,0,0,0,0,1,0,0,0,0,1);}
      31.25%{transform:matrix3d(1.01973,0,0,0,0,.97422,0,0,0,0,1,0,0,0,0,1);}
      33.3333%{transform:matrix3d(1.01191,0,0,0,0,.97618,0,0,0,0,1,0,0,0,0,1);}
      35.4167%{transform:matrix3d(1.00526,0,0,0,0,.98122,0,0,0,0,1,0,0,0,0,1);}
      37.5%{transform:matrix3d(1,0,0,0,0,.98773,0,0,0,0,1,0,0,0,0,1);}
      39.5833%{transform:matrix3d(.99617,0,0,0,0,.99433,0,0,0,0,1,0,0,0,0,1);}
      41.6667%{transform:matrix3d(.99368,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);}
      43.75%{transform:matrix3d(.99237,0,0,0,0,1.00413,0,0,0,0,1,0,0,0,0,1);}
      45.8333%{transform:matrix3d(.99202,0,0,0,0,1.00651,0,0,0,0,1,0,0,0,0,1);}
      47.9167%{transform:matrix3d(.99241,0,0,0,0,1.00726,0,0,0,0,1,0,0,0,0,1);}
      50%{opacity:1;transform:matrix3d(.99329,0,0,0,0,1.00671,0,0,0,0,1,0,0,0,0,1);}
      52.0833%{transform:matrix3d(.99447,0,0,0,0,1.00529,0,0,0,0,1,0,0,0,0,1);}
      54.1667%{transform:matrix3d(.99577,0,0,0,0,1.00346,0,0,0,0,1,0,0,0,0,1);}
      56.25%{transform:matrix3d(.99705,0,0,0,0,1.0016,0,0,0,0,1,0,0,0,0,1);}
      58.3333%{transform:matrix3d(.99822,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);}
      60.4167%{transform:matrix3d(.99921,0,0,0,0,.99884,0,0,0,0,1,0,0,0,0,1);}
      62.5%{transform:matrix3d(1,0,0,0,0,.99816,0,0,0,0,1,0,0,0,0,1);}
      64.5833%{transform:matrix3d(1.00057,0,0,0,0,.99795,0,0,0,0,1,0,0,0,0,1);}
      66.6667%{transform:matrix3d(1.00095,0,0,0,0,.99811,0,0,0,0,1,0,0,0,0,1);}
      68.75%{transform:matrix3d(1.00114,0,0,0,0,.99851,0,0,0,0,1,0,0,0,0,1);}
      70.8333%{transform:matrix3d(1.00119,0,0,0,0,.99903,0,0,0,0,1,0,0,0,0,1);}
      72.9167%{transform:matrix3d(1.00114,0,0,0,0,.99955,0,0,0,0,1,0,0,0,0,1);}
      75%{transform:matrix3d(1.001,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);}
      77.0833%{transform:matrix3d(1.00083,0,0,0,0,1.00033,0,0,0,0,1,0,0,0,0,1);}
      79.1667%{transform:matrix3d(1.00063,0,0,0,0,1.00052,0,0,0,0,1,0,0,0,0,1);}
      81.25%{transform:matrix3d(1.00044,0,0,0,0,1.00058,0,0,0,0,1,0,0,0,0,1);}
      83.3333%{transform:matrix3d(1.00027,0,0,0,0,1.00053,0,0,0,0,1,0,0,0,0,1);}
      85.4167%{transform:matrix3d(1.00012,0,0,0,0,1.00042,0,0,0,0,1,0,0,0,0,1);}
      87.5%{transform:matrix3d(1,0,0,0,0,1.00027,0,0,0,0,1,0,0,0,0,1);}
      89.5833%{transform:matrix3d(.99991,0,0,0,0,1.00013,0,0,0,0,1,0,0,0,0,1);}
      91.6667%{transform:matrix3d(.99986,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);}
      93.75%{transform:matrix3d(.99983,0,0,0,0,.99991,0,0,0,0,1,0,0,0,0,1);}
      95.8333%{transform:matrix3d(.99982,0,0,0,0,.99985,0,0,0,0,1,0,0,0,0,1);}
      97.9167%{transform:matrix3d(.99983,0,0,0,0,.99984,0,0,0,0,1,0,0,0,0,1);}
      100%{opacity:1;transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);}
      }
      @keyframes pops-anim-roll{0%{transform:perspective(1000px) rotate3d(1,0,0,90deg);}
      100%{transform:perspective(1000px) rotate3d(1,0,0,0deg);}
      }
      @keyframes pops-anim-sandra{0%{opacity:0;transform:scale3d(1.1,1.1,1);}
      100%{opacity:1;transform:scale3d(1,1,1);}
      }
      @keyframes pops-anim-gather{0%{opacity:0;transform:scale(5,0);}
      100%{opacity:1;transform:scale(1,1);}
      }
      @keyframes pops-anim-spread-reverse{0%{opacity:1;transform:scaleX(1);}
      100%{opacity:0;transform:scaleX(0);}
      }
      @keyframes pops-anim-shake-reverse{0%,100%{transform:translateX(10px);}
      10%,30%,50%,70%,90%{transform:translateX(-10px);}
      20%,40%,60%,80%{transform:translateX(0);}
      }
      @keyframes pops-anim-rolling-left-reverse{0%{opacity:1;transform:translateX(0) rotate(0);}
      100%{opacity:0;transform:translateX(-100%) rotate(-120deg);}
      }
      @keyframes pops-anim-rolling-right-reverse{0%{opacity:1;transform:translateX(0) rotate(0);}
      100%{opacity:0;transform:translateX(100%) rotate(120deg);}
      }
      @keyframes pops-anim-slide-top-reverse{0%{opacity:1;transform:translateY(0);}
      100%{opacity:0;transform:translateY(-200%);}
      }
      @keyframes pops-anim-slide-bottom-reverse{0%{opacity:1;transform:translateY(0);}
      100%{opacity:0;transform:translateY(200%);}
      }
      @keyframes pops-anim-slide-left-reverse{0%{opacity:1;transform:translateX(0);}
      100%{opacity:0;transform:translateX(-200%);}
      }
      @keyframes pops-anim-slide-right-reverse{0%{opacity:1;transform:translateX(0);}
      100%{transform:translateX(200%);}
      }
      @keyframes pops-anim-fadein-reverse{0%{opacity:1;}
      100%{opacity:0;}
      }
      @keyframes pops-anim-fadein-zoom-reverse{0%{opacity:1;transform:scale(1);}
      100%{opacity:0;transform:scale(.5);}
      }
      @keyframes pops-anim-fadein-alert-reverse{0%{transform:scale(1);}
      45%{transform:scale(.95);}
      80%{transform:scale(1.05);}
      100%{transform:scale(.5);}
      }
      @keyframes pops-anim-don-reverse{100%{opacity:0;transform:matrix3d(.7,0,0,0,0,.7,0,0,0,0,1,0,0,0,0,1);}
      97.9167%{transform:matrix3d(.75266,0,0,0,0,.76342,0,0,0,0,1,0,0,0,0,1);}
      95.8333%{transform:matrix3d(.81071,0,0,0,0,.84545,0,0,0,0,1,0,0,0,0,1);}
      93.75%{transform:matrix3d(.86808,0,0,0,0,.9286,0,0,0,0,1,0,0,0,0,1);}
      91.6667%{transform:matrix3d(.92038,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);}
      89.5833%{transform:matrix3d(.96482,0,0,0,0,1.05202,0,0,0,0,1,0,0,0,0,1);}
      87.5%{transform:matrix3d(1,0,0,0,0,1.08204,0,0,0,0,1,0,0,0,0,1);}
      85.4167%{transform:matrix3d(1.02563,0,0,0,0,1.09149,0,0,0,0,1,0,0,0,0,1);}
      83.3333%{transform:matrix3d(1.04227,0,0,0,0,1.08453,0,0,0,0,1,0,0,0,0,1);}
      81.25%{transform:matrix3d(1.05102,0,0,0,0,1.06666,0,0,0,0,1,0,0,0,0,1);}
      79.1667%{transform:matrix3d(1.05334,0,0,0,0,1.04355,0,0,0,0,1,0,0,0,0,1);}
      77.0833%{transform:matrix3d(1.05078,0,0,0,0,1.02012,0,0,0,0,1,0,0,0,0,1);}
      75%{transform:matrix3d(1.04487,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);}
      72.9167%{transform:matrix3d(1.03699,0,0,0,0,.98534,0,0,0,0,1,0,0,0,0,1);}
      70.8333%{transform:matrix3d(1.02831,0,0,0,0,.97688,0,0,0,0,1,0,0,0,0,1);}
      68.75%{transform:matrix3d(1.01973,0,0,0,0,.97422,0,0,0,0,1,0,0,0,0,1);}
      66.6667%{transform:matrix3d(1.01191,0,0,0,0,.97618,0,0,0,0,1,0,0,0,0,1);}
      64.5833%{transform:matrix3d(1.00526,0,0,0,0,.98122,0,0,0,0,1,0,0,0,0,1);}
      62.5%{transform:matrix3d(1,0,0,0,0,.98773,0,0,0,0,1,0,0,0,0,1);}
      60.4167%{transform:matrix3d(.99617,0,0,0,0,.99433,0,0,0,0,1,0,0,0,0,1);}
      58.3333%{transform:matrix3d(.99368,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);}
      56.25%{transform:matrix3d(.99237,0,0,0,0,1.00413,0,0,0,0,1,0,0,0,0,1);}
      54.1667%{transform:matrix3d(.99202,0,0,0,0,1.00651,0,0,0,0,1,0,0,0,0,1);}
      52.0833%{transform:matrix3d(.99241,0,0,0,0,1.00726,0,0,0,0,1,0,0,0,0,1);}
      50%{opacity:1;transform:matrix3d(.99329,0,0,0,0,1.00671,0,0,0,0,1,0,0,0,0,1);}
      47.9167%{transform:matrix3d(.99447,0,0,0,0,1.00529,0,0,0,0,1,0,0,0,0,1);}
      45.8333%{transform:matrix3d(.99577,0,0,0,0,1.00346,0,0,0,0,1,0,0,0,0,1);}
      43.75%{transform:matrix3d(.99705,0,0,0,0,1.0016,0,0,0,0,1,0,0,0,0,1);}
      41.6667%{transform:matrix3d(.99822,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);}
      39.5833%{transform:matrix3d(.99921,0,0,0,0,.99884,0,0,0,0,1,0,0,0,0,1);}
      37.5%{transform:matrix3d(1,0,0,0,0,.99816,0,0,0,0,1,0,0,0,0,1);}
      35.4167%{transform:matrix3d(1.00057,0,0,0,0,.99795,0,0,0,0,1,0,0,0,0,1);}
      33.3333%{transform:matrix3d(1.00095,0,0,0,0,.99811,0,0,0,0,1,0,0,0,0,1);}
      31.25%{transform:matrix3d(1.00114,0,0,0,0,.99851,0,0,0,0,1,0,0,0,0,1);}
      29.1667%{transform:matrix3d(1.00119,0,0,0,0,.99903,0,0,0,0,1,0,0,0,0,1);}
      27.0833%{transform:matrix3d(1.00114,0,0,0,0,.99955,0,0,0,0,1,0,0,0,0,1);}
      25%{transform:matrix3d(1.001,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);}
      22.9167%{transform:matrix3d(1.00083,0,0,0,0,1.00033,0,0,0,0,1,0,0,0,0,1);}
      20.8333%{transform:matrix3d(1.00063,0,0,0,0,1.00052,0,0,0,0,1,0,0,0,0,1);}
      18.75%{transform:matrix3d(1.00044,0,0,0,0,1.00058,0,0,0,0,1,0,0,0,0,1);}
      16.6667%{transform:matrix3d(1.00027,0,0,0,0,1.00053,0,0,0,0,1,0,0,0,0,1);}
      14.5833%{transform:matrix3d(1.00012,0,0,0,0,1.00042,0,0,0,0,1,0,0,0,0,1);}
      12.5%{transform:matrix3d(1,0,0,0,0,1.00027,0,0,0,0,1,0,0,0,0,1);}
      10.4167%{transform:matrix3d(.99991,0,0,0,0,1.00013,0,0,0,0,1,0,0,0,0,1);}
      8.33333%{transform:matrix3d(.99986,0,0,0,0,1,0,0,0,0,1,0,0,0,0,1);}
      6.25%{transform:matrix3d(.99983,0,0,0,0,.99991,0,0,0,0,1,0,0,0,0,1);}
      4.16667%{transform:matrix3d(.99982,0,0,0,0,.99985,0,0,0,0,1,0,0,0,0,1);}
      2.08333%{transform:matrix3d(.99983,0,0,0,0,.99984,0,0,0,0,1,0,0,0,0,1);}
      0%{opacity:1;transform:matrix3d(1,0,0,0,0,1,0,0,0,0,1,0,0,0,0type=close,1);}
      }
      @keyframes pops-anim-roll-reverse{0%{transform:perspective(1000px) rotate3d(1,0,0,0deg);}
      100%{transform:perspective(1000px) rotate3d(1,0,0,90deg);}
      }
      @keyframes pops-anim-sandra-reverse{0%{opacity:1;transform:scale3d(1,1,1);}
      100%{opacity:0;transform:scale3d(1.1,1.1,1);}
      }
      @keyframes pops-anim-gather-reverse{0%{opacity:0;transform:scale(5,0);}
      100%{opacity:0;transform:scale(5,0);}
      }
  
      @-webkit-keyframes pops-motion-fadeInTop{0%{opacity:0;-webkit-transform:translateY(-30px);transform:translateY(-30px);}
      100%{opacity:1;-webkit-transform:translateX(0);transform:translateX(0);}
      }
      @keyframes pops-motion-fadeInTop{0%{opacity:0;transform:translateY(-30px);-ms-transform:translateY(-30px);}
      100%{opacity:1;transform:translateX(0);-ms-transform:translateX(0);}
      }
      @-webkit-keyframes pops-motion-fadeOutTop{0%{opacity:10;-webkit-transform:translateY(0);transform:translateY(0);}
      100%{opacity:0;-webkit-transform:translateY(-30px);transform:translateY(-30px);}
      }
      @keyframes pops-motion-fadeOutTop{0%{opacity:1;transform:translateY(0);-ms-transform:translateY(0);}
      100%{opacity:0;transform:translateY(-30px);-ms-transform:translateY(-30px);}
      }
      @-webkit-keyframes pops-motion-fadeInBottom{0%{opacity:0;-webkit-transform:translateY(20px);transform:translateY(20px);}
      100%{opacity:1;-webkit-transform:translateY(0);transform:translateY(0);}
      }
      @keyframes pops-motion-fadeInBottom{0%{opacity:0;-webkit-transform:translateY(20px);transform:translateY(20px);-ms-transform:translateY(20px);}
      100%{opacity:1;-webkit-transform:translateY(0);transform:translateY(0);-ms-transform:translateY(0);}
      }
      @-webkit-keyframes pops-motion-fadeOutBottom{0%{opacity:1;-webkit-transform:translateY(0);transform:translateY(0);}
      100%{opacity:0;-webkit-transform:translateY(20px);transform:translateY(20px);}
      }
      @keyframes pops-motion-fadeOutBottom{0%{opacity:1;-webkit-transform:translateY(0);transform:translateY(0);-ms-transform:translateY(0);}
      100%{opacity:0;-webkit-transform:translateY(20px);transform:translateY(20px);-ms-transform:translateY(20px);}
      }
      @-webkit-keyframes pops-motion-fadeInLeft{0%{opacity:0;-webkit-transform:translateX(-20px);transform:translateX(-20px);}
      100%{opacity:1;-webkit-transform:translateX(0);transform:translateX(0);}
      }
      @keyframes pops-motion-fadeInLeft{0%{opacity:0;-webkit-transform:translateX(-30px);transform:translateX(-30px);-ms-transform:translateX(-30px);}
      100%{opacity:1;-webkit-transform:translateX(0);transform:translateX(0);-ms-transform:translateX(0);}
      }
      @-webkit-keyframes pops-motion-fadeOutLeft{0%{opacity:1;-webkit-transform:translateX(0);transform:translateX(0);}
      100%{opacity:0;-webkit-transform:translateX(-30px);transform:translateX(-30px);}
      }
      @keyframes pops-motion-fadeOutLeft{0%{opacity:1;-webkit-transform:translateX(0);transform:translateX(0);-ms-transform:translateX(0);}
      100%{opacity:0;-webkit-transform:translateX(-20px);transform:translateX(-20px);-ms-transform:translateX(-20px);}
      }
      @-webkit-keyframes pops-motion-fadeInRight{0%{opacity:0;-webkit-transform:translateX(20px);transform:translateX(20px);}
      100%{opacity:1;-webkit-transform:translateX(0);transform:translateX(0);}
      }
      @keyframes pops-motion-fadeInRight{0%{opacity:0;-webkit-transform:translateX(20px);transform:translateX(20px);-ms-transform:translateX(20px);}
      100%{opacity:1;-webkit-transform:translateX(0);transform:translateX(0);-ms-transform:translateX(0);}
      }
      @-webkit-keyframes pops-motion-fadeOutRight{0%{opacity:1;-webkit-transform:translateX(0);transform:translateX(0);}
      100%{opacity:0;-webkit-transform:translateX(20px);transform:translateX(20px);}
      }
      @keyframes pops-motion-fadeOutRight{0%{opacity:1;-webkit-transform:translateX(0);transform:translateX(0);-ms-transform:translateX(0);}
      100%{opacity:0;-webkit-transform:translateX(20px);transform:translateX(20px);-ms-transform:translateX(20px);}
      }


      /* 动画 */
      .pops-anim[anim=pops-anim-spread]{animation:pops-anim-spread .3s;}
      .pops-anim[anim=pops-anim-shake]{animation:pops-anim-shake .3s;}
      .pops-anim[anim=pops-anim-rolling-left]{animation:pops-anim-rolling-left .3s;}
      .pops-anim[anim=pops-anim-rolling-right]{animation:pops-anim-rolling-right .3s;}
      .pops-anim[anim=pops-anim-slide-top]{animation:pops-anim-slide-top .3s;}
      .pops-anim[anim=pops-anim-slide-bottom]{animation:pops-anim-slide-bottom .3s;}
      .pops-anim[anim=pops-anim-slide-left]{animation:pops-anim-slide-left .3s;}
      .pops-anim[anim=pops-anim-slide-right]{animation:pops-anim-slide-right .3s;}
      .pops-anim[anim=pops-anim-fadein]{animation:pops-anim-fadein .3s;}
      .pops-anim[anim=pops-anim-fadein-zoom]{animation:pops-anim-fadein-zoom .3s;}
      .pops-anim[anim=pops-anim-fadein-alert]{animation:pops-anim-fadein-alert .3s;}
      .pops-anim[anim=pops-anim-don]{animation:pops-anim-don .3s;}
      .pops-anim[anim=pops-anim-roll]{animation:pops-anim-roll .3s;}
      .pops-anim[anim=pops-anim-sandra]{animation:pops-anim-sandra .3s;}
      .pops-anim[anim=pops-anim-gather]{animation:pops-anim-gather .3s;}
      .pops-anim[anim=pops-anim-spread-reverse]{animation:pops-anim-spread-reverse .3s;}
      .pops-anim[anim=pops-anim-shake-reverse]{animation:pops-anim-shake-reverse .3s;}
      .pops-anim[anim=pops-anim-rolling-left-reverse]{animation:pops-anim-rolling-left-reverse .3s;}
      .pops-anim[anim=pops-anim-rolling-right-reverse]{animation:pops-anim-rolling-right-reverse .3s;}
      .pops-anim[anim=pops-anim-slide-top-reverse]{animation:pops-anim-slide-top-reverse .3s;}
      .pops-anim[anim=pops-anim-slide-bottom-reverse]{animation:pops-anim-slide-bottom-reverse .3s;}
      .pops-anim[anim=pops-anim-slide-left-reverse]{animation:pops-anim-slide-left-reverse .3s;}
      .pops-anim[anim=pops-anim-slide-right-reverse]{animation:pops-anim-slide-right-reverse .3s;}
      .pops-anim[anim=pops-anim-fadein-reverse]{animation:pops-anim-fadein-reverse .3s;}
      .pops-anim[anim=pops-anim-fadein-zoom-reverse]{animation:pops-anim-fadein-zoom-reverse .3s;}
      .pops-anim[anim=pops-anim-fadein-alert-reverse]{animation:pops-anim-fadein-alert-reverse .3s;}
      .pops-anim[anim=pops-anim-don-reverse]{animation:pops-anim-don-reverse .3s;}
      .pops-anim[anim=pops-anim-roll-reverse]{animation:pops-anim-roll-reverse .3s;}
      .pops-anim[anim=pops-anim-sandra-reverse]{animation:pops-anim-sandra-reverse .3s;}
      .pops-anim[anim=pops-anim-gather-reverse]{animation:pops-anim-gather-reverse .3s;}
      `,
      alertCSS: `
      .pops[type-value] .pops-alert-title{display: flex;align-items: center;justify-content: space-between;}
      .pops[type-value=alert] .pops-alert-title{width:100%;height:var(--container-title-height);border-bottom:1px solid rgb(229, 229, 229, var(--pops-bd-opacity));}
      .pops[type-value=alert] .pops-alert-title p[pops]{width:100%;overflow:hidden;color:rgb(51, 51, 51);text-indent:15px;text-overflow:ellipsis;white-space:nowrap;font-weight:500;line-height:var(--container-title-height);}
      .pops[type-value=alert] .pops-alert-content p[pops]{padding:5px 10px;color:rgb(51, 51, 51);text-indent:15px;}
      .pops[type-value=alert] .pops-alert-content{
      width:100%;
      height: calc(100% - var(--container-title-height) - var(--container-bottom-btn-height));
      overflow: auto;
      word-break:break-word;
      }
      .pops[type-value=alert] .pops-alert-btn{position:absolute;bottom:0;display:flex;padding:10px 10px 10px 10px;width:100%;height:var(--container-bottom-btn-height);border-top:1px solid rgb(229, 229, 229, var(--pops-bd-opacity));text-align:right;line-height:var(--container-bottom-btn-height);align-items:center;}

      `,
      confirmCSS: `
      .pops[type-value] .pops-confirm-title{display: flex;align-items: center;justify-content: space-between;}
      .pops[type-value=confirm] .pops-confirm-title{width:100%;height:var(--container-title-height);border-bottom:1px solid rgb(229, 229, 229, var(--pops-bd-opacity));}
      .pops[type-value=confirm] .pops-confirm-title p[pops]{width:100%;overflow:hidden;color:rgb(51, 51, 51);text-indent:15px;text-overflow:ellipsis;white-space:nowrap;font-weight:500;line-height:var(--container-title-height);}
      .pops[type-value=confirm] .pops-confirm-content p[pops]{padding:5px 10px;color:rgb(51, 51, 51);text-indent:15px;}
      .pops[type-value=confirm] .pops-confirm-content{
        width:100%;
        height: calc(100% - var(--container-title-height) - var(--container-bottom-btn-height));
        overflow: auto;
        word-break:break-word;
      }
      .pops[type-value=confirm] .pops-confirm-btn{position:absolute;bottom:0;display:flex;padding:10px 10px 10px 10px;width:100%;height:var(--container-bottom-btn-height);border-top:1px solid rgb(229, 229, 229, var(--pops-bd-opacity));text-align:right;line-height:var(--container-bottom-btn-height);align-items:center;}
      
      `,
      promptCSS: `
      .pops[type-value] .pops-prompt-title{display: flex;align-items: center;justify-content: space-between;}
      .pops[type-value=prompt] .pops-prompt-title{width:100%;height:var(--container-title-height);border-bottom:1px solid rgb(229, 229, 229, var(--pops-bd-opacity));}
      .pops[type-value=prompt] .pops-prompt-title p[pops]{width:100%;overflow:hidden;color:rgb(51, 51, 51);text-indent:15px;text-overflow:ellipsis;white-space:nowrap;font-weight:500;line-height:var(--container-title-height);}
      .pops[type-value=prompt] .pops-prompt-content p[pops]{padding:5px 10px;color:rgb(51, 51, 51);text-indent:15px;}
      .pops[type-value=prompt] .pops-prompt-content{
        width:100%;
        height: calc(100% - var(--container-title-height) - var(--container-bottom-btn-height));
        overflow: auto;
        word-break:break-word;
      }
      .pops[type-value=prompt] .pops-prompt-btn{position:absolute;bottom:0;display:flex;padding:10px 10px 10px 10px;width:100%;height:var(--container-bottom-btn-height);border-top:1px solid rgb(229, 229, 229, var(--pops-bd-opacity));text-align:right;line-height:var(--container-bottom-btn-height);align-items:center;}
      .pops[type-value=prompt] input[pops]{padding:5px 10px;}
      .pops[type-value=prompt] textarea[pops]{padding:5px 10px;resize:none;}
      .pops[type-value=prompt] input[pops],.pops[type-value=prompt] textarea[pops]{width:100%;height:100%;outline:0;border:0;color:rgb(51, 51, 51);}

      `,
      loadingCSS: `
      .pops[type-value=loading] {
        position: absolute;
        top: 272.5px;
        top: 50%;
        left: 26px;
        left: 50%;
        display: flex;
        overflow: hidden;
        padding: 10px 15px;
        max-width: 100%;
        max-height: 100%;
        min-width: 0;
        min-height: 0;
        border: 1px solid rgba(0,0,0,.2);
        border-radius: 5px;
        background-color: rgb(255, 255, 255, var(--pops-bg-opacity));
        box-shadow: 0 0 5px rgb(0 0 0 / 50%);
        vertical-align: middle;
        transition: all .35s;
        transform: translate(-50%,-50%);
        user-select: none;
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        align-content: center;
      }
      .pops[type-value=loading]:before{float:left;display:inline-block;width:2em;height:2em;border:.3em solid rgba(100,149,237,.1);border-top:.3em solid rgb(100, 149, 237, var(--pops-bd-opacity));border-radius:50%;content:" ";vertical-align:middle;font-size:inherit;animation:pops-anim-wait-rotate 1.2s linear infinite;}
      .pops[type-value=loading] .pops-loading-content{position:static;top:0;bottom:0;float:left;overflow:hidden;width:auto;font-size:inherit;line-height:2em;}
      .pops[type-value=loading] .pops-loading-content p[pops] {
        display: inline-block;
        padding: 5px 0px;
        color: rgb(51, 51, 51);
        text-indent: 15px;
        font-size: inherit;
        text-align: center;
      }
      
      `,
      iframeCSS: `
      .pops[type-value=iframe]{
        --container-title-height: 55px;
      }
      .pops[type-value] .pops-iframe-title{display: flex;align-items: center;justify-content: space-between;}
      .pops[type-value=iframe] .pops-iframe-title{width:calc(100% - 0px);height:var(--container-title-height);border-bottom:1px solid rgb(229, 229, 229, var(--pops-bd-opacity));}
      .pops[type-value=iframe] .pops-iframe-title p[pops]{width:100%;overflow:hidden;color:rgb(51, 51, 51);text-indent:15px;text-overflow:ellipsis;white-space:nowrap;font-weight:500;line-height:var(--container-title-height);}
      .pops[type-value=iframe] .pops-iframe-content p[pops]{padding:5px 10px;color:#333;text-indent:15px;}
      .pops[type-value=iframe] .pops-iframe-content{
        width:100%;
        height: calc(100% - var(--container-title-height));
        overflow: hidden;
        word-break:break-word;
      }
      .pops-loading{position:absolute;top:40px;right:0;bottom:0;left:0;z-index:5;background-color:rgb(255, 255, 255, var(--pops-bg-opacity));}
      .pops-loading:before{position:absolute;top:50%;left:50%;z-index:3;display:block;margin:-20px 0 0 -20px;padding:20px;border:4px solid rgb(221, 221, 221, var(--pops-bd-opacity));border-radius:50%;content:"";border-top-color:transparent;animation:pops-anim-wait-rotate 1.2s linear infinite;}
      .pops[type-value=iframe].pops[type-module=min]{top:unset!important;bottom:0;max-width:200px;max-height:53px;transform:none;}
      .pops[type-value=iframe].pops[type-module=min] .pops-header-control[type=min]{display:none;}
      .pops[type-value=iframe].pops[type-module=max]{top:unset!important;left:unset!important;width:100%!important;height:100%!important;transform:none;}
      .pops[type-value=iframe] iframe[pops]{width:calc(100% - 4px);height:calc(100% - 4px);border:0;}
      .pops-iframe-content-global-loading{position:absolute;top:0;left:0;z-index:999999;width:0;height:4px;background:linear-gradient(to right,#4995dd,#fff,rgb(202 224 246));animation:iframeLoadingChange 2s forwards;}
      `,
      drawerCSS: `
      .pops[type-value=drawer] {
        position: fixed;
        box-sizing: border-box;
        display: flex;
        flex-direction: column;
        box-shadow: 0px 16px 48px 16px rgba(0, 0, 0, .08), 0px 12px 32px rgba(0, 0, 0, .12), 0px 8px 16px -8px rgba(0, 0, 0, .16);
        overflow: hidden;
        transition: all .3s;
      }
      .pops[type-value] .pops-drawer-title{display: flex;align-items: center;justify-content: space-between;}
      
      .pops[type-value=drawer][direction=top]{width: 100%;left: 0;right: 0;top: 0;}
      .pops[type-value=drawer][direction=bottom]{width: 100%;left: 0;right: 0;bottom: 0;}
      .pops[type-value=drawer][direction=left]{height: 100%;top: 0;bottom: 0;left: 0;}
      .pops[type-value=drawer][direction=right]{height: 100%;top: 0;bottom: 0;right: 0;}
      .pops-drawer-content{height: 100%;}
      .pops[type-value="drawer"] .pops-drawer-btn{padding-top: 10px;padding-bottom: 10px;}
      
      `,
      folderCSS: `
      .pops[type-value] .pops-folder-title{display: flex;align-items: center;justify-content: space-between;}
      .pops[type-value=folder] .pops-folder-title{width:100%;height:var(--container-title-height);border-bottom:1px solid rgb(229, 229, 229, var(--pops-bd-opacity));}
      .pops[type-value=folder] .pops-folder-title p[pops]{width:100%;overflow:hidden;color:rgb(51, 51, 51);text-indent:15px;text-overflow:ellipsis;white-space:nowrap;font-weight:500;line-height:var(--container-title-height);}
      .pops[type-value=folder] .pops-folder-content p[pops]{padding:5px 10px;color:rgb(51, 51, 51);text-indent:15px;}
      .pops[type-value=folder] .pops-folder-content{
        width:100%;
        height: calc(100% - var(--container-title-height) - var(--container-bottom-btn-height));
        overflow: auto;
        word-break:break-word;
      }
      .pops[type-value=folder] .pops-folder-btn{position:absolute;bottom:0;display:flex;padding:10px 10px 10px 10px;width:100%;height:var(--container-bottom-btn-height);border-top:1px solid rgb(229, 229, 229, var(--pops-bd-opacity));text-align:right;line-height:var(--container-bottom-btn-height);align-items:center;}
      .pops-folder-list .cursor-p{cursor:pointer}
      .pops-folder-list a{background:0 0;text-decoration:none;-webkit-tap-highlight-color:transparent;color:#05082c}
      table.pops-folder-list-table__body,table.pops-folder-list-table__header{width:100%;table-layout:fixed;border-collapse:collapse;border-spacing:0;padding:0 20px}
      table.pops-folder-list-table__body,table.pops-folder-list-table__header{height:100%;background:0 0;overflow:hidden;display:-webkit-box;display:-ms-flexbox;-ms-flex-direction:column;-webkit-box-orient:vertical;-webkit-box-direction:normal}
      table.pops-folder-list-table__body{height:100%;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}
      .pops-folder-list table tr{line-height:1}
      .pops-folder-list-table__header-row{height:50px;line-height:50px;color:rgb(129, 137, 153);text-align:left;font-size:12px}
      .pops-folder-list-table__header-row{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}
      .pops-folder-list-table__body-row{height:50px;line-height:50px;color:#03081a;font-size:12px}
      .pops-folder-list-table__body-row:hover{background:rgb(245, 246, 247, var(--pops-bg-opacity))}
      .pops-folder-list table th{border:0;border-bottom:1px solid rgb(247, 248, 250, var(--pops-bg-opacity))}
      .pops-folder-list table td{border:0;border-bottom:1px solid rgb(247, 248, 250, var(--pops-bg-opacity));position:relative}
      .pops-folder-list .list-name-text{display:inline-block;padding-left:12px;line-height:40px;max-width:176px}
      .pops-folder-list-file-name > div{display:flex;align-items:center;}
      
      .pops-mobile-folder-list-file-name{display:flex;align-items:center}
      .pops-mobile-folder-list-file-name>div {
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start;
        align-items: flex-start;
        padding: 6px 0px;
        flex-direction: column;
      }
      .pops-mobile-folder-list-file-name img.pops-folder-list-file-icon{width:45px;height:45px}
      .pops-mobile-folder-list-file-name a.pops-folder-list-file-name-title-text {
        padding-left: unset;
        max-width: 250px;
        overflow-x: hidden;
        font-weight: 400;
        line-height: unset;
        margin-bottom: 4px;
        white-space: normal;
        text-overflow: unset;
      }
  
      /* 修改滚动 */
      .pops-folder-content{overflow: hidden !important}
      .pops-folder-content .pops-folder-list{height: 100%}
      .pops-folder-content .pops-folder-list-table__body-div{height: 100%;padding-bottom: 85px}
      .pops-mobile-folder-content .pops-folder-list-table__body-div{height: 100%;padding-bottom: 40px}
      .pops-folder-content table.pops-folder-list-table__body{overflow: auto}
      .pops-mobile-folder-content .pops-folder-list-table__header-div{display: none}
  
      .pops-folder-list-file-name-title-text:hover{text-decoration:none;color:rgb(6, 167, 255)}
      .pops-folder-list .text-ellip{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}
      .pops-folder-list .content{color:rgb(129, 137, 153);position:relative;width:100%;text-align:left}
      .pops-folder-list .inline-block-v-middle{display:inline-block;vertical-align:middle}
      .pops-folder-list .flex-a-i-center{display: flex;align-items: center;}
      .pops-folder-list .u-file-icon{display:inline-block;vertical-align:middle}
      .pops-folder-list .u-file-icon--list{width:32px;height:32px}
      .pops-folder-list .pops-folder-list-file-icon{line-height:1;position:relative;vertical-align:middle}
      .pops-folder-list .pops-folder-file-list-breadcrumb-primary {
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -webkit-align-items: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -webkit-flex-direction: row;
        -ms-flex-direction: row;
        flex-direction: row;
        min-height: 17px;
        flex-wrap: wrap;
      }
      .pops-folder-list .pops-folder-list-table__sort {
        display: inline-flex;
        margin-left: 4px;
        flex-direction: column;
      }
      
      .pops-folder-list .pops-folder-icon-arrow{
        width: 10px;
        height: 10px;
        fill: rgb(212, 215, 222);
      }
      .pops-folder-list .pops-folder-icon-active{
        fill: rgb(6, 167, 255);
      }
      .pops-folder-list .pops-folder-file-list-breadcrumb {
        padding: 4px 20px;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        display: -webkit-box;
        display: -webkit-flex;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -webkit-align-items: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -webkit-flex-direction: row;
        -ms-flex-direction: row;
        flex-direction: row;
        -webkit-box-pack: start;
        -webkit-justify-content: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
        min-height: 35px;
      }
      .pops-folder-list .pops-folder-file-list-breadcrumb-allFiles{font-size:12px;color:#333;line-height:20px;font-weight:700;display:inline-block;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;word-wrap:normal}
      .pops-folder-list .pops-folder-file-list-breadcrumb-allFiles:last-child a{color:rgb(153, 153, 153)}
      .pops-folder-list .pops-folder-file-list-breadcrumb-allFiles:first-child a{font-size:14px;color:rgb(18, 22, 26)}
      .pops-folder-list .pops-folder-file-list-breadcrumb .iconArrow{width:16px;height:16px}
      .pops-folder-list .iconArrow{
        background: url() 55% 50%/6px 9px no-repeat;
      }


      `,
      panelCSS: `
      .pops[type-value=panel]{
        --el-disabled-text-color: #a8abb2;
        --el-disabled-bg-color: #f5f7fa;
        --el-disabled-border-color: #e4e7ed;
        --aside-bg-color: #f2f2f2;
      }
      .pops[type-value] .pops-panel-title{display: flex;align-items: center;justify-content: space-between;}
    
      .pops[type-value=panel] .pops-panel-title{width:100%;height:var(--container-title-height);border-bottom:1px solid rgb(229, 229, 229, var(--pops-bd-opacity));}
      .pops[type-value=panel] .pops-panel-title p[pops]{width:100%;overflow:hidden;color:#333;text-indent:15px;text-overflow:ellipsis;white-space:nowrap;font-weight:500;line-height:var(--container-title-height);}
      .pops[type-value=panel] .pops-panel-content{
        width:100%;
        height: calc(100% - var(--container-title-height) - var(--container-bottom-btn-height));
        overflow: auto;
        word-break:break-word;
      }
      .pops[type-value=panel] .pops-panel-btn{position:absolute;bottom:0;display:flex;padding:10px 10px 10px 10px;width:100%;height:var(--container-bottom-btn-height);border-top:1px solid rgb(229, 229, 229, var(--pops-bd-opacity));text-align:right;line-height:var(--container-bottom-btn-height);align-items:center;}
      
      /* ↓panel的CSS↓ */
      aside.pops-panel-aside{overflow:auto;box-sizing:border-box;flex-shrink:0;width:200px;height:100%;background:var(--aside-bg-color);border-right:1px solid var(--aside-bg-color);font-size:0.9em;}
      .pops-panel-content{display:flex;flex-direction:row;flex:1;flex-basis:auto;box-sizing:border-box;min-width:0;bottom:0!important}
      section.pops-panel-container{width:100%;padding:10px;overflow:hidden}
      section.pops-panel-container .pops-panel-container-header-ul{border-bottom: 1px solid rgb(229, 229, 229, var(--pops-bd-opacity));}
      section.pops-panel-container .pops-panel-container-header-ul li{display: flex;justify-content: flex-start !important;text-align:left;}
      section.pops-panel-container > ul:last-child{overflow: auto;height: calc(100% - 45px);}
      aside.pops-panel-aside ul li{margin:6px 8px;border-radius:4px;padding:6px 10px;cursor:default;display:flex;align-items:center;justify-content:flex-start}
      aside.pops-panel-aside .pops-is-visited,aside.pops-panel-aside ul li:hover{color:rgb(64, 158, 255);background:rgba(64,158,255 ,.1)}
      section.pops-panel-container>ul li{display:flex;justify-content:space-between;align-items:center;margin:10px 20px}
      section.pops-panel-container li.pops-panel-forms-container-item{display:block;margin-top:20px}
      section.pops-panel-container .pops-panel-forms-container-item ul{border-radius:6px;background:var(--aside-bg-color);margin:10px}
      section.pops-panel-container .pops-panel-forms-container-item ul li {
        display: flex;
        justify-content: space-between;
        align-items: center;
        margin: 0 10px;
        padding: 10px 0;
        border-bottom: 1px solid rgb(229, 229, 229, var(--pops-bd-opacity));
        text-align: left;
      }
      section.pops-panel-container .pops-panel-forms-container-item ul li:last-child{border:0}
      section.pops-panel-container .pops-panel-forms-container-item>div{margin:10px;margin-left:20px;font-size:0.9em;text-align:left;}
      /* 主文字 */
      section.pops-panel-container .pops-panel-forms-container-item .pops-panel-item-left-text .pops-panel-item-left-main-text {
        /* line-height: 2; */
      }
      /* 描述文字 */
      section.pops-panel-container .pops-panel-forms-container-item .pops-panel-item-left-text .pops-panel-item-left-desc-text{
        /* line-height: 1; */
        font-size: 0.8em;
        color: rgb(108, 108, 108);
      }
      /* 兼容移动端CSS */
      .pops[type-value="panel"].pops-panel-is-mobile{
        width: 92vw;
      }
      .pops[type-value="panel"].pops-panel-is-mobile section.pops-panel-container{
        padding: 10px 0px;
      }
      .pops[type-value="panel"].pops-panel-is-mobile .pops-panel-content aside.pops-panel-aside{
        width: 20%;
      }
      .pops[type-value="panel"].pops-panel-is-mobile section.pops-panel-container .pops-panel-forms-container-item>div{
        margin: 5px 10px;
        text-align: left;
      }
      .pops[type-value="panel"].pops-panel-is-mobile section.pops-panel-container .pops-panel-forms-container-item ul{
        margin: 0px !important;
      }
      .pops[type-value="panel"].pops-panel-is-mobile section.pops-panel-container>ul li{
        margin: 5px 5px!important;
        padding: 5px 5px !important;
      }
      .pops[type-value="panel"].pops-panel-is-mobile section.pops-panel-container >ul > li div:nth-child(2){
        max-width: 55%;
        margin-left: 6px;
        text-align: right;
      }
      .pops[type-value="panel"].pops-panel-is-mobile section.pops-panel-container .pops-panel-select select{
        min-width: 88px !important;
        width: -webkit-fill-available;
        width: -moz-available;
      }
      .pops[type-value="panel"].pops-panel-is-mobile section.pops-panel-container .pops-panel-container-header-ul li{
        font-size: 16px;
      }
      .pops[type-value="panel"].pops-panel-is-mobile .pops-panel-title p[pops],
      .pops[type-value="panel"].pops-panel-is-mobile section.pops-panel-container>ul li,
      .pops[type-value="panel"].pops-panel-is-mobile aside.pops-panel-aside ul li{
        font-size: 14px;
      }
      /* switch的CSS */
      .pops-panel-switch {
        display: inline-flex;
        flex-direction: row-reverse;
        align-items: center;
        position: relative;
        font-size: 14px;
        line-height: 20px;
        height: 32px;
        vertical-align: middle
      }
      .pops-panel-switch input.pops-panel-switch__input {
        position: absolute;
        width: 0;
        height: 0;
        opacity: 0;
        margin: 0
      }
      .pops-panel-switch:has(input.pops-panel-switch__input:disabled),
      .pops-panel-switch[data-disabled],
      .pops-panel-switch[data-disabled] .pops-panel-switch__core,
      .pops-panel-switch input.pops-panel-switch__input:disabled + .pops-panel-switch__core{
        cursor: not-allowed;
        opacity: .6;
      }
      .pops-panel-switch span.pops-panel-switch__core {
        display: inline-flex;
        position: relative;
        align-items: center;
        min-width: 40px;
        height: 20px;
        border: 1px solid rgb(220, 223, 230, var(--pops-bd-opacity));
        outline: 0;
        border-radius: 10px;
        box-sizing: border-box;
        background: rgb(220, 223, 230, var(--pops-bg-opacity));
        cursor: pointer;
        transition: border-color .3s,background-color .3s
      }
      .pops-panel-switch .pops-panel-switch__action {
        position: absolute;
        left: 1px;
        border-radius: 100%;
        transition: all .3s;
        width: 16px;
        height: 16px;
        background-color: rgb(255, 255, 255, var(--pops-bg-opacity));
        display: flex;
        justify-content: center;
        align-items: center;
        color: rgb(220, 223, 230)
      }
      .pops-panel-switch.pops-panel-switch-is-checked span.pops-panel-switch__core{border-color:rgb(64, 158, 255, var(--pops-bd-opacity));background-color:rgb(64, 158, 255, var(--pops-bg-opacity))}
      .pops-panel-switch.pops-panel-switch-is-checked .pops-panel-switch__action{left:calc(100% - 17px);color:rgb(64, 158, 255)}
      /* switch的CSS */
      
      /* slider旧的CSS */
      section.pops-panel-container .pops-panel-slider:has(>input[type=range]){overflow:hidden;height:25px;line-height:25px;display:flex;align-items:center}
      section.pops-panel-container .pops-panel-slider input[type=range] {
        height: 6px;
        background: rgb(228, 231, 237, var(--pops-bg-opacity));
        outline: 0;
        -webkit-appearance: none;
        appearance: none;
        width: 100%;
      }
      section.pops-panel-container .pops-panel-slider input[type=range]::-webkit-slider-thumb{
        width: 20px;
        height: 20px;
        border-radius: 50%;
        border: 1px solid rgb(64, 158, 255, var(--pops-bd-opacity));
        background-color: rgb(255, 255, 255, var(--pops-bg-opacity));
        box-shadow: 0 0 2px rgba(0,0,0,.3),0 3px 5px rgba(0,0,0,.2);
        cursor: pointer;
        -webkit-appearance: none;
        appearance: none;
        border-image: linear-gradient(#409eff,#409eff) 0 fill/9 25 9 0/0 0 0 100vw;
      }
      section.pops-panel-container .pops-panel-slider input[type=range]::-moz-range-thumb {
        width: 20px;
        height: 20px;
        border-radius: 50%;
        border: 1px solid rgb(64, 159, 255, var(--pops-bd-opacity));
        background-color: rgb(255, 255, 255, var(--pops-bg-opacity));
        box-shadow: 0 0 2px rgba(0,0,0,.3),0 3px 5px rgba(0,0,0,.2);
        cursor: pointer;
        -webkit-appearance: none;
        appearance: none;
      }
      section.pops-panel-container .pops-panel-slider input[type=range]::-moz-range-progress{
        height: 6px;
        border-image: linear-gradient(#409eff,#409eff) 0 fill/9 25 9 0/0 0 0 100vw;
      }
      /* slider旧的CSS */
    
      /* slider的CSS */
      .pops-slider {
        --pops-slider-color-white: #ffffff;
        --pops-slider-color-primary: #409eff;
        --pops-slider-color-info: #909399;
        --pops-slider-text-color-placeholder: #a8abb2;
        --pops-slider-border-color-light: #e4e7ed;
        --pops-slider-border-radius-circle: 100%;
        --pops-slider-transition-duration-fast: 0.2s;
    
        --pops-slider-main-bg-color: var(--pops-slider-color-primary);
        --pops-slider-runway-bg-color: var(--pops-slider-border-color-light);
        --pops-slider-stop-bg-color: var(--pops-slider-color-white);
        --pops-slider-disabled-color: var(--pops-slider-text-color-placeholder);
        --pops-slider-border-radius: 3px;
        --pops-slider-height: 6px;
        --pops-slider-button-size: 20px;
        --pops-slider-button-wrapper-size: 36px;
        --pops-slider-button-wrapper-offset: -15px;
      }
    
      .pops-slider {
        width: 100%;
        height: 32px;
        display: flex;
        align-items: center;
      }
    
      .pops-slider-width{
        flex: 0 0 52%;
        margin-left: 10px;
      }
    
      .pops-slider__runway {
        flex: 1;
        height: var(--pops-slider-height);
        background-color: var(--pops-slider-runway-bg-color);
        border-radius: var(--pops-slider-border-radius);
        position: relative;
        cursor: pointer;
      }
    
      .pops-slider__runway.show-input {
        margin-right: 30px;
        width: auto;
      }
    
      .pops-slider__runway.pops-slider-is-disabled {
        cursor: default;
      }
    
      .pops-slider__runway.pops-slider-is-disabled .pops-slider__bar {
        background-color: var(--pops-slider-disabled-color);
      }
    
      .pops-slider__runway.pops-slider-is-disabled .pops-slider__button {
        border-color: var(--pops-slider-disabled-color);
      }
    
      .pops-slider__runway.pops-slider-is-disabled
        .pops-slider__button:hover,
      .pops-slider__runway.pops-slider-is-disabled
        .pops-slider__button.hover,
      .pops-slider__runway.pops-slider-is-disabled
        .pops-slider__button.dragging {
        cursor: not-allowed;
      }
    
      .pops-slider__runway.pops-slider-is-disabled .pops-slider__button:hover,
      .pops-slider__runway.pops-slider-is-disabled .pops-slider__button.hover,
      .pops-slider__runway.pops-slider-is-disabled
        .pops-slider__button.dragging {
        transform: scale(1);
      }
    
      .pops-slider__runway.pops-slider-is-disabled .pops-slider__button:hover,
      .pops-slider__runway.pops-slider-is-disabled .pops-slider__button.hover,
      .pops-slider__runway.pops-slider-is-disabled
        .pops-slider__button.dragging {
        cursor: not-allowed;
      }
    
      .pops-slider__input {
        flex-shrink: 0;
        width: 130px;
      }
    
      .pops-slider__bar {
        height: var(--pops-slider-height);
        background-color: var(--pops-slider-main-bg-color);
        border-top-left-radius: var(--pops-slider-border-radius);
        border-bottom-left-radius: var(--pops-slider-border-radius);
        position: absolute;
      }
    
      .pops-slider__button-wrapper {
        height: var(--pops-slider-button-wrapper-size);
        width: var(--pops-slider-button-wrapper-size);
        position: absolute;
        z-index: 1;
        top: var(--pops-slider-button-wrapper-offset);
        transform: translate(-50%);
        background-color: transparent;
        text-align: center;
        user-select: none;
        line-height: normal;
        outline: none;
      }
    
      .pops-slider__button-wrapper:after {
        display: inline-block;
        content: "";
        height: 100%;
        vertical-align: middle;
      }
    
      .pops-slider__button:hover,
      .pops-slider__button.hover {
        cursor: grab;
      }
    
      .pops-slider__button {
        display: inline-block;
        width: var(--pops-slider-button-size);
        height: var(--pops-slider-button-size);
        vertical-align: middle;
        border: solid 2px var(--pops-slider-main-bg-color);
        background-color: var(--pops-slider-color-white);
        border-radius: 50%;
        box-sizing: border-box;
        transition: var(--pops-slider-transition-duration-fast);
        user-select: none;
      }
    
      .pops-slider__button:hover,
      .pops-slider__button.hover,
      .pops-slider__button.dragging {
        transform: scale(1.2);
      }
    
      .pops-slider__button:hover,
      .pops-slider__button.hover {
        cursor: grab;
      }
    
      .pops-slider__button.dragging {
        cursor: grabbing;
      }
    
      .pops-slider__stop {
        position: absolute;
        height: var(--pops-slider-height);
        width: var(--pops-slider-height);
        border-radius: var(--pops-slider-border-radius-circle);
        background-color: var(--pops-slider-stop-bg-color);
        transform: translate(-50%);
      }
    
      .pops-slider__marks {
        top: 0;
        left: 12px;
        width: 18px;
        height: 100%;
      }
    
      .pops-slider__marks-text {
        position: absolute;
        transform: translate(-50%);
        font-size: 14px;
        color: var(--pops-slider-color-info);
        margin-top: 15px;
        white-space: pre;
      }
    
      .pops-slider.is-vertical {
        position: relative;
        display: inline-flex;
        width: auto;
        height: 100%;
        flex: 0;
      }
    
      .pops-slider.is-vertical .pops-slider__runway {
        width: var(--pops-slider-height);
        height: 100%;
        margin: 0 16px;
      }
    
      .pops-slider.is-vertical .pops-slider__bar {
        width: var(--pops-slider-height);
        height: auto;
        border-radius: 0 0 3px 3px;
      }
    
      .pops-slider.is-vertical .pops-slider__button-wrapper {
        top: auto;
        left: var(--pops-slider-button-wrapper-offset);
        transform: translateY(50%);
      }
    
      .pops-slider.is-vertical .pops-slider__stop {
        transform: translateY(50%);
      }
    
      .pops-slider.is-vertical .pops-slider__marks-text {
        margin-top: 0;
        left: 15px;
        transform: translateY(50%);
      }
    
      .pops-slider--large {
        height: 40px;
      }
    
      .pops-slider--small {
        height: 24px;
      }
      /* slider的CSS */
      
      /* input的CSS */
      .pops-panel-input{display:flex;align-items:center;border:1px solid #dcdfe6;border-radius:4px;background-color:#ffffff}
      .pops-panel-input:hover{box-shadow:0 0 0 1px #c0c4cc inset}
      .pops-panel-input:has(input:focus){outline:0;border:1px solid #409eff;border-radius:4px;box-shadow:none}
      .pops-panel-input input {
        display: inline-flex;
        justify-content: center;
        align-items: center;
        line-height: 1;
        height: 32px;
        white-space: nowrap;
        cursor: text;
        text-align: center;
        box-sizing: border-box;
        outline: 0;
        transition: .1s;
        font-weight: 500;
        user-select: none;
        vertical-align: middle;
        -webkit-appearance: none;
        appearance: none;
        background-color: transparent;
        border: 0;
        padding: 8px 8px;
        font-size: 14px;
        text-align: start;
        width: 100%;
        flex: 1;
      }    
      .pops-panel-input span.pops-panel-input__suffix {
        display: inline-flex;
        white-space: nowrap;
        flex-shrink: 0;
        flex-wrap: nowrap;
        height: 100%;
        text-align: center;
        color: #a8abb2;
        transition: all .3s;
        pointer-events: none;
        margin: 0 8px;
      }    
      .pops-panel-input span.pops-panel-input__suffix-inner{pointer-events:all;display:inline-flex;align-items:center;justify-content:center}
      .pops-panel-input .pops-panel-icon{cursor:pointer}
      .pops-panel-input .pops-panel-icon{height:inherit;line-height:inherit;display:flex;justify-content:center;align-items:center;transition:all .3s}
      .pops-panel-input .pops-panel-icon svg{height:1em;width:1em}
    
      .pops-input-disabled{
        background-color: var(--el-disabled-bg-color);
        box-shadow: 0 0 0 1px var(--el-disabled-border-color) inset;
      }
      .pops-panel-input.pops-input-disabled{
        border: none;
      }
      .pops-panel-input.pops-input-disabled:hover{
        box-shadow: 0 0 0 1px var(--el-disabled-border-color) inset;
      }
      .pops-panel-input input:disabled,
      .pops-panel-input input:disabled + .pops-panel-input__suffix{
        user-select: none;
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        color: var(--el-disabled-text-color);
        -webkit-text-fill-color: var(--el-disabled-text-color);
        cursor: not-allowed;
      }
      .pops-panel-input input:disabled + .pops-panel-input__suffix{
        display: none;
      }
      /* input的CSS */
    
      /* textarea的CSS */
      .pops-panel-textarea textarea {
        width: 100%;
        vertical-align: bottom;
        position: relative;
        display: block;
        resize: none;
        padding: 5px 11px;
        line-height: 1.5;
        box-sizing: border-box;
        font-size: inherit;
        font-family: inherit;
        background-color: rgb(255, 255, 255, var(--pops-bg-opacity));
        background-image: none;
        -webkit-appearance: none;
        appearance: none;
        box-shadow: 0 0 0 1px #dcdfe6 inset;
        border-radius: 0;
        transition: box-shadow .2s cubic-bezier(.645, .045, .355, 1);
        border: none;
      }
      .pops-panel-textarea textarea:hover{box-shadow:0 0 0 1px #c0c4cc inset}
      .pops-panel-textarea-disable .pops-panel-textarea textarea:hover{box-shadow:none}
      .pops-panel-textarea textarea:focus{outline:0;box-shadow:0 0 0 1px #409eff inset}
      /* textarea的CSS */
    
      /* select的CSS */
      .pops-panel-select select {
        height: 32px;
        line-height: 32px;
        min-width: 200px;
        border: 1px solid rgb(184, 184, 184, var(--pops-bd-opacity));
        border-radius: 5px;
        text-align: center;
        outline: 0;
        background: rgb(255, 255, 255, var(--pops-bg-opacity));
        box-shadow: none;
      }    
      .pops-panel-select select:hover{box-shadow:0 0 0 1px #c0c4cc inset}
      .pops-panel-select-disable .pops-panel-select select:hover{box-shadow:none}
      .pops-panel-select select:focus{border:1px solid rgb(64, 158, 255, var(--pops-bd-opacity));box-shadow:none}
      /* select的CSS */
    
      `,
      tooltipCSS: `
      .pops-tip {
        --tooltip-color: #4e4e4e;
        --tooltip-bg-color: rgb(255, 255, 255, var(--pops-bg-opacity));
        --tooltip-bd-radius: 2px;
        --tooltip-font-size: 14px;
        --tooltip-padding-top: 13px;
        --tooltip-padding-right: 13px;
        --tooltip-padding-bottom: 13px;
        --tooltip-padding-left: 13px;
    
    
        --tooltip-arrow--after-color: rgb(78, 78, 78);
        --tooltip-arrow--after-bg-color: rgb(255, 255, 255, var(--pops-bg-opacity));
        --tooltip-arrow--after-width: 12px;
        --tooltip-arrow--after-height: 12px;
        
        position: absolute;
        padding: var(--tooltip-padding-top) var(--tooltip-padding-right) var(--tooltip-padding-bottom) var(--tooltip-padding-left);
        max-width: 400px;
        max-height: 300px;
        border-radius: var(--tooltip-bd-radius);
        background-color: var(--tooltip-bg-color);
        box-shadow: 0 1.5px 4px rgba(0,0,0,.24),0 1.5px 6px rgba(0,0,0,.12);
        color: var(--tooltip-color);
        font-size: var(--tooltip-font-size);
      }
      /* github的样式 */
      .pops-tip.github-tooltip{
        --tooltip-bg-opacity: 1;
        --tooltip-color: rgb(255, 255, 255);
        --tooltip-bg-color: rgb(36, 41, 47, var(--tooltip-bg-opacity));
        --tooltip-bd-radius: 6px;
        --tooltip-padding-top: 6px;
        --tooltip-padding-right: 8px;
        --tooltip-padding-bottom: 6px;
        --tooltip-padding-left: 8px;
    
        --tooltip-arrow--after-color: rgb(255, 255, 255);
        --tooltip-arrow--after-bg-color: rgb(36, 41, 47, var(--tooltip-bg-opacity));
        --tooltip-arrow--after-width: 8px;
        --tooltip-arrow--after-height: 8px;
      }
      .pops-tip .pops-tip-arrow {
        position: absolute;
        top: 100%;
        left: 50%;
        overflow: hidden;
        width: 100%;
        height: 12.5px;
        transform: translateX(-50%);
      }
      
      .pops-tip .pops-tip-arrow::after {
        position: absolute;
        top: 0;
        left: 50%;
        width: var(--tooltip-arrow--after-width);
        height: var(--tooltip-arrow--after-height);
        background: var(--tooltip-arrow--after-bg-color);
        color: var(--tooltip-arrow--after-color);
        box-shadow: 0 1px 7px rgba(0,0,0,.24),0 1px 7px rgba(0,0,0,.12);
        content: "";
        transform: translateX(-50%) translateY(-50%) rotate(45deg);
      }
      
      .pops-tip .pops-tip-arrow[data-position=bottom] {
        position: absolute;
        top: 100%;
        left: 50%;
        overflow: hidden;
        width: 100%;
        height: 12.5px;
        transform: translateX(-50%);
      }
      
      .pops-tip .pops-tip-arrow[data-position=bottom]:after {
        position: absolute;
        top: 0;
        left: 50%;
        width: var(--tooltip-arrow--after-width);
        height: var(--tooltip-arrow--after-height);
        background: var(--tooltip-arrow--after-bg-color);
        box-shadow: 0 1px 7px rgba(0,0,0,.24),0 1px 7px rgba(0,0,0,.12);
        content: "";
        transform: translateX(-50%) translateY(-50%) rotate(45deg);
      }
      
      .pops-tip .pops-tip-arrow[data-position=left] {
        top: 50%;
        left: -12.5px;
        width: 12.5px;
        height: 50px;
        transform: translateY(-50%);
      }
      
      .pops-tip .pops-tip-arrow[data-position=left]:after {
        position: absolute;
        top: 50%;
        left: 100%;
        content: "";
      }
      
      .pops-tip .pops-tip-arrow[data-position=right] {
        top: 50%;
        right: -12.5px;
        left: auto;
        width: 12.5px;
        height: 50px;
        transform: translateY(-50%);
      }
      
      .pops-tip .pops-tip-arrow[data-position=right]:after {
        position: absolute;
        top: 50%;
        left: 0;
        content: "";
      }
      
      .pops-tip .pops-tip-arrow[data-position=top] {
        top: -12.5px;
        left: 50%;
        transform: translateX(-50%);
      }
      
      .pops-tip .pops-tip-arrow[data-position=top]:after {
        position: absolute;
        top: 100%;
        left: 50%;
        content: "";
      }
    
      .pops-tip[data-motion]{-webkit-animation-duration:.25s;animation-duration:.25s;-webkit-animation-fill-mode:forwards;animation-fill-mode:forwards;}
      .pops-tip[data-motion=fadeOutRight]{-webkit-animation-name:pops-motion-fadeOutRight;animation-name:pops-motion-fadeOutRight;}
      .pops-tip[data-motion=fadeInTop]{-webkit-animation-name:pops-motion-fadeInTop;animation-name:pops-motion-fadeInTop;animation-timing-function:cubic-bezier(.49,.49,.13,1.3);}
      .pops-tip[data-motion=fadeOutTop]{-webkit-animation-name:pops-motion-fadeOutTop;animation-name:pops-motion-fadeOutTop;animation-timing-function:cubic-bezier(.32,.37,.06,.87);}
      .pops-tip[data-motion=fadeInBottom]{-webkit-animation-name:pops-motion-fadeInBottom;animation-name:pops-motion-fadeInBottom;}
      .pops-tip[data-motion=fadeOutBottom]{-webkit-animation-name:pops-motion-fadeOutBottom;animation-name:pops-motion-fadeOutBottom;}
      .pops-tip[data-motion=fadeInLeft]{-webkit-animation-name:pops-motion-fadeInLeft;animation-name:pops-motion-fadeInLeft;}
      .pops-tip[data-motion=fadeOutLeft]{-webkit-animation-name:pops-motion-fadeOutLeft;animation-name:pops-motion-fadeOutLeft;}
      .pops-tip[data-motion=fadeInRight]{-webkit-animation-name:pops-motion-fadeInRight;animation-name:pops-motion-fadeInRight;}
      
      `,
    },
    /** icon图标的svg代码 */
    iconSVG: {
      min: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path fill="currentColor" d="M128 544h768a32 32 0 1 0 0-64H128a32 32 0 0 0 0 64z"></path>
      </svg>`,
      mise: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="M885.333333 85.333333H330.410667a53.333333 53.333333 0 0 0-53.333334 53.333334v106.666666H138.666667A53.333333 53.333333 0 0 0 85.333333 298.666667v586.666666a53.333333 53.333333 0 0 0 53.333334 53.333334H725.333333a53.333333 53.333333 0 0 0 53.333334-53.333334V746.154667h106.666666c29.44 0 53.333333-23.893333 53.333334-53.333334V138.666667A53.333333 53.333333 0 0 0 885.333333 85.333333zM725.333333 692.821333v192.512H138.666667V298.666667H725.333333v394.154666z m157.866667 0H778.666667V298.666667a53.333333 53.333333 0 0 0-53.333334-53.333334H330.410667v-106.666666h554.922666l-2.133333 554.154666z"></path>
      </svg>

      `,
      max: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="m160 96.064 192 .192a32 32 0 0 1 0 64l-192-.192V352a32 32 0 0 1-64 0V96h64v.064zm0 831.872V928H96V672a32 32 0 1 1 64 0v191.936l192-.192a32 32 0 1 1 0 64l-192 .192zM864 96.064V96h64v256a32 32 0 1 1-64 0V160.064l-192 .192a32 32 0 1 1 0-64l192-.192zm0 831.872-192-.192a32 32 0 0 1 0-64l192 .192V672a32 32 0 1 1 64 0v256h-64v-.064z"></path>
      </svg>
      `,
      close: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="M764.288 214.592 512 466.88 259.712 214.592a31.936 31.936 0 0 0-45.12 45.12L466.752 512 214.528 764.224a31.936 31.936 0 1 0 45.12 45.184L512 557.184l252.288 252.288a31.936 31.936 0 0 0 45.12-45.12L557.12 512.064l252.288-252.352a31.936 31.936 0 1 0-45.12-45.184z"></path>
      </svg>
      `,
      edit: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="M832 512a32 32 0 1 1 64 0v352a32 32 0 0 1-32 32H160a32 32 0 0 1-32-32V160a32 32 0 0 1 32-32h352a32 32 0 0 1 0 64H192v640h640V512z"></path>
        <path
          fill="currentColor"
          d="m469.952 554.24 52.8-7.552L847.104 222.4a32 32 0 1 0-45.248-45.248L477.44 501.44l-7.552 52.8zm422.4-422.4a96 96 0 0 1 0 135.808l-331.84 331.84a32 32 0 0 1-18.112 9.088L436.8 623.68a32 32 0 0 1-36.224-36.224l15.104-105.6a32 32 0 0 1 9.024-18.112l331.904-331.84a96 96 0 0 1 135.744 0z"></path>
      </svg>
      `,
      share: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="m679.872 348.8-301.76 188.608a127.808 127.808 0 0 1 5.12 52.16l279.936 104.96a128 128 0 1 1-22.464 59.904l-279.872-104.96a128 128 0 1 1-16.64-166.272l301.696-188.608a128 128 0 1 1 33.92 54.272z"></path>
      </svg>
      `,
      delete: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="M160 256H96a32 32 0 0 1 0-64h256V95.936a32 32 0 0 1 32-32h256a32 32 0 0 1 32 32V192h256a32 32 0 1 1 0 64h-64v672a32 32 0 0 1-32 32H192a32 32 0 0 1-32-32V256zm448-64v-64H416v64h192zM224 896h576V256H224v640zm192-128a32 32 0 0 1-32-32V416a32 32 0 0 1 64 0v320a32 32 0 0 1-32 32zm192 0a32 32 0 0 1-32-32V416a32 32 0 0 1 64 0v320a32 32 0 0 1-32 32z"></path>
      </svg>
      `,
      search: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="m795.904 750.72 124.992 124.928a32 32 0 0 1-45.248 45.248L750.656 795.904a416 416 0 1 1 45.248-45.248zM480 832a352 352 0 1 0 0-704 352 352 0 0 0 0 704z"></path>
      </svg>

      `,
      upload: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="M160 832h704a32 32 0 1 1 0 64H160a32 32 0 1 1 0-64zm384-578.304V704h-64V247.296L237.248 490.048 192 444.8 508.8 128l316.8 316.8-45.312 45.248L544 253.696z"></path>
      </svg>
      `,
      loading: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="M512 64a32 32 0 0 1 32 32v192a32 32 0 0 1-64 0V96a32 32 0 0 1 32-32zm0 640a32 32 0 0 1 32 32v192a32 32 0 1 1-64 0V736a32 32 0 0 1 32-32zm448-192a32 32 0 0 1-32 32H736a32 32 0 1 1 0-64h192a32 32 0 0 1 32 32zm-640 0a32 32 0 0 1-32 32H96a32 32 0 0 1 0-64h192a32 32 0 0 1 32 32zM195.2 195.2a32 32 0 0 1 45.248 0L376.32 331.008a32 32 0 0 1-45.248 45.248L195.2 240.448a32 32 0 0 1 0-45.248zm452.544 452.544a32 32 0 0 1 45.248 0L828.8 783.552a32 32 0 0 1-45.248 45.248L647.744 692.992a32 32 0 0 1 0-45.248zM828.8 195.264a32 32 0 0 1 0 45.184L692.992 376.32a32 32 0 0 1-45.248-45.248l135.808-135.808a32 32 0 0 1 45.248 0zm-452.544 452.48a32 32 0 0 1 0 45.248L240.448 828.8a32 32 0 0 1-45.248-45.248l135.808-135.808a32 32 0 0 1 45.248 0z"></path>
      </svg>
      `,
      next: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="M340.864 149.312a30.592 30.592 0 0 0 0 42.752L652.736 512 340.864 831.872a30.592 30.592 0 0 0 0 42.752 29.12 29.12 0 0 0 41.728 0L714.24 534.336a32 32 0 0 0 0-44.672L382.592 149.376a29.12 29.12 0 0 0-41.728 0z"></path>
      </svg>
      `,
      prev: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="M609.408 149.376 277.76 489.6a32 32 0 0 0 0 44.672l331.648 340.352a29.12 29.12 0 0 0 41.728 0 30.592 30.592 0 0 0 0-42.752L339.264 511.936l311.872-319.872a30.592 30.592 0 0 0 0-42.688 29.12 29.12 0 0 0-41.728 0z"></path>
      </svg>
      `,
      eleme: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="M300.032 188.8c174.72-113.28 408-63.36 522.24 109.44 5.76 10.56 11.52 20.16 17.28 30.72v.96a22.4 22.4 0 0 1-7.68 26.88l-352.32 228.48c-9.6 6.72-22.08 3.84-28.8-5.76l-18.24-27.84a54.336 54.336 0 0 1 16.32-74.88l225.6-146.88c9.6-6.72 12.48-19.2 5.76-28.8-.96-1.92-1.92-3.84-3.84-4.8a267.84 267.84 0 0 0-315.84-17.28c-123.84 81.6-159.36 247.68-78.72 371.52a268.096 268.096 0 0 0 370.56 78.72 54.336 54.336 0 0 1 74.88 16.32l17.28 26.88c5.76 9.6 3.84 21.12-4.8 27.84-8.64 7.68-18.24 14.4-28.8 21.12a377.92 377.92 0 0 1-522.24-110.4c-113.28-174.72-63.36-408 111.36-522.24zm526.08 305.28a22.336 22.336 0 0 1 28.8 5.76l23.04 35.52a63.232 63.232 0 0 1-18.24 87.36l-35.52 23.04c-9.6 6.72-22.08 3.84-28.8-5.76l-46.08-71.04c-6.72-9.6-3.84-22.08 5.76-28.8l71.04-46.08z"></path>
      </svg>
      `,
      elemePlus: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          d="M839.7 734.7c0 33.3-17.9 41-17.9 41S519.7 949.8 499.2 960c-10.2 5.1-20.5 5.1-30.7 0 0 0-314.9-184.3-325.1-192-5.1-5.1-10.2-12.8-12.8-20.5V368.6c0-17.9 20.5-28.2 20.5-28.2L466 158.6c12.8-5.1 25.6-5.1 38.4 0 0 0 279 161.3 309.8 179.2 17.9 7.7 28.2 25.6 25.6 46.1-.1-5-.1 317.5-.1 350.8zM714.2 371.2c-64-35.8-217.6-125.4-217.6-125.4-7.7-5.1-20.5-5.1-30.7 0L217.6 389.1s-17.9 10.2-17.9 23v297c0 5.1 5.1 12.8 7.7 17.9 7.7 5.1 256 148.5 256 148.5 7.7 5.1 17.9 5.1 25.6 0 15.4-7.7 250.9-145.9 250.9-145.9s12.8-5.1 12.8-30.7v-74.2l-276.5 169v-64c0-17.9 7.7-30.7 20.5-46.1L745 535c5.1-7.7 10.2-20.5 10.2-30.7v-66.6l-279 169v-69.1c0-15.4 5.1-30.7 17.9-38.4l220.1-128zM919 135.7c0-5.1-5.1-7.7-7.7-7.7h-58.9V66.6c0-5.1-5.1-5.1-10.2-5.1l-30.7 5.1c-5.1 0-5.1 2.6-5.1 5.1V128h-56.3c-5.1 0-5.1 5.1-7.7 5.1v38.4h69.1v64c0 5.1 5.1 5.1 10.2 5.1l30.7-5.1c5.1 0 5.1-2.6 5.1-5.1v-56.3h64l-2.5-38.4z"
          fill="currentColor"></path>
      </svg>
      `,
      chromeFilled: `
      <svg
        xmlns="http://www.w3.org/2000/svg"
        viewBox="0 0 1024 1024"
        xml:space="preserve">
        <path
          d="M938.67 512.01c0-44.59-6.82-87.6-19.54-128H682.67a212.372 212.372 0 0 1 42.67 128c.06 38.71-10.45 76.7-30.42 109.87l-182.91 316.8c235.65-.01 426.66-191.02 426.66-426.67z"
          fill="currentColor"></path>
        <path
          d="M576.79 401.63a127.92 127.92 0 0 0-63.56-17.6c-22.36-.22-44.39 5.43-63.89 16.38s-35.79 26.82-47.25 46.02a128.005 128.005 0 0 0-2.16 127.44l1.24 2.13a127.906 127.906 0 0 0 46.36 46.61 127.907 127.907 0 0 0 63.38 17.44c22.29.2 44.24-5.43 63.68-16.33a127.94 127.94 0 0 0 47.16-45.79v-.01l1.11-1.92a127.984 127.984 0 0 0 .29-127.46 127.957 127.957 0 0 0-46.36-46.91z"
          fill="currentColor"></path>
        <path
          d="M394.45 333.96A213.336 213.336 0 0 1 512 298.67h369.58A426.503 426.503 0 0 0 512 85.34a425.598 425.598 0 0 0-171.74 35.98 425.644 425.644 0 0 0-142.62 102.22l118.14 204.63a213.397 213.397 0 0 1 78.67-94.21zM512.01 938.68H512zM414.76 701.95a213.284 213.284 0 0 1-89.54-86.81L142.48 298.6c-36.35 62.81-57.13 135.68-57.13 213.42 0 203.81 142.93 374.22 333.95 416.55h.04l118.19-204.71a213.315 213.315 0 0 1-122.77-21.91z"
          fill="currentColor"></path>
      </svg>
      `,
      cpu: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="M320 256a64 64 0 0 0-64 64v384a64 64 0 0 0 64 64h384a64 64 0 0 0 64-64V320a64 64 0 0 0-64-64H320zm0-64h384a128 128 0 0 1 128 128v384a128 128 0 0 1-128 128H320a128 128 0 0 1-128-128V320a128 128 0 0 1 128-128z"></path>
        <path
          fill="currentColor"
          d="M512 64a32 32 0 0 1 32 32v128h-64V96a32 32 0 0 1 32-32zm160 0a32 32 0 0 1 32 32v128h-64V96a32 32 0 0 1 32-32zm-320 0a32 32 0 0 1 32 32v128h-64V96a32 32 0 0 1 32-32zm160 896a32 32 0 0 1-32-32V800h64v128a32 32 0 0 1-32 32zm160 0a32 32 0 0 1-32-32V800h64v128a32 32 0 0 1-32 32zm-320 0a32 32 0 0 1-32-32V800h64v128a32 32 0 0 1-32 32zM64 512a32 32 0 0 1 32-32h128v64H96a32 32 0 0 1-32-32zm0-160a32 32 0 0 1 32-32h128v64H96a32 32 0 0 1-32-32zm0 320a32 32 0 0 1 32-32h128v64H96a32 32 0 0 1-32-32zm896-160a32 32 0 0 1-32 32H800v-64h128a32 32 0 0 1 32 32zm0-160a32 32 0 0 1-32 32H800v-64h128a32 32 0 0 1 32 32zm0 320a32 32 0 0 1-32 32H800v-64h128a32 32 0 0 1 32 32z"></path>
      </svg>
      `,
      videoPlay: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="M512 64a448 448 0 1 1 0 896 448 448 0 0 1 0-896zm0 832a384 384 0 0 0 0-768 384 384 0 0 0 0 768zm-48-247.616L668.608 512 464 375.616v272.768zm10.624-342.656 249.472 166.336a48 48 0 0 1 0 79.872L474.624 718.272A48 48 0 0 1 400 678.336V345.6a48 48 0 0 1 74.624-39.936z"></path>
      </svg>
      `,
      videoPause: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="M512 64a448 448 0 1 1 0 896 448 448 0 0 1 0-896zm0 832a384 384 0 0 0 0-768 384 384 0 0 0 0 768zm-96-544q32 0 32 32v256q0 32-32 32t-32-32V384q0-32 32-32zm192 0q32 0 32 32v256q0 32-32 32t-32-32V384q0-32 32-32z"></path>
      </svg>
      `,
      headset: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="M896 529.152V512a384 384 0 1 0-768 0v17.152A128 128 0 0 1 320 640v128a128 128 0 1 1-256 0V512a448 448 0 1 1 896 0v256a128 128 0 1 1-256 0V640a128 128 0 0 1 192-110.848zM896 640a64 64 0 0 0-128 0v128a64 64 0 0 0 128 0V640zm-768 0v128a64 64 0 0 0 128 0V640a64 64 0 1 0-128 0z"></path>
      </svg>
      `,
      monitor: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="M544 768v128h192a32 32 0 1 1 0 64H288a32 32 0 1 1 0-64h192V768H192A128 128 0 0 1 64 640V256a128 128 0 0 1 128-128h640a128 128 0 0 1 128 128v384a128 128 0 0 1-128 128H544zM192 192a64 64 0 0 0-64 64v384a64 64 0 0 0 64 64h640a64 64 0 0 0 64-64V256a64 64 0 0 0-64-64H192z"></path>
      </svg>
      `,
      documentCopy: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="M128 320v576h576V320H128zm-32-64h640a32 32 0 0 1 32 32v640a32 32 0 0 1-32 32H96a32 32 0 0 1-32-32V288a32 32 0 0 1 32-32zM960 96v704a32 32 0 0 1-32 32h-96v-64h64V128H384v64h-64V96a32 32 0 0 1 32-32h576a32 32 0 0 1 32 32zM256 672h320v64H256v-64zm0-192h320v64H256v-64z"></path>
      </svg>
      `,
      picture: `
      <svg viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          fill="currentColor"
          d="M160 160v704h704V160H160zm-32-64h768a32 32 0 0 1 32 32v768a32 32 0 0 1-32 32H128a32 32 0 0 1-32-32V128a32 32 0 0 1 32-32z"></path>
        <path
          fill="currentColor"
          d="M384 288q64 0 64 64t-64 64q-64 0-64-64t64-64zM185.408 876.992l-50.816-38.912L350.72 556.032a96 96 0 0 1 134.592-17.856l1.856 1.472 122.88 99.136a32 32 0 0 0 44.992-4.864l216-269.888 49.92 39.936-215.808 269.824-.256.32a96 96 0 0 1-135.04 14.464l-122.88-99.072-.64-.512a32 32 0 0 0-44.8 5.952L185.408 876.992z"></path>
      </svg>
      `,
      circleClose: `
      <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1024 1024">
        <path
          fill="currentColor"
          d="m466.752 512-90.496-90.496a32 32 0 0 1 45.248-45.248L512 466.752l90.496-90.496a32 32 0 1 1 45.248 45.248L557.248 512l90.496 90.496a32 32 0 1 1-45.248 45.248L512 557.248l-90.496 90.496a32 32 0 0 1-45.248-45.248z"></path>
        <path
          fill="currentColor"
          d="M512 896a384 384 0 1 0 0-768 384 384 0 0 0 0 768m0 64a448 448 0 1 1 0-896 448 448 0 0 1 0 896"></path>
      </svg>
      `,
      view: `
      <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1024 1024">
        <path                        
          fill="currentColor"
          d="M512 160c320 0 512 352 512 352S832 864 512 864 0 512 0 512s192-352 512-352m0 64c-225.28 0-384.128 208.064-436.8 288 52.608 79.872 211.456 288 436.8 288 225.28 0 384.128-208.064 436.8-288-52.608-79.872-211.456-288-436.8-288zm0 64a224 224 0 1 1 0 448 224 224 0 0 1 0-448m0 64a160.192 160.192 0 0 0-160 160c0 88.192 71.744 160 160 160s160-71.808 160-160-71.744-160-160-160"></path>
      </svg>
      `,
      hide: `
      <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1024 1024">
        <path
          fill="currentColor"
          d="M876.8 156.8c0-9.6-3.2-16-9.6-22.4-6.4-6.4-12.8-9.6-22.4-9.6-9.6 0-16 3.2-22.4 9.6L736 220.8c-64-32-137.6-51.2-224-60.8-160 16-288 73.6-377.6 176C44.8 438.4 0 496 0 512s48 73.6 134.4 176c22.4 25.6 44.8 48 73.6 67.2l-86.4 89.6c-6.4 6.4-9.6 12.8-9.6 22.4 0 9.6 3.2 16 9.6 22.4 6.4 6.4 12.8 9.6 22.4 9.6 9.6 0 16-3.2 22.4-9.6l704-710.4c3.2-6.4 6.4-12.8 6.4-22.4Zm-646.4 528c-76.8-70.4-128-128-153.6-172.8 28.8-48 80-105.6 153.6-172.8C304 272 400 230.4 512 224c64 3.2 124.8 19.2 176 44.8l-54.4 54.4C598.4 300.8 560 288 512 288c-64 0-115.2 22.4-160 64s-64 96-64 160c0 48 12.8 89.6 35.2 124.8L256 707.2c-9.6-6.4-19.2-16-25.6-22.4Zm140.8-96c-12.8-22.4-19.2-48-19.2-76.8 0-44.8 16-83.2 48-112 32-28.8 67.2-48 112-48 28.8 0 54.4 6.4 73.6 19.2zM889.599 336c-12.8-16-28.8-28.8-41.6-41.6l-48 48c73.6 67.2 124.8 124.8 150.4 169.6-28.8 48-80 105.6-153.6 172.8-73.6 67.2-172.8 108.8-284.8 115.2-51.2-3.2-99.2-12.8-140.8-28.8l-48 48c57.6 22.4 118.4 38.4 188.8 44.8 160-16 288-73.6 377.6-176C979.199 585.6 1024 528 1024 512s-48.001-73.6-134.401-176Z"></path>
        <path
          fill="currentColor"
          d="M511.998 672c-12.8 0-25.6-3.2-38.4-6.4l-51.2 51.2c28.8 12.8 57.6 19.2 89.6 19.2 64 0 115.2-22.4 160-64 41.6-41.6 64-96 64-160 0-32-6.4-64-19.2-89.6l-51.2 51.2c3.2 12.8 6.4 25.6 6.4 38.4 0 44.8-16 83.2-48 112-32 28.8-67.2 48-112 48Z"></path>
      </svg>
      `,
      keyboard: `
      <svg viewBox="0 0 1123 1024" xmlns="http://www.w3.org/2000/svg">
        <path
          d="M1014.122186 1024H109.753483A109.753483 109.753483 0 0 1 0 914.246517V392.917471a109.753483 109.753483 0 0 1 109.753483-109.753484h904.368703a109.753483 109.753483 0 0 1 109.753484 109.753484v521.329046a109.753483 109.753483 0 0 1-109.753484 109.753483zM109.753483 370.966774a21.950697 21.950697 0 0 0-21.950696 21.950697v521.329046a21.950697 21.950697 0 0 0 21.950696 21.950696h904.368703a21.950697 21.950697 0 0 0 21.950697-21.950696V392.917471a21.950697 21.950697 0 0 0-21.950697-21.950697z"></path>
        <path
          d="M687.056806 891.198285H307.309753a43.901393 43.901393 0 0 1 0-87.802787h379.747053a43.901393 43.901393 0 0 1 0 87.802787zM175.605573 803.395498a43.901393 43.901393 0 1 0 43.901394 43.901394 43.901393 43.901393 0 0 0-43.901394-43.901394zM432.428725 414.868167a43.901393 43.901393 0 1 0 43.901393 43.901394 43.901393 43.901393 0 0 0-43.901393-43.901394zM561.937835 414.868167a43.901393 43.901393 0 1 0 43.901393 43.901394 43.901393 43.901393 0 0 0-43.901393-43.901394zM690.349411 414.868167a43.901393 43.901393 0 1 0 43.901393 43.901394 43.901393 43.901393 0 0 0-43.901393-43.901394zM818.760986 414.868167a43.901393 43.901393 0 1 0 43.901393 43.901394 43.901393 43.901393 0 0 0-43.901393-43.901394zM947.172562 414.868167a43.901393 43.901393 0 1 0 43.901393 43.901394 43.901393 43.901393 0 0 0-43.901393-43.901394zM175.605573 546.572347a43.901393 43.901393 0 1 0 43.901394 43.901394 43.901393 43.901393 0 0 0-43.901394-43.901394zM304.017149 546.572347a43.901393 43.901393 0 1 0 43.901393 43.901394 43.901393 43.901393 0 0 0-43.901393-43.901394zM432.428725 546.572347a43.901393 43.901393 0 1 0 43.901393 43.901394 43.901393 43.901393 0 0 0-43.901393-43.901394zM561.937835 546.572347a43.901393 43.901393 0 1 0 43.901393 43.901394 43.901393 43.901393 0 0 0-43.901393-43.901394zM690.349411 546.572347a43.901393 43.901393 0 1 0 43.901393 43.901394 43.901393 43.901393 0 0 0-43.901393-43.901394zM818.760986 546.572347a43.901393 43.901393 0 1 0 43.901393 43.901394 43.901393 43.901393 0 0 0-43.901393-43.901394zM818.760986 803.395498a43.901393 43.901393 0 1 0 43.901393 43.901394 43.901393 43.901393 0 0 0-43.901393-43.901394zM175.605573 678.276527a43.901393 43.901393 0 1 0 43.901394 43.901394 43.901393 43.901393 0 0 0-43.901394-43.901394zM304.017149 678.276527a43.901393 43.901393 0 1 0 43.901393 43.901394 43.901393 43.901393 0 0 0-43.901393-43.901394zM432.428725 678.276527a43.901393 43.901393 0 1 0 43.901393 43.901394 43.901393 43.901393 0 0 0-43.901393-43.901394zM561.937835 678.276527a43.901393 43.901393 0 1 0 43.901393 43.901394 43.901393 43.901393 0 0 0-43.901393-43.901394zM948.270096 803.395498a43.901393 43.901393 0 1 0 43.901394 43.901394 43.901393 43.901393 0 0 0-43.901394-43.901394z"></path>
        <path
          d="M881.320472 766.079314H689.251876a43.901393 43.901393 0 0 1 0-87.802787h192.068596a21.950697 21.950697 0 0 0 21.950696-21.950696v-65.85209a43.901393 43.901393 0 0 1 87.802787 0v65.85209a109.753483 109.753483 0 0 1-109.753483 109.753483zM305.114684 502.670954H175.605573a43.901393 43.901393 0 0 1 0-87.802787h129.509111a43.901393 43.901393 0 0 1 0 87.802787zM563.03537 365.4791a43.901393 43.901393 0 0 1-43.901394-43.901394v-105.363344A109.753483 109.753483 0 0 1 628.88746 106.460879h61.461951a21.950697 21.950697 0 0 0 21.950696-21.950697V43.901393a43.901393 43.901393 0 0 1 87.802787 0v40.608789a109.753483 109.753483 0 0 1-109.753483 109.753484h-61.461951a21.950697 21.950697 0 0 0-21.950697 21.950696v105.363344a43.901393 43.901393 0 0 1-43.901393 43.901394z"></path>
      </svg>
      `,
    },
    /**
     * 动画名
     * @type {string[]}
     */
    animation: [],
    /**
     * 是否已初始化
     */
    isInit: false,
    /**
     * 存储已创建的元素
     */
    layer: {
      /**
       * 存储已创建的pops.alert
       * @type { PopsLayerCommonConfig[] }
       */
      alert: [],
      /**
       * 存储已创建的pops.confirm
       * @type { PopsLayerCommonConfig[] }
       */
      confirm: [],
      /**
       * 存储已创建的pops.prompt
       * @type { PopsLayerCommonConfig[] }
       */
      prompt: [],
      /**
       * 存储已创建的pops.loading
       * @type { PopsLayerCommonConfig[] }
       */
      loading: [],
      /**
       * 存储已创建的pops.iframe
       * @type { PopsLayerConfig[] }
       */
      iframe: [],
      /**
       * 存储已创建的pops.tooltip
       * @type { PopsLayerCommonConfig[] }
       */
      tooltip: [],
      /**
       * 存储已创建的pops.drawer
       * @type { PopsLayerCommonConfig[] }
       */
      drawer: [],
      /**
       * 存储已创建的pops.folder
       * @type { PopsLayerCommonConfig[] }
       */
      folder: [],
      /**
       * 存储已创建的pops.panel
       * @type { PopsLayerCommonConfig[] }
       */
      panel: [],
    },
    forbiddenScroll: {
      event(event) {
        event.preventDefault();
        return false;
      },
    },
    Utils: PopsUtils,
    DOMUtils: PopsDOMUtils,
  };

  /**
   * 释放原有的pops控制权
   * @example
   * let pops = window.pops.noConflict()
   */
  pops.noConflict = function () {
    if (window.pops) {
      delete window.pops;
    }
    if (AnotherPops) {
      window.pops = AnotherPops;
    }
    return pops;
  };

  /**
   * 初始化CSS、动画
   */
  pops.init = function () {
    if (!this.config.isInit) {
      /* 处理获取当前所有的动画名 */
      this.config.isInit = true;
      let animationStyle = document.createElement("style");
      animationStyle.innerHTML = this.config.cssText.anim;
      (document.head || document.body || document.documentElement).appendChild(
        animationStyle
      );
      this.config.animation = PopsUtils.getKeyFrames(animationStyle.sheet);
      setTimeout(() => {
        animationStyle.remove();
      }, 50);
    }
  };

  /**
   * 通过navigator.userAgent判断是否是手机访问
   * @param {string} userAgent
   * @returns {boolean}
   */
  pops.isPhone = function (userAgent = navigator.userAgent) {
    return Boolean(/(iPhone|iPad|iPod|iOS|Android)/i.test(userAgent));
  };

  const PopsHandler = {
    /**
     * 创建shadow
     */
    handlerShadow() {
      let $shadowContainer = document.createElement("div");
      $shadowContainer.className = "pops-shadow-container";
      let $shadowRoot = $shadowContainer.attachShadow({ mode: "open" });
      return {
        $shadowContainer,
        $shadowRoot,
      };
    },
    /**
     * 处理初始化
     * @param {ShadowRoot} $shadowRoot
     * @param {string[]|string} cssText
     */
    handleInit($shadowRoot, cssText) {
      pops.init();
      if (!arguments.length) {
        return;
      }
      if (Array.isArray(cssText)) {
        cssText.forEach((text) => {
          this.handleInit($shadowRoot, text);
        });
      } else {
        let cssStyle = document.createElement("style");
        cssStyle.setAttribute("type", "text/css");
        cssStyle.innerHTML = cssText;
        $shadowRoot.appendChild(cssStyle);
      }
    },
    /**
     * 处理遮罩层
     * @param {?{
     * type: "alert"|"confirm"|"prompt"|"loading"|"iframe"|"drawer"|"folder"|"panel",
     * guid: string,
     * config: PopsAlertDetails,
     * animElement: HTMLElement,
     * maskHTML: string,
     * }} details
     * @returns { {
     * maskElement: HTMLDivElement
     * } }
     */
    handleMask(details = {}) {
      let result = {
        maskElement: PopsUtils.parseTextToDOM(details.maskHTML),
      };
      let isMaskClick = false;
      /**
       * 点击其它区域的事件
       * @param {Event} event
       * @returns
       */
      function clickEvent(event) {
        event?.preventDefault();
        event?.stopPropagation();
        event?.stopImmediatePropagation();
        let targetLayer = pops.config.layer[details.type];
        function originalRun() {
          if (details.config.mask.clickEvent.toClose) {
            /* 关闭 */
            PopsUtils.close(
              details.type,
              targetLayer,
              details.guid,
              details.config,
              details.animElement
            );
          } else if (details.config.mask.clickEvent.toHide) {
            /* 隐藏 */
            PopsUtils.hide(
              details.type,
              targetLayer,
              details.guid,
              details.config,
              details.animElement,
              result.maskElement
            );
          }
        }
        if (details.config.mask.clickCallBack) {
          details.config.mask.clickCallBack(originalRun);
        } else {
          originalRun();
        }
        return false;
      }
      function isAnimElement(element) {
        return Boolean(
          element?.localName?.toLowerCase() === "div" &&
            element.className &&
            element.className === "pops-anim" &&
            element.hasAttribute("anim")
        );
      }
      if (
        details.config.mask.clickEvent.toClose ||
        details.config.mask.clickEvent.toHide
      ) {
        /* 判断按下的元素是否是pops-anim */
        PopsDOMUtils.on(
          details.animElement,
          ["touchstart", "mousedown"],
          void 0,
          function (event) {
            isMaskClick = isAnimElement(event.composedPath()[0]);
          }
        );
        /* 如果有动画层,在动画层上监听点击事件 */
        PopsDOMUtils.on(details.animElement, "click", void 0, function (event) {
          if (isAnimElement(event.composedPath()[0]) && isMaskClick) {
            return clickEvent(event);
          }
        });
        /* 在遮罩层监听点击事件 */
        /* 如果有动画层,那么该点击事件触发不了 */
        PopsDOMUtils.on(result.maskElement, "click", void 0, (event) => {
          isMaskClick = true;
          clickEvent(event);
        });
      }
      return result;
    },
    /**
     * 处理获取元素
     * @param {HTMLDivElement} animElement
     * @param {"alert"|"confirm"|"prompt"|"loading"|"iframe"|"drawer"|"folder"|"panel"} type
     */
    handleQueryElement(animElement, type) {
      return {
        /**
         * 主元素
         * @type {?HTMLElement}
         */
        popsElement: animElement.querySelector(".pops[type-value"),
        /**
         * 确认按钮
         * @type {?HTMLElement}
         */
        btnOkElement: animElement.querySelector(`.pops-${type}-btn-ok`),
        /**
         * 取消按钮
         * @type {?HTMLElement}
         */
        btnCancelElement: animElement.querySelector(`.pops-${type}-btn-cancel`),
        /**
         * 其它按钮
         * @type {?HTMLElement}
         */
        btnOtherElement: animElement.querySelector(`.pops-${type}-btn-other`),
        /**
         * 标题元素
         * @type {?HTMLElement}
         */
        titleElement: animElement.querySelector(`.pops-${type}-title`),
        /**
         * 输入框元素
         * @type {?HTMLTextAreaElement|HTMLInputElement}
         */
        inputElement: animElement.querySelector(
          `.pops-${type}-content textarea[pops]`
        )
          ? animElement.querySelector(`.pops-${type}-content textarea[pops]`)
          : animElement.querySelector(`.pops-${type}-content input[pops]`),
        /**
         * 顶部按钮控制层元素
         * @type {?HTMLElement}
         */
        headerControlsElement: animElement.querySelector(
          ".pops-header-controls"
        ),
        /**
         * iframe元素
         * @type {?HTMLIFrameElement}
         */
        iframeElement: animElement.querySelector("iframe[pops]"),
        /**
         * 加载中元素
         * @type {?HTMLElement}
         */
        loadingElement: animElement.querySelector(".pops-loading"),
        /**
         * 内容元素
         * @type {?HTMLElement}
         */
        contentElement: animElement.querySelector(`.pops-${type}-content`),
        /**
         * 内容侧边栏容器元素
         * @type {?HTMLElement}
         */
        contentAsideElement: animElement.querySelector(
          `.pops-${type}-content aside.pops-${type}-aside`
        ),
        /**
         * 内容主要区域容器元素
         * @type {?HTMLElement}
         */
        contentSectionContainerElement: animElement.querySelector(
          `.pops-${type}-content section.pops-${type}-container`
        ),
        /**
         * 内容加载中元素
         * @type {?HTMLElement}
         */
        contentLoadingElement: animElement.querySelector(
          `.pops-${type}-content-global-loading`
        ),
        /**
         * 顶部缩小按钮
         * @type {?HTMLElement}
         */
        headerMinBtnElement: animElement.querySelector(
          ".pops-header-control[type='min']"
        ),
        /**
         * 顶部放大按钮
         * @type {?HTMLElement}
         */
        headerMaxBtnElement: animElement.querySelector(
          ".pops-header-control[type='max']"
        ),
        /**
         * 顶部恢复原样按钮
         * @type {?HTMLElement}
         */
        headerMiseBtnElement: animElement.querySelector(
          ".pops-header-control[type='mise']"
        ),
        /**
         * 顶部关闭按钮
         * @type {?HTMLElement}
         */
        headerCloseBtnElement: animElement.querySelector(
          ".pops-header-control[type='close']"
        ),
        /**
         * 文件夹列表元素
         * @type {?HTMLElement}
         */
        folderListElement: animElement.querySelector(".pops-folder-list"),
        /**
         * 文件夹列表顶部元素
         * @type {?HTMLElement}
         */
        folderListHeaderElement: animElement.querySelector(
          ".pops-folder-list .pops-folder-list-table__header-div"
        ),
        /**
         * 文件夹列表行元素
         * @type {?HTMLTableRowElement}
         */
        folderListHeaderRowElement: animElement.querySelector(
          ".pops-folder-list .pops-folder-list-table__header-div .pops-folder-list-table__header-row"
        ),
        /**
         * 文件夹列表tbody元素
         * @type {?HTMLTableElement}
         */
        folderListBodyElement: animElement.querySelector(
          ".pops-folder-list .pops-folder-list-table__body-div tbody"
        ),
        /**
         * 文件夹列表primary元素
         * @type {?HTMLElement}
         */
        folderFileListBreadcrumbPrimaryElement: animElement.querySelector(
          ".pops-folder-list .pops-folder-file-list-breadcrumb-primary"
        ),
        /**
         * 文件夹排序按钮-文件名
         */
        folderListSortFileNameElement: animElement.querySelector(
          '.pops-folder-list-table__sort[data-sort="fileName"]'
        ),
        /**
         * 文件夹排序按钮-修改时间
         */
        folderListSortLatestTimeElement: animElement.querySelector(
          '.pops-folder-list-table__sort[data-sort="latestTime"]'
        ),
        /**
         * 文件夹排序按钮-文件大小
         */
        folderListSortFileSizeElement: animElement.querySelector(
          '.pops-folder-list-table__sort[data-sort="fileSize"]'
        ),
      };
    },
    /**
     * 获取事件配置
     * @param {string} guid
     * @param {HTMLDivElement} $shadowContainer
     * @param {ShadowRoot} $shadowRoot
     * @param {"alert"|"confirm"|"prompt"|"loading"|"iframe"|"drawer"|"folder"|"panel"} mode 当前弹窗类型
     * @param {HTMLDivElement} animElement 动画层
     * @param {HTMLDivElement} popsElement 主元素
     * @param {HTMLDivElement} maskElement 遮罩层
     * @param {object} config 当前配置
     */
    handleEventDetails(
      guid,
      $shadowContainer,
      $shadowRoot,
      mode,
      animElement,
      popsElement,
      maskElement,
      config
    ) {
      return {
        $shadowContainer: $shadowContainer,
        $shadowRoot: $shadowRoot,
        element: animElement,
        animElement: animElement,
        popsElement: popsElement,
        maskElement: maskElement,
        type: "",
        mode: mode,
        guid: guid,
        close() {
          PopsUtils.close(
            mode,
            pops.config.layer[mode],
            guid,
            config,
            animElement
          );
        },
        hide() {
          PopsUtils.hide(
            mode,
            pops.config.layer[mode],
            guid,
            config,
            animElement,
            maskElement
          );
        },
        show() {
          PopsUtils.show(
            mode,
            pops.config.layer[mode],
            guid,
            config,
            animElement,
            maskElement
          );
        },
      };
    },
    /**
     * 处理返回的配置,针对popsHandler.handleEventDetails
     * @returns { {
     * $shadowContainer: HTMLDivElement,
     * $shadowRoot: ShadowRoot,
     * animElement: HTMLElement,
     * popsElement: HTMLElement,
     * maskElement: HTMLElement,
     * close: ()=> void,
     * hide: ()=> void,
     * show: ()=> void,
     * } }
     */
    handleResultDetails(details) {
      let _details_ = Object.assign({}, details);
      delete _details_["type"];
      delete _details_["function"];
      delete _details_["type"];
      return _details_;
    },
    /**
     * 处理点击事件
     * @param {HTMLElement} btnElement 按钮元素
     * @param {"ok"|"close"|"cancel"|"other"} type 触发事件类型
     * @param {object} event 事件配置,由popsHandler.handleEventDetails创建的
     * @param {(event)=>{}} callback 点击回调
     */
    handleClickEvent(btnElement, type, event, callback) {
      PopsDOMUtils.on(
        btnElement,
        "click",
        void 0,
        function () {
          let _event_ = {
            type: type,
          };
          _event_ = Object.assign(event, _event_);
          callback(_event_);
        },
        {
          capture: true,
        }
      );
    },
    /**
     * 全局监听键盘事件
     * @param {string|number} keyName 键名|键值
     * @param {"keyup"|"keypress"|"keydown"} eventName 事件名,默认keypress
     * @param {?string[]} otherKeyList 组合按键,数组类型,包含ctrl、shift、alt和meta(win键或mac的cmd键)
     * @param {(event:Event)=> void} callback 回调函数
     */
    handleKeyboardEvent(keyName, otherKeyList = [], callback) {
      let keyboardEvent = function (event) {
        let _keyName = event.code || event.key;
        let _keyValue = event.charCode || event.keyCode || event.which;
        if (otherKeyList.includes("ctrl") && !event.ctrlKey) {
          return;
        }
        if (otherKeyList.includes("alt") && !event.altKey) {
          return;
        }
        if (otherKeyList.includes("meta") && !event.metaKey) {
          return;
        }
        if (otherKeyList.includes("shift") && !event.shiftKey) {
          return;
        }
        if (typeof keyName === "string" && keyName === _keyName) {
          callback && callback(event);
        } else if (typeof keyName === "number" && keyName === _keyValue) {
          callback && callback(event);
        }
      };
      PopsDOMUtils.on(globalThis, "keydown", void 0, keyboardEvent, {
        capture: true,
      });
      return {
        removeKeyboardEvent() {
          PopsDOMUtils.off(globalThis, "keydown", void 0, keyboardEvent, {
            capture: true,
          });
        },
      };
    },
    /**
     * 处理prompt的点击事件
     * @param {HTMLInputElement} inputElement 输入框
     * @param {HTMLElement} btnElement 按钮元素
     * @param {"ok"|"close"} type 触发事件类型
     * @param {object} event 事件配置,由popsHandler.handleEventDetails创建的
     * @param {(event)=>{}} callback 点击回调
     */
    handlePromptClickEvent(inputElement, btnElement, type, event, callback) {
      PopsDOMUtils.on(
        btnElement,
        "click",
        void 0,
        function () {
          let _event_ = {
            type: type,
            text: inputElement.value,
          };
          _event_ = Object.assign(event, _event_);
          callback(_event_);
        },
        {
          capture: true,
        }
      );
    },
    /**
     * 处理config.only
     * @param {"alert"|"confirm"|"prompt"|"loading"|"tooltip"|"iframe"|"drawer"|"folder"|"rightClickMenu"} type 当前弹窗类型
     * @param {object} config 配置
     * @returns {object}
     */
    handleOnly(type, config) {
      if (config.only) {
        if (
          type === "loading" ||
          type === "tooltip" ||
          type === "rightClickMenu"
        ) {
          PopsUtils.configRemove([pops.config.layer[type]], "", true);
        } else {
          PopsUtils.configRemove(
            [
              pops.config.layer.alert,
              pops.config.layer.confirm,
              pops.config.layer.prompt,
              pops.config.layer.iframe,
              pops.config.layer.drawer,
              pops.config.layer.folder,
              pops.config.layer.panel,
            ],
            "",
            true
          );
        }
      } else {
        config.zIndex = PopsUtils.getPopsMaxZIndex(config.zIndex)["zIndex"] * 2;
      }
      return config;
    },
    /**
     * 处理把已创建的元素保存到内部环境中
     * @param {"alert"|"confirm"|"prompt"|"loading"|"tooltip"|"iframe"|"drawer"|"folder"|"panel"} type 当前弹窗类型
     * @param {PopsLayerCommonConfig} value
     */
    handlePush(type, value) {
      pops.config.layer[type].push(value);
    },
  };

  const PopsElementHandler = {
    /**
     * 获取遮罩层HTML
     * @param {string} guid
     * @param {number} zIndex z-index
     * @param {string} [style=""] style
     * @returns {string}
     */
    getMaskHTML(guid, zIndex, style = "") {
      zIndex = zIndex - 100;
      return `<div class="pops-mask" data-guid="${guid}" style="z-index:${zIndex};${style}"></div>`;
    },
    /**
     * 获取动画层HTML
     * @param {string} guid
     * @param {"alert"|"confirm"|"iframe"|"loading"|"prompt"|"drawer"|"folder"|"panel"} type
     * @param {object} config
     * @param {string} html
     * @param {string} bottomBtnHTML
     */
    getAnimHTML(guid, type, config, html = "", bottomBtnHTML = "") {
      let popsAnimStyle = "";
      let popsStyle = "";
      let popsPosition = config.position || "";
      if (config.zIndex != null) {
        popsAnimStyle += `z-index: ${config.zIndex};`;
        popsStyle += `z-index: ${config.zIndex};`;
      }
      if (config.width != null) {
        popsStyle += `width: ${config.width};`;
      }
      if (config.height != null) {
        popsStyle += `height: ${config.height};`;
      }
      /* 是否存在底部按钮 */
      let hasBottomBtn = bottomBtnHTML.trim() === "" ? false : true;
      return `<div 
                  class="pops-anim"
                  anim="${config.animation || ""}"
                  style="${popsAnimStyle};"
                  data-guid="${guid}">
                ${
                  config.style != null
                    ? `<style tyle="text/css">${config.style}</style>`
                    : ""
                }
                <div
                    class="pops ${config.class || ""}"
                    data-bottom-btn="${hasBottomBtn}"
                    type-value="${type}"
                    style="${popsStyle}"
                    position="${popsPosition}"
                    data-guid="${guid}">
                    ${html}
                </div>
              </div>`;
    },
    /**
     * 获取顶部按钮层HTML
     * @param {"alert"|"confirm"|"iframe"|"prompt"|"drawer"|"folder"|"panel"} type
     * @param {PopsIframeDetails} config
     * @returns {string}
     */
    getHeaderBtnHTML(type, config) {
      if (!config.btn) {
        return "";
      }
      if (type !== "iframe" && !config.btn?.close?.enable) {
        return "";
      }
      let resultHTML = "";
      let btnStyle = "";
      let closeHTML = "";
      if (type === "iframe" && config.topRightButton?.trim() !== "") {
        /* iframe的 */
        let topRightButtonHTML = "";
        config.topRightButton.split("|").forEach((item) => {
          item = item.toLowerCase();
          topRightButtonHTML += `
          <button class="pops-header-control" type="${item}">
            <i class="pops-icon">${pops.config.iconSVG[item]}</i>
          </button>`;
        });
        resultHTML = `
        <div class="pops-header-controls" data-margin>
            ${topRightButtonHTML}
          </div>`;
      } else {
        if (config.btn?.close?.enable) {
          closeHTML = `
          <div class="pops-header-controls">
            <button class="pops-header-control" type="close" data-header>
              <i class="pops-icon">${pops.config.iconSVG["close"]}</i>
            </button>
          </div>`;
        }
        resultHTML = closeHTML;
      }

      return resultHTML;
    },
    /**
     * 获取底部按钮层HTML
     * @param {"alert"|"confirm"|"prompt"|"drawer"|"folder"} type
     * @param {PopsConfirmDetails|PopsAlertDetails|PopsPromptDetails|PopsDrawerDetails} config
     * @returns {string}
     */
    getBottomBtnHTML(type, config) {
      if (!config.btn) {
        return "";
      }
      if (
        !(
          config.btn?.ok?.enable ||
          config.btn?.cancel?.enable ||
          config.btn?.other?.enable
        )
      ) {
        return "";
      }
      let btnStyle = "";
      let resultHTML = "";
      let okHTML = "";
      let cancelHTML = "";
      let ohterHTML = "";

      if (config.btn.position) {
        btnStyle += `justify-content: ${config.btn.position};`;
      }
      if (config.btn.reverse) {
        btnStyle += "flex-direction: row-reverse;";
      }
      if (config.btn?.ok?.enable) {
        /* 处理确定按钮的尺寸问题 */
        let okButtonSizeClassName = "";
        if (config.btn.ok.size === "large") {
          okButtonSizeClassName = "pops-button-" + config.btn.ok.size;
        } else if (config.btn.ok.size === "small") {
          okButtonSizeClassName = "pops-button-" + config.btn.ok.size;
        }
        let okIconHTML = "";
        if (config.btn.ok.icon !== "") {
          okIconHTML = `
          <i class="pops-bottom-icon" is-loading="${
            config.btn.ok.iconIsLoading
          }">
            ${
              config.btn.ok.icon in pops.config.iconSVG
                ? pops.config.iconSVG[config.btn.ok.icon]
                : config.btn.ok.icon
            }
          </i>`;
        }
        okHTML = `
        <button 
                class="pops-${type}-btn-ok ${okButtonSizeClassName}"
                type="${config.btn.ok.type}"
                data-icon="${config.btn.ok.icon}"
                data-rightIcon="${config.btn.ok.rightIcon}"
        >
          ${okIconHTML}
          <span>${config.btn.ok.text}</span>
        </button>`;
      }
      if (config.btn?.cancel?.enable) {
        /* 处理取消按钮的尺寸问题 */
        let cancelButtonSizeClassName = "";
        if (config.btn.cancel.size === "large") {
          cancelButtonSizeClassName = "pops-button-" + config.btn.cancel.size;
        } else if (config.btn.cancel.size === "small") {
          cancelButtonSizeClassName = "pops-button-" + config.btn.cancel.size;
        }
        let cancelIconHTML = "";
        if (config.btn.cancel.icon !== "") {
          cancelIconHTML = `
          <i class="pops-bottom-icon" is-loading="${
            config.btn.cancel.iconIsLoading
          }">
          ${
            config.btn.cancel.icon in pops.config.iconSVG
              ? pops.config.iconSVG[config.btn.cancel.icon]
              : config.btn.cancel.icon
          }
          </i>`;
        }
        cancelHTML = `
        <button
                class="pops-${type}-btn-cancel ${cancelButtonSizeClassName}"
                type="${config.btn.cancel.type}"
                data-icon="${config.btn.cancel.icon}"
                data-rightIcon="${config.btn.cancel.rightIcon}"
        >
          ${cancelIconHTML}
          <span>${config.btn.cancel.text}</span>
        </button>`;
      }
      if (config.btn?.other?.enable) {
        /* 处理其它按钮的尺寸问题 */
        let otherButtonSizeClassName = "";
        if (config.btn.other.size === "large") {
          otherButtonSizeClassName = "pops-button-" + config.btn.other.size;
        } else if (config.btn.other.size === "small") {
          otherButtonSizeClassName = "pops-button-" + config.btn.other.size;
        }
        let otherIconHTML = "";
        if (config.btn.other.icon !== "") {
          otherIconHTML = `
          <i class="pops-bottom-icon" is-loading="${
            config.btn.other.iconIsLoading
          }">
          ${
            config.btn.other.icon in pops.config.iconSVG
              ? pops.config.iconSVG[config.btn.other.icon]
              : config.btn.other.icon
          }
          </i>`;
        }
        ohterHTML = `
        <button
                class="pops-${type}-btn-other ${otherButtonSizeClassName}"
                type="${config.btn.other.type}"
                data-icon="${config.btn.other.icon}"
                data-rightIcon="${config.btn.other.rightIcon}"
        >
          ${otherIconHTML}
          <span>${config.btn.other.text}</span>
        </button>`;
      }
      if (config.btn.merge) {
        resultHTML = `
        <div class="pops-${type}-btn" style="${btnStyle}">
          ${ohterHTML}
          <div 
              class="pops-${type}-btn-merge"
              style="display: flex;
                    flex-direction: ${
                      config.btn.mergeReverse ? "row-reverse" : "row"
                    };
          ">
            ${okHTML}
            ${cancelHTML}
          </div>
        </div>
        `;
      } else {
        resultHTML = `
        <div class="pops-${type}-btn" style="${btnStyle}">
          ${okHTML}
          ${cancelHTML}
          ${ohterHTML}
        </div>
        `;
      }
      return resultHTML;
    },
    /**
     * 获取标题style
     * @param {"alert"|"confirm"|"prompt"|"drawer"|"folder"|"panel"} type
     * @param {PopsAlertDetails|PopsConfirmDetails|PopsPromptDetails|PopsDrawerDetails} config
     */
    getHeaderStyle(type, config) {
      return {
        headerStyle: config?.title?.html ? config?.title?.style || "" : "",
        headerPStyle: config?.title?.html ? "" : config?.title?.style || "",
      };
    },
    /**
     * 获取内容style
     * @param {"alert"|"confirm"|"prompt"|"drawer"} type
     * @param {PopsAlertDetails|PopsConfirmDetails|PopsPromptDetails|PopsDrawerDetails} config
     */
    getContentStyle(type, config) {
      return {
        contentStyle: config?.content?.html ? config?.content?.style || "" : "",
        contentPStyle: config?.content?.html
          ? ""
          : config?.content?.style || "",
      };
    },
    /**
     * 将html转换成元素
     * @param {string} html
     * @returns {HTMLElement}
     */
    parseElement(html) {
      return PopsUtils.parseTextToDOM(html);
    },
  };

  /**
   * 普通信息框
   * @param { PopsAlertDetails } details 配置
   */
  pops.alert = function (details) {
    let that = this;
    const { $shadowContainer, $shadowRoot } = PopsHandler.handlerShadow();
    PopsHandler.handleInit($shadowRoot, [
      pops.config.cssText.index,
      pops.config.cssText.ninePalaceGridPosition,
      pops.config.cssText.scrollbar,
      pops.config.cssText.button,
      pops.config.cssText.anim,
      pops.config.cssText.common,
      pops.config.cssText.alertCSS,
    ]);
    /**
     * @type {PopsAlertDetails}
     */
    let config = {
      title: {
        text: "默认标题",
        position: "left",
        html: false,
        style: "",
      },
      content: {
        text: "默认内容",
        html: false,
        style: "",
      },
      btn: {
        position: "flex-end",
        ok: {
          size: "",
          enable: true,
          icon: "",
          rightIcon: false,
          iconIsLoading: false,
          text: "确定",
          type: "primary",
          callback: function (event) {
            event.close();
          },
        },
        close: {
          enable: true,
          callback: function (event) {
            event.close();
          },
        },
      },
      class: "",
      only: false,
      width: "350px",
      height: "200px",
      position: "center",
      animation: "pops-anim-fadein-zoom",
      zIndex: 10000,
      mask: {
        enable: false,
        clickEvent: {
          toClose: false,
          toHide: false,
        },
        clickCallBack: null,
      },
      drag: false,
      dragLimit: true,
      dragExtraDistance: 3,
      dragMoveCallBack() {},
      dragEndCallBack() {},
      forbiddenScroll: false,
      style: void 0,
      beforeAppendToPageCallBack() {},
    };
    config = PopsUtils.assignJSON(config, details);
    let guid = PopsUtils.getRandomGUID();
    const PopsType = "alert";
    config = PopsHandler.handleOnly(PopsType, config);

    let maskHTML = PopsElementHandler.getMaskHTML(guid, config.zIndex);
    let headerBtnHTML = PopsElementHandler.getHeaderBtnHTML(PopsType, config);
    let bottomBtnHTML = PopsElementHandler.getBottomBtnHTML(PopsType, config);
    let { headerStyle, headerPStyle } = PopsElementHandler.getHeaderStyle(
      PopsType,
      config
    );
    let { contentStyle, contentPStyle } = PopsElementHandler.getContentStyle(
      PopsType,
      config
    );
    let animHTML = PopsElementHandler.getAnimHTML(
      guid,
      PopsType,
      config,
      `
      <div 
          class="pops-alert-title"
          style="text-align: ${config.title.position};
          ${headerStyle}">
          ${
            config.title.html
              ? config.title.text
              : `<p pops style="${headerPStyle}">${config.title.text}</p>`
          }
          ${headerBtnHTML}
      </div>
      <div class="pops-alert-content" style="${contentStyle}">
          ${
            config.content.html
              ? config.content.text
              : `<p pops style="${contentPStyle}">${config.content.text}</p>`
          }
      </div>
      ${bottomBtnHTML}`,
      bottomBtnHTML
    );
    /**
     * 弹窗的主元素,包括动画层
     */
    let animElement = PopsElementHandler.parseElement(animHTML);

    let {
      popsElement,
      headerCloseBtnElement: btnCloseElement,
      btnOkElement,
      titleElement,
    } = PopsHandler.handleQueryElement(animElement, PopsType);
    /**
     * 遮罩层元素
     * @type {?HTMLDivElement}
     */
    let maskElement = null;
    /**
     * 已创建的元素列表
     * @type {HTMLElement[]}
     */
    let elementList = [animElement];

    /* 遮罩层元素 */
    if (config.mask.enable) {
      let _handleMask_ = PopsHandler.handleMask({
        type: PopsType,
        guid: guid,
        config: config,
        animElement: animElement,
        maskHTML: maskHTML,
      });
      maskElement = _handleMask_.maskElement;
      elementList.push(maskElement);
    }
    /* 处理返回的配置 */
    let eventDetails = PopsHandler.handleEventDetails(
      guid,
      $shadowContainer,
      $shadowRoot,
      PopsType,
      animElement,
      popsElement,
      maskElement,
      config
    );
    /* 为顶部右边的关闭按钮添加点击事件 */
    PopsHandler.handleClickEvent(
      btnCloseElement,
      "close",
      eventDetails,
      config.btn.close.callback
    );
    /* 为底部ok按钮添加点击事件 */
    PopsHandler.handleClickEvent(
      btnOkElement,
      "ok",
      eventDetails,
      config.btn.ok.callback
    );

    /* 创建到页面中 */
    PopsUtils.appendChild($shadowRoot, elementList);
    if (typeof config.beforeAppendToPageCallBack === "function") {
      config.beforeAppendToPageCallBack($shadowRoot, $shadowContainer);
    }
    PopsUtils.appendChild($shadowContainer);
    if (maskElement != null) {
      animElement.after(maskElement);
    }
    /* 保存 */
    PopsHandler.handlePush(PopsType, {
      guid: guid,
      animElement: animElement,
      popsElement: popsElement,
      maskElement: maskElement,
      $shadowContainer: $shadowContainer,
      $shadowRoot: $shadowRoot,
    });
    /* 拖拽 */
    if (config.drag) {
      PopsUtils.drag(popsElement, {
        dragElement: titleElement,
        limit: config.dragLimit,
        extraDistance: config.dragExtraDistance,
        moveCallBack: config.dragMoveCallBack,
        endCallBack: config.dragEndCallBack,
      });
    }

    return PopsHandler.handleResultDetails(eventDetails);
  };

  /**
   * 询问框
   * @param {PopsConfirmDetails} details
   */
  pops.confirm = function (details) {
    let that = this;
    const { $shadowContainer, $shadowRoot } = PopsHandler.handlerShadow();
    PopsHandler.handleInit($shadowRoot, [
      pops.config.cssText.index,
      pops.config.cssText.ninePalaceGridPosition,
      pops.config.cssText.scrollbar,
      pops.config.cssText.button,
      pops.config.cssText.anim,
      pops.config.cssText.common,
      pops.config.cssText.confirmCSS,
    ]);
    /**
     * @type {PopsConfirmDetails}
     */
    let config = {
      title: {
        text: "默认标题",
        position: "left",
        html: false,
        style: "",
      },
      content: {
        text: "默认内容",
        html: false,
        style: "",
      },
      btn: {
        merge: false,
        mergeReverse: false,
        reverse: false,
        position: "flex-end",
        ok: {
          enable: true,
          size: "",
          icon: "",
          rightIcon: false,
          iconIsLoading: false,
          text: "确定",
          type: "primary",
          callback(event) {
            event.close();
          },
        },
        cancel: {
          enable: true,
          size: "",
          icon: "",
          rightIcon: false,
          iconIsLoading: false,
          text: "关闭",
          type: "default",
          callback(event) {
            event.close();
          },
        },
        other: {
          enable: false,
          size: "",
          icon: "",
          rightIcon: false,
          iconIsLoading: false,
          text: "其它按钮",
          type: "default",
          callback(event) {
            event.close();
          },
        },
        close: {
          enable: true,
          callback(event) {
            event.close();
          },
        },
      },
      class: "",
      only: false,
      width: "350px",
      height: "200px",
      position: "center",
      animation: "pops-anim-fadein-zoom",
      zIndex: 10000,
      mask: {
        enable: false,
        clickEvent: {
          toClose: false,
          toHide: false,
        },
        clickCallBack: null,
      },
      drag: false,
      dragLimit: true,
      dragExtraDistance: 3,
      dragMoveCallBack() {},
      dragEndCallBack() {},
      forbiddenScroll: false,
      style: void 0,
      beforeAppendToPageCallBack() {},
    };
    config = PopsUtils.assignJSON(config, details);
    let guid = PopsUtils.getRandomGUID();
    const PopsType = "confirm";
    config = PopsHandler.handleOnly(PopsType, config);
    let maskHTML = PopsElementHandler.getMaskHTML(guid, config.zIndex);
    let headerBtnHTML = PopsElementHandler.getHeaderBtnHTML(PopsType, config);
    let bottomBtnHTML = PopsElementHandler.getBottomBtnHTML(PopsType, config);
    let { headerStyle, headerPStyle } = PopsElementHandler.getHeaderStyle(
      PopsType,
      config
    );
    let { contentStyle, contentPStyle } = PopsElementHandler.getContentStyle(
      PopsType,
      config
    );
    let animHTML = PopsElementHandler.getAnimHTML(
      guid,
      PopsType,
      config,
      `
    <div class="pops-confirm-title" style="text-align: ${
      config.title.position
    };${headerStyle}">
					${
            config.title.html
              ? config.title.text
              : `<p pops style="${headerPStyle}">${config.title.text}</p>`
          }
          ${headerBtnHTML}
				</div>
				<div class="pops-confirm-content" style="${contentStyle}">
        ${
          config.content.html
            ? config.content.text
            : `<p pops style="${contentPStyle}">${config.content.text}</p>`
        }
          
				</div>
				${bottomBtnHTML}
    `,
      bottomBtnHTML
    );
    /**
     * 弹窗的主元素,包括动画层
     */
    let animElement = PopsElementHandler.parseElement(animHTML);
    let {
      popsElement,
      titleElement,
      headerCloseBtnElement: btnCloseElement,
      btnOkElement,
      btnCancelElement,
      btnOtherElement,
    } = PopsHandler.handleQueryElement(animElement, PopsType);
    /**
     * 遮罩层元素
     * @type {?HTMLDivElement}
     */
    let maskElement = null;
    /**
     * 已创建的元素列表
     * @type {HTMLElement[]}
     */
    let elementList = [animElement];
    if (config.mask.enable) {
      let _handleMask_ = PopsHandler.handleMask({
        type: PopsType,
        guid: guid,
        config: config,
        animElement: animElement,
        maskHTML: maskHTML,
      });
      maskElement = _handleMask_.maskElement;
      elementList.push(maskElement);
    }
    let eventDetails = PopsHandler.handleEventDetails(
      guid,
      $shadowContainer,
      $shadowRoot,
      PopsType,
      animElement,
      popsElement,
      maskElement,
      config
    );
    PopsHandler.handleClickEvent(
      btnCloseElement,
      "close",
      eventDetails,
      config.btn.close.callback
    );
    PopsHandler.handleClickEvent(
      btnOkElement,
      "ok",
      eventDetails,
      config.btn.ok.callback
    );
    PopsHandler.handleClickEvent(
      btnCancelElement,
      "cancel",
      eventDetails,
      config.btn.cancel.callback
    );
    PopsHandler.handleClickEvent(
      btnOtherElement,
      "other",
      eventDetails,
      config.btn.other.callback
    );

    /* 创建到页面中 */
    PopsUtils.appendChild($shadowRoot, elementList);
    if (typeof config.beforeAppendToPageCallBack === "function") {
      config.beforeAppendToPageCallBack($shadowRoot, $shadowContainer);
    }
    PopsUtils.appendChild($shadowContainer);
    if (maskElement != null) {
      animElement.after(maskElement);
    }
    PopsHandler.handlePush(PopsType, {
      guid: guid,
      animElement: animElement,
      popsElement: popsElement,
      maskElement: maskElement,
      $shadowContainer: $shadowContainer,
      $shadowRoot: $shadowRoot,
    });
    /* 拖拽 */
    if (config.drag) {
      0;
      PopsUtils.drag(popsElement, {
        dragElement: titleElement,
        limit: config.dragLimit,
        extraDistance: config.dragExtraDistance,
        moveCallBack: config.dragMoveCallBack,
        endCallBack: config.dragEndCallBack,
      });
    }
    return PopsHandler.handleResultDetails(eventDetails);
  };

  /**
   * 输入框
   * @param {PopsPromptDetails} details
   */
  pops.prompt = function (details) {
    let that = this;
    const { $shadowContainer, $shadowRoot } = PopsHandler.handlerShadow();
    PopsHandler.handleInit($shadowRoot, [
      pops.config.cssText.index,
      pops.config.cssText.ninePalaceGridPosition,
      pops.config.cssText.scrollbar,
      pops.config.cssText.button,
      pops.config.cssText.anim,
      pops.config.cssText.common,
      pops.config.cssText.promptCSS,
    ]);
    /**
     * @type {PopsPromptDetails}
     */
    let config = {
      title: {
        text: "默认标题",
        position: "left",
        html: false,
        style: "",
      },
      content: {
        text: "",
        password: false,
        row: false,
        focus: true,
        placeholder: "默认提示",
        style: "",
      },
      btn: {
        merge: false,
        mergeReverse: false,
        reverse: false,
        position: "flex-end",
        ok: {
          enable: true,
          size: "",
          icon: "",
          rightIcon: false,
          iconIsLoading: false,
          text: "确定",
          type: "success",
          callback(event) {
            console.log(event);
            event.close();
          },
        },
        cancel: {
          enable: true,
          size: "",
          icon: "",
          rightIcon: false,
          iconIsLoading: false,
          text: "关闭",
          type: "default",
          callback(event) {
            console.log(event);
            event.close();
          },
        },
        other: {
          enable: false,
          size: "",
          icon: "",
          rightIcon: false,
          iconIsLoading: false,
          text: "其它按钮",
          type: "default",
          callback(event) {
            console.log(event);
            event.close();
          },
        },
        close: {
          enable: true,
          callback(event) {
            console.log(event);
            event.close();
          },
        },
      },
      class: "",
      only: false,
      width: "350px",
      height: "200px",
      position: "center",
      animation: "pops-anim-fadein-zoom",
      zIndex: 10000,
      mask: {
        enable: false,
        clickEvent: {
          toClose: false,
          toHide: false,
        },
        clickCallBack: null,
      },
      drag: false,
      dragLimit: true,
      dragExtraDistance: 3,
      dragMoveCallBack() {},
      dragEndCallBack() {},
      forbiddenScroll: false,
      style: void 0,
      beforeAppendToPageCallBack() {},
    };
    config = PopsUtils.assignJSON(config, details);
    let guid = PopsUtils.getRandomGUID();
    const PopsType = "prompt";
    config = PopsHandler.handleOnly(PopsType, config);
    let maskHTML = PopsElementHandler.getMaskHTML(guid, config.zIndex);
    let headerBtnHTML = PopsElementHandler.getHeaderBtnHTML(PopsType, config);
    let bottomBtnHTML = PopsElementHandler.getBottomBtnHTML(PopsType, config);
    let { headerStyle, headerPStyle } = PopsElementHandler.getHeaderStyle(
      PopsType,
      config
    );
    let { contentPStyle } = PopsElementHandler.getContentStyle(
      PopsType,
      config
    );
    let animHTML = PopsElementHandler.getAnimHTML(
      guid,
      PopsType,
      config,
      `
    <div class="pops-prompt-title" style="text-align: ${
      config.title.position
    };${headerStyle}">
      ${
        config.title.html
          ? config.title.text
          : `<p pops style="${headerPStyle}">${config.title.text}</p>`
      }
      ${headerBtnHTML}
    </div>
    <div class="pops-prompt-content" style="${contentPStyle}">
    ${
      config.content.row
        ? '<textarea pops="" placeholder="' +
          config.content.placeholder +
          '"></textarea>'
        : '<input pops="" placeholder="' +
          config.content.placeholder +
          '" type="' +
          (config.content.password ? "password" : "text") +
          '">'
    }
    </div>
   ${bottomBtnHTML}
    `,
      bottomBtnHTML
    );
    /**
     * 弹窗的主元素,包括动画层
     * @type {HTMLDivElement}
     */
    let animElement = PopsElementHandler.parseElement(animHTML);

    let {
      popsElement,
      inputElement,
      headerCloseBtnElement: btnCloseElement,
      btnOkElement,
      btnCancelElement,
      btnOtherElement,
      titleElement,
    } = PopsHandler.handleQueryElement(animElement, PopsType);
    /**
     * 遮罩层元素
     * @type {?HTMLDivElement}
     */
    let maskElement = null;

    /**
     * 已创建的元素列表
     * @type {HTMLElement[]}
     */
    let elementList = [animElement];
    if (config.mask.enable) {
      let _handleMask_ = PopsHandler.handleMask({
        type: PopsType,
        guid: guid,
        config: config,
        animElement: animElement,
        maskHTML: maskHTML,
      });
      maskElement = _handleMask_.maskElement;
      elementList.push(maskElement);
    }
    let eventDetails = PopsHandler.handleEventDetails(
      guid,
      $shadowContainer,
      $shadowRoot,
      PopsType,
      animElement,
      popsElement,
      maskElement,
      config
    );
    /* 输入框赋值初始值 */
    inputElement.value = config.content.text;
    PopsHandler.handlePromptClickEvent(
      inputElement,
      btnCloseElement,
      "close",
      eventDetails,
      config.btn.close.callback
    );

    PopsHandler.handlePromptClickEvent(
      inputElement,
      btnOkElement,
      "ok",
      eventDetails,
      config.btn.ok.callback
    );
    PopsHandler.handlePromptClickEvent(
      inputElement,
      btnCancelElement,
      "cancel",
      eventDetails,
      config.btn.cancel.callback
    );

    PopsHandler.handlePromptClickEvent(
      inputElement,
      btnOtherElement,
      "other",
      eventDetails,
      config.btn.other.callback
    );
    /* 创建到页面中 */
    PopsUtils.appendChild($shadowRoot, elementList);
    if (typeof config.beforeAppendToPageCallBack === "function") {
      config.beforeAppendToPageCallBack($shadowRoot, $shadowContainer);
    }
    PopsUtils.appendChild($shadowContainer);
    if (maskElement != null) {
      animElement.after(maskElement);
    }
    PopsHandler.handlePush(PopsType, {
      guid: guid,
      animElement: animElement,
      popsElement: popsElement,
      maskElement: maskElement,
      $shadowContainer: $shadowContainer,
      $shadowRoot: $shadowRoot,
    });
    /* 拖拽 */
    if (config.drag) {
      PopsUtils.drag(popsElement, {
        dragElement: titleElement,
        limit: config.dragLimit,
        extraDistance: config.dragExtraDistance,
        moveCallBack: config.dragMoveCallBack,
        endCallBack: config.dragEndCallBack,
      });
    }
    /* 设置自动获取焦点 */
    if (config.content.focus) {
      inputElement?.focus();
    }

    return PopsHandler.handleResultDetails(eventDetails);
  };

  /**
   * 加载层
   * @param {PopsLoadingDetails} details
   */
  pops.loading = function (details) {
    let that = this;
    PopsHandler.handleInit();
    /**
     * @type {PopsLoadingDetails}
     */
    let config = {
      parent: document.body,
      content: {
        text: "加载中...",
        icon: "loading",
        style: "",
      },
      class: "",
      only: false,
      zIndex: 10000,
      mask: {
        enable: false,
        clickEvent: {
          toClose: false,
          toHide: false,
        },
        clickCallBack: null,
      },
      animation: "pops-anim-fadein-zoom",
      forbiddenScroll: false,
      style: void 0,
      addIndexCSS: true,
    };
    config = PopsUtils.assignJSON(config, details);
    let guid = PopsUtils.getRandomGUID();
    const PopsType = "loading";
    config = PopsHandler.handleOnly(PopsType, config);
    let maskHTML = PopsElementHandler.getMaskHTML(guid, config.zIndex);
    let { contentPStyle } = PopsElementHandler.getHeaderStyle(PopsType, config);
    let animHTML = PopsElementHandler.getAnimHTML(
      guid,
      PopsType,
      config,
      `
    <div class="pops-loading-content">
    ${
      config.addIndexCSS
        ? `
        <style type="text/css" data-model-name="index">${pops.config.cssText.index}</style>
        <style type="text/css" data-model-name="anim">${pops.config.cssText.anim}</style>
        <style type="text/css" data-model-name="common">${pops.config.cssText.common}</style>
        `
        : ""
    }
      <style type="text/css" data-model-name="loadingCSS">${
        pops.config.cssText.loadingCSS
      }</style>
      ${
        config.style != null
          ? `<style type="text/css">${config.style}</style>`
          : ""
      }
      <p pops style="${contentPStyle}">${config.content.text}</p>
    </div>
    `,
      ""
    );

    /**
     * 弹窗的主元素,包括动画层
     * @type {HTMLDivElement}
     */
    let animElement = PopsElementHandler.parseElement(animHTML);

    let { popsElement } = PopsHandler.handleQueryElement(animElement, PopsType);
    /**
     * 遮罩层元素
     * @type {?HTMLDivElement}
     */
    let maskElement = null;
    /**
     * 已创建的元素列表
     * @type {HTMLElement[]}
     */
    let elementList = [animElement];
    if (config.mask.enable) {
      let _handleMask_ = PopsHandler.handleMask({
        type: PopsType,
        guid: guid,
        config: config,
        animElement: animElement,
        maskHTML: maskHTML,
      });
      maskElement = _handleMask_.maskElement;
      elementList.push(maskElement);
    }
    let eventDetails = PopsHandler.handleEventDetails(
      guid,
      void 0,
      void 0,
      PopsType,
      animElement,
      popsElement,
      maskElement,
      config
    );
    PopsUtils.appendChild(config.parent, elementList);
    if (maskElement != null) {
      animElement.after(maskElement);
    }
    PopsHandler.handlePush(PopsType, {
      guid: guid,
      animElement: animElement,
      popsElement: popsElement,
      maskElement: maskElement,
    });

    return PopsHandler.handleResultDetails(eventDetails);
  };

  /**
   * iframe层
   * @param {PopsIframeDetails} details
   */
  pops.iframe = function (details) {
    let that = this;
    const { $shadowContainer, $shadowRoot } = PopsHandler.handlerShadow();
    PopsHandler.handleInit($shadowRoot, [
      pops.config.cssText.index,
      pops.config.cssText.ninePalaceGridPosition,
      pops.config.cssText.scrollbar,
      pops.config.cssText.anim,
      pops.config.cssText.common,
      pops.config.cssText.iframeCSS,
    ]);
    /**
     * @type {PopsIframeDetails}
     */
    let config = {
      title: {
        position: "center",
        text: "",
        html: false,
        style: "",
      },
      loading: {
        enable: true,
        icon: true,
        text: "",
        style: "",
      },
      class: "",
      url: window.location.href,
      only: false,
      zIndex: 10000,
      mask: {
        enable: false,
        clickEvent: {
          toClose: false,
          toHide: false,
        },
        clickCallBack: null,
      },
      animation: "pops-anim-fadein-zoom",
      position: "center",
      drag: false,
      dragLimit: true,
      dragExtraDistance: 3,
      dragMoveCallBack() {},
      dragEndCallBack() {},
      width: "300px",
      height: "250px",
      topRightButton: "min|max|mise|close",
      sandbox: false,
      forbiddenScroll: false,
      loadEndCallBack() {},
      btn: {
        min: {
          callback() {},
        },
        max: {
          callback() {},
        },
        mise: {
          callback() {},
        },
        close: {
          callback() {},
        },
      },
      style: void 0,
      beforeAppendToPageCallBack() {},
    };
    config = PopsUtils.assignJSON(config, details);
    if (config.url == null) {
      throw "config.url不能为空";
    }
    let guid = PopsUtils.getRandomGUID();
    const PopsType = "iframe";
    config = PopsHandler.handleOnly(PopsType, config);
    let maskExtraStyle =
      config.animation != null && config.animation != ""
        ? "position:absolute;"
        : "";
    let maskHTML = PopsElementHandler.getMaskHTML(
      guid,
      config.zIndex,
      maskExtraStyle
    );
    let headerBtnHTML = PopsElementHandler.getHeaderBtnHTML(PopsType, config);
    let iframeLoadingHTML = '<div class="pops-loading"></div>';
    let titleText =
      config.title.text.trim() !== "" ? config.title.text : config.url;
    let { headerStyle, headerPStyle } = PopsElementHandler.getHeaderStyle(
      PopsType,
      config
    );
    let animHTML = PopsElementHandler.getAnimHTML(
      guid,
      PopsType,
      config,
      `
      <div 
          class="pops-iframe-title"
          style="text-align: ${config.title.position};${headerStyle}"
      >
        ${
          config.title.html
            ? titleText
            : `<p pops style="${headerPStyle}">${titleText}</p>`
        }
        ${headerBtnHTML}
      </div>
				<div class="pops-iframe-content">
          <div class="pops-iframe-content-global-loading"></div>
          <iframe
                src="${config.url}"
                pops
                ${
                  config.sandbox
                    ? "sandbox='allow-forms allow-same-origin allow-scripts'"
                    : ""
                }>
          </iframe>
        </div>
        ${config.loading.enable ? iframeLoadingHTML : ""}
    `,
      ""
    );
    /**
     * 弹窗的主元素,包括动画层
     * @type {HTMLDivElement}
     */
    let animElement = PopsElementHandler.parseElement(animHTML);
    let {
      popsElement,
      headerCloseBtnElement,
      headerControlsElement,
      titleElement,
      iframeElement,
      loadingElement,
      contentLoadingElement,
      headerMinBtnElement,
      headerMaxBtnElement,
      headerMiseBtnElement,
    } = PopsHandler.handleQueryElement(animElement, PopsType);
    /**
     * 遮罩层元素
     * @type {?HTMLDivElement}
     */
    let maskElement = null;
    /**
     * 已创建的元素列表
     * @type {HTMLElement[]}
     */
    let elementList = [animElement];
    if (config.mask.enable) {
      let _handleMask_ = PopsHandler.handleMask({
        type: PopsType,
        guid: guid,
        config: config,
        animElement: animElement,
        maskHTML: maskHTML,
      });
      maskElement = _handleMask_.maskElement;
      elementList.push(maskElement);
    }

    let eventDetails = PopsHandler.handleEventDetails(
      guid,
      $shadowContainer,
      $shadowRoot,
      PopsType,
      animElement,
      popsElement,
      maskElement,
      config
    );
    eventDetails["iframeElement"] = iframeElement;
    PopsDOMUtils.on(
      animElement,
      PopsDOMUtils.getAnimationEndNameList(),
      void 0,
      function () {
        /* 动画加载完毕 */
        animElement.style.width = "0%";
        animElement.style.height = "0%";
      }
    );

    PopsDOMUtils.on(iframeElement, "load", void 0, function () {
      /* iframe加载中... */
      loadingElement?.remove();
      contentLoadingElement.style.animation =
        "iframeLoadingChange_85 0.3s forwards";
      PopsDOMUtils.on(
        contentLoadingElement,
        PopsDOMUtils.getAnimationEndNameList(),
        void 0,
        function () {
          /* 动画加载完毕就移除 */
          contentLoadingElement.remove();
        }
      );
      if (config.title.text.trim() === "" && iframeElement.contentDocument) {
        /* 同域名下的才可以获取网页标题 */
        titleElement.querySelector("p").innerText =
          iframeElement.contentDocument.title;
      }
      config.loadEndCallBack(eventDetails);
    });
    /* 创建到页面中 */
    PopsUtils.appendChild($shadowRoot, elementList);
    if (typeof config.beforeAppendToPageCallBack === "function") {
      config.beforeAppendToPageCallBack($shadowRoot, $shadowContainer);
    }
    PopsUtils.appendChild($shadowContainer);
    if (maskElement != null) {
      animElement.after(maskElement);
    }
    /* 拖拽 */
    if (config.drag) {
      PopsUtils.drag(popsElement, {
        dragElement: titleElement,
        limit: config.dragLimit,
        extraDistance: config.dragExtraDistance,
        moveCallBack: config.dragMoveCallBack,
        endCallBack: config.dragEndCallBack,
      });
    }
    let normalLeft = "";
    /* 最小化按钮点击事件 */

    PopsDOMUtils.on(
      headerMinBtnElement,
      "click",
      void 0,
      (event) => {
        /**
         * 所有最小化的iframe数组
         * @type { HTMLElement[] }
         */
        let allMinElementList = [];

        pops.config.layer.iframe.forEach((item) => {
          if (
            item.animElement != animElement &&
            item.popsElement.getAttribute("type-module") === "min"
          ) {
            allMinElementList.push(item.popsElement);
          }
        });
        let maxLeftValue = allMinElementList.length
          ? allMinElementList.length * 205
          : 0;
        popsElement.style.transitionDuration = "";
        normalLeft = popsElement.style.left;
        popsElement.style.left = maxLeftValue + "px";
        popsElement.setAttribute("type-module", "min");
        animElement
          .querySelector(".pops-header-controls")
          .setAttribute("type", "max");
        config.btn.min.callback(event);
      },
      {
        capture: true,
      }
    );
    /* 最大化按钮点击事件 */
    PopsDOMUtils.on(
      headerMaxBtnElement,
      "click",
      void 0,
      (event) => {
        popsElement.style.transitionDuration = "";
        normalLeft = popsElement.style.left;
        popsElement.removeAttribute("type-module");
        popsElement.setAttribute("type-module", "max");
        headerControlsElement.setAttribute("type", "max");
        headerMaxBtnElement.style.setProperty("display", "none");
        headerMiseBtnElement.style.setProperty("display", "");
        config.btn.max.callback(event);
      },
      {
        capture: true,
      }
    );
    /* 先隐藏窗口化按钮 */
    headerMiseBtnElement?.style?.setProperty("display", "none");
    /* 窗口化按钮点击事件 */
    PopsDOMUtils.on(
      headerMiseBtnElement,
      "click",
      void 0,
      (event) => {
        popsElement.style.transitionDuration = "";
        popsElement.style.left = normalLeft;
        headerControlsElement.removeAttribute("type");
        popsElement.removeAttribute("type-module");
        /**
         * 所有最小化的iframe数组
         * @type { HTMLElement[] }
         */
        let allMinElementList = [];
        pops.config.layer.iframe.forEach((item) => {
          if (
            item.animElement != animElement &&
            popsElement.getAttribute("type-module") === "min"
          ) {
            allMinElementList.push(item.popsElement);
          }
        });
        allMinElementList.sort(
          PopsUtils.sortElementListByProperty(
            (obj) => {
              return parseInt(getComputedStyle(obj).left);
            },
            (obj) => {
              return parseInt(getComputedStyle(obj).left);
            },
            false
          )
        );
        allMinElementList.forEach((item, index) => {
          item.style.left = index * 205 + "px";
        });
        headerMiseBtnElement.style.setProperty("display", "none");
        headerMaxBtnElement.style.setProperty("display", "");
        config.btn.mise.callback(event);
      },
      {
        capture: true,
      }
    );
    /* 关闭按钮点击事件 */
    PopsDOMUtils.on(
      headerCloseBtnElement,
      "click",
      void 0,
      (event) => {
        PopsUtils.configRemove([that.config.layer.iframe], guid, false);
        setTimeout(() => {
          let allIsMinElementList = [];
          pops.config.layer.iframe.forEach((item) => {
            if (
              item.animElement != animElement &&
              popsElement.getAttribute("type-module") === "min"
            ) {
              allIsMinElementList.push(item.popsElement);
            }
          });
          allIsMinElementList.sort(
            PopsUtils.sortElementListByProperty(
              (obj) => {
                return parseInt(getComputedStyle(obj).left);
              },
              (obj) => {
                return parseInt(getComputedStyle(obj).left);
              },
              false
            )
          );
          allIsMinElementList.forEach((item, index) => {
            item.style.left = index * 205 + "px";
          });
        }, 1000 * 0.3);
        config.btn.close.callback(event);
      },
      {
        capture: true,
      }
    );

    PopsHandler.handlePush(PopsType, {
      guid: guid,
      animElement: animElement,
      popsElement: popsElement,
      maskElement: maskElement,
      $shadowContainer: $shadowContainer,
      $shadowRoot: $shadowRoot,
    });

    let result = PopsHandler.handleResultDetails(eventDetails);
    return result;
  };

  /**
   * 提示框
   * @param {PopsToolTipDetails} details
   */
  pops.tooltip = function (details) {
    let that = this;
    const { $shadowContainer, $shadowRoot } = PopsHandler.handlerShadow();
    PopsHandler.handleInit($shadowRoot, [
      pops.config.cssText.index,
      pops.config.cssText.anim,
      pops.config.cssText.common,
      pops.config.cssText.tooltipCSS,
    ]);
    /**
     * @type {PopsToolTipDetails}
     */
    let config = {
      target: null,
      content: "默认文字",
      position: "top",
      className: "",
      alwaysShow: false,
      triggerShowEventName: "mouseenter touchstart",
      triggerCloseEventName: "mouseleave touchend",
      zIndex: 10000,
      only: false,
      eventOption: {
        passive: false,
        capture: true,
        once: false,
      },
      showBeforeCallBack() {},
      showAfterCallBack() {},
      closeBeforeCallBack() {},
      closeAfterCallBack() {},
      arrowDistance: 12.5,
      otherDistance: 0,
      style: void 0,
      beforeAppendToPageCallBack() {},
    };
    config = PopsUtils.assignJSON(config, details);
    if (!(config.target instanceof HTMLElement)) {
      throw "config.target 必须是HTMLElement类型";
    }
    let guid = PopsUtils.getRandomGUID();
    const PopsType = "tooltip";
    config = PopsHandler.handleOnly(PopsType, config);
    function getContent() {
      return typeof config.content === "function"
        ? config.content()
        : config.content;
    }
    /**
     * 获取悬浮提示的元素信息
     */
    function getToolTipElementInfo() {
      let _toolTipHTML_ = `<div class="pops-tip"></div>`;
      let _toolTipElement_ = PopsUtils.parseTextToDOM(_toolTipHTML_);
      if (
        typeof config.className === "string" &&
        config.className.trim() !== ""
      ) {
        PopsDOMUtils.addClassName(_toolTipElement_, config.className);
      }
      _toolTipElement_.setAttribute("data-guid", guid);
      _toolTipElement_.style.zIndex = config.zIndex;
      _toolTipElement_.innerHTML = `
      <div style="text-align: center;">${getContent()}</div>
      `;
      /* 箭头元素 */
      let _toolTipArrowHTML_ = '<div class="pops-tip-arrow"></div>';
      let _toolTipArrowNode_ = PopsUtils.parseTextToDOM(_toolTipArrowHTML_);
      _toolTipElement_.appendChild(_toolTipArrowNode_);
      if (config.style != null) {
        /* 添加自定义style */
        let cssNode = document.createElement("style");
        cssNode.setAttribute("type", "text/css");
        cssNode.innerHTML = config.style;
        _toolTipElement_.appendChild(cssNode);
      }
      return {
        toolTipElement: _toolTipElement_,
        toolTipArrowElement: _toolTipArrowNode_,
        toolTipHTML: _toolTipHTML_,
        toolTipArrowHTML: _toolTipArrowHTML_,
      };
    }
    config.position = config.position.toLowerCase();
    let { toolTipElement } = getToolTipElementInfo();

    /**
     * 设置 提示框的位置
     * @param {object} positionDetails
     */
    function setToolTipPosition(positionDetails) {
      let positionDetail = positionDetails[config.position.toUpperCase()];
      if (positionDetail) {
        toolTipElement.style.left = positionDetail.left + "px";
        toolTipElement.style.top = positionDetail.top + "px";
        toolTipElement.setAttribute("data-motion", positionDetail.motion);
        toolTipElement
          .querySelector(".pops-tip-arrow")
          .setAttribute("data-position", positionDetail.arrow);
      } else {
        console.error("不存在该位置", config.position);
      }
    }

    /**
     * 获取 提示框的位置
     * @param {HTMLElement} targetElement 目标元素
     * @param {number} arrowDistance 箭头和目标元素的距离
     * @param {number} otherDistance 其它位置的偏移
     */
    function getToolTipPosition(targetElement, arrowDistance, otherDistance) {
      let targetElement_width = PopsDOMUtils.offset(targetElement).width;
      let targetElement_height = PopsDOMUtils.offset(targetElement).height;
      let targetElement_top = PopsDOMUtils.offset(targetElement).top;
      let targetElement_bottom = PopsDOMUtils.offset(targetElement).bottom;
      let targetElement_left = PopsDOMUtils.offset(targetElement).left;
      let targetElement_right = PopsDOMUtils.offset(targetElement).right;

      let toolTipElement_width = PopsDOMUtils.outerWidth(toolTipElement);
      let toolTipElement_height = PopsDOMUtils.outerHeight(toolTipElement);
      /* 目标元素的x轴的中间位置 */
      let targetElement_X_center_pos =
        targetElement_left + targetElement_width / 2 - toolTipElement_width / 2;
      /* 目标元素的Y轴的中间位置 */
      let targetElement_Y_center_pos =
        targetElement_top +
        targetElement_height / 2 -
        toolTipElement_height / 2;
      return {
        TOP: {
          left: targetElement_X_center_pos - otherDistance,
          top: targetElement_top - toolTipElement_height - arrowDistance,
          arrow: "bottom",
          motion: "fadeInTop",
        },
        RIGHT: {
          left: targetElement_left + targetElement_width + arrowDistance,
          top: targetElement_Y_center_pos + otherDistance,
          arrow: "left",
          motion: "fadeInRight",
        },
        BOTTOM: {
          left: targetElement_X_center_pos - otherDistance,
          top: targetElement_top + targetElement_height + arrowDistance,
          arrow: "top",
          motion: "fadeInBottom",
        },
        LEFT: {
          left: targetElement_left - toolTipElement_width - arrowDistance,
          top: targetElement_Y_center_pos + otherDistance,
          arrow: "right",
          motion: "fadeInLeft",
        },
      };
    }
    /**
     * 显示提示框
     */
    function showToolTipNode() {
      if (typeof config.showBeforeCallBack === "function") {
        let result = config.showBeforeCallBack();
        if (typeof result === "boolean" && !result) {
          return;
        }
      }
      if (!PopsUtils.contains($shadowRoot, toolTipElement)) {
        PopsUtils.appendChild($shadowRoot, toolTipElement);
      }
      if (!PopsUtils.contains($shadowContainer)) {
        if (typeof config.beforeAppendToPageCallBack === "function") {
          config.beforeAppendToPageCallBack($shadowRoot, $shadowContainer);
        }
        PopsUtils.appendChild($shadowContainer);
      }
      setToolTipPosition(
        getToolTipPosition(
          config.target,
          config.arrowDistance,
          config.otherDistance
        )
      );
      if (typeof config.showAfterCallBack === "function") {
        config.showAfterCallBack(toolTipElement);
      }
    }
    /**
     * 关闭提示框
     */
    function closeToolTipNode() {
      if (typeof config.closeBeforeCallBack === "function") {
        let result = config.closeBeforeCallBack(toolTipElement);
        if (typeof result === "boolean" && !result) {
          return;
        }
      }
      toolTipElement.setAttribute(
        "data-motion",
        toolTipElement.getAttribute("data-motion").replace("fadeIn", "fadeOut")
      );
      if (typeof config.closeAfterCallBack === "function") {
        config.closeAfterCallBack(toolTipElement);
      }
    }
    /**
     * 绑定 显示事件
     */
    function onShowEvent() {
      PopsDOMUtils.on(
        config.target,
        config.triggerShowEventName,
        null,
        showToolTipNode,
        config.eventOption
      );
    }
    /**
     * 绑定 关闭事件
     */
    function onCloseEvent() {
      PopsDOMUtils.on(
        config.target,
        config.triggerCloseEventName,
        null,
        closeToolTipNode,
        config.eventOption
      );
    }
    /**
     * 取消绑定 显示事件
     */
    function offShowEvent() {
      PopsDOMUtils.off(
        config.target,
        null,
        config.triggerShowEventName,
        showToolTipNode,
        {
          capture: true,
        }
      );
    }
    /**
     * 取消绑定 关闭事件
     */
    function offCloseEvent() {
      PopsDOMUtils.off(
        config.target,
        null,
        config.triggerCloseEventName,
        closeToolTipNode,
        {
          capture: true,
        }
      );
    }

    /**
     * 即使存在动画属性,但是当前设置的动画Out结束后移除元素
     */
    function endEvent() {
      if (toolTipElement.getAttribute("data-motion").includes("In")) {
        return;
      }
      toolTipElement.remove();
    }
    if (config.alwaysShow) {
      /* 总是显示 */
      showToolTipNode();
      return {
        guid: guid,
        config: config,
        toolTipNode: toolTipElement,
        show: showToolTipNode,
        close() {
          PopsDOMUtils.on(
            toolTipElement,
            PopsDOMUtils.getAnimationEndNameList(),
            null,
            endEvent,
            config.eventOption
          );
          closeToolTipNode();
        },
        off: null,
        on: null,
      };
    } else {
      /* 事件触发才显示 */

      /**
       * 进入动画
       */
      PopsDOMUtils.on(
        toolTipElement,
        "mouseenter touchstart",
        void 0,
        function () {
          if (parseInt(getComputedStyle(this)) > 0.5) {
            this.style.animationPlayState = "paused";
          }
        },
        config.eventOption
      );
      /**
       * 退出动画
       */
      PopsDOMUtils.on(
        toolTipElement,
        "mouseleave touchend",
        void 0,
        function () {
          this.style.animationPlayState = "running";
        },
        config.eventOption
      );
      PopsDOMUtils.on(
        toolTipElement,
        PopsDOMUtils.getAnimationEndNameList(),
        null,
        endEvent,
        config.eventOption
      );

      onShowEvent();
      onCloseEvent();
      return {
        guid: guid,
        $shadowContainer: $shadowContainer,
        $shadowRoot: $shadowRoot,
        config: config,
        toolTipNode: toolTipElement,
        show: showToolTipNode,
        close: closeToolTipNode,
        off() {
          offShowEvent();
          offCloseEvent();
        },
        on() {
          onShowEvent();
          onCloseEvent();
        },
      };
    }
  };

  /**
   * 抽屉
   * @param {PopsDrawerDetails} details
   */
  pops.drawer = function (details) {
    let that = this;
    const { $shadowContainer, $shadowRoot } = PopsHandler.handlerShadow();
    PopsHandler.handleInit($shadowRoot, [
      pops.config.cssText.index,
      pops.config.cssText.ninePalaceGridPosition,
      pops.config.cssText.scrollbar,
      pops.config.cssText.button,
      pops.config.cssText.anim,
      pops.config.cssText.common,
      pops.config.cssText.drawerCSS,
    ]);
    /**
     * @type {PopsDrawerDetails}
     */
    let config = {
      title: {
        enable: true,
        position: "center",
        text: "默认标题",
        html: false,
        style: "height: 60px;line-height: 60px;",
      },
      content: {
        text: "默认内容",
        html: false,
        style: "overflow: auto;padding: 0px 10px;",
      },
      btn: {
        position: "flex-end",
        ok: {
          enable: true,
          size: "",
          icon: "",
          rightIcon: false,
          iconIsLoading: false,
          text: "确定",
          type: "primary",
          callback(event) {
            event.close();
          },
        },
        cancel: {
          enable: true,
          size: "",
          icon: "",
          rightIcon: false,
          iconIsLoading: false,
          text: "关闭",
          type: "default",
          callback(event) {
            event.close();
          },
        },
        other: {
          enable: false,
          size: "",
          icon: "",
          rightIcon: false,
          iconIsLoading: false,
          text: "其它按钮",
          type: "default",
          callback(event) {
            event.close();
          },
        },
        close: {
          enable: true,
          callback(event) {
            event.close();
          },
        },
      },
      mask: {
        enable: true,
        clickEvent: {
          toClose: true,
          toHide: false,
        },
        clickCallBack: null,
      },
      class: "",
      zIndex: 10000,
      only: false,
      direction: "right",
      size: "30%",
      lockScroll: false,
      closeOnPressEscape: true,
      openDelay: 0,
      closeDelay: 0,
      borderRadius: 0,
      style: void 0,
      beforeAppendToPageCallBack() {},
    };
    config = PopsUtils.assignJSON(config, details);
    let guid = PopsUtils.getRandomGUID();
    const PopsType = "drawer";
    config = PopsHandler.handleOnly(PopsType, config);
    let maskHTML = PopsElementHandler.getMaskHTML(guid, config.zIndex);
    let headerBtnHTML = PopsElementHandler.getHeaderBtnHTML(PopsType, config);
    let bottomBtnHTML = PopsElementHandler.getBottomBtnHTML(PopsType, config);
    let { headerStyle, headerPStyle } = PopsElementHandler.getHeaderStyle(
      PopsType,
      config
    );
    let { contentStyle, contentPStyle } = PopsElementHandler.getContentStyle(
      PopsType,
      config
    );
    let animHTML = PopsElementHandler.getAnimHTML(
      guid,
      PopsType,
      config,
      `
      ${
        config.title.enable
          ? `
      <div class="pops-${PopsType}-title" style="${headerStyle}">
          ${
            config.title.html
              ? config.title.text
              : `<p 
                    pops
                    style="
                          width: 100%;
                          text-align: ${config.title.position};
                          ${headerPStyle}">${config.title.text}</p>`
          }
          ${headerBtnHTML}
      </div>
      `
          : ""
      }
      
      <div class="pops-${PopsType}-content" style="${contentStyle}">
          ${
            config.content.html
              ? config.content.text
              : `<p pops style="${contentPStyle}">${config.content.text}</p>`
          }
      </div>

      ${bottomBtnHTML}
      `,
      bottomBtnHTML
    );
    /**
     * 弹窗的主元素,包括动画层
     */
    let animElement = PopsElementHandler.parseElement(animHTML);
    let {
      popsElement,
      headerCloseBtnElement,
      btnCancelElement,
      btnOkElement,
      btnOtherElement,
    } = PopsHandler.handleQueryElement(animElement, PopsType);
    /**
     * 遮罩层元素
     * @type {?HTMLDivElement}
     */
    let maskElement = null;
    /**
     * 已创建的元素列表
     * @type {HTMLElement[]}
     */
    let elementList = [animElement];
    if (config.mask.enable) {
      let _handleMask_ = PopsHandler.handleMask({
        type: PopsType,
        guid: guid,
        config: config,
        animElement: animElement,
        maskHTML: maskHTML,
      });
      maskElement = _handleMask_.maskElement;
      elementList.push(maskElement);
    }
    let eventDetails = PopsHandler.handleEventDetails(
      guid,
      $shadowContainer,
      $shadowRoot,
      PopsType,
      animElement,
      popsElement,
      maskElement,
      config
    );
    /* 处理方向 */
    popsElement.setAttribute("direction", config.direction);

    /* 处理border-radius */
    /* 处理动画前的宽高 */
    if (config.direction === "top") {
      popsElement.style.setProperty("height", 0);
      popsElement.style.setProperty(
        "border-radius",
        `0px 0px ${config.borderRadius}px ${config.borderRadius}px`
      );
    } else if (config.direction === "bottom") {
      popsElement.style.setProperty("height", 0);
      popsElement.style.setProperty(
        "border-radius",
        `${config.borderRadius}px ${config.borderRadius}px 0px 0px`
      );
    } else if (config.direction === "left") {
      popsElement.style.setProperty("width", 0);
      popsElement.style.setProperty(
        "border-radius",
        `0px ${config.borderRadius}px 0px ${config.borderRadius}px`
      );
    } else if (config.direction === "right") {
      popsElement.style.setProperty("width", 0);
      popsElement.style.setProperty(
        "border-radius",
        `${config.borderRadius}px 0px ${config.borderRadius}px 0px`
      );
    }

    /* 按下Esc键触发关闭 */
    if (config.closeOnPressEscape) {
      PopsHandler.handleKeyboardEvent("Escape", [], function () {
        eventDetails.close();
      });
    }
    /* 待处理的点击事件列表 */
    let needHandleClickEventList = [
      { close: headerCloseBtnElement },
      { cancel: btnCancelElement },
      { ok: btnOkElement },
      { other: btnOtherElement },
    ];
    needHandleClickEventList.forEach((item) => {
      let btnName = Object.keys(item)[0];
      PopsHandler.handleClickEvent(
        item[btnName],
        btnName,
        eventDetails,
        function (_eventDetails_) {
          if (typeof config.btn[btnName].callback === "function") {
            config.btn[btnName].callback(_eventDetails_);
          }
        }
      );
    });

    /* 先隐藏,然后根据config.openDelay来显示 */
    elementList.forEach((element) => {
      element.style.setProperty("display", "none");
      if (["top"].includes(config.direction)) {
        popsElement.style.setProperty("height", config.size);
        popsElement.style.setProperty("transform", "translateY(-100%)");
      } else if (["bottom"].includes(config.direction)) {
        popsElement.style.setProperty("height", config.size);
        popsElement.style.setProperty("transform", "translateY(100%)");
      } else if (["left"].includes(config.direction)) {
        popsElement.style.setProperty("width", config.size);
        popsElement.style.setProperty("transform", "translateX(-100%)");
      } else if (["right"].includes(config.direction)) {
        popsElement.style.setProperty("width", config.size);
        popsElement.style.setProperty("transform", "translateX(100%)");
      }
      element.style.setProperty("display", "");
    });
    /* 创建到页面中 */
    PopsUtils.appendChild($shadowRoot, elementList);
    if (typeof config.beforeAppendToPageCallBack === "function") {
      config.beforeAppendToPageCallBack($shadowRoot, $shadowContainer);
    }
    PopsUtils.appendChild($shadowContainer);
    setTimeout(() => {
      setTimeout(() => {
        popsElement.style.setProperty("transform", "");
      }, config.openDelay);
    }, 50);

    if (maskElement != null) {
      animElement.after(maskElement);
    }

    PopsHandler.handlePush(PopsType, {
      guid: guid,
      animElement: animElement,
      popsElement: popsElement,
      maskElement: maskElement,
      $shadowContainer: $shadowContainer,
      $shadowRoot: $shadowRoot,
    });
    return PopsHandler.handleResultDetails(eventDetails);
  };

  /**
   * 文件夹
   * @param {PopsFolderDetails} details
   */
  pops.folder = function (details) {
    let that = this;
    const { $shadowContainer, $shadowRoot } = PopsHandler.handlerShadow();
    PopsHandler.handleInit($shadowRoot, [
      pops.config.cssText.index,
      pops.config.cssText.ninePalaceGridPosition,
      pops.config.cssText.scrollbar,
      pops.config.cssText.button,
      pops.config.cssText.anim,
      pops.config.cssText.common,
      pops.config.cssText.folderCSS,
    ]);
    /**
     * @type {PopsFolderDetails}
     */
    let config = {
      title: {
        text: "pops.Folder",
        position: "center",
        html: false,
        style: "",
      },
      sort: {
        name: "latestTime",
        isDesc: false,
        callback() {},
      },
      folder: [
        {
          fileName: "测试文件夹",
          fileSize: 0,
          fileType: "",
          createTime: 0,
          latestTime: 0,
          isFolder: true,
          index: 0,
          clickEvent() {
            return [
              {
                fileName: "内部-测试文件.zip",
                fileSize: 1025000,
                fileType: "zip",
                createTime: 1702038410440,
                latestTime: 1702039602126,
                isFolder: false,
                index: 1,
                clickEvent() {
                  console.log("下载文件:", this.fileName);
                  return "https://update.greasyfork.org/scripts/456485/pops.js";
                },
              },
            ];
          },
        },
        {
          fileName: "测试文件.apk",
          fileSize: 30125682,
          fileType: "apk",
          createTime: 1702036410440,
          latestTime: 1702039410440,
          isFolder: false,
          index: 1,
          clickEvent() {
            console.log("下载文件:", this.fileName);
            return "https://update.greasyfork.org/scripts/456485/pops.js";
          },
        },
      ],
      btn: {
        merge: false,
        mergeReverse: false,
        reverse: false,
        position: "flex-end",
        ok: {
          enable: true,
          size: "",
          icon: "",
          rightIcon: false,
          iconIsLoading: false,
          text: "确定",
          type: "primary",
          callback(event) {
            event.close();
          },
        },
        cancel: {
          enable: true,
          size: "",
          icon: "",
          rightIcon: false,
          iconIsLoading: false,
          text: "关闭",
          type: "default",
          callback(event) {
            event.close();
          },
        },
        other: {
          enable: false,
          size: "",
          icon: "",
          rightIcon: false,
          iconIsLoading: false,
          text: "其它按钮",
          type: "default",
          callback(event) {
            event.close();
          },
        },
        close: {
          enable: true,
          callback(event) {
            event.close();
          },
        },
      },
      class: "",
      only: false,
      width: "500px",
      height: "400px",
      position: "center",
      animation: "pops-anim-fadein-zoom",
      zIndex: 10000,
      mask: {
        enable: false,
        clickEvent: {
          toClose: false,
          toHide: false,
        },
        clickCallBack: null,
      },
      drag: false,
      dragLimit: true,
      dragExtraDistance: 3,
      dragMoveCallBack() {},
      dragEndCallBack() {},
      forbiddenScroll: false,
      style: void 0,
      beforeAppendToPageCallBack() {},
    };
    /**
     * 图标
     */
    const Folder_ICON = {
      folder:
        "",
      zip: "",
      mp4: "",
      apk: "",
      gif: "",
      txt: "",
      exe: "",
      qm: "",
      php: "",
      pdf: "",
      Null: "",
      ipa: "",
      doc: "",
      xls: "",
      ppt: "",
      png: "",
      html: "",
      js: "",
      css: "",
      epub: "",
      psd: "",
      dwg: "",
    };
    /* 办公几件套 */
    Folder_ICON.docx = Folder_ICON.doc;
    Folder_ICON.rtf = Folder_ICON.doc;
    Folder_ICON.xlsx = Folder_ICON.xls;
    Folder_ICON.pptx = Folder_ICON.ppt;

    Folder_ICON.dmg = Folder_ICON.ipa;

    Folder_ICON.json = Folder_ICON.js;

    /* 压缩包 */
    let zipIconList = [
      "rar",
      "7z",
      "arj",
      "bz2",
      "cab",
      "iso",
      "jar",
      "lz",
      "lzh",
      "tar",
      "uue",
      "xz",
      "z",
      "zipx",
      "zst",
      "001",
    ];

    /* 图片 */
    let imageIconList = ["jpg", "jpeg", "ico", "webp"];

    /* 代码语言 */
    let codeLanguageIconList = [
      "htm",
      "py",
      "vue",
      "bat",
      "sh",
      "vbs",
      "java",
      "kt",
    ];

    /* Android安装包 */
    let androidIconList = ["apk", "apkm", "xapk"];

    zipIconList.forEach((keyName) => {
      Folder_ICON[keyName] = Folder_ICON.zip;
    });
    imageIconList.forEach((keyName) => {
      Folder_ICON[keyName] = Folder_ICON.png;
    });
    codeLanguageIconList.forEach((keyName) => {
      Folder_ICON[keyName] = Folder_ICON.html;
    });
    androidIconList.forEach((keyName) => {
      Folder_ICON[keyName] = Folder_ICON.apk;
    });

    config = PopsUtils.assignJSON(config, details);
    if (details?.folder) {
      config.folder = details.folder;
    }
    let guid = PopsUtils.getRandomGUID();
    const PopsType = "folder";
    config = PopsHandler.handleOnly(PopsType, config);
    let maskHTML = PopsElementHandler.getMaskHTML(guid, config.zIndex);
    let headerBtnHTML = PopsElementHandler.getHeaderBtnHTML(PopsType, config);
    let bottomBtnHTML = PopsElementHandler.getBottomBtnHTML(PopsType, config);
    let { headerStyle, headerPStyle } = PopsElementHandler.getHeaderStyle(
      PopsType,
      config
    );
    let animHTML = PopsElementHandler.getAnimHTML(
      guid,
      PopsType,
      config,
      `
    <div class="pops-folder-title" style="text-align: ${
      config.title.position
    };${headerStyle}">
					${
            config.title.html
              ? config.title.text
              : `<p pops style="${headerPStyle}">${config.title.text}</p>`
          }
          ${headerBtnHTML}
				</div>
				<div class="pops-folder-content ${
          pops.isPhone() ? "pops-mobile-folder-content" : ""
        }">
          <div class="pops-folder-list">
            <div class="pops-folder-file-list-breadcrumb">
              <div class="pops-folder-file-list-breadcrumb-primary">
                <span class="pops-folder-file-list-breadcrumb-allFiles cursor-p" title="全部文件">
                  <a>全部文件</a>
                </span>
              </div>
            </div>
            <div class="pops-folder-list-table__header-div">
              <table class="pops-folder-list-table__header">
                <colgroup>
                  <!-- <col width="8%"> --!>
                  <col width="52%">
                  <col width="24%">
                  <col width="16%">
                </colgroup>
                <thead>
                  <tr class="pops-folder-list-table__header-row">
                    <th class="pops-folder-list-table__header-th cursor-p">
                      <div class="text-ellip content flex-a-i-center">
                        <span>文件名</span>
                        <div class="pops-folder-list-table__sort" data-sort="fileName">
                          <div class="pops-folder-icon-arrow">
                            <svg
                              viewBox="0 0 1024 1024"
                              xmlns="http://www.w3.org/2000/svg">
                              <path
                                d="M509.624392 5.882457 57.127707 458.379143 962.121078 458.379143Z"
                                class="pops-folder-icon-arrow-up"></path>
                              <path
                                d="M509.624392 1024 962.121078 571.503314 57.127707 571.503314Z"
                                class="pops-folder-icon-arrow-down"></path>
                            </svg>
                          </div>
                        </div>
                      </div>
                    </th>
                    <th class="pops-folder-list-table__header-th cursor-p">
                      <div class="text-ellip content flex-a-i-center">
                        <span>修改时间</span>
                        <div class="pops-folder-list-table__sort" data-sort="latestTime">
                          <div class="pops-folder-icon-arrow">
                            <svg
                              viewBox="0 0 1024 1024"
                              xmlns="http://www.w3.org/2000/svg">
                              <path
                                d="M509.624392 5.882457 57.127707 458.379143 962.121078 458.379143Z"
                                class="pops-folder-icon-arrow-up"></path>
                              <path
                                d="M509.624392 1024 962.121078 571.503314 57.127707 571.503314Z"
                                class="pops-folder-icon-arrow-down"></path>
                            </svg>
                          </div>
                        </div>
                      </div>
                    </th>
                    <th class="pops-folder-list-table__header-th cursor-p">
                      <div class="text-ellip content flex-a-i-center">
                        <span>大小</span>
                        <div class="pops-folder-list-table__sort" data-sort="fileSize">
                          <div class="pops-folder-icon-arrow">
                            <svg
                              viewBox="0 0 1024 1024"
                              xmlns="http://www.w3.org/2000/svg">
                              <path
                                d="M509.624392 5.882457 57.127707 458.379143 962.121078 458.379143Z"
                                class="pops-folder-icon-arrow-up"></path>
                              <path
                                d="M509.624392 1024 962.121078 571.503314 57.127707 571.503314Z"
                                class="pops-folder-icon-arrow-down"></path>
                            </svg>
                          </div>
                        </div>
                      </div>
                    </th>
                  </tr>
                </thead>
              </table>
            </div>
            <div class="pops-folder-list-table__body-div">
              <table class="pops-folder-list-table__body">
                <colgroup>
                  <!-- <col width="8%"> --!>
                  ${
                    pops.isPhone()
                      ? `<col width="100%">`
                      : `
                      <col width="52%">
                      <col width="24%">
                      <col width="16%">`
                  }
                  
                </colgroup>
                <tbody>
                  
                </tbody>
              </table>
            </div>
          </div>
				</div>
				${bottomBtnHTML}
    `,
      bottomBtnHTML
    );
    /**
     * 弹窗的主元素,包括动画层
     */
    let animElement = PopsElementHandler.parseElement(animHTML);
    let {
      popsElement,
      titleElement,
      contentElement,
      folderListElement,
      folderListHeaderElement,
      folderListHeaderRowElement,
      folderListBodyElement,
      folderFileListBreadcrumbPrimaryElement,
      headerCloseBtnElement: btnCloseElement,
      btnOkElement,
      btnCancelElement,
      btnOtherElement,
      folderListSortFileNameElement,
      folderListSortLatestTimeElement,
      folderListSortFileSizeElement,
    } = PopsHandler.handleQueryElement(animElement, PopsType);
    /**
     * 遮罩层元素
     * @type {?HTMLDivElement}
     */
    let maskElement = null;
    /**
     * 已创建的元素列表
     * @type {HTMLElement[]}
     */
    let elementList = [animElement];
    if (config.mask.enable) {
      let _handleMask_ = PopsHandler.handleMask({
        type: PopsType,
        guid: guid,
        config: config,
        animElement: animElement,
        maskHTML: maskHTML,
      });
      maskElement = _handleMask_.maskElement;
      elementList.push(maskElement);
    }
    /* 事件 */
    let eventDetails = PopsHandler.handleEventDetails(
      guid,
      $shadowContainer,
      $shadowRoot,
      PopsType,
      animElement,
      popsElement,
      maskElement,
      config
    );
    PopsHandler.handleClickEvent(
      btnCloseElement,
      "close",
      eventDetails,
      config.btn.close.callback
    );
    PopsHandler.handleClickEvent(
      btnOkElement,
      "ok",
      eventDetails,
      config.btn.ok.callback
    );
    PopsHandler.handleClickEvent(
      btnCancelElement,
      "cancel",
      eventDetails,
      config.btn.cancel.callback
    );
    PopsHandler.handleClickEvent(
      btnOtherElement,
      "other",
      eventDetails,
      config.btn.other.callback
    );
    /* 创建到页面中 */
    PopsUtils.appendChild($shadowRoot, elementList);
    if (typeof config.beforeAppendToPageCallBack === "function") {
      config.beforeAppendToPageCallBack($shadowRoot, $shadowContainer);
    }
    PopsUtils.appendChild($shadowContainer);
    if (maskElement != null) {
      animElement.after(maskElement);
    }
    /* 添加文件信息 */
    config.folder.sort();
    /**
     * 创建文件夹元素
     * @param {string} fileName
     * @param {string} [fileSize="-"]
     * @param {string} [latestTime="-"]
     */
    function createFolderRowElement(
      fileName,
      latestTime = "-",
      fileSize = "-"
    ) {
      let origin_fileName = fileName;
      let origin_latestTime = latestTime;
      let origin_fileSize = fileSize;
      let folderELement = PopsDOMUtils.createElement("tr");
      let fileNameElement = PopsDOMUtils.createElement("td");
      let fileTimeElement = PopsDOMUtils.createElement("td");
      let fileFormatSize = PopsDOMUtils.createElement("td");
      let fileType = "";
      let fileIcon = Folder_ICON.folder;
      if (arguments.length === 1) {
        /* 文件夹 */
        latestTime = "";
        fileSize = "";
      } else {
        /* 文件 */
        fileIcon = "";
        if (typeof latestTime === "number") {
          latestTime = PopsUtils.formatTime(latestTime);
        }
        if (typeof fileSize === "number") {
          fileSize = PopsUtils.formatByteToSize(fileSize);
        }
        for (let keyName in Folder_ICON) {
          if (fileName.toLowerCase().endsWith("." + keyName)) {
            fileType = keyName;
            fileIcon = Folder_ICON[keyName];
            break;
          }
        }
        if (!Boolean(fileIcon)) {
          fileType = "Null";
          fileIcon = Folder_ICON.Null;
        }
      }
      folderELement.className = "pops-folder-list-table__body-row";
      fileNameElement.className = "pops-folder-list-table__body-td";
      fileTimeElement.className = "pops-folder-list-table__body-td";
      fileFormatSize.className = "pops-folder-list-table__body-td";
      fileNameElement.innerHTML = `
        <div class="pops-folder-list-file-name cursor-p">
          <div>
            <img src="${fileIcon}" alt="${fileType}" class="pops-folder-list-file-icon u-file-icon u-file-icon--list">
            <a title="${fileName}" class="pops-folder-list-file-name-title-text inline-block-v-middle text-ellip list-name-text">
              ${fileName}
            </a>
          </div>
        </div>
        `;
      fileTimeElement.innerHTML = `
        <div class="pops-folder-list__time">
          <span>${latestTime}</span>
        </div>
        `;
      fileFormatSize.innerHTML = `
        <div class="pops-folder-list-format-size">
          <span>${fileSize}</span>
        </div>
        `;
      /* 存储原来的值 */
      let __value__ = {
        fileName: origin_fileName,
        latestTime: origin_latestTime,
        fileSize: origin_fileSize,
      };
      fileNameElement["__value__"] = __value__;
      fileTimeElement["__value__"] = __value__;
      fileFormatSize["__value__"] = __value__;
      folderELement["__value__"] = __value__;
      folderELement.appendChild(fileNameElement);
      folderELement.appendChild(fileTimeElement);
      folderELement.appendChild(fileFormatSize);
      return {
        folderELement,
        fileNameElement,
        fileTimeElement,
        fileFormatSize,
      };
    }
    /**
     * 创建移动端文件夹元素
     * @param {string} fileName
     */
    function createMobileFolderRowElement(
      fileName,
      latestTime = "-",
      fileSize = "-"
    ) {
      let origin_fileName = fileName;
      let origin_latestTime = latestTime;
      let origin_fileSize = fileSize;
      let folderELement = PopsDOMUtils.createElement("tr");
      let fileNameElement = PopsDOMUtils.createElement("td");
      let fileType = "";
      let fileIcon = Folder_ICON.folder;
      if (arguments.length === 1) {
        /* 文件夹 */
        latestTime = "";
        fileSize = "";
      } else {
        /* 文件 */
        fileIcon = "";
        if (typeof latestTime === "number") {
          latestTime = PopsUtils.formatTime(latestTime);
        }
        if (typeof fileSize === "number") {
          fileSize = PopsUtils.formatByteToSize(fileSize);
        }
        for (let keyName in Folder_ICON) {
          if (fileName.toLowerCase().endsWith("." + keyName)) {
            fileType = keyName;
            fileIcon = Folder_ICON[keyName];
            break;
          }
        }
        if (!Boolean(fileIcon)) {
          fileType = "Null";
          fileIcon = Folder_ICON.Null;
        }
      }
      folderELement.className = "pops-folder-list-table__body-row";
      fileNameElement.className = "pops-folder-list-table__body-td";
      fileNameElement.innerHTML = `
          <div class="pops-folder-list-file-name pops-mobile-folder-list-file-name cursor-p">
            <img src="${fileIcon}" alt="${fileType}" class="pops-folder-list-file-icon u-file-icon u-file-icon--list">
            <div>
              <a title="${fileName}" class="pops-folder-list-file-name-title-text inline-block-v-middle text-ellip list-name-text">
                ${fileName}
              </a>
              <span>${latestTime} ${fileSize}</span>
            </div>
          </div>
          `;
      /* 存储原来的值 */
      let __value__ = {
        fileName: origin_fileName,
        latestTime: origin_latestTime,
        fileSize: origin_fileSize,
      };
      fileNameElement["__value__"] = __value__;
      folderELement["__value__"] = __value__;
      folderELement.appendChild(fileNameElement);
      return {
        folderELement,
        fileNameElement,
      };
    }
    /**
     * 清空每行的元素
     */
    function clearFolerRow() {
      folderListBodyElement.innerHTML = "";
    }
    function getArrowIconElement() {
      let iconArrowElement = PopsDOMUtils.createElement("div", {
        className: "iconArrow",
      });
      return iconArrowElement;
    }
    /**
     * 添加顶部导航
     * @param {string} name
     * @param {PopsFolderDataConfig} _config_
     * @returns
     */
    function getBreadcrumbAllFilesElement(name, _config_) {
      let spanElement = PopsDOMUtils.createElement(
        "span",
        {
          className: "pops-folder-file-list-breadcrumb-allFiles cursor-p",
          innerHTML: `<a>${name}</a>`,
          _config_: _config_,
        },
        {
          title: "name",
        }
      );
      return spanElement;
    }
    /**
     * 顶部导航的点击事件
     * @param {Event} event
     * @param {boolean} isTop 是否是全部文件按钮
     * @param {PopsFolderDataConfig} _config_ 配置
     */
    function breadcrumbAllFilesElementClickEvent(event, isTop, _config_) {
      clearFolerRow();
      /* 获取当前的导航元素 */
      let currentBreadcrumb = event.target.closest(
        "span.pops-folder-file-list-breadcrumb-allFiles"
      );
      if (currentBreadcrumb) {
        while (currentBreadcrumb.nextElementSibling) {
          currentBreadcrumb.nextElementSibling.remove();
        }
      } else {
        console.error("获取导航按钮失败");
      }
      let loadingMask = pops.loading({
        parent: contentElement,
        content: {
          text: "获取文件列表中...",
        },
        mask: {
          enable: true,
          clickEvent: {
            toClose: false,
            toHide: false,
          },
        },
        addIndexCSS: false,
      });
      addFolderElement(_config_);
      loadingMask.close();
    }
    /**
     * 刷新文件列表界面信息
     * @param {Event} event
     * @param {PopsFolderDataConfig} _config_
     */
    async function refreshFolderInfoClickEvent(event, _config_) {
      clearFolerRow();
      let loadingMask = pops.loading({
        parent: contentElement,
        content: {
          text: "获取文件列表中...",
        },
        mask: {
          enable: true,
        },
        addIndexCSS: false,
      });
      if (typeof _config_.clickEvent === "function") {
        let childConfig = await _config_.clickEvent(event, _config_);
        /* 添加顶部导航的箭头 */
        folderFileListBreadcrumbPrimaryElement.appendChild(
          getArrowIconElement()
        );
        /* 获取顶部导航 */
        let breadcrumbAllFilesElement = getBreadcrumbAllFilesElement(
          _config_["fileName"],
          childConfig
        );
        folderFileListBreadcrumbPrimaryElement.appendChild(
          breadcrumbAllFilesElement
        );
        /* 设置顶部导航点击事件 */
        PopsDOMUtils.on(
          breadcrumbAllFilesElement,
          "click",
          void 0,
          function (event) {
            breadcrumbAllFilesElementClickEvent(event, false, childConfig);
          }
        );
        addFolderElement(childConfig);
      }
      loadingMask.close();
    }
    /**
     * 设置文件点击事件
     * @param {HTMLElement} targetElement
     * @param {PopsFolderDataConfig} _config_
     */
    function setFileClickEvent(targetElement, _config_) {
      PopsDOMUtils.on(targetElement, "click", void 0, async function (event) {
        event?.preventDefault();
        event?.stopPropagation();
        event?.stopImmediatePropagation();
        let linkElement = targetElement.querySelector("a");
        if (typeof _config_.clickEvent === "function") {
          let downloadInfo = await _config_.clickEvent(event, _config_);
          if (
            typeof downloadInfo === "object" &&
            typeof downloadInfo.url === "string" &&
            downloadInfo.url.trim() !== ""
          ) {
            linkElement.setAttribute("href", downloadInfo.url);
            linkElement.setAttribute("target", "_blank");
            if (downloadInfo.autoDownload) {
              if (downloadInfo.mode == null || downloadInfo.mode === "") {
                /* 未设置mode的话默认为aBlank */
                downloadInfo.mode = "aBlank";
              }
              if (downloadInfo.mode === "a" || downloadInfo.mode === "aBlank") {
                /* a标签下载 */
                let downloadLinkElement = document.createElement("a");
                if (downloadInfo.mode === "aBlank") {
                  downloadLinkElement.setAttribute("target", "_blank");
                }
                downloadLinkElement.href = downloadInfo.url;
                downloadLinkElement.click();
              } else if (
                downloadInfo.mode === "open" ||
                downloadInfo.mode === "openBlank"
              ) {
                /* window.open下载 */
                if (downloadInfo.mode === "openBlank") {
                  globalThis.open(downloadInfo.url, "_blank");
                } else {
                  globalThis.open(downloadInfo.url);
                }
              } else if (downloadInfo.mode === "iframe") {
                /* iframe下载 */
                let downloadIframeLinkElement =
                  document.createElement("iframe");
                downloadIframeLinkElement.src = downloadInfo.url;
                downloadIframeLinkElement.onload = function () {
                  setTimeout(() => {
                    downloadIframeLinkElement.remove();
                  }, 1000);
                };
                $shadowRoot.appendChild(downloadIframeLinkElement);
                setTimeout(() => {
                  downloadIframeLinkElement.remove();
                }, 3 * 60 * 1000);
              } else {
                console.error("未知的下载模式", downloadInfo);
              }
            }
          }
        }
      });
    }
    /**
     * 对配置进行排序
     * @param {PopsFolderDataConfig[]} _config_
     * @param {"fileName"|"fileSize"|"latestTime"} sortName 比较的属性,默认fileName
     * @param {boolean} isDesc 是否降序,默认false(升序)
     */
    function sortFolderConfig(_config_, sortName = "fileName", isDesc = false) {
      _config_.sort((a, b) => {
        let beforeVal = a[sortName];
        let afterVal = b[sortName];
        if (sortName === "fileName") {
          /* 文件名,进行字符串转换 */
          beforeVal = beforeVal.toString();
          afterVal = afterVal.toString();
        } else if (sortName === "fileSize") {
          /* 文件大小,进行Float转换 */
          beforeVal = parseFloat(beforeVal);
          afterVal = parseFloat(afterVal);
        } else if (sortName === "latestTime") {
          /* 文件时间 */
          beforeVal = new Date(beforeVal).getTime();
          afterVal = new Date(afterVal).getTime();
        }
        if (typeof beforeVal === "string" && typeof afterVal === "string") {
          let compareVal = beforeVal.localeCompare(afterVal);
          if (isDesc) {
            /* 降序 */
            if (compareVal > 0) {
              compareVal = -1;
            } else if (compareVal < 0) {
              compareVal = 1;
            }
          }
          return compareVal;
        } else {
          if (beforeVal > afterVal) {
            if (isDesc) {
              /* 降序 */
              return -1;
            } else {
              return 1;
            }
          } else if (beforeVal < afterVal) {
            if (isDesc) {
              /* 降序 */
              return 1;
            } else {
              return -1;
            }
          } else {
            return 0;
          }
        }
      });
      return _config_;
    }
    /**
     * 添加元素
     * @param {PopsFolderDataConfig[]} _config_
     */
    function addFolderElement(_config_) {
      sortFolderConfig(_config_, config.sort.name, config.sort.isDesc);
      _config_.forEach((item) => {
        if (item["isFolder"]) {
          let { folderELement, fileNameElement } = pops.isPhone()
            ? createMobileFolderRowElement(item["fileName"])
            : createFolderRowElement(item["fileName"]);
          PopsDOMUtils.on(fileNameElement, "click", void 0, function (event) {
            refreshFolderInfoClickEvent(event, item);
          });
          folderListBodyElement.appendChild(folderELement);
        } else {
          let { folderELement, fileNameElement } = pops.isPhone()
            ? createMobileFolderRowElement(
                item["fileName"],
                item["latestTime"],
                item["fileSize"]
              )
            : createFolderRowElement(
                item["fileName"],
                item["latestTime"],
                item["fileSize"]
              );
          setFileClickEvent(fileNameElement, item);
          folderListBodyElement.appendChild(folderELement);
        }
      });
    }
    addFolderElement(config.folder);
    /* 将数据存到全部文件的属性_config_中 */
    let allFilesElement = folderFileListBreadcrumbPrimaryElement.querySelector(
      ".pops-folder-list .pops-folder-file-list-breadcrumb-allFiles:first-child"
    );
    allFilesElement._config_ = config.folder;
    /* 设置点击顶部的全部文件事件 */
    PopsDOMUtils.on(allFilesElement, "click", void 0, function (event) {
      breadcrumbAllFilesElementClickEvent(event, true, config.folder);
    });

    /* 移除所有的当前排序的arrow */
    function removeAllArrowActive() {
      [
        ...folderListSortFileNameElement.querySelectorAll(
          ".pops-folder-icon-active"
        ),
        ...folderListSortLatestTimeElement.querySelectorAll(
          ".pops-folder-icon-active"
        ),
        ...folderListSortFileSizeElement.querySelectorAll(
          ".pops-folder-icon-active"
        ),
      ].forEach((ele) => ele.classList.remove("pops-folder-icon-active"));
    }
    /* 设置当前的排序的arrow */
    function changeArrowActive(arrowUp, arrowDown, isDesc) {
      removeAllArrowActive();
      if (isDesc) {
        arrowDown.classList.add("pops-folder-icon-active");
      } else {
        arrowUp.classList.add("pops-folder-icon-active");
      }
    }
    /**
     * 排序按钮的点击事件
     * @param {PointerEvent} target
     * @param {HTMLElement} event
     * @param {string} sortName
     * @returns
     */
    function arrowSortClickEvent(target, event, sortName) {
      if (!event["notChangeSortRule"]) {
        config.sort.name = sortName;
        config.sort.isDesc = !config.sort.isDesc;
      }
      let arrowUp = target.querySelector(".pops-folder-icon-arrow-up");
      let arrowDown = target.querySelector(".pops-folder-icon-arrow-down");
      changeArrowActive(arrowUp, arrowDown, config.sort.isDesc);
      if (
        typeof config.sort.callback === "function" &&
        config.sort.callback(
          target,
          event,
          config.sort.name,
          config.sort.isDesc
        )
      ) {
        return;
      }
      let childrenList = [];
      Array.from(folderListBodyElement.children).forEach((trElement) => {
        let __value__ = trElement["__value__"];
        __value__["target"] = trElement;
        childrenList.push(__value__);
      });
      let sortedConfigList = sortFolderConfig(
        childrenList,
        config.sort.name,
        config.sort.isDesc
      );
      sortedConfigList.forEach((item) => {
        folderListBodyElement.appendChild(item.target);
      });
    }
    /* 设置当前排序的图标按钮 */
    PopsDOMUtils.on(
      folderListSortFileNameElement.closest("th"),
      "click",
      void 0,
      function (event) {
        arrowSortClickEvent(folderListSortFileNameElement, event, "fileName");
      },
      {
        capture: true,
      }
    );
    PopsDOMUtils.on(
      folderListSortLatestTimeElement.closest("th"),
      "click",
      void 0,
      function (event) {
        arrowSortClickEvent(
          folderListSortLatestTimeElement,
          event,
          "latestTime"
        );
      },
      {
        capture: true,
      }
    );
    PopsDOMUtils.on(
      folderListSortFileSizeElement.closest("th"),
      "click",
      void 0,
      function (event) {
        arrowSortClickEvent(folderListSortFileSizeElement, event, "fileSize");
      },
      {
        capture: true,
      }
    );
    /* 设置默认触发的arrow */
    if (config.sort.name === "fileName") {
      PopsDOMUtils.trigger(folderListSortFileNameElement, "click", {
        notChangeSortRule: true,
      });
    } else if (config.sort.name === "latestTime") {
      PopsDOMUtils.trigger(folderListSortLatestTimeElement, "click", {
        notChangeSortRule: true,
      });
    } else if (config.sort.name === "fileSize") {
      PopsDOMUtils.trigger(folderListSortFileSizeElement, "click", {
        notChangeSortRule: true,
      });
    }
    /* 拖拽 */
    if (config.drag) {
      PopsUtils.drag(popsElement, {
        dragElement: titleElement,
        limit: config.dragLimit,
        extraDistance: config.dragExtraDistance,
        moveCallBack: config.dragMoveCallBack,
        endCallBack: config.dragEndCallBack,
      });
    }
    PopsHandler.handlePush(PopsType, {
      guid: guid,
      animElement: animElement,
      popsElement: popsElement,
      maskElement: maskElement,
      $shadowContainer: $shadowContainer,
      $shadowRoot: $shadowRoot,
    });
    return PopsHandler.handleResultDetails(eventDetails);
  };

  /**
   * 配置面板
   * @param { PopsPanelDetails } details 配置
   */
  pops.panel = function (details) {
    let that = this;
    const { $shadowContainer, $shadowRoot } = PopsHandler.handlerShadow();
    PopsHandler.handleInit($shadowRoot, [
      pops.config.cssText.index,
      pops.config.cssText.ninePalaceGridPosition,
      pops.config.cssText.scrollbar,
      pops.config.cssText.button,
      pops.config.cssText.anim,
      pops.config.cssText.common,
      pops.config.cssText.panelCSS,
    ]);
    /**
     * @type {PopsPanelDetails}
     */
    let config = {
      title: {
        text: "默认标题",
        position: "center",
        html: false,
        style: "",
      },
      content: [
        {
          id: "whitesev-panel-config-1",
          title: "菜单配置1",
          headerTitle: "菜单配置1",
          isDefault: true,
          attributes: [
            {
              "data-test": "test",
              "data-test-2": "test2",
            },
          ],
          forms: [
            {
              className: "forms-1",
              text: "区域设置",
              type: "forms",
              attributes: [],
              forms: [
                {
                  className: "panel-switch",
                  text: "switch",
                  type: "switch",
                  attributes: [],
                  getValue() {
                    return true;
                  },
                  callback(event, value) {
                    console.log("按钮开启状态:", value);
                  },
                },
                {
                  className: "panel-slider",
                  text: "slider",
                  type: "slider",
                  attributes: [],
                  getValue() {
                    return 50;
                  },
                  callback(event, value) {
                    console.log("滑块当前数值:", value);
                  },
                  min: 1,
                  max: 100,
                },
                {
                  className: "panel-button",
                  text: "button",
                  type: "button",
                  attributes: [],
                  buttonIcon: "eleme",
                  buttonIconIsLoading: true,
                  buttonType: "warning",
                  buttonText: "warning按钮",
                  callback(event) {
                    console.log("点击按钮", event);
                  },
                },
                {
                  className: "panel-button",
                  text: "button",
                  type: "button",
                  attributes: [],
                  buttonIcon: "chromeFilled",
                  buttonIconIsLoading: true,
                  buttonType: "danger",
                  buttonText: "danger按钮",
                  callback(event) {
                    console.log("点击按钮", event);
                  },
                },
                {
                  className: "panel-button",
                  text: "button",
                  type: "button",
                  attributes: [],
                  buttonIcon: "upload",
                  buttonIconIsLoading: false,
                  buttonType: "info",
                  buttonText: "info按钮",
                  callback(event) {
                    console.log("点击按钮", event);
                  },
                },
              ],
            },
          ],
        },
        {
          id: "whitesev-panel-config-2",
          title: "菜单配置2",
          headerTitle: "菜单配置2",
          isDefault: false,
          attributes: [
            {
              "data-value": "value",
              "data-value-2": "value2",
            },
          ],
          forms: [
            {
              className: "panel-input",
              text: "input",
              type: "input",
              attributes: [],
              getValue() {
                return 50;
              },
              callback(event, value) {
                console.log("输入框内容改变:", value);
              },
              placeholder: "请输入内容",
            },
            {
              className: "panel-input-password",
              text: "input-password",
              type: "input",
              attributes: [],
              getValue() {
                return "123456";
              },
              callback(event, value) {
                console.log("密码输入框内容改变:", value);
              },
              isPassword: true,
              placeholder: "请输入密码",
            },
            {
              className: "panel-textarea",
              text: "textarea",
              type: "textarea",
              attributes: [],
              getValue() {
                return 50;
              },
              callback(event, value) {
                console.log("textarea输入框内容改变:", value);
              },
              placeholder: "请输入内容",
            },
            {
              className: "panel-select",
              text: "select",
              type: "select",
              attributes: [],
              getValue() {
                return 50;
              },
              callback(event, isSelectedValue, isSelectedText) {
                console.log(
                  `select当前选项:${isSelectedValue},当前选项文本:${isSelectedText}`
                );
              },
              data: [
                {
                  value: "all",
                  text: "所有",
                },
                {
                  value: "text",
                  text: "文本",
                  selected: true,
                },
                {
                  value: "html",
                  text: "超文本",
                },
              ],
            },
          ],
        },
      ],
      btn: {
        close: {
          enable: true,
          callback(event) {
            event.close();
          },
        },
      },
      mask: {
        enable: false,
        clickEvent: {
          toClose: false,
          toHide: false,
        },
        clickCallBack: null,
      },
      class: "",
      mobileClassName: "pops-panel-is-mobile",
      isMobile: false,
      only: false,
      width: "700px",
      height: "500px",
      position: "center",
      animation: "pops-anim-fadein-zoom",
      zIndex: 10000,
      drag: false,
      dragLimit: true,
      dragExtraDistance: 3,
      dragMoveCallBack() {},
      dragEndCallBack() {},
      forbiddenScroll: false,
      style: void 0,
      beforeAppendToPageCallBack() {},
    };
    config = PopsUtils.assignJSON(config, details);
    if (details && Array.isArray(details.content)) {
      config.content = details.content;
    }
    let guid = PopsUtils.getRandomGUID();
    const PopsType = "panel";
    config = PopsHandler.handleOnly(PopsType, config);
    let maskHTML = PopsElementHandler.getMaskHTML(guid, config.zIndex);
    let headerBtnHTML = PopsElementHandler.getHeaderBtnHTML(PopsType, config);
    let { headerStyle, headerPStyle } = PopsElementHandler.getHeaderStyle(
      PopsType,
      config
    );

    let animHTML = PopsElementHandler.getAnimHTML(
      guid,
      PopsType,
      config,
      `
      <div 
          class="pops-${PopsType}-title"
          style="text-align: ${config.title.position};
          ${headerStyle}">
          ${
            config.title.html
              ? config.title.text
              : `<p pops style="${headerPStyle}">${config.title.text}</p>`
          }
          ${headerBtnHTML}
      </div>
      <div class="pops-${PopsType}-content">
          <aside class="pops-${PopsType}-aside">
            <ul></ul>
          </aside>
          <section class="pops-${PopsType}-container">
            <ul class="pops-panel-container-header-ul"></ul>
            <ul></ul>
          </section>
      </div>
      `,
      ""
    );
    /**
     * 弹窗的主元素,包括动画层
     */
    let animElement = PopsElementHandler.parseElement(animHTML);
    /* 结构元素 */
    let {
      popsElement,
      headerCloseBtnElement: btnCloseElement,
      titleElement,
      contentElement,
      contentAsideElement,
      contentSectionContainerElement,
    } = PopsHandler.handleQueryElement(animElement, PopsType);
    if (config.isMobile || pops.isPhone()) {
      PopsDOMUtils.addClassName(popsElement, config.mobileClassName);
    }
    /**
     * 遮罩层元素
     * @type {?HTMLDivElement}
     */
    let maskElement = null;
    /**
     * 已创建的元素列表
     * @type {HTMLElement[]}
     */
    let elementList = [animElement];

    /* 遮罩层元素 */
    if (config.mask.enable) {
      let _handleMask_ = PopsHandler.handleMask({
        type: PopsType,
        guid: guid,
        config: config,
        animElement: animElement,
        maskHTML: maskHTML,
      });
      maskElement = _handleMask_.maskElement;
      elementList.push(maskElement);
    }

    /* 处理返回的配置 */
    let eventDetails = PopsHandler.handleEventDetails(
      guid,
      $shadowContainer,
      $shadowRoot,
      PopsType,
      animElement,
      popsElement,
      maskElement,
      config
    );
    /* 为顶部右边的关闭按钮添加点击事件 */
    PopsHandler.handleClickEvent(
      btnCloseElement,
      "close",
      eventDetails,
      config.btn.close.callback
    );

    /* 创建到页面中 */
    PopsUtils.appendChild($shadowRoot, elementList);
    if (typeof config.beforeAppendToPageCallBack === "function") {
      config.beforeAppendToPageCallBack($shadowRoot, $shadowContainer);
    }
    PopsUtils.appendChild($shadowContainer);
    /* 追加遮罩层元素 */
    if (maskElement != null) {
      animElement.after(maskElement);
    }

    /**
     * 处理内部配置
     */
    const HandleContetDetails = {
      /**
       * @type {HTMLUListElement}
       */
      asideULElement: null,
      /**
       * @type {HTMLUListElement}
       */
      sectionContainerHeaderULElement: null,
      /**
       * @type {HTMLUListElement}
       */
      sectionContainerULElement: null,
      init() {
        this.asideULElement = contentAsideElement.querySelector("ul");
        this.sectionContainerHeaderULElement =
          contentSectionContainerElement.querySelectorAll("ul")[0];
        this.sectionContainerULElement =
          contentSectionContainerElement.querySelectorAll("ul")[1];
        /**
         * 默认点击的左侧容器
         * @type {HTMLLIElement}
         */
        let asideDefaultItemElement = null;
        let isScrollToDefaultView = false;
        config.content.forEach((asideItem) => {
          let asideLiElement = this.getAsideItem(asideItem);
          this.setAsideItemClickEvent(asideLiElement, asideItem);
          this.asideULElement.appendChild(asideLiElement);
          if (asideDefaultItemElement == null) {
            let flag = false;
            if (typeof asideItem.isDefault === "function") {
              flag = Boolean(asideItem.isDefault());
            } else {
              flag = Boolean(asideItem.isDefault);
            }
            if (flag) {
              asideDefaultItemElement = asideLiElement;
              isScrollToDefaultView = Boolean(asideItem.scrollToDefaultView);
            }
          }
        });

        /* 点击左侧列表 */
        if (
          asideDefaultItemElement == null &&
          this.asideULElement.children.length
        ) {
          /* 默认第一个 */
          asideDefaultItemElement = this.asideULElement.children[0];
        }
        if (asideDefaultItemElement) {
          /* 点击选择的那一项 */
          asideDefaultItemElement.click();
          if (isScrollToDefaultView) {
            asideDefaultItemElement?.scrollIntoView();
          }
        } else {
          console.error("左侧容器没有项");
        }
      },
      /**
       * 清空container容器的元素
       */
      clearContainer() {
        this.sectionContainerHeaderULElement.innerHTML = "";
        this.sectionContainerULElement.innerHTML = "";
      },
      /**
       * 清空左侧容器已访问记录
       */
      clearAsideItemIsVisited() {
        contentAsideElement
          .querySelectorAll(".pops-is-visited")
          .forEach((element) => {
            PopsDOMUtils.removeClassName(element, "pops-is-visited");
          });
      },
      /**
       * 设置左侧容器已访问记录
       * @param {HTMLElement} element
       */
      setAsideItemIsVisited(element) {
        PopsDOMUtils.addClassName(element, "pops-is-visited");
      },
      /**
       * 为元素添加自定义属性
       * @param {HTMLElement} element
       * @param {object | object[]} attributes
       */
      addElementAttributes(element, attributes) {
        if (attributes == null) {
          return;
        }
        if (Array.isArray(attributes)) {
          attributes.forEach((attrObject) => {
            this.addElementAttributes(element, attrObject);
          });
        } else {
          Object.keys(attributes).forEach((attributeName) => {
            element.setAttribute(attributeName, attributes[attributeName]);
          });
        }
      },
      /**
       * 为元素设置(自定义)属性
       * @param {HTMLElement} element
       * @param {?HTMLElement} props
       */
      setElementProps(element, props) {
        if (props == null) {
          return;
        }
        Object.keys(props).forEach((propName) => {
          element[propName] = props[propName];
        });
      },
      /**
       * 获取左侧容器元素<li>
       * @param { PopsPanelContentConfig } asideConfig
       * @returns
       */
      getAsideItem(asideConfig) {
        let liElement = document.createElement("li");
        liElement.id = asideConfig.id;
        liElement.__forms__ = asideConfig.forms;
        liElement.innerHTML = asideConfig.title;
        this.addElementAttributes(liElement, asideConfig.attributes);
        this.setElementProps(liElement, asideConfig.props);
        return liElement;
      },
      /**
       * 获取中间容器的元素<li>
       * type ==> switch
       * @param {PopsPanelSwitchDetails} formConfig
       * @returns
       */
      getSectionContainerItem_switch(formConfig) {
        function setSwitchChecked(
          switchElement,
          switchInputElement,
          checked = false
        ) {
          switchInputElement.checked = Boolean(checked);
          if (checked) {
            PopsDOMUtils.addClassName(
              switchElement,
              "pops-panel-switch-is-checked"
            );
          } else {
            PopsDOMUtils.removeClassName(
              switchElement,
              "pops-panel-switch-is-checked"
            );
          }
        }
        let liElement = document.createElement("li");
        liElement.__formConfig__ = formConfig;
        if (formConfig.className) {
          liElement.className = formConfig.className;
        }
        this.addElementAttributes(liElement, formConfig.attributes);
        this.setElementProps(liElement, formConfig.props);
        /* 左边底部的描述的文字 */
        let leftDescriptionText = "";
        if (Boolean(formConfig.description)) {
          leftDescriptionText = `<p class="pops-panel-item-left-desc-text">${formConfig.description}</p>`;
        }
        liElement.innerHTML = `
        <div class="pops-panel-item-left-text">
          <p class="pops-panel-item-left-main-text">${formConfig.text}</p>
          ${leftDescriptionText}
        </div>
        <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>
        `;
        const PopsPanelSwitch = {
          [Symbol.toStringTag]: "PopsPanelSwitch",
          $data: {
            value: Boolean(formConfig.getValue()),
          },
          $ele: {
            /**
             * @type {HTMLDivElement}
             */
            switch: liElement.querySelector(".pops-panel-switch"),
            /**
             * @type {HTMLInputElement}
             */
            input: liElement.querySelector(".pops-panel-switch__input"),
            /**
             * @type {HTMLSpanElement}
             */
            core: liElement.querySelector(".pops-panel-switch__core"),
          },
          init() {
            this.setStatus(this.$data.value);
            if (formConfig.disabled) {
              this.disable();
            }
            this.setClickEvent();
          },
          setClickEvent() {
            let that = this;
            PopsDOMUtils.on(this.$ele.core, "click", void 0, function (event) {
              if (
                that.$ele.input.disabled ||
                that.$ele.switch.hasAttribute("data-disabled")
              ) {
                return;
              }
              that.$data.value = that.getStatus();
              that.setStatus(that.$data.value);
              if (typeof formConfig.callback === "function") {
                formConfig.callback(event, that.$data.value);
              }
            });
          },
          /**
           * 设置状态
           */
          setStatus(isChecked = false) {
            isChecked = Boolean(isChecked);
            this.$ele.input.checked = isChecked;
            if (isChecked) {
              PopsDOMUtils.addClassName(
                this.$ele.switch,
                "pops-panel-switch-is-checked"
              );
            } else {
              PopsDOMUtils.removeClassName(
                this.$ele.switch,
                "pops-panel-switch-is-checked"
              );
            }
          },
          /**
           * 根据className来获取逆反值
           */
          getStatus() {
            let checkedValue = false;
            if (
              !PopsDOMUtils.containsClassName(
                this.$ele.switch,
                "pops-panel-switch-is-checked"
              )
            ) {
              checkedValue = true;
            }
            return checkedValue;
          },
          /**
           * 禁用复选框
           */
          disable() {
            this.$ele.input.disabled = true;
            this.$ele.switch.setAttribute("data-disabled", true);
          },
          /**
           * 启用复选框
           */
          notDisable() {
            this.$ele.input.disabled = false;
            this.$ele.switch.removeAttribute("data-disabled");
          },
        };

        PopsPanelSwitch.init();
        liElement["data-switch"] = PopsPanelSwitch;
        return liElement;
      },
      /**
       * 获取中间容器的元素<li>
       * type ==> slider
       * @param {PopsPanelSliderDetails} formConfig
       * @returns
       */
      getSectionContainerItem_slider(formConfig) {
        let liElement = document.createElement("li");
        liElement.__formConfig__ = formConfig;
        if (formConfig.className) {
          liElement.className = formConfig.className;
        }
        this.addElementAttributes(liElement, formConfig.attributes);
        this.setElementProps(liElement, formConfig.props);
        /* 左边底部的描述的文字 */
        let leftDescriptionText = "";
        if (Boolean(formConfig.description)) {
          leftDescriptionText = `<p class="pops-panel-item-left-desc-text">${formConfig.description}</p>`;
        }
        liElement.innerHTML = `
       <div class="pops-panel-item-left-text">
         <p class="pops-panel-item-left-main-text">${formConfig.text}</p>
         ${leftDescriptionText}
       </div>
       <div class="pops-panel-slider">
         <input type="range" min="${formConfig.min}" max="${formConfig.max}">
       </div>
       `;
        /**
         * @type {HTMLInputElement}
         */
        let rangeInputElement = liElement.querySelector(
          ".pops-panel-slider input[type=range]"
        );
        if (formConfig.step) {
          rangeInputElement.setAttribute("step", formConfig.step);
        }
        rangeInputElement.value = formConfig.getValue();
        /**
         * 获取提示的内容
         * @param {number} value
         * @returns {string}
         */
        let getToolTipContent = function (value) {
          if (typeof formConfig.getToolTipContent === "function") {
            return formConfig.getToolTipContent(value);
          } else {
            return value;
          }
        };
        let tooltip = pops.tooltip({
          target: rangeInputElement.parentElement,
          content: getToolTipContent(rangeInputElement.value),
          zIndex: 1000000,
          className: "github-tooltip",
          triggerShowEventCallBack(toolTipNode) {
            toolTipNode.querySelector("div").innerText = getToolTipContent(
              rangeInputElement.value
            );
          },
          alwaysShow: false,
          only: false,
          position: "top",
          arrowDistance: 10,
        });
        PopsDOMUtils.on(
          rangeInputElement,
          ["input", "propertychange"],
          void 0,
          function (event) {
            tooltip.toolTipNode.querySelector("div").innerText =
              getToolTipContent(rangeInputElement.value);
            if (typeof formConfig.callback === "function") {
              formConfig.callback(event, event.target.value);
            }
          }
        );
        return liElement;
      },
      /**
       * 获取中间容器的元素<li>
       * type ==> slider
       * @param {PopsPanelSliderDetails} formConfig
       * @returns
       */
      getSectionContainerItem_slider_new(formConfig) {
        let liElement = document.createElement("li");
        liElement.__formConfig__ = formConfig;
        if (formConfig.className) {
          liElement.className = formConfig.className;
        }
        this.addElementAttributes(liElement, formConfig.attributes);
        this.setElementProps(liElement, formConfig.props);
        /* 左边底部的描述的文字 */
        let leftDescriptionText = "";
        if (Boolean(formConfig.description)) {
          leftDescriptionText = `<p class="pops-panel-item-left-desc-text">${formConfig.description}</p>`;
        }
        liElement.innerHTML = `
        <div class="pops-panel-item-left-text" style="flex: 1;">
          <p class="pops-panel-item-left-main-text">${formConfig.text}</p>
          ${leftDescriptionText}
        </div>
        <div class="pops-slider pops-slider-width">
          <div class="pops-slider__runway">
            <div class="pops-slider__bar" style="width: 0%; left: 0%"></div>
            <div
              class="pops-slider__button-wrapper"
              style="left: 0%">
              <div class="pops-slider__button"></div>
            </div>
          </div>
        </div>
        `;
        const PopsPanelSlider = {
          [Symbol.toStringTag]: "PopsPanelSlider",
          /**
           * 值
           */
          value: formConfig.getValue(),
          /**
           * 最小值
           */
          min: formConfig.min,
          /**
           * 最大值
           */
          max: formConfig.max,
          /**
           * 间隔
           */
          step: formConfig.step || 1,
          $data: {
            /**
             * 是否正在移动
             */
            isMove: false,
            /**
             * 是否已初始化已拖拽的距离
             */
            isInitDragPosition: false,
            /**
             * 是否正在检测是否停止拖拽
             */
            isCheckingStopDragMove: false,
            /**
             * 总宽度(px)
             */
            totalWidth: 0,
            /**
             * 每一块的间隔(px)
             */
            stepPx: 0,
            /**
             * 已拖拽的距离(px)
             */
            dragWidth: 0,
            /**
             * 已拖拽的百分比
             */
            dragPercent: 0,
            /**
             * 每一次块的信息
             * 例如:当最小值是2,最大值是10,step为2
             * 那么生成[2,4,6,8,10] 共计5个
             * 又获取到当前滑块总长度是200px
             * 那么生成映射
             * 2 => 0px~40px
             * 4 => 40px~80px
             * 6 => 80px~120px
             * 8 => 120px~160px
             * 10 => 160px~200px
             * @type {Map<number,{
             * value: number,
             * px: number,
             * pxLeft: number,
             * pxRight: number,
             * percent: number,
             * }>}
             */
            stepBlockMap: new Map(),
          },
          $ele: {
            slider: liElement.querySelector(".pops-slider"),
            runAway: liElement.querySelector(".pops-slider__runway"),
            bar: liElement.querySelector(".pops-slider__bar"),
            buttonWrapper: liElement.querySelector(
              ".pops-slider__button-wrapper"
            ),
            button: liElement.querySelector(".pops-slider__button"),
            /**
             * @type {{
             * guid: string,
             * $shadowContainer: HTMLDivElement,
             * $shadowRoot: ShadowRoot,
             * config: PopsToolTipDetails,
             * toolTipNode: HTMLDivElement,
             * show: ()=>void,
             * close: ()=>void,
             * off: ()=>void,
             * on: ()=>void,
             * }}
             */
            tooltip: null,
          },
          $interval: {
            isCheck: false,
          },
          $tooltip: null,
          init() {
            this.initEleData();
            this.setToolTipEvent();
            this.setPanEvent();
            this.setRunAwayClickEvent();
            this.intervalInit();
            if (formConfig.disabled) {
              this.disableDrag();
            }
          },
          /**
           * 10s内循环获取slider的宽度等信息
           * 获取到了就可以初始化left的值
           * @param {number} [checkStepTime=200] 每次检测的间隔时间
           * @param {number} [maxTime=10000] 最大的检测时间
           */
          intervalInit(checkStepTime = 200, maxTime = 10000) {
            if (this.$interval.isCheck) {
              return;
            }
            this.$interval.isCheck = true;
            let isSuccess = false;
            let oldTotalWidth = this.$data.totalWidth;
            let timer = null;
            let interval = setInterval(() => {
              if (isSuccess) {
                this.$interval.isCheck = false;
                clearTimeout(timer);
                clearInterval(interval);
              } else {
                this.initTotalWidth();
                if (this.$data.totalWidth !== 0) {
                  isSuccess = true;
                  if (this.$data.totalWidth !== oldTotalWidth) {
                    /* slider的总宽度改变了 */
                    if (MathFloatUtils.isFloat(this.step)) {
                      this.initFloatStepMap();
                    } else {
                      this.initStepMap();
                    }
                    this.initSliderPosition();
                  }
                }
              }
            }, checkStepTime);
            /* 最长检测时间是10s */
            timer = setTimeout(() => {
              clearInterval(interval);
            }, maxTime);
          },
          /**
           * 把数据添加到元素上
           */
          initEleData() {
            this.$ele.slider.setAttribute("data-min", this.min);
            this.$ele.slider.setAttribute("data-max", this.max);
            this.$ele.slider.setAttribute("data-value", this.value);
            this.$ele.slider.setAttribute("data-step", this.step);
            this.$ele.slider["data-min"] = this.min;
            this.$ele.slider["data-max"] = this.max;
            this.$ele.slider["data-value"] = this.value;
            this.$ele.slider["data-step"] = this.step;
          },
          /**
           * 初始化滑块的总长度的数据(px)
           */
          initTotalWidth() {
            this.$data.totalWidth = PopsDOMUtils.width(this.$ele.runAway);
          },
          /**
           * 初始化每一个块的具体数据信息
           */
          initStepMap() {
            let index = 0;
            // 计算出份数
            let blockNums = (this.max - this.min) / this.step;
            // 计算出每一份占据的px
            this.$data.stepPx = this.$data.totalWidth / blockNums;
            let widthPx = 0;
            for (
              let stepValue = this.min;
              stepValue <= this.max;
              stepValue += this.step
            ) {
              let value = this.formatValue(stepValue);
              let info = {};
              if (value === this.min) {
                /* 起始 */
                info = {
                  value: value,
                  px: 0,
                  pxLeft: 0,
                  pxRight: this.$data.stepPx / 2,
                  percent: 0,
                };
              } else {
                info = {
                  value: value,
                  px: widthPx,
                  pxLeft: widthPx - this.$data.stepPx / 2,
                  pxRight: widthPx + this.$data.stepPx / 2,
                  percent: widthPx / this.$data.totalWidth,
                };
                //if (value === this.max) {
                //  info["pxLeft"] = this.$data.stepBlockMap.get(
                //    index - 1
                //  ).pxRight;
                //  info["pxRight"] = this.$data.totalWidth;
                //}
              }
              this.$data.stepBlockMap.set(index, info);
              index++;
              widthPx += this.$data.stepPx;
            }
          },
          /**
           * 初始化每一个块的具体数据信息(浮点)
           */
          initFloatStepMap() {
            let index = 0;
            // 计算出份数
            let blockNums = (this.max - this.min) / this.step;
            // 计算出每一份占据的px
            this.$data.stepPx = this.$data.totalWidth / blockNums;
            let widthPx = 0;
            for (
              let stepValue = this.min;
              stepValue <= this.max;
              stepValue = MathFloatUtils.add(stepValue, this.step)
            ) {
              let value = this.formatValue(stepValue);
              let info = {};
              if (value === this.min) {
                /* 起始 */
                info = {
                  value: value,
                  px: 0,
                  pxLeft: 0,
                  pxRight: this.$data.stepPx / 2,
                  percent: 0,
                };
              } else {
                info = {
                  value: value,
                  px: widthPx,
                  pxLeft: widthPx - this.$data.stepPx / 2,
                  pxRight: widthPx + this.$data.stepPx / 2,
                  percent: widthPx / this.$data.totalWidth,
                };
                //if (value === this.max) {
                //  info["pxLeft"] = this.$data.stepBlockMap.get(
                //    index - 1
                //  ).pxRight;
                //  info["pxRight"] = this.$data.totalWidth;
                //}
              }
              this.$data.stepBlockMap.set(index, info);
              index++;
              widthPx += this.$data.stepPx;
            }
          },
          /**
           * 初始化slider的默认起始left的百分比值
           */
          initSliderPosition() {
            /* 设置起始默认style的left值 */
            let percent = 0;
            for (const [
              index,
              stepBlockInfo,
            ] of this.$data.stepBlockMap.entries()) {
              /* 判断值是否和区域内的值相等 */
              if (stepBlockInfo.value == this.value) {
                percent = stepBlockInfo.percent;
                this.$data.dragWidth = stepBlockInfo.px;
                break;
              }
            }
            percent = this.formatValue(percent * 100);
            this.setSliderPosition(percent);
          },
          /**
           * 判断数字是否是浮点数
           * @param {number} num
           * @returns
           */
          isFloat(num) {
            return Number(num) === num && num % 1 !== 0;
          },
          /**
           * 值改变的回调
           * @param {any} event
           * @param {number} value
           */
          valueChangeCallBack(event, value) {
            if (typeof formConfig.callback === "function") {
              formConfig.callback(event, value);
            }
          },
          /**
           * 根据拖拽距离获取滑块应该在的区间和值
           */
          getDragInfo(dragX) {
            let result = this.$data.stepBlockMap.get(0);
            for (const [
              index,
              stepBlockInfo,
            ] of this.$data.stepBlockMap.entries()) {
              if (
                stepBlockInfo.pxLeft <= dragX &&
                dragX < stepBlockInfo.pxRight
              ) {
                result = stepBlockInfo;
                break;
              }
            }
            return result;
          },
          /**
           * 获取滑块的当前脱拖拽占据的百分比
           * @param {number} dragWidth
           */
          getSliderPositonPercent(dragWidth) {
            return dragWidth / this.$data.totalWidth;
          },
          /**
           * 根据step格式化value
           * @param {number} num
           */
          formatValue(num) {
            if (MathFloatUtils.isFloat(this.step)) {
              num = parseFloat(num.toFixed(2));
            } else {
              num = parseInt(num);
            }
            return num;
          },
          /**
           * 设置滑块的位置偏移(left)
           * @param {number} percent 百分比
           */
          setSliderPosition(percent) {
            if (parseInt(percent) === 1) {
              percent = 1;
            }
            if (percent > 1) {
              percent = percent / 100;
            }
            /* 滑块按钮的偏移 */
            this.$ele.buttonWrapper.style.left = `${percent * 100}%`;
            /* 滑块进度的宽度 */
            this.$ele.bar.style.width = `${percent * 100}%`;
          },
          /**
           * 禁止拖拽
           */
          disableDrag() {
            this.$ele.runAway.classList.add("pops-slider-is-disabled");
          },
          /**
           * 允许拖拽
           */
          allowDrag() {
            this.$ele.runAway.classList.remove("pops-slider-is-disabled");
          },
          /**
           * 判断当前滑块是否被禁用
           */
          isDisabledDrag() {
            return this.$ele.runAway.classList.contains(
              "pops-slider-is-disabled"
            );
          },
          /**
           * 设置进度条点击定位的事件
           */
          setRunAwayClickEvent() {
            PopsDOMUtils.on(
              this.$ele.runAway,
              "click",
              void 0,
              /**
               *
               * @param {PointerEvent} event
               */
              (event) => {
                if (
                  event.target !== this.$ele.runAway &&
                  event.target !== this.$ele.bar
                ) {
                  return;
                }
                let clickX = parseFloat(event.offsetX);
                this.dragStartCallBack();
                this.dragMoveCallBack(event, clickX, this.value);
                this.dragEndCallBack(clickX);
              },
              {
                capture: false,
              }
            );
          },
          /**
           * 拖拽开始的回调,如果返回false,禁止拖拽
           */
          dragStartCallBack() {
            if (!this.$data.isMove) {
              if (this.isDisabledDrag()) {
                return false;
              }
              this.$data.isMove = true;
            }
            return true;
          },
          /**
           * 拖拽中的回调
           * @param {MouseEvent|TouchEvent} event 事件
           * @param {number} dragX 当前拖拽的距离
           * @param {number} oldValue 旧的值
           */
          dragMoveCallBack(event, dragX, oldValue) {
            let dragPercent = 0;
            if (dragX <= 0) {
              dragPercent = 0;
              this.value = this.min;
            } else if (dragX >= this.$data.totalWidth) {
              dragPercent = 1;
              this.value = this.max;
            } else {
              const dragInfo = this.getDragInfo(dragX);
              dragPercent = dragInfo.percent;
              this.value = this.formatValue(dragInfo.value);
            }
            this.$data.dragPercent = dragPercent;
            this.setSliderPosition(this.$data.dragPercent);
            this.showToolTip();
            if (oldValue !== this.value) {
              this.valueChangeCallBack(event, this.value);
            }
          },
          /**
           * 拖拽结束的回调
           */
          dragEndCallBack(dragX) {
            this.$data.isMove = false;
            if (dragX <= 0) {
              this.$data.dragWidth = 0;
            } else if (dragX >= this.$data.totalWidth) {
              this.$data.dragWidth = this.$data.totalWidth;
            } else {
              this.$data.dragWidth = dragX;
            }
            this.closeToolTip();
          },
          /**
           * 设置点击拖拽事件
           */
          setPanEvent() {
            const AnyTouch = PopsUtils.AnyTouch();
            this.$tooltip = new AnyTouch(this.$ele.button, {
              preventEvent() {
                return false;
              },
            });
            /**
             * 当前的拖拽的距离px
             * @type {number}
             */
            let currentDragX = 0;
            /* 监听拖拽 */
            this.$tooltip.on("at:move", (event) => {
              if (!this.dragStartCallBack()) {
                return;
              }
              let oldValue = this.value;
              const runAwayRect = this.$ele.runAway.getBoundingClientRect();
              let displacementX =
                event.x - (runAwayRect.left + globalThis.screenX);
              if (displacementX <= 0) {
                displacementX = 0;
              } else if (displacementX >= runAwayRect.width) {
                displacementX = runAwayRect.width;
              }
              currentDragX = displacementX;
              /* 拖拽移动 */
              this.dragMoveCallBack(event, currentDragX, oldValue);
            });
            /* 监听触点离开,处理某些情况下,拖拽松开,但是未触发pan事件,可以通过设置这个来关闭tooltip */
            this.$tooltip.on("at:end", (event) => {
              this.dragEndCallBack(currentDragX);
            });
          },
          /**
           * 显示悬浮的
           */
          showToolTip() {
            this.$ele.tooltip.show();
          },
          /**
           * 关闭悬浮的
           */
          closeToolTip() {
            this.$ele.tooltip.close();
          },
          /**
           * 检测在1000ms内,是否停止了拖拽
           */
          checkStopDragMove() {
            if (this.$data.isCheckingStopDragMove) {
              return;
            }
            this.$data.isCheckingStopDragMove = true;
            let interval = setInterval(() => {
              if (!this.$data.isMove) {
                this.$data.isCheckingStopDragMove = false;
                this.closeToolTip();
                clearInterval(interval);
              }
            }, 200);
            setTimeout(() => {
              this.$data.isCheckingStopDragMove = false;
              clearInterval(interval);
            }, 2000);
          },
          /**
           * 设置拖拽按钮的悬浮事件
           */
          setToolTipEvent() {
            /**
             * 获取提示的内容
             */
            function getToolTipContent() {
              if (typeof formConfig.getToolTipContent === "function") {
                return formConfig.getToolTipContent(PopsPanelSlider.value);
              } else {
                return PopsPanelSlider.value;
              }
            }
            let tooltipContent = null;
            this.$ele.tooltip = pops.tooltip({
              target: this.$ele.button,
              content: getToolTipContent,
              zIndex: 1000000,
              className: "github-tooltip",
              only: false,
              eventOption: {
                capture: true,
                passive: true,
              },
              showBeforeCallBack: () => {
                this.intervalInit();
              },
              showAfterCallBack: (toolTipNode) => {
                tooltipContent.innerText = getToolTipContent();
              },
              closeBeforeCallBack: () => {
                if (this.$data.isMove) {
                  this.checkStopDragMove();
                  return false;
                }
              },
              alwaysShow: false,
              only: false,
              position: "top",
              arrowDistance: 10,
            });
            tooltipContent = this.$ele.tooltip.toolTipNode.querySelector("div");
          },
        };
        PopsPanelSlider.init();
        liElement["data-slider"] = PopsPanelSlider;
        return liElement;
      },
      /**
       * 获取中间容器的元素<li>
       * type ==> input
       * @param {PopsPanelInputDetails} formConfig
       * @returns
       */
      getSectionContainerItem_input(formConfig) {
        let liElement = document.createElement("li");
        liElement.__formConfig__ = formConfig;
        if (formConfig.className) {
          liElement.className = formConfig.className;
        }
        this.addElementAttributes(liElement, formConfig.attributes);
        this.setElementProps(liElement, formConfig.props);
        let inputType = "text";
        if (formConfig.isPassword) {
          inputType = "password";
        } else if (formConfig.isNumber) {
          inputType = "number";
        }
        /* 左边底部的描述的文字 */
        let leftDescriptionText = "";
        if (Boolean(formConfig.description)) {
          leftDescriptionText = `<p class="pops-panel-item-left-desc-text">${formConfig.description}</p>`;
        }
        liElement.innerHTML = `
        <div class="pops-panel-item-left-text">
          <p class="pops-panel-item-left-main-text">${formConfig.text}</p>
          ${leftDescriptionText}
        </div>
        <div class="pops-panel-input">
          <input type="${inputType}" placeholder="${formConfig.placeholder}">
        </div>
        `;
        const PopsPanelInput = {
          [Symbol.toStringTag]: "PopsPanelInput",
          $ele: {
            /**
             * @type {HTMLDivElement}
             */
            panelInput: liElement.querySelector(".pops-panel-input"),
            /**
             * @type {HTMLInputElement}
             */
            input: liElement.querySelector("input"),
            inputSpanIcon: document.createElement("span"),
            /**
             * @type {HTMLSpanElement}
             */
            inputSpanIconInner: null,
            /**
             * @type {HTMLElement}
             */
            icon: null,
          },
          $data: {
            value: formConfig.getValue(),
            isView: false,
          },
          init() {
            this.initEle();
            this.setInputValue(this.$data.value);
            /* 如果是密码框,放进图标 */
            if (formConfig.isPassword) {
              this.setCircleIcon(pops.config.iconSVG.view);
              this.setCircleIconClickEvent();
            } else {
              /* 先判断预设值是否为空,不为空添加清空图标按钮 */
              if (this.$ele.input.value != "") {
                this.setCircleIcon(pops.config.iconSVG.circleClose);
                this.setCircleIconClickEvent();
              }
            }

            this.setInputChangeEvent();
            if (formConfig.disabled) {
              this.disable();
            }
            if (typeof formConfig.handlerCallBack === "function") {
              formConfig.handlerCallBack(liElement, this.$ele.input);
            }
          },
          /**
           * 初始化$ele的配置
           */
          initEle() {
            this.$ele.input.parentElement.insertBefore(
              this.$ele.inputSpanIcon,
              this.$ele.input.nextSibling
            );
            this.$ele.inputSpanIcon.className = "pops-panel-input__suffix";
            this.$ele.inputSpanIcon.innerHTML = `
            <span class="pops-panel-input__suffix-inner">
              <i class="pops-panel-icon"></i>
            </span>
            `;
            this.$ele.inputSpanIconInner =
              this.$ele.inputSpanIcon.querySelector(
                ".pops-panel-input__suffix-inner"
              );
            this.$ele.icon =
              this.$ele.inputSpanIcon.querySelector(".pops-panel-icon");
          },
          /**
           * 禁用
           */
          disable() {
            this.$ele.input.disabled = true;
            this.$ele.panelInput.classList.add("pops-input-disabled");
          },
          /**
           * 取消禁用
           */
          notDisable() {
            this.$ele.input.disabled = false;
            this.$ele.panelInput.classList.remove("pops-input-disabled");
          },
          /**
           * 判断是否已被禁用
           */
          isDisabled() {
            return this.$ele.input.disabled;
          },
          /**
           * 设置输入框内容
           * @param {string} [value=""] 值
           */
          setInputValue(value = "") {
            this.$ele.input.value = value;
          },
          /**
           * 设置input元素的type
           * @param {string} [typeValue="text"] type值
           */
          setInputType(typeValue = "text") {
            this.$ele.input.setAttribute("type", typeValue);
          },
          /**
           * 删除图标按钮
           */
          removeCircleIcon() {
            this.$ele.icon.innerHTML = "";
          },
          /**
           * 添加清空图标按钮
           * @param {string} [svgHTML=pops.config.iconSVG.circleClose] svg图标,默认为清空的图标
           */
          setCircleIcon(svgHTML = pops.config.iconSVG.circleClose) {
            this.$ele.icon.innerHTML = svgHTML;
          },
          /**
           * 添加图标按钮的点击事件
           */
          setCircleIconClickEvent() {
            PopsDOMUtils.on(this.$ele.icon, "click", void 0, () => {
              if (this.isDisabled()) {
                return;
              }
              /* 删除图标 */
              this.removeCircleIcon();
              if (formConfig.isPassword) {
                /* 密码输入框 */
                if (this.$data.isView) {
                  /* 当前可见 => 点击改变为隐藏 */
                  this.$data.isView = false;
                  /* 显示输入框内容,且更换图标为隐藏图标 */
                  this.setInputType("text");
                  this.setCircleIcon(pops.config.iconSVG.hide);
                } else {
                  /* 当前不可见 => 点击改变为显示 */
                  this.$data.isView = true;
                  /* 隐藏输入框内容,且更换图标为显示图标 */
                  this.setInputType("password");
                  this.setCircleIcon(pops.config.iconSVG.view);
                }
              } else {
                /* 普通输入框 */
                /* 清空内容 */
                this.setInputValue("");
                /* 获取焦点 */
                this.$ele.input.focus();
                /* 触发内容改变事件 */
                this.$ele.input.dispatchEvent(new Event("input"));
              }
            });
          },
          /**
           * 监听输入框内容改变
           */
          setInputChangeEvent() {
            PopsDOMUtils.on(
              this.$ele.input,
              ["input", "propertychange"],
              void 0,
              (event) => {
                this.$data.value = this.$ele.input.value;
                if (!formConfig.isPassword) {
                  /* 不是密码框 */
                  if (
                    this.$ele.input.value !== "" &&
                    this.$ele.icon.innerHTML === ""
                  ) {
                    /* 不为空,显示清空图标 */
                    this.setCircleIcon(pops.config.iconSVG.circleClose);
                    this.setCircleIconClickEvent();
                  } else if (this.$ele.input.value === "") {
                    this.removeCircleIcon();
                  }
                }
                if (typeof formConfig.callback === "function") {
                  if (formConfig.isNumber) {
                    formConfig.callback(
                      event,
                      this.$ele.input.value,
                      this.$ele.input.valueAsNumber
                    );
                  } else {
                    formConfig.callback(event, this.$ele.input.value);
                  }
                }
              }
            );
          },
        };
        PopsPanelInput.init();
        liElement["data-input"] = PopsPanelInput;
        return liElement;
      },
      /**
       * 获取中间容器的元素<li>
       * type ==> textarea
       * @param {PopsPanelTextAreaDetails} formConfig
       * @returns
       */
      getSectionContainerItem_textarea(formConfig) {
        let liElement = document.createElement("li");
        liElement.__formConfig__ = formConfig;
        if (formConfig.className) {
          liElement.className = formConfig.className;
        }
        this.addElementAttributes(liElement, formConfig.attributes);
        this.setElementProps(liElement, formConfig.props);

        /* 左边底部的描述的文字 */
        let leftDescriptionText = "";
        if (Boolean(formConfig.description)) {
          leftDescriptionText = `<p class="pops-panel-item-left-desc-text">${formConfig.description}</p>`;
        }
        liElement.innerHTML = `
        <div class="pops-panel-item-left-text">
          <p class="pops-panel-item-left-main-text">${formConfig.text}</p>
          ${leftDescriptionText}
        </div>
        <div class="pops-panel-textarea">
          <textarea placeholder="${formConfig.placeholder ?? ""}">
          </textarea>
        </div>
        `;

        const PopsPanelTextArea = {
          [Symbol.toStringTag]: "PopsPanelTextArea",
          $ele: {
            /**
             * @type {HTMLDivElement}
             */
            panelTextarea: liElement.querySelector(".pops-panel-textarea"),
            /**
             * @type {HTMLTextAreaElement}
             */
            textarea: liElement.querySelector(".pops-panel-textarea textarea"),
          },
          $data: {
            value: formConfig.getValue(),
          },
          init() {
            this.setValue(this.$data.value);
            this.setChangeEvent();
            if (formConfig.disabled) {
              this.disable();
            }
          },
          disable() {
            this.$ele.textarea.setAttribute("disabled", true);
            this.$ele.panelTextarea.classList.add(
              "pops-panel-textarea-disable"
            );
          },
          notDisable() {
            this.$ele.textarea.removeAttribute("disabled", true);
            this.$ele.panelTextarea.classList.remove(
              "pops-panel-textarea-disable"
            );
          },
          isDisabled() {
            return (
              this.$ele.textarea.hasAttribute("disabled") ||
              this.$ele.panelTextarea.classList.hasAttribute(
                "pops-panel-textarea-disable"
              )
            );
          },
          setValue(value) {
            this.$ele.textarea.value = value;
          },
          /**
           * 监听选择内容改变
           */
          setChangeEvent() {
            PopsDOMUtils.on(
              this.$ele.textarea,
              ["input", "propertychange"],
              void 0,
              (event) => {
                this.$data.value = event.target.value;
                if (typeof formConfig.callback === "function") {
                  formConfig.callback(event, event.target.value);
                }
              }
            );
          },
        };

        PopsPanelTextArea.init();
        liElement["data-textarea"] = PopsPanelTextArea;

        return liElement;
      },
      /**
       * 获取中间容器的元素<li>
       * type ==> select
       * @param {PopsPanelSelectDetails} formConfig
       * @returns
       */
      getSectionContainerItem_select(formConfig) {
        let liElement = document.createElement("li");
        liElement.__formConfig__ = formConfig;
        if (formConfig.className) {
          liElement.className = formConfig.className;
        }
        this.addElementAttributes(liElement, formConfig.attributes);
        this.setElementProps(liElement, formConfig.props);
        /* 左边底部的描述的文字 */
        let leftDescriptionText = "";
        if (Boolean(formConfig.description)) {
          leftDescriptionText = `<p class="pops-panel-item-left-desc-text">${formConfig.description}</p>`;
        }
        liElement.innerHTML = `
        <div class="pops-panel-item-left-text">
          <p class="pops-panel-item-left-main-text">${formConfig.text}</p>
          ${leftDescriptionText}
        </div>
        <div class="pops-panel-select">
          <select>

          </select>
        </div>
        `;

        const PopsPanelSelect = {
          [Symbol.toStringTag]: "PopsPanelSelect",
          $ele: {
            /**
             * @type {HTMLDivElement}
             */
            panelSelect: liElement.querySelector(".pops-panel-select"),
            /**
             * @type {HTMLSelectElement}
             */
            select: liElement.querySelector(".pops-panel-select select"),
          },
          $data: {
            defaultValue: formConfig.getValue(),
          },
          init() {
            this.initOption();
            this.setChangeEvent();
            this.setClickEvent();
            if (formConfig.disabled) {
              this.disable();
            }
          },
          disable() {
            this.$ele.select.setAttribute("disabled", true);
            this.$ele.panelSelect.classList.add("pops-panel-select-disable");
          },
          notDisable() {
            this.$ele.select.removeAttribute("disabled", true);
            this.$ele.panelSelect.classList.remove("pops-panel-select-disable");
          },
          isDisabled() {
            return (
              this.$ele.select.hasAttribute("disabled") ||
              this.$ele.panelSelect.classList.hasAttribute(
                "pops-panel-select-disable"
              )
            );
          },
          initOption() {
            formConfig.data.forEach((dataItem) => {
              let optionElement = document.createElement("option");
              optionElement.__value__ = dataItem.value;
              optionElement.__disable__ = dataItem.disable;
              if (dataItem.value === this.$data.defaultValue) {
                optionElement.setAttribute("selected", true);
              }
              optionElement.innerText = dataItem.text;
              this.$ele.select.appendChild(optionElement);
            });
          },
          setSelectOptionsDisableStatus() {
            if (this.$ele.select.options && this.$ele.select.options.length) {
              Array.from(this.$ele.select.options).forEach((optionItem) => {
                this.setOptionDisableStatus(optionItem);
              });
            }
          },
          setOptionDisableStatus(optionElement) {
            if (typeof optionElement.__disable__ === "function") {
              let disableStatus = optionElement.__disable__(
                optionElement.__value__
              );
              if (disableStatus) {
                optionElement.setAttribute("disabled", true);
              } else {
                optionElement.removeAttribute("disabled");
              }
            }
          },
          /**
           * 监听选择内容改变
           */
          setChangeEvent() {
            PopsDOMUtils.on(this.$ele.select, "change", void 0, (event) => {
              this.setSelectOptionsDisableStatus();
              if (typeof formConfig.callback === "function") {
                /**
                 * @type {HTMLOptionElement}
                 */
                let isSelectedElement =
                  event.target[event.target.selectedIndex];
                let isSelectedValue = isSelectedElement.__value__;
                let isSelectedText =
                  isSelectedElement.innerText || isSelectedElement.textContent;
                formConfig.callback(event, isSelectedValue, isSelectedText);
              }
            });
          },
          /**
           * 监听点击事件
           */
          setClickEvent() {
            PopsDOMUtils.on(this.$ele.select, "click", void 0, (event) => {
              this.setSelectOptionsDisableStatus();
              if (typeof formConfig.clickCallBack === "function") {
                formConfig.clickCallBack(event, this.$ele.select);
              }
            });
          },
        };

        PopsPanelSelect.init();
        liElement["data-select"] = PopsPanelSelect;
        return liElement;
      },
      /**
       * 获取中间容器的元素<li>
       * type ==> button
       * @param {PopsPanelButtonDetails} formConfig
       * @returns
       */
      getSectionContainerItem_button(formConfig) {
        let liElement = document.createElement("li");
        liElement.__formConfig__ = formConfig;
        if (formConfig.className) {
          liElement.className = formConfig.className;
        }
        this.addElementAttributes(liElement, formConfig.attributes);
        this.setElementProps(liElement, formConfig.props);

        /* 左边底部的描述的文字 */
        let leftDescriptionText = "";
        if (Boolean(formConfig.description)) {
          leftDescriptionText = `<p class="pops-panel-item-left-desc-text">${formConfig.description}</p>`;
        }
        liElement.innerHTML = `
        <div class="pops-panel-item-left-text">
          <p class="pops-panel-item-left-main-text">${formConfig.text}</p>
          ${leftDescriptionText}
        </div>
        <div class="pops-panel-button">
          <button class="pops-panel-button_inner">
            <i class="pops-bottom-icon"></i>
            <span class="pops-panel-button-text"></span>
          </button>
        </div>
        `;

        const PopsPanelButton = {
          [Symbol.toStringTag]: "PopsPanelButton",
          $ele: {
            panelButton: liElement.querySelector(".pops-panel-button"),
            button: liElement.querySelector(
              ".pops-panel-button .pops-panel-button_inner"
            ),
            icon: liElement.querySelector(
              ".pops-panel-button .pops-bottom-icon"
            ),
            spanText: liElement.querySelector(
              ".pops-panel-button .pops-panel-button-text"
            ),
          },
          $data: {},
          init() {
            this.$ele.panelButton.appendChild(this.$ele.button);
            this.initButton();
            this.setClickEvent();
          },
          initButton() {
            if (
              typeof formConfig.buttonIcon === "string" &&
              formConfig.buttonIcon.trim() !== ""
            ) {
              /* 存在icon图标且不为空 */
              if (formConfig.buttonIcon in pops.config.iconSVG) {
                this.setIconSVG(pops.config.iconSVG[formConfig.buttonIcon]);
              } else {
                this.setIconSVG(formConfig.buttonIcon);
              }
              this.showIcon();
            } else {
              this.hideIcon();
            }
            /* 按钮文字 */
            let buttonText = formConfig.buttonText;
            if (typeof formConfig.buttonText === "function") {
              buttonText = formConfig.buttonText();
            }
            this.setButtonType(formConfig.buttonType);
            if (formConfig.buttonIsRightIcon) {
              this.setIconRight();
            } else {
              this.setIconLeft();
            }
            if (formConfig.disable) {
              this.disable();
            }
            this.setButtonText(buttonText);
            this.setIconLoadingStatus(formConfig.buttonIconIsLoading);
          },
          disable() {
            this.$ele.button.setAttribute("disabled", "true");
          },
          notDisable() {
            this.$ele.button.removeAttribute("disabled");
          },
          /**
           * 隐藏icon图标
           */
          hideIcon() {
            this.$ele.panelButton.classList.add("pops-panel-button-no-icon");
          },
          /**
           * 显示icon图标
           */
          showIcon() {
            this.$ele.panelButton.classList.remove("pops-panel-button-no-icon");
          },
          /**
           * 设置icon图标的svg
           */
          setIconSVG(svgHTML) {
            this.$ele.icon.innerHTML = svgHTML;
          },
          /**
           * 设置icon图标是否旋转
           * @param {boolean} status
           */
          setIconLoadingStatus(status) {
            this.$ele.icon.setAttribute("is-loading", Boolean(status));
          },
          /**
           * 设置属性上是否存在icon图标
           */
          setHasIcon(value) {
            this.$ele.button.setAttribute("data-icon", Boolean(value));
          },
          /**
           * 设置按钮类型
           * @param {string} typeValue
           */
          setButtonType(typeValue) {
            this.$ele.button.setAttribute("type", typeValue);
          },
          /**
           * 添加按钮的图标在右边
           */
          setIconRight() {
            this.$ele.button.classList.add("pops-panel-button-right-icon");
          },
          /**
           * (默认)添加按钮的图标在左边
           */
          setIconLeft() {
            this.$ele.button.classList.remove("pops-panel-button-right-icon");
          },
          /**
           * 设置按钮文本
           * @param {string} text
           */
          setButtonText(text) {
            this.$ele.spanText.innerHTML = text;
          },
          setClickEvent() {
            PopsDOMUtils.on(this.$ele.button, "click", void 0, (event) => {
              if (typeof formConfig.callback === "function") {
                formConfig.callback(event);
              }
            });
          },
        };
        PopsPanelButton.init();
        liElement["data-button"] = PopsPanelButton;
        return liElement;
      },
      /**
       * 获取中间容器的元素<li>
       * type ===> own
       * @param {PopsPanelOwnDetails} formConfig
       * @returns
       */
      getSectionContainerItem_own(formConfig) {
        let liElement = document.createElement("li");
        liElement.__formConfig__ = formConfig;
        if (formConfig.className) {
          liElement.className = formConfig.className;
        }
        liElement = formConfig.getLiElementCallBack(liElement);
        return liElement;
      },
      /**
       * 获取中间容器的元素<li>
       * @param {PopsPanelFormsTotalDetails} formConfig
       * @returns
       */
      getSectionContainerItem(formConfig) {
        if (formConfig["type"] === "switch") {
          return this.getSectionContainerItem_switch(formConfig);
        } else if (formConfig["type"] === "slider") {
          return this.getSectionContainerItem_slider_new(formConfig);
        } else if (formConfig["type"] === "input") {
          return this.getSectionContainerItem_input(formConfig);
        } else if (formConfig["type"] === "textarea") {
          return this.getSectionContainerItem_textarea(formConfig);
        } else if (formConfig["type"] === "select") {
          return this.getSectionContainerItem_select(formConfig);
        } else if (formConfig["type"] === "button") {
          return this.getSectionContainerItem_button(formConfig);
        } else if (formConfig["type"] === "own") {
          return this.getSectionContainerItem_own(formConfig);
        } else {
          console.error("尚未实现的type类型", formConfig);
        }
      },

      /**
       * 为左侧容器元素添加点击事件
       * @param {HTMLElement} asideLiElement 左侧的容器<li>元素
       * @param {PopsPanelContentConfig} asideConfig 配置
       */
      setAsideItemClickEvent(asideLiElement, asideConfig) {
        let that = this;
        /**
         *
         * @param {PopsPanelFormsTotalDetails} formConfig
         * @param {PopsPanelRightAsideContainerOptions} containerOptions
         */
        function uListContainerAddItem(formConfig, containerOptions) {
          let itemLiElement = that.getSectionContainerItem(formConfig);
          if (itemLiElement) {
            containerOptions["ulElement"].appendChild(itemLiElement);
          }
          if (typeof formConfig.afterAddToUListCallBack === "function") {
            formConfig.afterAddToUListCallBack(formConfig, containerOptions);
          }
        }
        PopsDOMUtils.on(asideLiElement, "click", void 0, function (event) {
          that.clearContainer();
          that.clearAsideItemIsVisited();
          that.setAsideItemIsVisited(asideLiElement);
          /* 顶部标题栏,存在就设置 */
          let headerTitleText = asideConfig.headerTitle || asideConfig.title;
          if (
            typeof headerTitleText === "string" &&
            headerTitleText.trim() !== ""
          ) {
            let containerHeaderTitleLIElement = document.createElement("li");
            containerHeaderTitleLIElement.__asideConfig__ = asideConfig;
            containerHeaderTitleLIElement.innerHTML = headerTitleText;
            that.sectionContainerHeaderULElement.appendChild(
              containerHeaderTitleLIElement
            );
          }

          /**
           * @type {PopsPanelContentConfig[]}
           */
          let __forms__ = asideLiElement.__forms__;
          __forms__.forEach((formConfig) => {
            if (formConfig["type"] === "forms") {
              let childForms = formConfig["forms"];
              /* 父<li>元素 */
              let formContainerListElement = document.createElement("li");
              /* 子<ul>元素 */
              let formContainerULElement = document.createElement("ul");
              formContainerListElement.className =
                "pops-panel-forms-container-item";
              /* 区域头部的文字 */
              let formHeaderDivElement = PopsDOMUtils.createElement("div", {
                className: "pops-panel-forms-container-item-header-text",
              });
              formHeaderDivElement.innerHTML = formConfig["text"];
              /* 加进容器内 */
              formContainerListElement.appendChild(formHeaderDivElement);
              if (formConfig.className) {
                PopsDOMUtils.addClassName(
                  formContainerListElement,
                  formConfig.className
                );
              }
              that.addElementAttributes(
                formContainerListElement,
                formConfig.attributes
              );
              that.setElementProps(formContainerListElement, formConfig.props);
              childForms.forEach((childFormConfig) => {
                uListContainerAddItem(childFormConfig, {
                  ulElement: formContainerULElement,
                  sectionContainerULElement: that.sectionContainerULElement,
                  formContainerListElement: formContainerListElement,
                  formHeaderDivElement: formHeaderDivElement,
                });
              });
              formContainerListElement.appendChild(formContainerULElement);
              that.sectionContainerULElement.appendChild(
                formContainerListElement
              );
            } else {
              /* 如果成功创建,加入到中间容器中 */
              uListContainerAddItem(formConfig, {
                ulElement: that.sectionContainerULElement,
              });
            }
          });

          let autoAdaptionContentHeight =
            asideConfig.autoAdaptionContentHeight ?? true;
          if (autoAdaptionContentHeight) {
            /* 根据标题的高度来自适应内容高度,默认开启 */
            /* 中间容器的偏移量,看设置的section.pops-panel-container的padding,默认0 */
            let contentContainerOffset =
              asideConfig.contentContainerOffset ?? 0;
            /* 获取标题的<ul>元素的高度 */
            let sectionContainerHeaderULElementHeight = PopsDOMUtils.height(
              that.sectionContainerHeaderULElement
            );
            that.sectionContainerULElement.style.setProperty(
              "height",
              `calc( 100% - ${
                sectionContainerHeaderULElementHeight + contentContainerOffset
              }px )`
            );
          }

          if (typeof asideConfig.callback === "function") {
            /* 执行回调 */
            asideConfig.callback(
              event,
              that.sectionContainerHeaderULElement,
              that.sectionContainerULElement
            );
          }
        });
      },
    };

    HandleContetDetails.init();

    PopsHandler.handlePush(PopsType, {
      guid: guid,
      animElement: animElement,
      popsElement: popsElement,
      maskElement: maskElement,
      $shadowContainer: $shadowContainer,
      $shadowRoot: $shadowRoot,
    });
    /* 拖拽 */
    if (config.drag) {
      PopsUtils.drag(popsElement, {
        dragElement: titleElement,
        limit: config.dragLimit,
        extraDistance: config.dragExtraDistance,
        moveCallBack: config.dragMoveCallBack,
        endCallBack: config.dragEndCallBack,
      });
    }
    return PopsHandler.handleResultDetails(eventDetails);
  };

  /**
   * 右键菜单
   * @param { PopsRightClickMenuDetails } details 配置
   */
  pops.rightClickMenu = function (details = {}) {
    let that = this;
    const { $shadowContainer, $shadowRoot } = PopsHandler.handlerShadow();
    PopsHandler.handleInit($shadowRoot, [
      pops.config.cssText.index,
      pops.config.cssText.anim,
      pops.config.cssText.common,
    ]);
    /**
     * @type {PopsRightClickMenuDetails}
     */
    let config = {
      target: document.documentElement,
      targetSelector: void 0,
      data: [
        {
          icon: pops.config.iconSVG.search,
          iconIsLoading: false,
          text: "搜索",
          callback(clickEvent, contextMenuEvent, liElement) {
            console.log("点击:" + this.text, [
              clickEvent,
              contextMenuEvent,
              liElement,
            ]);
          },
        },
        {
          icon: pops.config.iconSVG.documentCopy,
          iconIsLoading: false,
          text: "复制",
          callback(clickEvent, contextMenuEvent, liElement) {
            console.log("点击:" + this.text, [
              clickEvent,
              contextMenuEvent,
              liElement,
            ]);
          },
        },
        {
          icon: pops.config.iconSVG.delete,
          text: "删除",
          iconIsLoading: false,
          callback(clickEvent, contextMenuEvent, liElement) {
            console.log("点击:" + this.text, [
              clickEvent,
              contextMenuEvent,
              liElement,
            ]);
          },
        },
        {
          icon: pops.config.iconSVG.loading,
          iconIsLoading: true,
          text: "加载",
          callback(clickEvent, contextMenuEvent, liElement) {
            console.log("点击:" + this.text, [
              clickEvent,
              contextMenuEvent,
              liElement,
            ]);
            return false;
          },
        },
        {
          icon: pops.config.iconSVG.elemePlus,
          iconIsLoading: true,
          text: "饿了么",
          callback(clickEvent, contextMenuEvent, liElement) {
            console.log("点击:" + this.text, [
              clickEvent,
              contextMenuEvent,
              liElement,
            ]);
            return false;
          },
          item: [
            {
              icon: "",
              iconIsLoading: false,
              text: "处理文件",
              callback(clickEvent, contextMenuEvent, liElement) {
                console.log("点击:" + this.text, [
                  clickEvent,
                  contextMenuEvent,
                  liElement,
                ]);
              },
            },
            {
              icon: "",
              iconIsLoading: false,
              text: "其它处理",
              callback(clickEvent, contextMenuEvent, liElement) {
                console.log("点击:" + this.text, [
                  clickEvent,
                  contextMenuEvent,
                  liElement,
                ]);
              },
              item: [
                {
                  icon: pops.config.iconSVG.view,
                  iconIsLoading: false,
                  text: "查看",
                  callback(clickEvent, contextMenuEvent, liElement) {
                    console.log("点击:" + this.text, [
                      clickEvent,
                      contextMenuEvent,
                      liElement,
                    ]);
                  },
                },
              ],
            },
          ],
        },
      ],
      className: "",
      isAnimation: true,
      only: false,
      zIndex: 10000,
      preventDefault: true,
      style: void 0,
      beforeAppendToPageCallBack() {},
    };
    config = PopsUtils.assignJSON(config, details);
    if (config.target == null) {
      throw "config.target 不能为空";
    }
    if (details.data) {
      config.data = details.data;
    }
    let guid = PopsUtils.getRandomGUID();
    const PopsType = "rightClickMenu";
    config = PopsHandler.handleOnly(PopsType, config);

    if (config.style != null) {
      let cssNode = document.createElement("style");
      cssNode.setAttribute("type", "text/css");
      cssNode.innerHTML = config.style;
      $shadowRoot.appendChild(cssNode);
    }

    const PopsContextMenu = {
      /**
       * 根元素
       * @type {?HTMLElement}
       */
      rootElement: null,
      /**
       * 全局点击检测
       * @param {TouchEvent|PointerEvent} event
       */
      windowCheckClickEvent(event) {
        if (!PopsContextMenu.rootElement) {
          return;
        }
        if (event.target.closest(`.pops-${PopsType}`)) {
          return;
        }
        if (
          event.target.className &&
          event.target.className === "pops-shadow-container" &&
          event.target.shadowRoot != null
        ) {
          return;
        }
        PopsContextMenu.closeAllMenu(PopsContextMenu.rootElement);
      },
      /**
       * target为shadowRoot或shadowRoot内的全局点击检测
       * @param {TouchEvent|PointerEvent} event
       */
      shadowRootCheckClickEvent(event) {
        if (!PopsContextMenu.rootElement) {
          return;
        }
        if (event.target.closest(`.pops-${PopsType}`)) {
          return;
        }
        PopsContextMenu.closeAllMenu(PopsContextMenu.rootElement);
      },
      /**
       * 添加全局点击检测事件
       */
      addWindowCheckClickListener() {
        PopsDOMUtils.on(
          globalThis,
          "click touchstart",
          void 0,
          PopsContextMenu.windowCheckClickEvent,
          {
            capture: true,
          }
        );
        const $shadowRoot = config.target.getRootNode();
        if ($shadowRoot instanceof ShadowRoot) {
          PopsDOMUtils.on(
            $shadowRoot,
            "click touchstart",
            void 0,
            PopsContextMenu.shadowRootCheckClickEvent,
            {
              capture: true,
            }
          );
        }
      },
      /**
       * 移除全局点击检测事件
       */
      removeWindowCheckClickListener() {
        PopsDOMUtils.off(
          globalThis,
          "click touchstart",
          void 0,
          PopsContextMenu.windowCheckClickEvent,
          {
            capture: true,
          }
        );
        const $shadowRoot = config.target.getRootNode();
        if ($shadowRoot instanceof ShadowRoot) {
          PopsDOMUtils.off(
            $shadowRoot,
            "click touchstart",
            void 0,
            PopsContextMenu.windowCheckClickEvent,
            {
              capture: true,
            }
          );
        }
      },
      /**
       * contextmenu事件
       * @param {PointerEvent} event
       */
      contextMenuEvent(event) {
        if (config.preventDefault) {
          PopsUtils.preventEvent(event);
        }
        if (PopsContextMenu.rootElement) {
          PopsContextMenu.closeAllMenu(PopsContextMenu.rootElement);
        }
        PopsContextMenu.rootElement = PopsContextMenu.showMenu(
          event,
          config.data
        );
      },
      /**
       * 添加contextmenu事件
       * @param {HTMLElement|globalThis|Window} target 目标
       * @param {?string} selector 子元素选择器
       */
      addContextMenuEvent(target, selector) {
        PopsDOMUtils.on(
          target,
          "contextmenu",
          selector,
          PopsContextMenu.contextMenuEvent
        );
      },
      /**
       * 移除contextmenu事件
       * @param {HTMLElement|globalThis|Window} target 目标
       * @param {?string} selector 子元素选择器
       */
      removeContextMenuEvent(target) {
        PopsDOMUtils.off(
          target,
          "contextmenu",
          string,
          PopsContextMenu.contextMenuEvent
        );
      },
      /**
       * 自动判断是否存在动画,存在动画就执行关闭动画并删除
       * @param {HTMLElement} element
       */
      animationCloseMenu(element) {
        /**
         * 动画结束触发的事件
         */
        function transitionEndEvent(event) {
          PopsDOMUtils.off(
            element,
            PopsDOMUtils.getTransitionEndNameList(),
            void 0,
            transitionEndEvent,
            {
              capture: true,
            }
          );
          element.remove();
        }
        if (element.classList.contains(`pops-${PopsType}-anim-show`)) {
          /* 有动画 */
          PopsDOMUtils.on(
            element,
            PopsDOMUtils.getTransitionEndNameList(),
            void 0,
            transitionEndEvent,
            {
              capture: true,
            }
          );
          element.classList.remove(`pops-${PopsType}-anim-show`);
        } else {
          /* 无动画 */
          element.remove();
        }
      },
      /**
       * 关闭所有菜单
       * @param {HTMLElement} rootElement
       */
      closeAllMenu(rootElement) {
        if (rootElement?.__menuData__?.root) {
          rootElement = rootElement?.__menuData__?.root;
        }
        /**
         * @type {HTMLElement[]}
         */
        let childMenuList = rootElement.__menuData__.child;
        childMenuList.forEach((childMenuElement) => {
          this.animationCloseMenu(childMenuElement);
        });
        this.animationCloseMenu(rootElement);
        PopsContextMenu.rootElement = null;
      },
      /**
       * 获取菜单容器
       * @param {number} zIndex z-index值
       * @param {boolean} isChildren 是否是rightClickMenu的某一项的子菜单
       */
      getMenuContainerElement(zIndex, isChildren) {
        let menuElement = PopsUtils.parseTextToDOM(`
        <div class="pops-${PopsType}" ${isChildren ? 'is-children="true"' : ""}>
          <style type="text/css" data-from="pops-${PopsType}">
          .pops-${PopsType} *{
            -webkit-box-sizing: border-box;
            box-sizing: border-box;
            margin: 0;
            padding: 0;
            -webkit-tap-highlight-color: transparent;
            scrollbar-width: thin;
          }
          .pops-${PopsType}{
            position: fixed;
            z-index: ${zIndex};
            text-align: center;
            border-radius: 3px;
            font-size: 16px;
            font-weight: 500;
            background: #fff;
            box-shadow: 0px 1px 6px 1px #cacaca;
          }
          .pops-${PopsType}-anim-grid{
            display: grid;
            transition: 0.3s;
            grid-template-rows: 0fr;
          }
          .pops-${PopsType}-anim-show{
            grid-template-rows: 1fr;
          }
          .pops-${PopsType}-is-visited{
            background: #dfdfdf;
          }
          i.pops-${PopsType}-icon {
            height: 1em;
            width: 1em;
            line-height: 1em;
            display: inline-flex;
            justify-content: center;
            align-items: center;
            position: relative;
            fill: currentColor;
            color: inherit;
            font-size: inherit;
            margin-right: 6px;
          }
          i.pops-${PopsType}-icon[is-loading="true"]{
            animation: rotating 2s linear infinite;
          }
          .pops-${PopsType} li:hover{background:#dfdfdf;cursor:pointer}
          .pops-${PopsType} ul{
            margin: 0;
            padding: 0;
            display: flex;
            flex-direction: column;
            align-items: flex-start;
            justify-content: center;
            overflow: hidden;
          }
          .pops-${PopsType} ul li {
            padding: 5px 10px;
            margin: 2.5px 5px;
            border-radius: 3px;
            display: flex;
            width: -webkit-fill-available;
            width: -moz-available;
            text-align: left;
            user-select: none;
            -webkit-user-select: none;
            -moz-user-select: none;
            -ms-user-select: none;
            align-items: center;
          }
          .pops-${PopsType} ul li:first-child{
            margin-top: 5px;
          }
          .pops-${PopsType} ul li:last-child{
            margin-bottom: 5px;
          }
          </style>
          <ul></ul>
        </div>
        `);
        /* 添加动画 */
        if (config.isAnimation) {
          PopsDOMUtils.addClassName(menuElement, `pops-${PopsType}-anim-grid`);
        }
        return menuElement;
      },
      /**
       * 获取left、top偏移
       * @param {HTMLElement} menuElement 菜单元素
       * @param {number} x
       * @param {number} y
       */
      getOffset(menuElement, x, y) {
        /* left最大偏移 */
        let maxLeftOffset =
          PopsDOMUtils.width(globalThis) - PopsDOMUtils.width(menuElement) - 1;
        /* top最大偏移 */
        let maxTopOffset =
          PopsDOMUtils.height(globalThis) -
          PopsDOMUtils.height(menuElement) -
          8;

        let currentLeftOffset = x;
        let currentTopOffset = y;
        /* 不允许超出left最大值 */
        currentLeftOffset = currentLeftOffset < 0 ? 0 : currentLeftOffset;
        currentLeftOffset =
          currentLeftOffset < maxLeftOffset ? currentLeftOffset : maxLeftOffset;
        /* 不允许超出top最大值 */
        currentTopOffset = currentTopOffset < 0 ? 0 : currentTopOffset;
        currentTopOffset =
          currentTopOffset < maxTopOffset ? currentTopOffset : maxTopOffset;
        return {
          left: currentLeftOffset,
          top: currentTopOffset,
        };
      },
      /**
       * 显示菜单
       * @param {PointerEvent} menuEvent 触发的事件
       * @param {PopsRightClickMenuDataDetails[]} _config_
       */
      showMenu(menuEvent, _config_) {
        let menuElement = this.getMenuContainerElement(config.zIndex, false);
        menuElement.__menuData__ = {
          child: [],
        };
        PopsContextMenu.addMenuLiELement(
          menuEvent,
          menuElement,
          menuElement,
          _config_
        );
        /* 先隐藏 */
        PopsDOMUtils.css(menuElement, {
          display: "none",
        });
        PopsUtils.appendChild($shadowRoot, menuElement);
        /* 添加到页面 */
        if (!document.contains($shadowContainer)) {
          if (typeof config.beforeAppendToPageCallBack === "function") {
            config.beforeAppendToPageCallBack($shadowRoot, $shadowContainer);
          }
          PopsUtils.appendChild($shadowContainer);
        }
        let { left: menuLeftOffset, top: menuTopOffset } = this.getOffset(
          menuElement,
          menuEvent.clientX,
          menuEvent.clientY
        );
        PopsDOMUtils.css(menuElement, {
          left: menuLeftOffset,
          top: menuTopOffset,
          display: "",
        });
        /* 过渡动画 */
        if (config.isAnimation) {
          PopsDOMUtils.addClassName(menuElement, `pops-${PopsType}-anim-show`);
        }
        return menuElement;
      },
      /**
       * 显示子菜单
       * @param {Event} menuEvent 事件
       * @param {{
       * clientX: number,
       * clientY: number
       * }} posInfo 位置信息
       * @param {PopsRightClickMenuDataDetails[]} _config_
       * @param {?HTMLDivElement} rootElement 根菜单元素
       * @param {?HTMLLIElement} targetLiElement 父li项元素
       */
      showClildMenu(
        menuEvent,
        posInfo,
        _config_,
        rootElement,
        targetLiElement
      ) {
        let menuElement = this.getMenuContainerElement(config.zIndex, true);
        menuElement.__menuData__ = {
          parent: targetLiElement,
          root: rootElement,
        };
        rootElement.__menuData__.child.push(menuElement);
        PopsContextMenu.addMenuLiELement(
          menuEvent,
          rootElement,
          menuElement,
          _config_
        );
        /* 先隐藏 */
        PopsDOMUtils.css(menuElement, {
          display: "none",
        });
        /* 添加到页面 */
        PopsUtils.appendChild($shadowRoot, menuElement);
        let { left: menuLeftOffset, top: menuTopOffset } = this.getOffset(
          menuElement,
          posInfo.clientX,
          posInfo.clientY
        );
        PopsDOMUtils.css(menuElement, {
          left: menuLeftOffset,
          top: menuTopOffset,
          display: "",
        });
        /* 过渡动画 */
        if (config.isAnimation) {
          PopsDOMUtils.addClassName(menuElement, `pops-${PopsType}-anim-show`);
        }
        return menuElement;
      },
      /**
       * 获取菜单项的元素
       * @param {PointerEvent} menuEvent 事件
       * @param {HTMLElement} rootElement 根元素
       * @param {HTMLDivElement} menuElement 菜单元素
       * @param {PopsRightClickMenuDataDetails[]} _config_ 配置
       */
      addMenuLiELement(menuEvent, rootElement, menuElement, _config_) {
        let menuEventTarget = menuEvent.target;
        let menuULElement = menuElement.querySelector("ul");
        _config_.forEach((item) => {
          /**
           * @type {HTMLLIElement}
           */
          let menuLiElement = PopsUtils.parseTextToDOM(`
          <li></li>
          `);
          /* 判断有无图标,有就添加进去 */
          if (typeof item.icon === "string" && item.icon.trim() !== "") {
            let iconSVGHTML = pops.config.iconSVG[item.icon] ?? item.icon;
            let iconElement = PopsUtils.parseTextToDOM(
              `<i class="pops-${PopsType}-icon" is-loading="${item.iconIsLoading}">${iconSVGHTML}</i>`
            );
            menuLiElement.appendChild(iconElement);
          }
          /* 插入文字 */
          menuLiElement.insertAdjacentHTML(
            "beforeend",
            `<span>${item.text}</span>`
          );
          /* 如果存在子数据,显示 */
          if (item.item && Array.isArray(item.item)) {
            PopsDOMUtils.addClassName(menuLiElement, `pops-${PopsType}-item`);
          }
          /* 鼠标|触摸 移入事件 */
          function liElementHoverEvent() {
            Array.from(menuULElement.children).forEach((liElement) => {
              PopsDOMUtils.removeClassName(
                liElement,
                `pops-${PopsType}-is-visited`
              );
              if (!liElement.__menuData__) {
                return;
              }
              function removeElement(element) {
                element.querySelectorAll("ul li").forEach((ele) => {
                  if (ele?.__menuData__?.child) {
                    removeElement(ele.__menuData__.child);
                  }
                });
                element.remove();
              }
              /* 遍历根元素的上的__menuData__.child,判断 */
              removeElement(liElement.__menuData__.child);
            });
            /* 清理根元素上的children不存在于页面中的元素 */
            for (
              let index = 0;
              index < rootElement.__menuData__.child.length;
              index++
            ) {
              let element = rootElement.__menuData__.child[index];
              if (!$shadowRoot.contains(element)) {
                rootElement.__menuData__.child.splice(index, 1);
                index--;
              }
            }
            PopsDOMUtils.addClassName(
              menuLiElement,
              `pops-${PopsType}-is-visited`
            );
            if (!item.item) {
              return;
            }
            let rect = menuLiElement.getBoundingClientRect();
            let childMenu = PopsContextMenu.showClildMenu(
              menuEvent,
              {
                clientX: rect.left + PopsDOMUtils.outerWidth(menuLiElement),
                clientY: rect.top,
              },
              item.item,
              rootElement,
              menuLiElement
            );
            menuLiElement.__menuData__ = {
              child: childMenu,
            };
          }
          /**
           * 点击事件
           * @param {PointerEvent} clickEvent
           * @returns
           */
          async function liElementClickEvent(clickEvent) {
            if (typeof item.callback === "function") {
              OriginPrototype.Object.defineProperty(menuEvent, "target", {
                get() {
                  return menuEventTarget;
                },
              });
              let callbackResult = await item.callback(
                clickEvent,
                menuEvent,
                menuLiElement
              );
              if (
                typeof callbackResult === "boolean" &&
                callbackResult == false
              ) {
                return;
              }
            }
            /* 取消绑定的鼠标/触摸事件,防止关闭的时候再次触发 */
            Array.from(menuULElement.children).forEach((liEle) => {
              PopsDOMUtils.off(liEle, "mouseenter touchstart");
            });
            PopsContextMenu.closeAllMenu(rootElement);
          }
          PopsDOMUtils.on(
            menuLiElement,
            "mouseenter touchstart",
            void 0,
            liElementHoverEvent
          );
          /* 项-点击事件 */
          PopsDOMUtils.on(menuLiElement, "click", void 0, liElementClickEvent);

          menuULElement.appendChild(menuLiElement);
        });
      },
    };

    PopsContextMenu.addContextMenuEvent(
      config.target,
      config.targetSelector,
      config.preventDefault
    );
    PopsContextMenu.addWindowCheckClickListener();

    return {
      guid: guid,
      config: config,
      removeWindowCheckClickListener:
        PopsContextMenu.removeWindowCheckClickListener,
      addWindowCheckClickListener: PopsContextMenu.addWindowCheckClickListener,
      removeContextMenuEvent: PopsContextMenu.removeContextMenuEvent,
      addContextMenuEvent: PopsContextMenu.addContextMenuEvent,
    };
  };

  /**
   * 搜索建议悬浮窗
   * @param {PopsSearchSuggestionDetails} details
   */
  pops.searchSuggestion = function (details) {
    const { $shadowContainer, $shadowRoot } = PopsHandler.handlerShadow();
    PopsHandler.handleInit($shadowRoot, [
      pops.config.cssText.index,
      pops.config.cssText.anim,
      pops.config.cssText.common,
    ]);
    /** @type {PopsSearchSuggestionDetails} */
    let config = {
      target: null,
      inputTarget: null,
      selfDocument: document,
      data: [
        {
          value: "数据1",
          text: "数据1-html",
        },
        {
          value: "数据2",
          text: "数据2-html",
        },
      ],
      deleteIcon: {
        enable: true,
        callback(event, liElement, data) {
          console.log("删除当前项", [event, liElement, data]);
          liElement.remove();
        },
      },
      className: "",
      isAbsolute: true,
      isAnimation: true,
      width: "250px",
      maxHeight: "300px",
      followTargetWidth: true,
      topDistance: 0,
      zIndex: 10000,
      searchingTip: "正在搜索中...",
      toSearhNotResultHTML: '<li data-none="true">暂无其它数据</li>',
      getItemHTML(item) {
        return item.text ?? item;
      },
      async getData(value) {
        console.log("当前输入框的值是:", value);
        return [];
      },
      itemClickCallBack(event, liElement, data) {
        console.log("item项的点击回调", [event, liElement, data]);
        this.inputTarget.value = data.value;
      },
      style: void 0,
    };
    config = PopsUtils.assignJSON(config, details);
    if (config.target == null) {
      throw new TypeError("config.target 不能为空");
    }
    /* 做下兼容处理 */
    if (config.inputTarget == null) {
      config.inputTarget = config.target;
    }
    if (details.data) {
      config.data = details.data;
    }
    const guid = PopsUtils.getRandomGUID();
    const PopsType = "searchSuggestion";

    if (config.style != null) {
      let cssNode = document.createElement("style");
      cssNode.setAttribute("type", "text/css");
      cssNode.innerHTML = config.style;
      $shadowRoot.appendChild(cssNode);
    }

    const SearchSuggestion = {
      /**
       * 当前的环境,可以是document,可以是shadowroot,默认是document
       */
      selfDocument: config.selfDocument,
      /**
       * 根元素
       * @type {HTMLElement}
       */
      root: null,
      /**
       * ul元素
       * @type {HTMLUListElement}
       */
      hintULElement: null,
      /**
       * 初始化
       */
      init(parentElement = document.body || document.documentElement) {
        this.root = this.getSearchSelectElement();
        this.hintULElement = this.root.querySelector("ul");
        this.update(config.data);
        this.changeHintULElementWidth();
        this.changeHintULElementPosition();

        this.hide();
        if (config.isAnimation) {
          this.root.classList.add(`pops-${PopsType}-animation`);
        }
        $shadowRoot.appendChild(this.root);
        parentElement.appendChild($shadowContainer);
      },
      /**
       * 获取显示出搜索建议框的html
       */
      getSearchSelectElement() {
        let element = PopsDOMUtils.createElement(
          "div",
          {
            className: `pops pops-${PopsType}-search-suggestion`,
            innerHTML: `
            <style>
            .pops-${PopsType}-animation{
              -moz-animation: searchSelectFalIn 0.5s 1 linear;
              -webkit-animation: searchSelectFalIn 0.5s 1 linear;
              -o-animation: searchSelectFalIn 0.5s 1 linear;
              -ms-animation: searchSelectFalIn 0.5s 1 linear;
            }
            .pops-${PopsType}-search-suggestion{
              position: ${config.isAbsolute ? "absolute" : "fixed"};
              z-index: ${config.zIndex};
              top: 0;
              bottom: 0;
              left: 0;
              right: 0;
              height: 0;
              border: initial;
              overflow: initial;
            }
            ul.pops-${PopsType}-search-suggestion-hint{
              width: 0;
              left: 0;
              max-height: ${config.maxHeight};
              overflow-x: hidden;
              overflow-y: auto;
              padding: 5px 0;
              background-color: #fff;
              box-sizing: border-box;
              border-radius: 4px;
              box-shadow: 0 1px 6px rgb(0 0 0 / 20%);
              position: absolute;
            }
            ul.pops-${PopsType}-search-suggestion-hint li{
              padding: 7px;
              margin: 0;
              clear: both;
              color: #515a6e;
              font-size: 14px;
              list-style: none;
              cursor: pointer;
              transition: background .2s ease-in-out;
              overflow: hidden;
              text-overflow: ellipsis;
            }
            ul.pops-${PopsType}-search-suggestion-hint li[data-none]{
              text-align: center;
              font-size: 12px;
              color: #8e8e8e;
            }
            ul.pops-${PopsType}-search-suggestion-hint li:hover{
              background-color: rgba(0, 0, 0, .1);
            }            
            </style>
            <ul class="pops-${PopsType}-search-suggestion-hint">
                ${config.toSearhNotResultHTML}
            </ul>
          `,
          },
          {
            "data-guid": guid,
            "type-value": PopsType,
          }
        );
        if (config.className !== "" && config.className != null) {
          PopsDOMUtils.addClassName(element, config.className);
        }
        return element;
      },
      /**
       * 获取显示出搜索建议框的每一项的html
       * @param {PopsSearchSuggestionData} item 当前项的值
       * @param {number} index 当前项的下标
       */
      getSearchItemLiElement(item, index) {
        return PopsDOMUtils.createElement("li", {
          className: `pops-${PopsType}-search-suggestion-hint-item pops-flex-items-center pops-flex-y-center`,
          "data-index": index,
          "data-value": this.getItemDataValue(item),
          innerHTML: `
          ${config.getItemHTML(item)}
          ${config.deleteIcon.enable ? this.getDeleteIconHTML() : ""}
          `,
        });
      },
      /**
       * 获取data-value值
       * @param {PopsSearchSuggestionData} item
       */
      getItemDataValue(item) {
        return item;
      },
      /**
       * 设置搜索建议框每一项的点击事件
       * @param {HTMLLIElement} liElement
       */
      setSearchItemClickEvent(liElement) {
        PopsDOMUtils.on(
          liElement,
          "click",
          void 0,
          (event) => {
            PopsUtils.preventEvent(event);
            if (event.target.closest(`.pops-${PopsType}-delete-icon`)) {
              /* 点击的是删除按钮 */
              config.deleteIcon.callback(
                event,
                liElement,
                liElement["data-value"]
              );
              if (!this.hintULElement.children.length) {
                /* 全删完了 */
                this.clear();
              }
            } else {
              /* 点击项主体 */
              config.itemClickCallBack(
                event,
                liElement,
                liElement["data-value"]
              );
            }
          },
          {
            capture: true,
          }
        );
      },
      /**
       * 监听输入框内容改变
       */
      setInputChangeEvent() {
        /* 是input输入框 */
        /* 禁用输入框自动提示 */
        config.inputTarget.setAttribute("autocomplete", "off");
        /* 内容改变事件 */
        PopsDOMUtils.on(
          config.inputTarget,
          "input",
          void 0,
          async (event) => {
            let getListResult = await config.getData(event.target.value);
            this.update(getListResult);
          },
          {
            capture: true,
          }
        );
      },
      /**
       * 移除输入框内容改变的监听
       */
      removeInputChangeEvent() {
        PopsDOMUtils.off(config.inputTarget, "input", void 0, void 0, {
          capture: true,
        });
      },
      /**
       * 显示搜索建议框的事件
       */
      showEvent() {
        SearchSuggestion.changeHintULElementPosition();
        SearchSuggestion.changeHintULElementWidth();
        SearchSuggestion.show();
      },
      /**
       * 设置显示搜索建议框的事件
       */
      setShowEvent() {
        /* 焦点|点击事件*/
        PopsDOMUtils.on(
          [config.target, config.inputTarget],
          ["focus", "click"],
          void 0,
          this.showEvent,
          {
            capture: true,
          }
        );
      },
      /**
       * 移除显示搜索建议框的事件
       */
      removeShowEvent() {
        /* 焦点|点击事件*/
        PopsDOMUtils.off(
          [config.target, config.inputTarget],
          ["focus", "click"],
          void 0,
          this.showEvent,
          {
            capture: true,
          }
        );
      },
      /**
       * 隐藏搜索建议框的事件
       * @param {PointerEvent|MouseEvent} event
       */
      hideEvent(event) {
        if (event.target instanceof Node) {
          if ($shadowContainer.contains(event.target)) {
            /* 点击在shadow上的 */
            return;
          }
          if (config.target.contains(event.target)) {
            /* 点击在目标元素内 */
            return;
          }
          if (config.inputTarget.contains(event.target)) {
            /* 点击在目标input内 */
            return;
          }
          SearchSuggestion.hide();
        }
      },
      /**
       * 设置隐藏搜索建议框的事件
       */
      setHideEvent() {
        /* 全局点击事件 */
        /* 全局触摸屏点击事件 */
        PopsDOMUtils.on(
          SearchSuggestion.selfDocument,
          ["click", "touchstart"],
          void 0,
          this.hideEvent,
          {
            capture: true,
          }
        );
      },
      /**
       * 移除隐藏搜索建议框的事件
       */
      removeHideEvent() {
        PopsDOMUtils.off(
          SearchSuggestion.selfDocument,
          ["click", "touchstart"],
          void 0,
          this.hideEvent,
          {
            capture: true,
          }
        );
      },
      /**
       * 设置所有监听
       */
      setAllEvent() {
        this.setInputChangeEvent();
        this.setHideEvent();
        this.setShowEvent();
      },
      /**
       * 移除所有监听
       */
      removeAllEvent() {
        this.removeInputChangeEvent();
        this.removeHideEvent();
        this.removeShowEvent();
      },
      /**
       * 获取删除按钮的html
       */
      getDeleteIconHTML(size = 16, fill = "#bababa") {
        return `
        <svg class="pops-${PopsType}-delete-icon" viewBox="0 0 1024 1024" xmlns="http://www.w3.org/2000/svg" width="${size}" height="${size}" fill="${fill}">
          <path d="M512 883.2A371.2 371.2 0 1 0 140.8 512 371.2 371.2 0 0 0 512 883.2z m0 64a435.2 435.2 0 1 1 435.2-435.2 435.2 435.2 0 0 1-435.2 435.2z"></path>
          <path d="M557.056 512l122.368 122.368a31.744 31.744 0 1 1-45.056 45.056L512 557.056l-122.368 122.368a31.744 31.744 0 1 1-45.056-45.056L466.944 512 344.576 389.632a31.744 31.744 0 1 1 45.056-45.056L512 466.944l122.368-122.368a31.744 31.744 0 1 1 45.056 45.056z"></path>
        </svg>
        `;
      },
      /**
       * 设置当前正在搜索中的提示
       */
      setPromptsInSearch() {
        let isSearchingElement = PopsDOMUtils.createElement("li", {
          className: `pops-${PopsType}-search-suggestion-hint-searching-item`,
          innerHTML: config.searchingTip,
        });
        SearchSuggestion.hintULElement.appendChild(isSearchingElement);
      },
      /**
       * 移除正在搜索中的提示
       */
      removePromptsInSearch() {
        SearchSuggestion.hintULElement
          .querySelector(
            `li.pops-${PopsType}-search-suggestion-hint-searching-item`
          )
          ?.remove();
      },
      /**
       * 清空所有的搜索结果
       */
      clearAllSearchItemLi() {
        SearchSuggestion.hintULElement.innerHTML = "";
      },
      /**
       * 修改搜索建议框的位置(top、left)
       * 因为目标元素可能是动态隐藏的
       */
      changeHintULElementPosition(
        target = config.target ?? config.inputTarget
      ) {
        let targetRect = config.isAbsolute
          ? PopsDOMUtils.offset(target)
          : target.getBoundingClientRect();

        SearchSuggestion.hintULElement.style.top =
          targetRect.height + targetRect.top + config.topDistance + "px";
        SearchSuggestion.hintULElement.style.left = targetRect.left + "px";
      },
      /**
       * 修改搜索建议框的width
       * 因为目标元素可能是动态隐藏的
       */
      changeHintULElementWidth(target = config.target ?? config.inputTarget) {
        let targetRect = target.getBoundingClientRect();
        if (config.followTargetWidth) {
          SearchSuggestion.hintULElement.style.width = targetRect.width + "px";
        } else {
          SearchSuggestion.hintULElement.style.width = config.width;
        }
      },
      /**
       * 更新页面显示的搜索结果
       * @param {PopsSearchSuggestionData[]} data
       */
      update(data = []) {
        if (!Array.isArray(data)) {
          throw new TypeError("传入的数据不是数组");
        }
        config.data = data;
        /* 清空已有的搜索结果 */
        if (config.data.length) {
          this.clearAllSearchItemLi();
          /* 添加进ul中 */
          config.data.forEach((item, index) => {
            let itemElement = this.getSearchItemLiElement(item, index);
            this.setSearchItemClickEvent(itemElement);
            this.hintULElement.appendChild(itemElement);
          });
        } else {
          /* 清空 */
          this.clear();
        }
      },
      /**
       * 清空当前的搜索结果并显示无结果
       */
      clear() {
        this.clearAllSearchItemLi();
        this.hintULElement.appendChild(
          PopsUtils.parseTextToDOM(config.toSearhNotResultHTML)
        );
      },
      /**
       * 隐藏搜索建议框
       */
      hide() {
        this.root.style.display = "none";
      },
      /**
       * 显示搜索建议框
       */
      show() {
        this.root.style.display = "";
      },
    };
    return SearchSuggestion;
  };
  return pops;
});