MediaWiki:Gadget-Toastify.js

MediaWiki系统消息页面
/**
 * SPDX-License-Identifier: MIT
 * _addText: '{{Gadget Header|license=MIT|attribution=2018 apvarun}}'
 *
 * @base {@link https://github.com/apvarun/toastify-js}
 * @source {@link https://git.qiuwen.net.cn/InterfaceAdmin/QiuwenGadgets/src/branch/master/src/Toastify}
 * @license MIT {@link https://github.com/apvarun/toastify-js/blob/master/LICENSE}
 */

/**
 * Copyright (c) 2018 apvarun
 *
 * Permission is hereby granted, free of charge, to any person obtaining
 * a copy of this software and associated documentation files (the
 * "Software"), to deal in the Software without restriction, including
 * without limitation the rights to use, copy, modify, merge, publish,
 * distribute, sublicense, and/or sell copies of the Software, and to
 * permit persons to whom the Software is furnished to do so, subject to
 * the following conditions:
 *
 * The above copyright notice and this permission notice shall be
 * included in all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
 * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
 * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
 * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 */
/**
 * +------------------------------------------------------------+
 * |            === WARNING: GLOBAL GADGET FILE ===             |
 * +------------------------------------------------------------+
 * |       All changes should be made in the repository,        |
 * |                otherwise they will be lost.                |
 * +------------------------------------------------------------+
 * |        Changes to this page may affect many users.         |
 * | Please discuss changes by opening an issue before editing. |
 * +------------------------------------------------------------+
 */
/* <nowiki> */

