mirror of
https://github.com/idanoo/autobrr
synced 2025-07-23 00:39:13 +00:00

* feat(web): vendor react-hot-toast * vendor react-hot-toast to be react 19 compatible * feat: remove react-hot-toast and add goober * chore: fix lint warnings
92 lines
1.9 KiB
TypeScript
92 lines
1.9 KiB
TypeScript
import {
|
|
Renderable,
|
|
Toast,
|
|
ToastOptions,
|
|
ToastType,
|
|
DefaultToastOptions,
|
|
ValueOrFunction,
|
|
resolveValue,
|
|
} from './types';
|
|
import { genId } from './utils';
|
|
import { dispatch, ActionType } from './store';
|
|
|
|
type Message = ValueOrFunction<Renderable, Toast>;
|
|
|
|
type ToastHandler = (message: Message, options?: ToastOptions) => string;
|
|
|
|
const createToast = (
|
|
message: Message,
|
|
type: ToastType = 'blank',
|
|
opts?: ToastOptions
|
|
): Toast => ({
|
|
createdAt: Date.now(),
|
|
visible: true,
|
|
type,
|
|
ariaProps: {
|
|
role: 'status',
|
|
'aria-live': 'polite',
|
|
},
|
|
message,
|
|
pauseDuration: 0,
|
|
...opts,
|
|
id: opts?.id || genId(),
|
|
});
|
|
|
|
const createHandler =
|
|
(type?: ToastType): ToastHandler =>
|
|
(message, options) => {
|
|
const toast = createToast(message, type, options);
|
|
dispatch({ type: ActionType.UPSERT_TOAST, toast });
|
|
return toast.id;
|
|
};
|
|
|
|
const toast = (message: Message, opts?: ToastOptions) =>
|
|
createHandler('blank')(message, opts);
|
|
|
|
toast.error = createHandler('error');
|
|
toast.success = createHandler('success');
|
|
toast.loading = createHandler('loading');
|
|
toast.custom = createHandler('custom');
|
|
|
|
toast.dismiss = (toastId?: string) => {
|
|
dispatch({
|
|
type: ActionType.DISMISS_TOAST,
|
|
toastId,
|
|
});
|
|
};
|
|
|
|
toast.remove = (toastId?: string) =>
|
|
dispatch({ type: ActionType.REMOVE_TOAST, toastId });
|
|
|
|
toast.promise = <T>(
|
|
promise: Promise<T>,
|
|
msgs: {
|
|
loading: Renderable;
|
|
success: ValueOrFunction<Renderable, T>;
|
|
error: ValueOrFunction<Renderable, unknown>;
|
|
},
|
|
opts?: DefaultToastOptions
|
|
) => {
|
|
const id = toast.loading(msgs.loading, { ...opts, ...opts?.loading });
|
|
|
|
promise
|
|
.then((p) => {
|
|
toast.success(resolveValue(msgs.success, p), {
|
|
id,
|
|
...opts,
|
|
...opts?.success,
|
|
});
|
|
return p;
|
|
})
|
|
.catch((e) => {
|
|
toast.error(resolveValue(msgs.error, e), {
|
|
id,
|
|
...opts,
|
|
...opts?.error,
|
|
});
|
|
});
|
|
|
|
return promise;
|
|
};
|
|
|
|
export { toast };
|