import React from 'react' import {Pressable, StyleSheet, View} from 'react-native' import {msg} from '@lingui/macro' import {useLingui} from '@lingui/react' import TextareaAutosize from 'react-textarea-autosize' import {atoms as a, useTheme} from '#/alf' import {PaperPlane_Stroke2_Corner0_Rounded as PaperPlane} from '#/components/icons/PaperPlane' export function MessageInput({ onSendMessage, }: { onSendMessage: (message: string) => void onFocus: () => void onBlur: () => void }) { const {_} = useLingui() const t = useTheme() const [message, setMessage] = React.useState('') const onSubmit = React.useCallback(() => { if (message.trim() === '') { return } onSendMessage(message.trimEnd()) setMessage('') }, [message, onSendMessage]) const onKeyDown = React.useCallback( (e: React.KeyboardEvent) => { if (e.key === 'Enter') { if (e.shiftKey) return e.preventDefault() onSubmit() } }, [onSubmit], ) const onChange = React.useCallback( (e: React.ChangeEvent) => { setMessage(e.target.value) }, [], ) return ( ) }