Spaces:
Configuration error
Configuration error
import React, { useState, useEffect } from "react"; | |
import { | |
Card, | |
Text, | |
Grid, | |
Button, | |
TextInput, | |
TableCell, | |
} from "@tremor/react"; | |
import { Typography, message, Divider } from "antd"; | |
import { serviceHealthCheck, setCallbacksCall } from "./networking"; | |
import { EmailEventSettings } from "./email_events"; | |
const { Title } = Typography; | |
interface EmailSettingsProps { | |
accessToken: string | null; | |
premiumUser: boolean; | |
alerts: any[]; | |
} | |
const EmailSettings: React.FC<EmailSettingsProps> = ({ | |
accessToken, | |
premiumUser, | |
alerts, | |
}) => { | |
const handleSaveEmailSettings = () => { | |
if (!accessToken) { | |
return; | |
} | |
let updatedVariables: Record<string, string> = {}; | |
alerts | |
.filter((alert) => alert.name === "email") | |
.forEach((alert) => { | |
Object.entries(alert.variables ?? {}).forEach(([key, value]) => { | |
const inputElement = document.querySelector(`input[name="${key}"]`) as HTMLInputElement; | |
if (inputElement && inputElement.value) { | |
updatedVariables[key] = inputElement?.value; | |
} | |
}); | |
}); | |
console.log("updatedVariables", updatedVariables); | |
//filter out null / undefined values for updatedVariables | |
const payload = { | |
general_settings: { | |
alerting: ["email"], | |
}, | |
environment_variables: updatedVariables, | |
}; | |
try { | |
setCallbacksCall(accessToken, payload); | |
} catch (error) { | |
message.error("Failed to update alerts: " + error, 20); | |
} | |
message.success("Email settings updated successfully"); | |
} | |
return ( | |
<> | |
<div className="mt-6 mb-6"> | |
<EmailEventSettings accessToken={accessToken} /> | |
</div> | |
<Card> | |
<Title level={4}>Email Server Settings</Title> | |
<Text> | |
<a href="https://docs.litellm.ai/docs/proxy/email" target="_blank" style={{ color: "blue" }}> LiteLLM Docs: email alerts</a> <br/> | |
</Text> | |
<div className="flex w-full"> | |
{alerts | |
.filter((alert) => alert.name === "email") | |
.map((alert, index) => ( | |
<TableCell key={index}> | |
<ul> | |
<Grid numItems={2}> | |
{Object.entries(alert.variables ?? {}).map(([key, value]) => ( | |
<li key={key} className="mx-2 my-2"> | |
{ premiumUser!= true && (key === "EMAIL_LOGO_URL" || key === "EMAIL_SUPPORT_CONTACT") ? ( | |
<div> | |
<a | |
href="https://forms.gle/W3U4PZpJGFHWtHyA9" | |
target="_blank" | |
> | |
<Text className="mt-2"> | |
{" "} | |
✨ {key} | |
</Text> | |
</a> | |
<TextInput | |
name={key} | |
defaultValue={value as string} | |
type="password" | |
disabled={true} | |
style={{ width: "400px" }} | |
/> | |
</div> | |
) : ( | |
<div> | |
<Text className="mt-2">{key}</Text> | |
<TextInput | |
name={key} | |
defaultValue={value as string} | |
type="password" | |
style={{ width: "400px" }} | |
/> | |
</div> | |
)} | |
{/* Added descriptions for input fields */} | |
<p style={{ fontSize: "small", fontStyle: "italic" }}> | |
{key === "SMTP_HOST" && ( | |
<div style={{ color: "gray" }}> | |
Enter the SMTP host address, e.g. `smtp.resend.com` | |
<span style={{ color: "red" }}> Required * </span> | |
</div> | |
)} | |
{key === "SMTP_PORT" && ( | |
<div style={{ color: "gray" }}> | |
Enter the SMTP port number, e.g. `587` | |
<span style={{ color: "red" }}> Required * </span> | |
</div> | |
)} | |
{key === "SMTP_USERNAME" && ( | |
<div style={{ color: "gray" }}> | |
Enter the SMTP username, e.g. `username` | |
<span style={{ color: "red" }}> Required * </span> | |
</div> | |
)} | |
{key === "SMTP_PASSWORD" && ( | |
<span style={{ color: "red" }}> Required * </span> | |
)} | |
{key === "SMTP_SENDER_EMAIL" && ( | |
<div style={{ color: "gray" }}> | |
Enter the sender email address, e.g. `[email protected]` | |
<span style={{ color: "red" }}> Required * </span> | |
</div> | |
)} | |
{key === "TEST_EMAIL_ADDRESS" && ( | |
<div style={{ color: "gray" }}> | |
Email Address to send `Test Email Alert` to. example: `[email protected]` | |
<span style={{ color: "red" }}> Required * </span> | |
</div> | |
) | |
} | |
{key === "EMAIL_LOGO_URL" && ( | |
<div style={{ color: "gray" }}> | |
(Optional) Customize the Logo that appears in the email, pass a url to your logo | |
</div> | |
) | |
} | |
{key === "EMAIL_SUPPORT_CONTACT" && ( | |
<div style={{ color: "gray" }}> | |
(Optional) Customize the support email address that appears in the email. Default is [email protected] | |
</div> | |
) | |
} | |
</p> | |
</li> | |
))} | |
</Grid> | |
</ul> | |
</TableCell> | |
))} | |
</div> | |
<Button | |
className="mt-2" | |
onClick={() => handleSaveEmailSettings()} | |
> | |
Save Changes | |
</Button> | |
<Button | |
onClick={() => | |
accessToken && serviceHealthCheck(accessToken, "email") | |
} | |
className="mx-2" | |
> | |
Test Email Alerts | |
</Button> | |
</Card> | |
</> | |
); | |
}; | |
export default EmailSettings; |