import Note from '@/components/Note' import { Button } from '@/components/ui/button' import { ScrollArea } from '@/components/ui/scroll-area' import { useToast } from '@/hooks/use-toast' import { createCommentDraftEvent, createShortTextNoteDraftEvent } from '@/lib/draft-event' import { useNostr } from '@/providers/NostrProvider' import postContentCache from '@/services/post-content-cache.service' import { ChevronDown, ImageUp, LoaderCircle } from 'lucide-react' import { Event, kinds } from 'nostr-tools' import { useRef, useState } from 'react' import { useTranslation } from 'react-i18next' import Mentions from './Mentions' import { usePostEditor } from './PostEditorProvider' import PostOptions from './PostOptions' import PostTextarea, { TPostTextareaHandle } from './PostTextarea' import SendOnlyToSwitch from './SendOnlyToSwitch' import Uploader from './Uploader' export default function PostContent({ defaultContent = '', parentEvent, close }: { defaultContent?: string parentEvent?: Event close: () => void }) { const { t } = useTranslation() const { toast } = useToast() const { publish, checkLogin } = useNostr() const { uploadingFiles, setUploadingFiles } = usePostEditor() const [text, setText] = useState('') const textareaRef = useRef(null) const [posting, setPosting] = useState(false) const [showMoreOptions, setShowMoreOptions] = useState(false) const [addClientTag, setAddClientTag] = useState(false) const [specifiedRelayUrls, setSpecifiedRelayUrls] = useState(undefined) const [mentions, setMentions] = useState([]) const canPost = !!text && !posting && !uploadingFiles const post = async (e: React.MouseEvent) => { e.stopPropagation() checkLogin(async () => { if (!canPost) { close() return } setPosting(true) try { const draftEvent = parentEvent && parentEvent.kind !== kinds.ShortTextNote ? await createCommentDraftEvent(text, parentEvent, mentions, { addClientTag, protectedEvent: !!specifiedRelayUrls }) : await createShortTextNoteDraftEvent(text, mentions, { parentEvent, addClientTag, protectedEvent: !!specifiedRelayUrls }) await publish(draftEvent, { specifiedRelayUrls }) postContentCache.clearPostCache({ defaultContent, parentEvent }) close() } catch (error) { if (error instanceof AggregateError) { error.errors.forEach((e) => toast({ variant: 'destructive', title: t('Failed to post'), description: e.message }) ) } else if (error instanceof Error) { toast({ variant: 'destructive', title: t('Failed to post'), description: error.message }) } console.error(error) return } finally { setPosting(false) } toast({ title: t('Post successful'), description: t('Your post has been published') }) }) } return (
{parentEvent && (
)}
{ textareaRef.current?.appendText(url) }} onUploadingChange={(uploading) => setUploadingFiles((prev) => (uploading ? prev + 1 : prev - 1)) } accept="image/*,video/*,audio/*" >
) }