import { AxiosError } from 'axios'; import React from 'react'; import toast from 'react-hot-toast'; import { defineMessages, MessageDescriptor } from 'react-intl'; import { Toast } from './components/ui'; import { httpErrorMessages } from './utils/errors'; export type ToastText = string | MessageDescriptor export type ToastType = 'success' | 'error' | 'info' interface IToastOptions { action?(): void actionLink?: string actionLabel?: ToastText duration?: number } const DEFAULT_DURATION = 4000; const createToast = (type: ToastType, message: ToastText, opts?: IToastOptions) => { const duration = opts?.duration || DEFAULT_DURATION; toast.custom((t) => , { duration, }); }; function info(message: ToastText, opts?: IToastOptions) { createToast('info', message, opts); } function success(message: ToastText, opts?: IToastOptions) { createToast('success', message, opts); } function error(message: ToastText, opts?: IToastOptions) { createToast('error', message, opts); } const messages = defineMessages({ unexpectedMessage: { id: 'alert.unexpected.message', defaultMessage: 'An unexpected error occurred.' }, }); function showAlertForError(networkError: AxiosError) { if (networkError?.response) { const { data, status, statusText } = networkError.response; if (status === 502) { return error('The server is down'); } if (status === 404 || status === 410) { // Skip these errors as they are reflected in the UI return null; } let message: string | undefined = statusText; if (data?.error) { message = data.error; } if (!message) { message = httpErrorMessages.find((httpError) => httpError.code === status)?.description; } if (message) { return error(message); } } else { console.error(networkError); return error(messages.unexpectedMessage); } } export default { info, success, error, showAlertForError, };