45 lines
No EOL
1.3 KiB
TypeScript
45 lines
No EOL
1.3 KiB
TypeScript
import React from 'react';
|
|
|
|
import { Textarea } from 'soapbox/components/ui';
|
|
import { Attachment } from 'soapbox/types/entities';
|
|
|
|
import ChatUpload from './chat-upload';
|
|
|
|
interface IChatTextarea extends React.ComponentProps<typeof Textarea> {
|
|
attachments?: Attachment[]
|
|
onDeleteAttachment?: () => void
|
|
}
|
|
|
|
/** Custom textarea for chats. */
|
|
const ChatTextarea: React.FC<IChatTextarea> = ({ attachments, onDeleteAttachment, ...rest }) => {
|
|
return (
|
|
<div className={`
|
|
bg-white
|
|
dark:bg-transparent
|
|
shadow-sm block w-full
|
|
sm:text-sm rounded-md
|
|
text-gray-900 dark:text-gray-100
|
|
border
|
|
placeholder:text-gray-600 dark:placeholder:text-gray-600 border-gray-400 dark:border-gray-800
|
|
dark:ring-1 focus-within:ring-1 dark:ring-gray-800 focus-within:ring-primary-500 focus-within:border-primary-500
|
|
dark:focus-within:ring-primary-500 dark:focus-within:border-primary-500
|
|
`}
|
|
>
|
|
{(!!attachments?.length) && (
|
|
<div className='p-3 pb-0'>
|
|
{attachments?.map(attachment => (
|
|
<ChatUpload
|
|
key={attachment.id}
|
|
attachment={attachment}
|
|
onDelete={onDeleteAttachment}
|
|
/>
|
|
))}
|
|
</div>
|
|
)}
|
|
|
|
<Textarea theme='transparent' {...rest} />
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default ChatTextarea; |