(() => {

"use strict";

// dist/Toastify/Toastify.js
function _createForOfIteratorHelper(o, allowArrayLike) {
  var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"];
  if (!it) {
    if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") {
      if (it)
        o = it;
      var i = 0;
      var F = function() {
      };
      return { s: F, n: function() {
        if (i >= o.length)
          return { done: true };
        return { done: false, value: o[i++] };
      }, e: function(e) {
        throw e;
      }, f: F };
    }
    throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
  }
  var normalCompletion = true, didErr = false, err;
  return { s: function() {
    it = it.call(o);
  }, n: function() {
    var step = it.next();
    normalCompletion = step.done;
    return step;
  }, e: function(e) {
    didErr = true;
    err = e;
  }, f: function() {
    try {
      if (!normalCompletion && it.return != null)
        it.return();
    } finally {
      if (didErr)
        throw err;
    }
  } };
}
function _unsupportedIterableToArray(o, minLen) {
  if (!o)
    return;
  if (typeof o === "string")
    return _arrayLikeToArray(o, minLen);
  var n = Object.prototype.toString.call(o).slice(8, -1);
  if (n === "Object" && o.constructor)
    n = o.constructor.name;
  if (n === "Map" || n === "Set")
    return Array.from(o);
  if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))
    return _arrayLikeToArray(o, minLen);
}
function _arrayLikeToArray(arr, len) {
  if (len == null || len > arr.length)
    len = arr.length;
  for (var i = 0, arr2 = new Array(len); i < len; i++)
    arr2[i] = arr[i];
  return arr2;
}
var __create = Object.create;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __getProtoOf = Object.getPrototypeOf;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __commonJS = (cb, mod) => function __require() {
  return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = {
    exports: {}
  }).exports, mod), mod.exports;
};
var __export = (target, all) => {
  for (var name in all)
    __defProp(target, name, {
      get: all[name],
      enumerable: true
    });
};
var __copyProps = (to, from, except, desc) => {
  if (from && typeof from === "object" || typeof from === "function") {
    var _iterator = _createForOfIteratorHelper(__getOwnPropNames(from)), _step;
    try {
      for (_iterator.s(); !(_step = _iterator.n()).done; ) {
        let key = _step.value;
        if (!__hasOwnProp.call(to, key) && key !== except)
          __defProp(to, key, {
            get: () => from[key],
            enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
          });
      }
    } catch (err) {
      _iterator.e(err);
    } finally {
      _iterator.f();
    }
  }
  return to;
};
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
  // If the importer is in node compatibility mode or this is not an ESM
  // file that has been converted to a CommonJS file using a Babel-
  // compatible transform (i.e. "__esModule" has not been set), then set
  // "default" to the CommonJS "module.exports" for node compatibility.
  isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
    value: mod,
    enumerable: true
  }) : target,
  mod
));
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", {
  value: true
}), mod);
var require_toastify = __commonJS({
  "node_modules/.pnpm/toastify-js@1.12.0/node_modules/toastify-js/src/toastify.js"(exports2, module2) {
    /*!
     * Toastify js 1.12.0
     * https://github.com/apvarun/toastify-js
     * @license MIT licensed
     *
     * Copyright (C) 2018 Varun A P
     */
    (function(root, factory) {
      if (typeof module2 === "object" && module2.exports) {
        module2.exports = factory();
      } else {
        root.Toastify = factory();
      }
    })(exports2, function(global) {
      var Toastify2 = function(options) {
        return new Toastify2.lib.init(options);
      }, version = "1.12.0";
      Toastify2.defaults = {
        oldestFirst: true,
        text: "Toastify is awesome!",
        node: void 0,
        duration: 3e3,
        selector: void 0,
        callback: function() {
        },
        destination: void 0,
        newWindow: false,
        close: false,
        gravity: "toastify-top",
        positionLeft: false,
        position: "",
        backgroundColor: "",
        avatar: "",
        className: "",
        stopOnFocus: true,
        onClick: function() {
        },
        offset: {
          x: 0,
          y: 0
        },
        escapeMarkup: true,
        ariaLive: "polite",
        style: {
          background: ""
        }
      };
      Toastify2.lib = Toastify2.prototype = {
        toastify: version,
        constructor: Toastify2,
        // Initializing the object with required parameters
        init: function(options) {
          if (!options) {
            options = {};
          }
          this.options = {};
          this.toastElement = null;
          this.options.text = options.text || Toastify2.defaults.text;
          this.options.node = options.node || Toastify2.defaults.node;
          this.options.duration = options.duration === 0 ? 0 : options.duration || Toastify2.defaults.duration;
          this.options.selector = options.selector || Toastify2.defaults.selector;
          this.options.callback = options.callback || Toastify2.defaults.callback;
          this.options.destination = options.destination || Toastify2.defaults.destination;
          this.options.newWindow = options.newWindow || Toastify2.defaults.newWindow;
          this.options.close = options.close || Toastify2.defaults.close;
          this.options.gravity = options.gravity === "bottom" ? "toastify-bottom" : Toastify2.defaults.gravity;
          this.options.positionLeft = options.positionLeft || Toastify2.defaults.positionLeft;
          this.options.position = options.position || Toastify2.defaults.position;
          this.options.backgroundColor = options.backgroundColor || Toastify2.defaults.backgroundColor;
          this.options.avatar = options.avatar || Toastify2.defaults.avatar;
          this.options.className = options.className || Toastify2.defaults.className;
          this.options.stopOnFocus = options.stopOnFocus === void 0 ? Toastify2.defaults.stopOnFocus : options.stopOnFocus;
          this.options.onClick = options.onClick || Toastify2.defaults.onClick;
          this.options.offset = options.offset || Toastify2.defaults.offset;
          this.options.escapeMarkup = options.escapeMarkup !== void 0 ? options.escapeMarkup : Toastify2.defaults.escapeMarkup;
          this.options.ariaLive = options.ariaLive || Toastify2.defaults.ariaLive;
          this.options.style = options.style || Toastify2.defaults.style;
          if (options.backgroundColor) {
            this.options.style.background = options.backgroundColor;
          }
          return this;
        },
        // Building the DOM element
        buildToast: function() {
          if (!this.options) {
            throw "Toastify is not initialized";
          }
          var divElement = document.createElement("div");
          divElement.className = "toastify on " + this.options.className;
          if (!!this.options.position) {
            divElement.className += " toastify-" + this.options.position;
          } else {
            if (this.options.positionLeft === true) {
              divElement.className += " toastify-left";
              console.warn("Property `positionLeft` will be depreciated in further versions. Please use `position` instead.");
            } else {
              divElement.className += " toastify-right";
            }
          }
          divElement.className += " " + this.options.gravity;
          if (this.options.backgroundColor) {
            console.warn('DEPRECATION NOTICE: "backgroundColor" is being deprecated. Please use the "style.background" property.');
          }
          for (var property in this.options.style) {
            divElement.style[property] = this.options.style[property];
          }
          if (this.options.ariaLive) {
            divElement.setAttribute("aria-live", this.options.ariaLive);
          }
          if (this.options.node && this.options.node.nodeType === Node.ELEMENT_NODE) {
            divElement.appendChild(this.options.node);
          } else {
            if (this.options.escapeMarkup) {
              divElement.innerText = this.options.text;
            } else {
              divElement.innerHTML = this.options.text;
            }
            if (this.options.avatar !== "") {
              var avatarElement = document.createElement("img");
              avatarElement.src = this.options.avatar;
              avatarElement.className = "toastify-avatar";
              if (this.options.position == "left" || this.options.positionLeft === true) {
                divElement.appendChild(avatarElement);
              } else {
                divElement.insertAdjacentElement("afterbegin", avatarElement);
              }
            }
          }
          if (this.options.close === true) {
            var closeElement = document.createElement("button");
            closeElement.type = "button";
            closeElement.setAttribute("aria-label", "Close");
            closeElement.className = "toast-close";
            closeElement.innerHTML = "&#10006;";
            closeElement.addEventListener("click", function(event) {
              event.stopPropagation();
              this.removeElement(this.toastElement);
              window.clearTimeout(this.toastElement.timeOutValue);
            }.bind(this));
            var width = window.innerWidth > 0 ? window.innerWidth : screen.width;
            if ((this.options.position == "left" || this.options.positionLeft === true) && width > 360) {
              divElement.insertAdjacentElement("afterbegin", closeElement);
            } else {
              divElement.appendChild(closeElement);
            }
          }
          if (this.options.stopOnFocus && this.options.duration > 0) {
            var self = this;
            divElement.addEventListener("mouseover", function(event) {
              window.clearTimeout(divElement.timeOutValue);
            });
            divElement.addEventListener("mouseleave", function() {
              divElement.timeOutValue = window.setTimeout(function() {
                self.removeElement(divElement);
              }, self.options.duration);
            });
          }
          if (typeof this.options.destination !== "undefined") {
            divElement.addEventListener("click", function(event) {
              event.stopPropagation();
              if (this.options.newWindow === true) {
                window.open(this.options.destination, "_blank");
              } else {
                window.location = this.options.destination;
              }
            }.bind(this));
          }
          if (typeof this.options.onClick === "function" && typeof this.options.destination === "undefined") {
            divElement.addEventListener("click", function(event) {
              event.stopPropagation();
              this.options.onClick();
            }.bind(this));
          }
          if (typeof this.options.offset === "object") {
            var x = getAxisOffsetAValue("x", this.options);
            var y = getAxisOffsetAValue("y", this.options);
            var xOffset = this.options.position == "left" ? x : "-" + x;
            var yOffset = this.options.gravity == "toastify-top" ? y : "-" + y;
            divElement.style.transform = "translate(" + xOffset + "," + yOffset + ")";
          }
          return divElement;
        },
        // Displaying the toast
        showToast: function() {
          this.toastElement = this.buildToast();
          var rootElement;
          if (typeof this.options.selector === "string") {
            rootElement = document.getElementById(this.options.selector);
          } else if (this.options.selector instanceof HTMLElement || typeof ShadowRoot !== "undefined" && this.options.selector instanceof ShadowRoot) {
            rootElement = this.options.selector;
          } else {
            rootElement = document.body;
          }
          if (!rootElement) {
            throw "Root element is not defined";
          }
          var elementToInsert = Toastify2.defaults.oldestFirst ? rootElement.firstChild : rootElement.lastChild;
          rootElement.insertBefore(this.toastElement, elementToInsert);
          Toastify2.reposition();
          if (this.options.duration > 0) {
            this.toastElement.timeOutValue = window.setTimeout(function() {
              this.removeElement(this.toastElement);
            }.bind(this), this.options.duration);
          }
          return this;
        },
        hideToast: function() {
          if (this.toastElement.timeOutValue) {
            clearTimeout(this.toastElement.timeOutValue);
          }
          this.removeElement(this.toastElement);
        },
        // Removing the element from the DOM
        removeElement: function(toastElement) {
          toastElement.className = toastElement.className.replace(" on", "");
          window.setTimeout(function() {
            if (this.options.node && this.options.node.parentNode) {
              this.options.node.parentNode.removeChild(this.options.node);
            }
            if (toastElement.parentNode) {
              toastElement.parentNode.removeChild(toastElement);
            }
            this.options.callback.call(toastElement);
            Toastify2.reposition();
          }.bind(this), 400);
        }
      };
      Toastify2.reposition = function() {
        var topLeftOffsetSize = {
          top: 15,
          bottom: 15
        };
        var topRightOffsetSize = {
          top: 15,
          bottom: 15
        };
        var offsetSize = {
          top: 15,
          bottom: 15
        };
        var allToasts = document.getElementsByClassName("toastify");
        var classUsed;
        for (var i = 0; i < allToasts.length; i++) {
          if (containsClass(allToasts[i], "toastify-top") === true) {
            classUsed = "toastify-top";
          } else {
            classUsed = "toastify-bottom";
          }
          var height = allToasts[i].offsetHeight;
          classUsed = classUsed.substr(9, classUsed.length - 1);
          var offset = 15;
          var width = window.innerWidth > 0 ? window.innerWidth : screen.width;
          if (width <= 360) {
            allToasts[i].style[classUsed] = offsetSize[classUsed] + "px";
            offsetSize[classUsed] += height + offset;
          } else {
            if (containsClass(allToasts[i], "toastify-left") === true) {
              allToasts[i].style[classUsed] = topLeftOffsetSize[classUsed] + "px";
              topLeftOffsetSize[classUsed] += height + offset;
            } else {
              allToasts[i].style[classUsed] = topRightOffsetSize[classUsed] + "px";
              topRightOffsetSize[classUsed] += height + offset;
            }
          }
        }
        return this;
      };
      function getAxisOffsetAValue(axis, options) {
        if (options.offset[axis]) {
          if (isNaN(options.offset[axis])) {
            return options.offset[axis];
          } else {
            return options.offset[axis] + "px";
          }
        }
        return "0px";
      }
      function containsClass(elem, yourClass) {
        if (!elem || typeof yourClass !== "string") {
          return false;
        } else if (elem.className && elem.className.trim().split(/\s+/gi).indexOf(yourClass) > -1) {
          return true;
        } else {
          return false;
        }
      }
      Toastify2.lib.init.prototype = Toastify2.lib;
      return Toastify2;
    });
  }
});
//! src/Toastify/Toastify.ts
var Toastify_exports = {};
__export(Toastify_exports, {
  toastify: () => toastify
});
module.exports = __toCommonJS(Toastify_exports);
var import_toastify_js = __toESM(require_toastify());
var toastify = (options, type) => {
  var _options;
  (_options = options) !== null && _options !== void 0 ? _options : options = {};
  let className = "gadget-toastify";
  if (type) {
    switch (type) {
      case "error":
        className += " ".concat(className, "--error");
        break;
      case "success":
        className += " ".concat(className, "--success");
        break;
      case "warning":
        className += " ".concat(className, "--warning");
        break;
      default:
        className += " ".concat(className, "--info");
    }
  }
  options.className = className;
  if (!options.gravity) {
    options.gravity = "bottom";
  }
  if (!options.position) {
    options.position = "center";
  }
  const instance = (0, import_toastify_js.default)(options);
  instance.showToast();
  return {
    hideToast: instance.hideToast.bind(instance)
  };
};

})();

