(Git commit 9a13ee3: feat: 小工具迁移) |
小 (Git commit ef0a04a: refactor: 更新小工具逻辑) |
||
第4行: | 第4行: | ||
* |
* |
||
* @base {@link https://github.com/apvarun/toastify-js} |
* @base {@link https://github.com/apvarun/toastify-js} |
||
* @source {@link https://github.com/TopRealm/ |
* @source {@link https://github.com/TopRealm/YsArchives-Gadgets/tree/master/src/Toastify} |
||
*/ |
*/ |
||
/** |
/** |
2024年4月17日 (三) 19:08的版本
/**
* SPDX-License-Identifier: MIT
* _addText: '{{Gadget Header|license=MIT|attribution=2018 apvarun}}'
*
* @base {@link https://github.com/apvarun/toastify-js}
* @source {@link https://github.com/TopRealm/YsArchives-Gadgets/tree/master/src/Toastify}
*/
/**
* +------------------------------------------------------------+
* | === 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 = "✖";
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"]
}
