import { INITIAL_SOUND_SETTINGS } from '@components/settings/SoundSettings' import mangoStore from '@store/mangoStore' import { Howl } from 'howler' import { SOUND_SETTINGS_KEY } from './constants' export type TransactionNotification = { type: 'success' | 'info' | 'error' | 'confirm' title: string description?: null | string txid?: string show: boolean id: number } const successSound = new Howl({ src: ['/sounds/transaction-success.mp3'], volume: 0.5, }) const failSound = new Howl({ src: ['/sounds/transaction-fail.mp3'], volume: 0.5, }) export function notify(newNotification: { type?: 'success' | 'info' | 'error' | 'confirm' title: string description?: string txid?: string noSound?: boolean }) { const setMangoStore = mangoStore.getState().set const notifications = mangoStore.getState().transactionNotifications const lastId = mangoStore.getState().transactionNotificationIdCounter const newId = lastId + 1 const savedSoundSettings = localStorage.getItem(SOUND_SETTINGS_KEY) const soundSettings = savedSoundSettings ? JSON.parse(savedSoundSettings) : INITIAL_SOUND_SETTINGS if (newNotification.type && !newNotification.noSound) { switch (newNotification.type) { case 'success': { if (soundSettings['transaction-success']) { successSound.play() } break } case 'error': { if (soundSettings['transaction-fail']) { failSound.play() } } } } const newNotif: TransactionNotification = { id: newId, type: 'success', show: true, description: null, ...newNotification, } setMangoStore((state) => { state.transactionNotificationIdCounter = newId state.transactionNotifications = [...notifications, newNotif] }) }