123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437 |
- /*!
- * Toastify js 1.11.2
- * https://github.com/apvarun/toastify-js
- * @license MIT licensed
- *
- * Copyright (C) 2018 Varun A P
- */
- (function(root, factory) {
- if (typeof module === "object" && module.exports) {
- module.exports = factory();
- } else {
- root.Toastify = factory();
- }
- })(this, function(global) {
- // Object initialization
- var Toastify = function(options) {
- // Returning a new init object
- return new Toastify.lib.init(options);
- },
- // Library version
- version = "1.11.2";
- // Set the default global options
- Toastify.defaults = {
- oldestFirst: true,
- text: "Toastify is awesome!",
- node: undefined,
- duration: 3000,
- selector: undefined,
- callback: function () {
- },
- destination: undefined,
- newWindow: false,
- close: false,
- gravity: "toastify-top",
- positionLeft: false,
- position: '',
- backgroundColor: '',
- avatar: "",
- className: "",
- stopOnFocus: true,
- onClick: function () {
- },
- offset: {x: 0, y: 0},
- escapeMarkup: true,
- style: {background: ''}
- };
- // Defining the prototype of the object
- Toastify.lib = Toastify.prototype = {
- toastify: version,
- constructor: Toastify,
- // Initializing the object with required parameters
- init: function(options) {
- // Verifying and validating the input object
- if (!options) {
- options = {};
- }
- // Creating the options object
- this.options = {};
- this.toastElement = null;
- // Validating the options
- this.options.text = options.text || Toastify.defaults.text; // Display message
- this.options.node = options.node || Toastify.defaults.node; // Display content as node
- this.options.duration = options.duration === 0 ? 0 : options.duration || Toastify.defaults.duration; // Display duration
- this.options.selector = options.selector || Toastify.defaults.selector; // Parent selector
- this.options.callback = options.callback || Toastify.defaults.callback; // Callback after display
- this.options.destination = options.destination || Toastify.defaults.destination; // On-click destination
- this.options.newWindow = options.newWindow || Toastify.defaults.newWindow; // Open destination in new window
- this.options.close = options.close || Toastify.defaults.close; // Show toast close icon
- this.options.gravity = options.gravity === "bottom" ? "toastify-bottom" : Toastify.defaults.gravity; // toast position - top or bottom
- this.options.positionLeft = options.positionLeft || Toastify.defaults.positionLeft; // toast position - left or right
- this.options.position = options.position || Toastify.defaults.position; // toast position - left or right
- this.options.backgroundColor = options.backgroundColor || Toastify.defaults.backgroundColor; // toast background color
- this.options.avatar = options.avatar || Toastify.defaults.avatar; // img element src - url or a path
- this.options.className = options.className || Toastify.defaults.className; // additional class names for the toast
- this.options.stopOnFocus = options.stopOnFocus === undefined ? Toastify.defaults.stopOnFocus : options.stopOnFocus; // stop timeout on focus
- this.options.onClick = options.onClick || Toastify.defaults.onClick; // Callback after click
- this.options.offset = options.offset || Toastify.defaults.offset; // toast offset
- this.options.escapeMarkup = options.escapeMarkup !== undefined ? options.escapeMarkup : Toastify.defaults.escapeMarkup;
- this.options.style = options.style || Toastify.defaults.style;
- if(options.backgroundColor) {
- this.options.style.background = options.backgroundColor;
- }
- // Returning the current object for chaining functions
- return this;
- },
- // Building the DOM element
- buildToast: function() {
- // Validating if the options are defined
- if (!this.options) {
- throw "Toastify is not initialized";
- }
- // Creating the DOM object
- var divElement = document.createElement("div");
- divElement.className = "toastify on " + this.options.className;
- // Positioning toast to left or right or center
- if (!!this.options.position) {
- divElement.className += " toastify-" + this.options.position;
- } else {
- // To be depreciated in further versions
- if (this.options.positionLeft === true) {
- divElement.className += " toastify-left";
- console.warn('Property `positionLeft` will be depreciated in further versions. Please use `position` instead.')
- } else {
- // Default position
- divElement.className += " toastify-right";
- }
- }
- // Assigning gravity of element
- divElement.className += " " + this.options.gravity;
- if (this.options.backgroundColor) {
- // This is being deprecated in favor of using the style HTML DOM property
- console.warn('DEPRECATION NOTICE: "backgroundColor" is being deprecated. Please use the "style.background" property.');
- }
- // Loop through our style object and apply styles to divElement
- for (var property in this.options.style) {
- divElement.style[property] = this.options.style[property];
- }
- // Adding the toast message/node
- if (this.options.node && this.options.node.nodeType === Node.ELEMENT_NODE) {
- // If we have a valid node, we insert it
- 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) {
- // Adding close icon on the left of content
- divElement.appendChild(avatarElement);
- } else {
- // Adding close icon on the right of content
- divElement.insertAdjacentElement("afterbegin", avatarElement);
- }
- }
- }
- // Adding a close icon to the toast
- if (this.options.close === true) {
- // Create a span for close element
- var closeElement = document.createElement("span");
- closeElement.innerHTML = "✖";
- closeElement.className = "toast-close";
- // Triggering the removal of toast from DOM on close click
- closeElement.addEventListener(
- "click",
- function(event) {
- event.stopPropagation();
- this.removeElement(this.toastElement);
- window.clearTimeout(this.toastElement.timeOutValue);
- }.bind(this)
- );
- //Calculating screen width
- var width = window.innerWidth > 0 ? window.innerWidth : screen.width;
- // Adding the close icon to the toast element
- // Display on the right if screen width is less than or equal to 360px
- if ((this.options.position == "left" || this.options.positionLeft === true) && width > 360) {
- // Adding close icon on the left of content
- divElement.insertAdjacentElement("afterbegin", closeElement);
- } else {
- // Adding close icon on the right of content
- divElement.appendChild(closeElement);
- }
- }
- // Clear timeout while toast is focused
- if (this.options.stopOnFocus && this.options.duration > 0) {
- var self = this;
- // stop countdown
- divElement.addEventListener(
- "mouseover",
- function(event) {
- window.clearTimeout(divElement.timeOutValue);
- }
- )
- // add back the timeout
- divElement.addEventListener(
- "mouseleave",
- function() {
- divElement.timeOutValue = window.setTimeout(
- function() {
- // Remove the toast from DOM
- self.removeElement(divElement);
- },
- self.options.duration
- )
- }
- )
- }
- // Adding an on-click destination path
- 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)
- );
- }
- // Adding offset
- 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 + ")";
- }
- // Returning the generated element
- return divElement;
- },
- // Displaying the toast
- showToast: function() {
- // Creating the DOM object for the toast
- this.toastElement = this.buildToast();
- // Getting the root element to with the toast needs to be added
- 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;
- }
- // Validating if root element is present in DOM
- if (!rootElement) {
- throw "Root element is not defined";
- }
- // Adding the DOM element
- var elementToInsert = Toastify.defaults.oldestFirst ? rootElement.firstChild : rootElement.lastChild;
- rootElement.insertBefore(this.toastElement, elementToInsert);
- // Repositioning the toasts in case multiple toasts are present
- Toastify.reposition();
- if (this.options.duration > 0) {
- this.toastElement.timeOutValue = window.setTimeout(
- function() {
- // Remove the toast from DOM
- this.removeElement(this.toastElement);
- }.bind(this),
- this.options.duration
- ); // Binding `this` for function invocation
- }
- // Supporting function chaining
- 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) {
- // Hiding the element
- // toastElement.classList.remove("on");
- toastElement.className = toastElement.className.replace(" on", "");
- // Removing the element from DOM after transition end
- window.setTimeout(
- function() {
- // remove options node if any
- if (this.options.node && this.options.node.parentNode) {
- this.options.node.parentNode.removeChild(this.options.node);
- }
- // Remove the element from the DOM, only when the parent node was not removed before.
- if (toastElement.parentNode) {
- toastElement.parentNode.removeChild(toastElement);
- }
- // Calling the callback function
- this.options.callback.call(toastElement);
- // Repositioning the toasts again
- Toastify.reposition();
- }.bind(this),
- 400
- ); // Binding `this` for function invocation
- },
- };
- // Positioning the toasts on the DOM
- Toastify.reposition = function() {
- // Top margins with gravity
- var topLeftOffsetSize = {
- top: 15,
- bottom: 15,
- };
- var topRightOffsetSize = {
- top: 15,
- bottom: 15,
- };
- var offsetSize = {
- top: 15,
- bottom: 15,
- };
- // Get all toast messages on the DOM
- var allToasts = document.getElementsByClassName("toastify");
- var classUsed;
- // Modifying the position of each toast element
- for (var i = 0; i < allToasts.length; i++) {
- // Getting the applied gravity
- 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)
- // Spacing between toasts
- var offset = 15;
- var width = window.innerWidth > 0 ? window.innerWidth : screen.width;
- // Show toast in center if screen with less than or equal to 360px
- if (width <= 360) {
- // Setting the position
- allToasts[i].style[classUsed] = offsetSize[classUsed] + "px";
- offsetSize[classUsed] += height + offset;
- } else {
- if (containsClass(allToasts[i], "toastify-left") === true) {
- // Setting the position
- allToasts[i].style[classUsed] = topLeftOffsetSize[classUsed] + "px";
- topLeftOffsetSize[classUsed] += height + offset;
- } else {
- // Setting the position
- allToasts[i].style[classUsed] = topRightOffsetSize[classUsed] + "px";
- topRightOffsetSize[classUsed] += height + offset;
- }
- }
- }
- // Supporting function chaining
- return this;
- };
- // Helper function to get offset.
- 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;
- }
- }
- // Setting up the prototype for the init object
- Toastify.lib.init.prototype = Toastify.lib;
- // Returning the Toastify function to be assigned to the window object/module
- return Toastify;
- });
|