@wix/design-system
Version:
@wix/design-system
43 lines • 2.27 kB
JavaScript
import React, { memo } from 'react';
import { StatusCompleteFilled, StatusAlertFilled, StatusWarningFilled, InfoCircleFilled, } from '@wix/wix-ui-icons-common';
import Text from '../Text';
import Toast from '../Toast';
import { useToastTimeout } from './hooks/useToastTimeout';
import { st, classes } from './StatusToast.st.css.js';
import ToastAction from './components/ToastAction/ToastAction';
import ToastLink from './components/ToastLink/ToastLink';
const DEFAULT_STATUS = 'info';
const SUCCESS_AUTO_DISMISS_DELAY = 7000;
const iconByStatus = {
success: React.createElement(StatusCompleteFilled, null),
error: React.createElement(StatusAlertFilled, null),
warning: React.createElement(StatusWarningFilled, null),
info: React.createElement(InfoCircleFilled, null),
};
const roleByStatus = {
success: 'status',
error: 'alert',
warning: 'alert',
info: 'status',
};
const StatusToast = memo(({ status = DEFAULT_STATUS, action, children, className, duration, ...rest }) => {
const autoDismissEnabled = duration !== null;
const defaultAutoDismissDuration = ['info', 'success'].includes(status)
? SUCCESS_AUTO_DISMISS_DELAY
: undefined;
useToastTimeout(autoDismissEnabled ? (duration ?? defaultAutoDismissDuration) : undefined, rest.onDismiss);
return (React.createElement(Toast, { role: roleByStatus[status], className: st(classes.toast, className), ...rest },
React.createElement("div", { "data-hook": "status-toast-root", className: st(classes.root, {
success: status === 'success',
error: status === 'error',
warning: status === 'warning',
}), "data-status": status },
React.createElement("div", { className: classes.content },
React.createElement("div", { className: classes.icon }, iconByStatus[status] ?? iconByStatus[DEFAULT_STATUS]),
React.createElement(Text, { light: true, size: "medium", dataHook: "status-toast-content", className: classes.text }, children)),
action && React.createElement("div", { className: classes.action }, action))));
});
StatusToast.Action = ToastAction;
StatusToast.Link = ToastLink;
export default StatusToast;
//# sourceMappingURL=StatusToast.js.map