2026-03-30 00:25:40 +03:00
|
|
|
import { useTranslation } from "react-i18next";
|
|
|
|
|
import { Alert, AlertDescription } from "@/components/ui/alert";
|
|
|
|
|
import { LuInfo, LuTriangleAlert, LuCircleAlert } from "react-icons/lu";
|
|
|
|
|
import type { MessageSeverity } from "./section-configs/types";
|
|
|
|
|
|
|
|
|
|
const severityVariantMap: Record<
|
|
|
|
|
MessageSeverity,
|
|
|
|
|
"info" | "warning" | "destructive"
|
|
|
|
|
> = {
|
|
|
|
|
info: "info",
|
|
|
|
|
warning: "warning",
|
|
|
|
|
error: "destructive",
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
function SeverityIcon({ severity }: { severity: string }) {
|
|
|
|
|
switch (severity) {
|
|
|
|
|
case "info":
|
2026-06-04 21:48:58 +03:00
|
|
|
return <LuInfo className="size-4 shrink-0" />;
|
2026-03-30 00:25:40 +03:00
|
|
|
case "warning":
|
2026-06-04 21:48:58 +03:00
|
|
|
return <LuTriangleAlert className="size-4 shrink-0" />;
|
2026-03-30 00:25:40 +03:00
|
|
|
case "error":
|
2026-06-04 21:48:58 +03:00
|
|
|
return <LuCircleAlert className="size-4 shrink-0" />;
|
2026-03-30 00:25:40 +03:00
|
|
|
default:
|
2026-06-04 21:48:58 +03:00
|
|
|
return <LuInfo className="size-4 shrink-0" />;
|
2026-03-30 00:25:40 +03:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type ConfigFieldMessageProps = {
|
|
|
|
|
messageKey: string;
|
|
|
|
|
severity: string;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export function ConfigFieldMessage({
|
|
|
|
|
messageKey,
|
|
|
|
|
severity,
|
|
|
|
|
}: ConfigFieldMessageProps) {
|
|
|
|
|
const { t } = useTranslation("views/settings");
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<Alert
|
|
|
|
|
variant={severityVariantMap[severity as MessageSeverity] ?? "info"}
|
|
|
|
|
className="flex items-center [&>svg+div]:translate-y-0 [&>svg]:static [&>svg~*]:pl-2"
|
|
|
|
|
>
|
|
|
|
|
<SeverityIcon severity={severity} />
|
|
|
|
|
<AlertDescription>{t(messageKey)}</AlertDescription>
|
|
|
|
|
</Alert>
|
|
|
|
|
);
|
|
|
|
|
}
|