import Toastify from 'toastify-js' import 'toastify-js/src/toastify.css' import '@/styles/css/toasts.css' import { socket } from '@/utils/socket' const sharedOptions = { gravity: 'bottom', position: 'left' } let toastsWithId = {} export const toast = function(msg, icon = null, dismiss = true, id = null) { if (toastsWithId[id]) { let toastObj = toastsWithId[id] let toastElement = document.querySelectorAll(`div.toastify[toast_id=${id}]`) if (msg) { toastElement.forEach(toast => { const messages = toast.querySelectorAll('.toast-message') messages.forEach(message => { message.innerHTML = msg }) }) } if (icon) { if (icon == 'loading') { icon = `
` } else { icon = `${icon}` } toastElement.forEach(toast => { const icons = toast.querySelectorAll('.toast-icon') icons.forEach(toastIcon => { toastIcon.innerHTML = icon }) }) } if (dismiss !== null && dismiss) { toastElement.forEach(toast => { toast.classList.add('dismissable') }) setTimeout(() => { toastObj.hideToast() delete toastsWithId[id] }, 3000) } } else { if (icon == null) { icon = '' } else if (icon == 'loading') { icon = `` } else { icon = `${icon}` } let toastObj = Toastify({ ...sharedOptions, text: `