1
0
Fork 0
mirror of https://github.com/muerwre/vault-frontend.git synced 2025-05-07 02:26:41 +07:00
vault-frontend/src/utils/toast/index.tsx
2023-11-20 22:35:07 +06:00

41 lines
1.1 KiB
TypeScript

import classNames from 'classnames';
import toast, { ToastOptions } from 'react-hot-toast';
import { isTablet } from '~/constants/dom';
import styles from './styles.module.scss';
const defaultOptions: ToastOptions = {
icon: null,
duration: 3000,
position: isTablet() ? 'top-center' : 'bottom-center',
};
export const showToastError = (message: string) =>
toast.error(
(t) => <span onClick={() => toast.dismiss(t.id)}>{message}</span>,
{
...defaultOptions,
className: classNames(styles.toast, styles.error),
},
);
export const showToastSuccess = (message: string) =>
toast.success(
(t) => <span onClick={() => toast.dismiss(t.id)}>{message}</span>,
{
...defaultOptions,
className: classNames(styles.toast, styles.success),
},
);
export const showToastInfo = (message: string) =>
toast.success(
(t) => <span onClick={() => toast.dismiss(t.id)}>{message}</span>,
{
...defaultOptions,
className: classNames(styles.toast, styles.info),
},
);
export const hideToast = (id: string) => toast.dismiss(id);