2022-12-20 07:47:02 -08:00
|
|
|
import React from 'react';
|
2022-12-21 11:14:31 -08:00
|
|
|
import toast from 'react-hot-toast';
|
|
|
|
import { defineMessages, MessageDescriptor } from 'react-intl';
|
2022-12-20 07:47:02 -08:00
|
|
|
|
2024-10-19 05:34:03 -07:00
|
|
|
import Toast from './components/ui/toast';
|
2022-12-20 07:47:02 -08:00
|
|
|
import { httpErrorMessages } from './utils/errors';
|
|
|
|
|
2024-05-23 09:16:10 -07:00
|
|
|
import type { PlfeResponse } from './api';
|
|
|
|
|
2024-05-13 10:00:42 -07:00
|
|
|
type ToastText = string | MessageDescriptor
|
|
|
|
type ToastType = 'success' | 'error' | 'info'
|
2022-12-20 07:47:02 -08:00
|
|
|
|
2024-05-13 10:00:42 -07:00
|
|
|
interface IToastOptions {
|
2023-10-02 11:54:02 -07:00
|
|
|
action?(): void;
|
|
|
|
actionLink?: string;
|
|
|
|
actionLabel?: ToastText;
|
|
|
|
duration?: number;
|
|
|
|
summary?: string;
|
2022-12-20 07:47:02 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
const DEFAULT_DURATION = 4000;
|
|
|
|
|
|
|
|
const createToast = (type: ToastType, message: ToastText, opts?: IToastOptions) => {
|
|
|
|
const duration = opts?.duration || DEFAULT_DURATION;
|
|
|
|
|
2022-12-21 11:14:31 -08:00
|
|
|
toast.custom((t) => <Toast t={t} message={message} type={type} {...opts} />, {
|
2022-12-20 07:47:02 -08:00
|
|
|
duration,
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2024-05-12 06:24:15 -07:00
|
|
|
const info = (message: ToastText, opts?: IToastOptions) =>
|
2022-12-20 07:47:02 -08:00
|
|
|
createToast('info', message, opts);
|
|
|
|
|
2024-05-12 06:24:15 -07:00
|
|
|
const success = (message: ToastText, opts?: IToastOptions) =>
|
2022-12-20 07:47:02 -08:00
|
|
|
createToast('success', message, opts);
|
|
|
|
|
2024-05-12 06:24:15 -07:00
|
|
|
const error = (message: ToastText, opts?: IToastOptions) =>
|
2022-12-20 07:47:02 -08:00
|
|
|
createToast('error', message, opts);
|
|
|
|
|
|
|
|
const messages = defineMessages({
|
2023-10-11 12:57:53 -07:00
|
|
|
unexpectedMessage: { id: 'alert.unexpected.message', defaultMessage: 'Something went wrong.' },
|
2022-12-20 07:47:02 -08:00
|
|
|
});
|
|
|
|
|
2024-05-23 09:16:10 -07:00
|
|
|
const showAlertForError = (networkError: { response: PlfeResponse }) => {
|
2022-12-20 07:47:02 -08:00
|
|
|
if (networkError?.response) {
|
2024-05-11 14:37:37 -07:00
|
|
|
const { json, status, statusText } = networkError.response;
|
2022-12-20 07:47:02 -08:00
|
|
|
|
|
|
|
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;
|
|
|
|
|
2024-05-11 14:37:37 -07:00
|
|
|
if (json?.error) {
|
|
|
|
message = json.error;
|
2022-12-20 07:47:02 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!message) {
|
|
|
|
message = httpErrorMessages.find((httpError) => httpError.code === status)?.description;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (message) {
|
|
|
|
return error(message);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
console.error(networkError);
|
|
|
|
return error(messages.unexpectedMessage);
|
|
|
|
}
|
2024-05-12 06:24:15 -07:00
|
|
|
};
|
2022-12-20 07:47:02 -08:00
|
|
|
|
2024-05-13 10:00:42 -07:00
|
|
|
export {
|
|
|
|
type ToastText,
|
|
|
|
type IToastOptions,
|
|
|
|
type ToastType,
|
|
|
|
};
|
|
|
|
|
2022-12-20 07:47:02 -08:00
|
|
|
export default {
|
|
|
|
info,
|
|
|
|
success,
|
|
|
|
error,
|
|
|
|
showAlertForError,
|
2024-05-13 10:00:42 -07:00
|
|
|
};
|