feat: per newsletter folder move setting

This commit is contained in:
Leon
2025-07-17 14:36:53 +02:00
parent e915330a78
commit 19426e3108
13 changed files with 355 additions and 13 deletions

View File

@@ -14,16 +14,26 @@ import { Plus } from "lucide-react"
import { createNewsletter } from "@/lib/api"
import { Checkbox } from "@/components/ui/checkbox"
import {
Select,
SelectContent,
SelectItem,
SelectTrigger,
SelectValue,
} from "@/components/ui/select"
interface AddNewsletterDialogProps {
isOpen: boolean
folderOptions: string[]
onOpenChange: (isOpen: boolean) => void
onSuccess: () => void
}
export function AddNewsletterDialog({ isOpen, onOpenChange, onSuccess }: AddNewsletterDialogProps) {
export function AddNewsletterDialog({ isOpen, folderOptions, onOpenChange, onSuccess }: AddNewsletterDialogProps) {
const [newNewsletter, setNewNewsletter] = useState({
name: "",
emails: [""],
move_to_folder: "",
extract_content: false,
})
@@ -54,9 +64,10 @@ export function AddNewsletterDialog({ isOpen, onOpenChange, onSuccess }: AddNews
await createNewsletter({
name: newNewsletter.name,
sender_emails: newNewsletter.emails.filter((email) => email.trim()),
move_to_folder: newNewsletter.move_to_folder,
extract_content: newNewsletter.extract_content,
})
setNewNewsletter({ name: "", emails: [""], extract_content: false })
setNewNewsletter({ name: "", emails: [""], move_to_folder: "", extract_content: false })
onOpenChange(false)
onSuccess()
} catch (error) {
@@ -83,6 +94,28 @@ export function AddNewsletterDialog({ isOpen, onOpenChange, onSuccess }: AddNews
/>
</div>
<div className="space-y-2">
<Label htmlFor="move_to_folder">Move To Folder</Label>
<Select
value={newNewsletter.move_to_folder || "None"}
onValueChange={(value) =>
setNewNewsletter((prev) => ({ ...prev, move_to_folder: value === "None" ? "" : value }))
}
>
<SelectTrigger>
<SelectValue placeholder="Select folder or leave empty" />
</SelectTrigger>
<SelectContent>
<SelectItem value="None">Default (use global setting)</SelectItem>
{folderOptions.map((folder) => (
<SelectItem key={folder} value={folder}>
{folder}
</SelectItem>
))}
</SelectContent>
</Select>
</div>
<div className="space-y-2">
<Label>Email Addresses</Label>
{newNewsletter.emails.map((email, index) => (