summaryrefslogtreecommitdiff
path: root/lib/bidding/list/biddings-delete-dialog.tsx
diff options
context:
space:
mode:
authordujinkim <dujin.kim@dtsolution.co.kr>2025-12-01 01:21:52 +0000
committerdujinkim <dujin.kim@dtsolution.co.kr>2025-12-01 01:21:52 +0000
commitc92ddd6bae8e187cccfddb37373460ebea0ade27 (patch)
tree7f04c61501f9d6caf068784add1dd22ca9891b1f /lib/bidding/list/biddings-delete-dialog.tsx
parent8440ac29c7dcbef992039678ecc0fabff2fd04ec (diff)
(최겸) 구매 입찰 SAP 삭제(취소) 개발
Diffstat (limited to 'lib/bidding/list/biddings-delete-dialog.tsx')
-rw-r--r--lib/bidding/list/biddings-delete-dialog.tsx102
1 files changed, 102 insertions, 0 deletions
diff --git a/lib/bidding/list/biddings-delete-dialog.tsx b/lib/bidding/list/biddings-delete-dialog.tsx
new file mode 100644
index 00000000..9291742f
--- /dev/null
+++ b/lib/bidding/list/biddings-delete-dialog.tsx
@@ -0,0 +1,102 @@
+"use client"
+
+import * as React from "react"
+import {
+ AlertDialog,
+ AlertDialogAction,
+ AlertDialogCancel,
+ AlertDialogContent,
+ AlertDialogDescription,
+ AlertDialogFooter,
+ AlertDialogHeader,
+ AlertDialogTitle,
+} from "@/components/ui/alert-dialog"
+import { Input } from "@/components/ui/input"
+import { Label } from "@/components/ui/label"
+import { BiddingListItem } from "@/db/schema"
+import { deleteBidding } from "@/lib/bidding/delete-action"
+import { toast } from "sonner"
+import { Loader2 } from "lucide-react"
+
+interface BiddingDeleteDialogProps {
+ open: boolean
+ onOpenChange: (open: boolean) => void
+ bidding: BiddingListItem
+ onSuccess?: () => void
+}
+
+export function BiddingDeleteDialog({
+ open,
+ onOpenChange,
+ bidding,
+ onSuccess
+}: BiddingDeleteDialogProps) {
+ const [isDeleting, setIsDeleting] = React.useState(false)
+ const [deleteReason, setDeleteReason] = React.useState("")
+
+ const handleDelete = async () => {
+ if (!bidding) return
+
+ setIsDeleting(true)
+ try {
+ const result = await deleteBidding([bidding.id], deleteReason)
+
+ if (result.success) {
+ toast.success(result.message)
+ onOpenChange(false)
+ onSuccess?.()
+ } else {
+ toast.error(result.message)
+ }
+ } catch (error) {
+ toast.error("삭제 중 오류가 발생했습니다.")
+ console.error(error)
+ } finally {
+ setIsDeleting(false)
+ }
+ }
+
+ return (
+ <AlertDialog open={open} onOpenChange={onOpenChange}>
+ <AlertDialogContent>
+ <AlertDialogHeader>
+ <AlertDialogTitle>입찰 삭제</AlertDialogTitle>
+ <AlertDialogDescription>
+ 선택한 입찰({bidding?.biddingNumber})을 삭제하시겠습니까?<br/>
+ 삭제된 입찰은 복구할 수 없습니다.
+ <div className="mt-4">
+ <Label htmlFor="deleteReason" className="mb-2 block">삭제 사유</Label>
+ <Input
+ id="deleteReason"
+ value={deleteReason}
+ onChange={(e) => setDeleteReason(e.target.value)}
+ placeholder="삭제 사유를 입력하세요"
+ />
+ </div>
+ </AlertDialogDescription>
+ </AlertDialogHeader>
+ <AlertDialogFooter>
+ <AlertDialogCancel disabled={isDeleting}>취소</AlertDialogCancel>
+ <AlertDialogAction
+ onClick={(e) => {
+ e.preventDefault()
+ handleDelete()
+ }}
+ disabled={isDeleting}
+ className="bg-destructive text-destructive-foreground hover:bg-destructive/90"
+ >
+ {isDeleting ? (
+ <>
+ <Loader2 className="mr-2 size-4 animate-spin" />
+ 삭제 중...
+ </>
+ ) : (
+ "삭제"
+ )}
+ </AlertDialogAction>
+ </AlertDialogFooter>
+ </AlertDialogContent>
+ </AlertDialog>
+ )
+}
+