62 lines
2.0 KiB
TypeScript
62 lines
2.0 KiB
TypeScript
import { ArrowRight } from 'lucide-react';
|
|
import { useState } from 'react';
|
|
import TextareaAutosize from 'react-textarea-autosize';
|
|
import { Attach, CopilotToggle, Focus } from './MessageInputActions';
|
|
|
|
const EmptyChatMessageInput = ({
|
|
sendMessage,
|
|
}: {
|
|
sendMessage: (message: string) => void;
|
|
}) => {
|
|
const [copilotEnabled, setCopilotEnabled] = useState(false);
|
|
const [message, setMessage] = useState('');
|
|
|
|
return (
|
|
<form
|
|
onSubmit={(e) => {
|
|
e.preventDefault();
|
|
sendMessage(message);
|
|
setMessage('');
|
|
}}
|
|
onKeyDown={(e) => {
|
|
if (e.key === 'Enter' && !e.shiftKey) {
|
|
e.preventDefault();
|
|
sendMessage(message);
|
|
setMessage('');
|
|
}
|
|
}}
|
|
className="w-full"
|
|
>
|
|
<div className="flex flex-col bg-[#111111] px-5 pt-5 pb-2 rounded-lg w-full border border-[#1C1C1C]">
|
|
<TextareaAutosize
|
|
value={message}
|
|
onChange={(e) => setMessage(e.target.value)}
|
|
minRows={2}
|
|
className="bg-transparent placeholder:text-white/50 text-sm text-white resize-none focus:outline-none w-full max-h-24 lg:max-h-36 xl:max-h-48"
|
|
placeholder="Ask anything..."
|
|
/>
|
|
<div className="flex flex-row items-center justify-between mt-4">
|
|
<div className="flex flex-row items-center space-x-1 -mx-2">
|
|
<Focus />
|
|
<Attach />
|
|
</div>
|
|
<div className="flex flex-row items-center space-x-4 -mx-2">
|
|
<CopilotToggle
|
|
copilotEnabled={copilotEnabled}
|
|
setCopilotEnabled={setCopilotEnabled}
|
|
/>
|
|
<button
|
|
disabled={message.trim().length === 0}
|
|
className="bg-[#24A0ED] text-white disabled:text-white/50 hover:bg-opacity-85 transition duration-100 disabled:bg-[#ececec21] rounded-full p-2"
|
|
>
|
|
<ArrowRight className="bg-background" size={17} />
|
|
</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</form>
|
|
);
|
|
};
|
|
|
|
export default EmptyChatMessageInput;
|