diff --git a/packages/frontend/src/components/shared/Toast/SimpleToast.theme.ts b/packages/frontend/src/components/shared/Toast/SimpleToast.theme.ts
index 0d8ae24..bac805c 100644
--- a/packages/frontend/src/components/shared/Toast/SimpleToast.theme.ts
+++ b/packages/frontend/src/components/shared/Toast/SimpleToast.theme.ts
@@ -5,6 +5,7 @@ export const simpleToastTheme = tv(
slots: {
wrapper: [
'flex',
+ 'items-center',
'py-2',
'pl-2',
'pr-1.5',
@@ -18,6 +19,15 @@ export const simpleToastTheme = tv(
'shadow-sm',
],
icon: ['flex', 'items-center', 'justify-center', 'w-5', 'h-5'],
+ closeIcon: [
+ 'cursor-pointer',
+ 'flex',
+ 'items-center',
+ 'justify-center',
+ 'w-6',
+ 'h-6',
+ 'text-elements-on-high-contrast',
+ ],
title: ['text-sm', 'text-elements-on-high-contrast'],
},
variants: {
diff --git a/packages/frontend/src/components/shared/Toast/SimpleToast.tsx b/packages/frontend/src/components/shared/Toast/SimpleToast.tsx
index e134d64..b3bafc2 100644
--- a/packages/frontend/src/components/shared/Toast/SimpleToast.tsx
+++ b/packages/frontend/src/components/shared/Toast/SimpleToast.tsx
@@ -2,41 +2,80 @@ import React, { useMemo } from 'react';
import * as ToastPrimitive from '@radix-ui/react-toast';
import { ToastProps } from '@radix-ui/react-toast';
import { simpleToastTheme, type SimpleToastTheme } from './SimpleToast.theme';
-import { CheckIcon, CheckRoundFilledIcon } from 'components/shared/CustomIcon';
+import {
+ LoadingIcon,
+ CheckRoundFilledIcon,
+ CrossIcon,
+ InfoRoundFilledIcon,
+ WarningIcon,
+} from 'components/shared/CustomIcon';
+import { Button, ButtonBaseProps, ButtonTheme } from 'components/shared/Button';
import { cloneIcon } from 'utils/cloneIcon';
+import { cn } from 'utils/classnames';
+interface CtaProps extends ButtonBaseProps, ButtonTheme {
+ buttonLabel: string;
+}
export interface SimpleToastProps extends ToastProps {
title: string;
variant?: SimpleToastTheme['variant'];
+ cta?: CtaProps[];
+ onDismiss: (id?: string) => void;
}
export const SimpleToast = ({
className,
title,
variant = 'success',
+ cta = [],
+ onDismiss,
...props
}: SimpleToastProps) => {
+ const hasCta = cta.length > 0;
const {
wrapper: wrapperCls,
icon: iconCls,
+ closeIcon: closeIconCls,
title: titleCls,
} = simpleToastTheme({ variant });
const Icon = useMemo(() => {
if (variant === 'success') return
{title}