"use client" import { useState } from "react" import { Button } from "@/components/ui/button" import { Card, CardContent, CardHeader, CardTitle } from "@/components/ui/card" import { Input } from "@/components/ui/input" import { Alert, AlertDescription } from "@/components/ui/alert" import { CreditCard, Search, CheckCircle, XCircle } from "lucide-react" export function GiftCardBalanceChecker() { const [giftCardCode, setGiftCardCode] = useState("") const [balance, setBalance] = useState(null) const [isLoading, setIsLoading] = useState(false) const [error, setError] = useState("") const checkBalance = async () => { if (!giftCardCode.trim()) { setError("Please enter a gift card code") return } setIsLoading(true) setError("") setBalance(null) try { const response = await fetch(`/api/gift-cards?code=${encodeURIComponent(giftCardCode)}`) const data = await response.json() if (data.success) { setBalance(data.giftCard.remainingBalance) } else { setError(data.error || "Gift card not found") } } catch (err) { setError("Failed to check balance. Please try again.") } finally { setIsLoading(false) } } return ( Check Gift Card Balance
setGiftCardCode(e.target.value.toUpperCase())} placeholder="XXXX-XXXX-XXXX" maxLength={14} />
{balance !== null && ( Balance: ${balance} )} {error && ( {error} )}
) }