Spaces:
Paused
Paused
| 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; |