Files
formbricks-formbricks/apps/formbricks-com/components/shared/Callout.tsx
2023-08-22 15:20:43 +02:00

41 lines
1.6 KiB
TypeScript

import clsx from "clsx";
import { Icon } from "@/components/shared/Icon";
const styles = {
note: {
container: "bg-slate-100 dark:bg-slate-800/60 dark:ring-1 dark:ring-slate-300/10",
title: "text-slate-900 dark:text-slate-400",
body: "text-slate-800 [--tw-prose-background:theme(colors.slate.50)] prose-a:text-slate-900 prose-code:text-slate-900 dark:text-slate-300 dark:prose-code:text-slate-300",
},
warning: {
container: "bg-amber-50 dark:bg-slate-800/60 dark:ring-1 dark:ring-slate-300/10",
title: "text-amber-900 dark:text-amber-500",
body: "text-amber-800 [--tw-prose-underline:theme(colors.amber.400)] [--tw-prose-background:theme(colors.amber.50)] prose-a:text-amber-900 prose-code:text-amber-900 dark:text-slate-300 dark:[--tw-prose-underline:theme(colors.slate.700)] dark:prose-code:text-slate-300",
},
};
const icons = {
note: (props: any) => <Icon icon="lightbulb" {...props} />,
warning: (props: any) => <Icon icon="warning" color="amber" {...props} />,
};
interface CalloutProps {
type: "note" | "warning";
title: string;
children: React.ReactNode;
}
export function Callout({ type = "note", title, children }: CalloutProps) {
let IconComponent = icons[type];
return (
<div className={clsx("my-8 flex rounded-3xl p-6", styles[type].container)}>
<IconComponent className="h-8 w-8 flex-none" />
<div className="ml-4 flex-auto">
<p className={clsx("font-display m-0 text-xl", styles[type].title)}>{title}</p>
<div className={clsx("prose mt-2.5", styles[type].body)}>{children}</div>
</div>
</div>
);
}