'use client'; import { useState } from 'react'; import { Loader2, Search } from 'lucide-react'; import { z } from 'zod'; const schema = z.object({ question: z.string().min(1, 'กรุณาระบุคำถาม').max(500, 'คำถามต้องไม่เกิน 500 ตัวอักษร'), }); interface RagSearchBarProps { onSearch: (question: string) => void; isLoading: boolean; } export function RagSearchBar({ onSearch, isLoading }: RagSearchBarProps) { const [question, setQuestion] = useState(''); const [error, setError] = useState(null); const handleSubmit = (e: React.FormEvent) => { e.preventDefault(); const result = schema.safeParse({ question }); if (!result.success) { setError(result.error.issues[0]?.message ?? 'ข้อมูลไม่ถูกต้อง'); return; } setError(null); onSearch(question); }; return (
setQuestion(e.target.value)} placeholder="ถามคำถามเกี่ยวกับเอกสารโครงการ..." className="w-full rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring" disabled={isLoading} maxLength={500} /> {error &&

{error}

}

{question.length}/500

); }