File size: 2,149 Bytes
18e5e63 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 |
import { startTransition, useEffect, useState } from "react"
import { Button } from "@/components/ui/button"
import { Dialog, DialogContent, DialogDescription, DialogFooter, DialogHeader, DialogTitle, DialogTrigger } from "@/components/ui/dialog"
import { cn } from "@/lib/utils"
import { Post } from "@/types"
import { deletePost } from "@/app/server/actions/community"
export function Delete({ post, moderationKey = "", onDelete = () => {} }: { post?: Post, moderationKey?: string; onDelete: (post: Post) => void }) {
const [isOpen, setOpen] = useState(false)
useEffect(() => {
if (post?.postId && !isOpen) {
setOpen(true)
}
}, [post?.postId])
const handleDelete = () => {
startTransition(() => {
const fn = async () => {
setOpen(false)
if (!post) { return }
const postId = post.postId
await deletePost({ postId, moderationKey })
onDelete(post)
}
fn()
})
}
return (
<Dialog open={isOpen} onOpenChange={setOpen}>
<DialogContent className="sm:max-w-[800px]">
<DialogHeader>
<DialogTitle>Delete</DialogTitle>
</DialogHeader>
{post ?<div className="flex flex-col py-4 text-stone-800">
<div className="w-full h-64">
<img
src={post.assetUrl}
className={cn(
`w-full h-64 rounded-xl overflow-hidden object-cover`,
`border border-zinc-900/70`
)}
/>
</div>
<div className="text-lg text-stone-800/80 word-break w-full py-6">{post.prompt}</div>
</div> : null}
<DialogFooter>
<div className="w-full flex flex-row space-x-6 items-center justify-center">
<Button type="submit" className="text-xl bg-green-800 text-green-100 hover:bg-green-700 hover:text-green-50" onClick={() => setOpen(false)}>Keep</Button>
<Button type="submit" className="text-xl bg-red-800 text-red-100 hover:bg-red-700 hover:text-red-50" onClick={handleDelete}>Delete</Button>
</div>
</DialogFooter>
</DialogContent>
</Dialog>
)
} |