Files
LetterFeed/frontend/components/letterfeed/AddNewsletterDialog.tsx
2025-07-15 22:54:35 +02:00

116 lines
3.5 KiB
TypeScript

import { useState } from "react"
import { Button } from "@/components/ui/button"
import {
Dialog,
DialogContent,
DialogDescription,
DialogFooter,
DialogHeader,
DialogTitle,
} from "@/components/ui/dialog"
import { Input } from "@/components/ui/input"
import { Label } from "@/components/ui/label"
import { Plus } from "lucide-react"
import { createNewsletter } from "@/lib/api"
interface AddNewsletterDialogProps {
isOpen: boolean
onOpenChange: (isOpen: boolean) => void
onSuccess: () => void
}
export function AddNewsletterDialog({ isOpen, onOpenChange, onSuccess }: AddNewsletterDialogProps) {
const [newNewsletter, setNewNewsletter] = useState({
name: "",
emails: [""],
})
const handleAddEmail = () => {
setNewNewsletter((prev) => ({
...prev,
emails: [...prev.emails, ""],
}))
}
const handleRemoveEmail = (index: number) => {
setNewNewsletter((prev) => ({
...prev,
emails: prev.emails.filter((_, i) => i !== index),
}))
}
const handleEmailChange = (index: number, value: string) => {
setNewNewsletter((prev) => ({
...prev,
emails: prev.emails.map((email, i) => (i === index ? value : email)),
}))
}
const handleSubmit = async () => {
if (newNewsletter.name && newNewsletter.emails.some((email) => email.trim())) {
try {
await createNewsletter({
name: newNewsletter.name,
sender_emails: newNewsletter.emails.filter((email) => email.trim()),
})
setNewNewsletter({ name: "", emails: [""] })
onOpenChange(false)
onSuccess()
} catch (error) {
console.error("Failed to create newsletter:", error)
}
}
}
return (
<Dialog open={isOpen} onOpenChange={onOpenChange}>
<DialogContent className="sm:max-w-[425px]">
<DialogHeader>
<DialogTitle>Register New Newsletter</DialogTitle>
<DialogDescription>Add a new newsletter.</DialogDescription>
</DialogHeader>
<div className="grid gap-4 py-4">
<div className="space-y-2">
<Label htmlFor="name">Newsletter Name</Label>
<Input
id="name"
value={newNewsletter.name}
onChange={(e) => setNewNewsletter((prev) => ({ ...prev, name: e.target.value }))}
placeholder="Enter newsletter name"
/>
</div>
<div className="space-y-2">
<Label>Email Addresses</Label>
{newNewsletter.emails.map((email, index) => (
<div key={index} className="flex gap-2">
<Input
value={email}
onChange={(e) => handleEmailChange(index, e.target.value)}
placeholder="Enter email address"
type="email"
/>
{newNewsletter.emails.length > 1 && (
<Button variant="outline" size="sm" onClick={() => handleRemoveEmail(index)}>
Remove
</Button>
)}
</div>
))}
<Button variant="outline" size="sm" onClick={handleAddEmail} className="w-full bg-transparent">
<Plus className="w-4 h-4 mr-2" />
Add Another Email
</Button>
</div>
</div>
<DialogFooter>
<Button variant="outline" onClick={() => onOpenChange(false)}>
Cancel
</Button>
<Button onClick={handleSubmit}>Register Newsletter</Button>
</DialogFooter>
</DialogContent>
</Dialog>
)
}