/* </nowiki> */

//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["node_modules/.pnpm/toastify-js@1.12.0/node_modules/toastify-js/src/toastify.js", "src/Toastify/Toastify.ts"],
  "sourcesContent": ["/*!\n * Toastify js 1.12.0\n * https://github.com/apvarun/toastify-js\n * @license MIT licensed\n *\n * Copyright (C) 2018 Varun A P\n */\n(function(root, factory) {\n  if (typeof module === \"object\" && module.exports) {\n    module.exports = factory();\n  } else {\n    root.Toastify = factory();\n  }\n})(this, function(global) {\n  // Object initialization\n  var Toastify = function(options) {\n      // Returning a new init object\n      return new Toastify.lib.init(options);\n    },\n    // Library version\n    version = \"1.12.0\";\n\n  // Set the default global options\n  Toastify.defaults = {\n    oldestFirst: true,\n    text: \"Toastify is awesome!\",\n    node: undefined,\n    duration: 3000,\n    selector: undefined,\n    callback: function () {\n    },\n    destination: undefined,\n    newWindow: false,\n    close: false,\n    gravity: \"toastify-top\",\n    positionLeft: false,\n    position: '',\n    backgroundColor: '',\n    avatar: \"\",\n    className: \"\",\n    stopOnFocus: true,\n    onClick: function () {\n    },\n    offset: {x: 0, y: 0},\n    escapeMarkup: true,\n    ariaLive: 'polite',\n    style: {background: ''}\n  };\n\n  // Defining the prototype of the object\n  Toastify.lib = Toastify.prototype = {\n    toastify: version,\n\n    constructor: Toastify,\n\n    // Initializing the object with required parameters\n    init: function(options) {\n      // Verifying and validating the input object\n      if (!options) {\n        options = {};\n      }\n\n      // Creating the options object\n      this.options = {};\n\n      this.toastElement = null;\n\n      // Validating the options\n      this.options.text = options.text || Toastify.defaults.text; // Display message\n      this.options.node = options.node || Toastify.defaults.node;  // Display content as node\n      this.options.duration = options.duration === 0 ? 0 : options.duration || Toastify.defaults.duration; // Display duration\n      this.options.selector = options.selector || Toastify.defaults.selector; // Parent selector\n      this.options.callback = options.callback || Toastify.defaults.callback; // Callback after display\n      this.options.destination = options.destination || Toastify.defaults.destination; // On-click destination\n      this.options.newWindow = options.newWindow || Toastify.defaults.newWindow; // Open destination in new window\n      this.options.close = options.close || Toastify.defaults.close; // Show toast close icon\n      this.options.gravity = options.gravity === \"bottom\" ? \"toastify-bottom\" : Toastify.defaults.gravity; // toast position - top or bottom\n      this.options.positionLeft = options.positionLeft || Toastify.defaults.positionLeft; // toast position - left or right\n      this.options.position = options.position || Toastify.defaults.position; // toast position - left or right\n      this.options.backgroundColor = options.backgroundColor || Toastify.defaults.backgroundColor; // toast background color\n      this.options.avatar = options.avatar || Toastify.defaults.avatar; // img element src - url or a path\n      this.options.className = options.className || Toastify.defaults.className; // additional class names for the toast\n      this.options.stopOnFocus = options.stopOnFocus === undefined ? Toastify.defaults.stopOnFocus : options.stopOnFocus; // stop timeout on focus\n      this.options.onClick = options.onClick || Toastify.defaults.onClick; // Callback after click\n      this.options.offset = options.offset || Toastify.defaults.offset; // toast offset\n      this.options.escapeMarkup = options.escapeMarkup !== undefined ? options.escapeMarkup : Toastify.defaults.escapeMarkup;\n      this.options.ariaLive = options.ariaLive || Toastify.defaults.ariaLive;\n      this.options.style = options.style || Toastify.defaults.style;\n      if(options.backgroundColor) {\n        this.options.style.background = options.backgroundColor;\n      }\n\n      // Returning the current object for chaining functions\n      return this;\n    },\n\n    // Building the DOM element\n    buildToast: function() {\n      // Validating if the options are defined\n      if (!this.options) {\n        throw \"Toastify is not initialized\";\n      }\n\n      // Creating the DOM object\n      var divElement = document.createElement(\"div\");\n      divElement.className = \"toastify on \" + this.options.className;\n\n      // Positioning toast to left or right or center\n      if (!!this.options.position) {\n        divElement.className += \" toastify-\" + this.options.position;\n      } else {\n        // To be depreciated in further versions\n        if (this.options.positionLeft === true) {\n          divElement.className += \" toastify-left\";\n          console.warn('Property `positionLeft` will be depreciated in further versions. Please use `position` instead.')\n        } else {\n          // Default position\n          divElement.className += \" toastify-right\";\n        }\n      }\n\n      // Assigning gravity of element\n      divElement.className += \" \" + this.options.gravity;\n\n      if (this.options.backgroundColor) {\n        // This is being deprecated in favor of using the style HTML DOM property\n        console.warn('DEPRECATION NOTICE: \"backgroundColor\" is being deprecated. Please use the \"style.background\" property.');\n      }\n\n      // Loop through our style object and apply styles to divElement\n      for (var property in this.options.style) {\n        divElement.style[property] = this.options.style[property];\n      }\n\n      // Announce the toast to screen readers\n      if (this.options.ariaLive) {\n        divElement.setAttribute('aria-live', this.options.ariaLive)\n      }\n\n      // Adding the toast message/node\n      if (this.options.node && this.options.node.nodeType === Node.ELEMENT_NODE) {\n        // If we have a valid node, we insert it\n        divElement.appendChild(this.options.node)\n      } else {\n        if (this.options.escapeMarkup) {\n          divElement.innerText = this.options.text;\n        } else {\n          divElement.innerHTML = this.options.text;\n        }\n\n        if (this.options.avatar !== \"\") {\n          var avatarElement = document.createElement(\"img\");\n          avatarElement.src = this.options.avatar;\n\n          avatarElement.className = \"toastify-avatar\";\n\n          if (this.options.position == \"left\" || this.options.positionLeft === true) {\n            // Adding close icon on the left of content\n            divElement.appendChild(avatarElement);\n          } else {\n            // Adding close icon on the right of content\n            divElement.insertAdjacentElement(\"afterbegin\", avatarElement);\n          }\n        }\n      }\n\n      // Adding a close icon to the toast\n      if (this.options.close === true) {\n        // Create a span for close element\n        var closeElement = document.createElement(\"button\");\n        closeElement.type = \"button\";\n        closeElement.setAttribute(\"aria-label\", \"Close\");\n        closeElement.className = \"toast-close\";\n        closeElement.innerHTML = \"&#10006;\";\n\n        // Triggering the removal of toast from DOM on close click\n        closeElement.addEventListener(\n          \"click\",\n          function(event) {\n            event.stopPropagation();\n            this.removeElement(this.toastElement);\n            window.clearTimeout(this.toastElement.timeOutValue);\n          }.bind(this)\n        );\n\n        //Calculating screen width\n        var width = window.innerWidth > 0 ? window.innerWidth : screen.width;\n\n        // Adding the close icon to the toast element\n        // Display on the right if screen width is less than or equal to 360px\n        if ((this.options.position == \"left\" || this.options.positionLeft === true) && width > 360) {\n          // Adding close icon on the left of content\n          divElement.insertAdjacentElement(\"afterbegin\", closeElement);\n        } else {\n          // Adding close icon on the right of content\n          divElement.appendChild(closeElement);\n        }\n      }\n\n      // Clear timeout while toast is focused\n      if (this.options.stopOnFocus && this.options.duration > 0) {\n        var self = this;\n        // stop countdown\n        divElement.addEventListener(\n          \"mouseover\",\n          function(event) {\n            window.clearTimeout(divElement.timeOutValue);\n          }\n        )\n        // add back the timeout\n        divElement.addEventListener(\n          \"mouseleave\",\n          function() {\n            divElement.timeOutValue = window.setTimeout(\n              function() {\n                // Remove the toast from DOM\n                self.removeElement(divElement);\n              },\n              self.options.duration\n            )\n          }\n        )\n      }\n\n      // Adding an on-click destination path\n      if (typeof this.options.destination !== \"undefined\") {\n        divElement.addEventListener(\n          \"click\",\n          function(event) {\n            event.stopPropagation();\n            if (this.options.newWindow === true) {\n              window.open(this.options.destination, \"_blank\");\n            } else {\n              window.location = this.options.destination;\n            }\n          }.bind(this)\n        );\n      }\n\n      if (typeof this.options.onClick === \"function\" && typeof this.options.destination === \"undefined\") {\n        divElement.addEventListener(\n          \"click\",\n          function(event) {\n            event.stopPropagation();\n            this.options.onClick();\n          }.bind(this)\n        );\n      }\n\n      // Adding offset\n      if(typeof this.options.offset === \"object\") {\n\n        var x = getAxisOffsetAValue(\"x\", this.options);\n        var y = getAxisOffsetAValue(\"y\", this.options);\n\n        var xOffset = this.options.position == \"left\" ? x : \"-\" + x;\n        var yOffset = this.options.gravity == \"toastify-top\" ? y : \"-\" + y;\n\n        divElement.style.transform = \"translate(\" + xOffset + \",\" + yOffset + \")\";\n\n      }\n\n      // Returning the generated element\n      return divElement;\n    },\n\n    // Displaying the toast\n    showToast: function() {\n      // Creating the DOM object for the toast\n      this.toastElement = this.buildToast();\n\n      // Getting the root element to with the toast needs to be added\n      var rootElement;\n      if (typeof this.options.selector === \"string\") {\n        rootElement = document.getElementById(this.options.selector);\n      } else if (this.options.selector instanceof HTMLElement || (typeof ShadowRoot !== 'undefined' && this.options.selector instanceof ShadowRoot)) {\n        rootElement = this.options.selector;\n      } else {\n        rootElement = document.body;\n      }\n\n      // Validating if root element is present in DOM\n      if (!rootElement) {\n        throw \"Root element is not defined\";\n      }\n\n      // Adding the DOM element\n      var elementToInsert = Toastify.defaults.oldestFirst ? rootElement.firstChild : rootElement.lastChild;\n      rootElement.insertBefore(this.toastElement, elementToInsert);\n\n      // Repositioning the toasts in case multiple toasts are present\n      Toastify.reposition();\n\n      if (this.options.duration > 0) {\n        this.toastElement.timeOutValue = window.setTimeout(\n          function() {\n            // Remove the toast from DOM\n            this.removeElement(this.toastElement);\n          }.bind(this),\n          this.options.duration\n        ); // Binding `this` for function invocation\n      }\n\n      // Supporting function chaining\n      return this;\n    },\n\n    hideToast: function() {\n      if (this.toastElement.timeOutValue) {\n        clearTimeout(this.toastElement.timeOutValue);\n      }\n      this.removeElement(this.toastElement);\n    },\n\n    // Removing the element from the DOM\n    removeElement: function(toastElement) {\n      // Hiding the element\n      // toastElement.classList.remove(\"on\");\n      toastElement.className = toastElement.className.replace(\" on\", \"\");\n\n      // Removing the element from DOM after transition end\n      window.setTimeout(\n        function() {\n          // remove options node if any\n          if (this.options.node && this.options.node.parentNode) {\n            this.options.node.parentNode.removeChild(this.options.node);\n          }\n\n          // Remove the element from the DOM, only when the parent node was not removed before.\n          if (toastElement.parentNode) {\n            toastElement.parentNode.removeChild(toastElement);\n          }\n\n          // Calling the callback function\n          this.options.callback.call(toastElement);\n\n          // Repositioning the toasts again\n          Toastify.reposition();\n        }.bind(this),\n        400\n      ); // Binding `this` for function invocation\n    },\n  };\n\n  // Positioning the toasts on the DOM\n  Toastify.reposition = function() {\n\n    // Top margins with gravity\n    var topLeftOffsetSize = {\n      top: 15,\n      bottom: 15,\n    };\n    var topRightOffsetSize = {\n      top: 15,\n      bottom: 15,\n    };\n    var offsetSize = {\n      top: 15,\n      bottom: 15,\n    };\n\n    // Get all toast messages on the DOM\n    var allToasts = document.getElementsByClassName(\"toastify\");\n\n    var classUsed;\n\n    // Modifying the position of each toast element\n    for (var i = 0; i < allToasts.length; i++) {\n      // Getting the applied gravity\n      if (containsClass(allToasts[i], \"toastify-top\") === true) {\n        classUsed = \"toastify-top\";\n      } else {\n        classUsed = \"toastify-bottom\";\n      }\n\n      var height = allToasts[i].offsetHeight;\n      classUsed = classUsed.substr(9, classUsed.length-1)\n      // Spacing between toasts\n      var offset = 15;\n\n      var width = window.innerWidth > 0 ? window.innerWidth : screen.width;\n\n      // Show toast in center if screen with less than or equal to 360px\n      if (width <= 360) {\n        // Setting the position\n        allToasts[i].style[classUsed] = offsetSize[classUsed] + \"px\";\n\n        offsetSize[classUsed] += height + offset;\n      } else {\n        if (containsClass(allToasts[i], \"toastify-left\") === true) {\n          // Setting the position\n          allToasts[i].style[classUsed] = topLeftOffsetSize[classUsed] + \"px\";\n\n          topLeftOffsetSize[classUsed] += height + offset;\n        } else {\n          // Setting the position\n          allToasts[i].style[classUsed] = topRightOffsetSize[classUsed] + \"px\";\n\n          topRightOffsetSize[classUsed] += height + offset;\n        }\n      }\n    }\n\n    // Supporting function chaining\n    return this;\n  };\n\n  // Helper function to get offset.\n  function getAxisOffsetAValue(axis, options) {\n\n    if(options.offset[axis]) {\n      if(isNaN(options.offset[axis])) {\n        return options.offset[axis];\n      }\n      else {\n        return options.offset[axis] + 'px';\n      }\n    }\n\n    return '0px';\n\n  }\n\n  function containsClass(elem, yourClass) {\n    if (!elem || typeof yourClass !== \"string\") {\n      return false;\n    } else if (\n      elem.className &&\n      elem.className\n        .trim()\n        .split(/\\s+/gi)\n        .indexOf(yourClass) > -1\n    ) {\n      return true;\n    } else {\n      return false;\n    }\n  }\n\n  // Setting up the prototype for the init object\n  Toastify.lib.init.prototype = Toastify.lib;\n\n  // Returning the Toastify function to be assigned to the window object/module\n  return Toastify;\n});\n", "import 'toastify-js/src/toastify.css';\nimport './custom.less';\nimport Toastify from 'toastify-js';\nimport type {ToastifyWithHideToast} from './modules/types';\n\nconst toastify: ToastifyWithHideToast = (options, type) => {\n\toptions ??= {};\n\n\tlet className: string = 'gadget-toastify';\n\tif (type) {\n\t\tswitch (type) {\n\t\t\tcase 'error':\n\t\t\t\tclassName += ` ${className}--error`;\n\t\t\t\tbreak;\n\t\t\tcase 'success':\n\t\t\t\tclassName += ` ${className}--success`;\n\t\t\t\tbreak;\n\t\t\tcase 'warning':\n\t\t\t\tclassName += ` ${className}--warning`;\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tclassName += ` ${className}--info`;\n\t\t}\n\t}\n\t// eslint-disable-next-line mediawiki/class-doc\n\toptions.className = className;\n\n\tif (!options.gravity) {\n\t\toptions.gravity = 'bottom';\n\t}\n\tif (!options.position) {\n\t\toptions.position = 'center';\n\t}\n\n\tconst instance = Toastify(options);\n\tinstance.showToast();\n\n\treturn {\n\t\thideToast: instance.hideToast.bind(instance),\n\t};\n};\n\nexport {toastify};\n"],
  "mappings": "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",
  "names": ["require_toastify", "__commonJS", "exports", "module2", "root", "factory", "Toastify", "global", "Toastify2", "options", "lib", "init", "version", "defaults", "oldestFirst", "text", "node", "duration", "selector", "callback", "destination", "newWindow", "close", "gravity", "positionLeft", "position", "backgroundColor", "avatar", "className", "stopOnFocus", "onClick", "offset", "x", "y", "escapeMarkup", "ariaLive", "style", "background", "prototype", "toastify", "constructor", "toastElement", "buildToast", "divElement", "document", "createElement", "console", "warn", "property", "setAttribute", "nodeType", "Node", "ELEMENT_NODE", "appendChild", "innerText", "innerHTML", "avatarElement", "src", "insertAdjacentElement", "closeElement", "type", "addEventListener", "event", "stopPropagation", "removeElement", "window", "clearTimeout", "timeOutValue", "bind", "width", "innerWidth", "screen", "self", "setTimeout", "open", "location", "getAxisOffsetAValue", "xOffset", "yOffset", "transform", "showToast", "rootElement", "getElementById", "HTMLElement", "ShadowRoot", "body", "elementToInsert", "firstChild", "lastChild", "insertBefore", "reposition", "hideToast", "replace", "parentNode", "removeChild", "call", "topLeftOffsetSize", "top", "bottom", "topRightOffsetSize", "offsetSize", "allToasts", "getElementsByClassName", "classUsed", "i", "length", "containsClass", "height", "offsetHeight", "substr", "axis", "isNaN", "elem", "yourClass", "trim", "split", "indexOf", "Toastify_exports", "__export", "module", "__toCommonJS", "import_toastify_js", "__toESM", "_options", "concat", "instance", "default"]
}
