bigbuffet-rw/app/soapbox/actions/snackbar.ts

51 lines
1.3 KiB
TypeScript
Raw Normal View History

import { ALERT_SHOW } from './alerts';
import type { MessageDescriptor } from 'react-intl';
export type SnackbarActionSeverity = 'info' | 'success' | 'error';
type SnackbarMessage = string | MessageDescriptor;
export type SnackbarAction = {
type: typeof ALERT_SHOW,
message: SnackbarMessage,
actionLabel?: SnackbarMessage,
actionLink?: string,
action?: () => void,
severity: SnackbarActionSeverity,
};
2022-06-23 15:53:04 -07:00
type SnackbarOpts = {
actionLabel?: SnackbarMessage,
actionLink?: string,
action?: () => void,
2022-06-23 16:03:35 -07:00
dismissAfter?: number | false,
2022-06-23 15:53:04 -07:00
};
export const show = (
severity: SnackbarActionSeverity,
message: SnackbarMessage,
opts?: SnackbarOpts,
): SnackbarAction => ({
type: ALERT_SHOW,
message,
severity,
2022-06-23 15:53:04 -07:00
...opts,
});
export const info = (message: SnackbarMessage, actionLabel?: SnackbarMessage, actionLink?: string) =>
2022-06-23 15:53:04 -07:00
show('info', message, { actionLabel, actionLink });
export const success = (message: SnackbarMessage, actionLabel?: SnackbarMessage, actionLink?: string) =>
2022-06-23 15:53:04 -07:00
show('success', message, { actionLabel, actionLink });
export const error = (message: SnackbarMessage, actionLabel?: SnackbarMessage, actionLink?: string) =>
2022-06-23 15:53:04 -07:00
show('error', message, { actionLabel, actionLink });
export default {
info,
success,
error,
show,
};