"use client"
import { useMemo, useState } from "react"
import {
Archive,
ArrowLeft,
Inbox,
Pencil,
RotateCcw,
Search,
Send,
Star,
Trash2,
X,
} from "lucide-react"
import { toast } from "sonner"
import { Button } from "@/components/ui/button"
import { avatarColor, senderInitial } from "@/lib/sender-display"
import {
DEMO_EMAILS,
DEMO_USER,
type DemoEmail,
type DemoFolder,
} from "@/components/demo/demo-mail-data"
import { cn } from "@/lib/utils"
const FOLDERS: { id: DemoFolder; label: string; icon: typeof Inbox }[] = [
{ id: "inbox", label: "Boîte de réception", icon: Inbox },
{ id: "starred", label: "Favoris", icon: Star },
{ id: "sent", label: "Envoyés", icon: Send },
{ id: "archive", label: "Archive", icon: Archive },
{ id: "trash", label: "Corbeille", icon: Trash2 },
]
function demoToast(message: string) {
toast.message(message, {
description: "Mode démo : rien n'est envoyé ni conservé.",
})
}
function Avatar({ name, className }: { name: string; className?: string }) {
return (
{senderInitial(name)}
)
}
function ComposeModal({
onClose,
onSend,
}: {
onClose: () => void
onSend: (email: { to: string; subject: string; body: string }) => void
}) {
const [to, setTo] = useState("")
const [subject, setSubject] = useState("")
const [body, setBody] = useState("")
return (
)
}
export function DemoMailApp() {
const [emails, setEmails] = useState(DEMO_EMAILS)
const [folder, setFolder] = useState("inbox")
const [selectedId, setSelectedId] = useState(null)
const [query, setQuery] = useState("")
const [composeOpen, setComposeOpen] = useState(false)
const [replyDraft, setReplyDraft] = useState("")
const visible = useMemo(() => {
const inFolder =
folder === "starred"
? emails.filter((e) => e.starred && e.folder !== "trash")
: emails.filter((e) => e.folder === folder)
const q = query.trim().toLowerCase()
if (!q) return inFolder
return inFolder.filter((e) =>
[e.fromName, e.fromEmail, e.subject, e.preview].some((field) =>
field.toLowerCase().includes(q)
)
)
}, [emails, folder, query])
const selected = emails.find((e) => e.id === selectedId) ?? null
const unreadCount = emails.filter(
(e) => e.folder === "inbox" && e.unread
).length
const patchEmail = (id: string, patch: Partial) =>
setEmails((prev) => prev.map((e) => (e.id === id ? { ...e, ...patch } : e)))
const openEmail = (email: DemoEmail) => {
setSelectedId(email.id)
setReplyDraft("")
if (email.unread) patchEmail(email.id, { unread: false })
}
const moveEmail = (id: string, dest: DemoEmail["folder"], message: string) => {
patchEmail(id, { folder: dest })
if (selectedId === id) setSelectedId(null)
demoToast(message)
}
const sendCompose = (draft: { to: string; subject: string; body: string }) => {
setEmails((prev) => [
{
id: `sent-${Date.now()}`,
fromName: DEMO_USER.name,
fromEmail: DEMO_USER.email,
subject: draft.subject || "(sans objet)",
preview: draft.body.slice(0, 110) || "(message vide)",
body: draft.body ? draft.body.split("\n\n") : ["(message vide)"],
time: "À l'instant",
unread: false,
starred: false,
folder: "sent",
},
...prev,
])
demoToast("Message « envoyé »")
}
return (
{/* Barre supérieure */}
{/* Barre latérale */}
{/* Contenu */}
{selected ? (
{selected.subject}
{selected.fromName}
<{selected.fromEmail}>
À moi · {selected.time}
{selected.body.map((paragraph, i) => (
{paragraph}
))}
) : (
{visible.length === 0 ? (
{query
? "Aucun message ne correspond à votre recherche."
: "Ce dossier est vide."}
) : (
{visible.map((email) => (
-
openEmail(email)}
onKeyDown={(e) => {
if (e.key === "Enter" || e.key === " ") openEmail(email)
}}
className={cn(
"group flex w-full cursor-pointer items-center gap-3 px-3 py-3 text-left transition-colors hover:bg-[var(--mail-hover)] sm:px-4",
email.unread
? "bg-[var(--mail-row-unread)]"
: "bg-[var(--mail-row-read)]"
)}
>
{email.fromName}
{email.label ? (
{email.label.text}
) : null}
{email.subject}
{" "}
— {email.preview}
{email.time}
))}
)}
)}
{/* Bouton composer (mobile) */}
{composeOpen ? (
setComposeOpen(false)} onSend={sendCompose} />
) : null}
)
}