hts/apps/migrant/components-ai/prompt-form.tsx

116 lines
3.3 KiB
TypeScript

'use client'
import * as React from 'react'
import Textarea from 'react-textarea-autosize'
import { useActions, useUIState } from '@aigxion/isdk/rsc'
import { UserMessage } from './stocks/message'
import { type AI } from '@/lib/chat/actions'
import { Button } from './ui/button'
import { IconArrowElbow, IconPlus } from './ui/icons'
import {
Tooltip,
TooltipContent,
TooltipTrigger
} from './ui/tooltip'
import { useEnterSubmit } from '@/lib/hooks/use-enter-submit'
import { nanoid } from 'nanoid'
import { useRouter } from 'next/navigation'
export function PromptForm({
input,
setInput
}: {
input: string
setInput: (value: string) => void
}) {
const router = useRouter()
const { formRef, onKeyDown } = useEnterSubmit()
const inputRef = React.useRef<HTMLTextAreaElement>(null)
const { submitUserMessage } = useActions()
const [_, setMessages] = useUIState<typeof AI>()
React.useEffect(() => {
if (inputRef.current) {
inputRef.current.focus()
}
}, [])
return (
<form
ref={formRef}
onSubmit={async (e: any) => {
e.preventDefault()
// Blur focus on mobile
if (window.innerWidth < 600) {
e.target['message']?.blur()
}
const value = input.trim()
setInput('')
if (!value) return
// Optimistically add user message UI
setMessages((currentMessages: any) => [
...currentMessages,
{
id: nanoid(),
display: <UserMessage>{value}</UserMessage>
}
])
// Submit and get response message
const responseMessage = await submitUserMessage(value)
setMessages((currentMessages: any) => [...currentMessages, responseMessage])
}}
>
<div className="relative flex max-h-60 w-full grow flex-col overflow-hidden bg-background px-8 sm:rounded-md sm:border sm:px-12">
<Tooltip>
<TooltipTrigger asChild>
<Button
variant="outline"
size="icon"
className="absolute left-0 top-[14px] size-8 rounded-full bg-background p-0 sm:left-4"
onClick={() => {
router.push('/new')
}}
>
<IconPlus />
<span className="sr-only">New Chat</span>
</Button>
</TooltipTrigger>
<TooltipContent>New Chat</TooltipContent>
</Tooltip>
<Textarea
ref={inputRef}
tabIndex={0}
onKeyDown={onKeyDown}
placeholder="Send a message."
className="min-h-[60px] w-full resize-none bg-transparent px-4 py-[1.3rem] focus-within:outline-none sm:text-sm"
autoFocus
spellCheck={false}
autoComplete="off"
autoCorrect="off"
name="message"
rows={1}
value={input}
onChange={e => setInput(e.target.value)}
/>
<div className="absolute right-0 top-[13px] sm:right-4">
<Tooltip>
<TooltipTrigger asChild>
<Button type="submit" size="icon" disabled={input === ''}>
<IconArrowElbow />
<span className="sr-only">Send message</span>
</Button>
</TooltipTrigger>
<TooltipContent>Send message</TooltipContent>
</Tooltip>
</div>
</div>
</form>
)
}