import React, { useState } from 'react'; import { defineMessages, FormattedMessage, useIntl } from 'react-intl'; import { joinEvent } from 'soapbox/actions/events'; import { closeModal } from 'soapbox/actions/modals'; import { Modal, Text } from 'soapbox/components/ui'; import { useAppDispatch } from 'soapbox/hooks'; const messages = defineMessages({ placeholder: { id: 'join_event.placeholder', defaultMessage: 'Message to organizer' }, join: { id: 'join_event.join', defaultMessage: 'Request join' }, }); interface IAccountNoteModal { statusId: string, } const AccountNoteModal: React.FC = ({ statusId }) => { const intl = useIntl(); const dispatch = useAppDispatch(); const [participationMessage, setParticipationMessage] = useState(''); const [isSubmitting, setIsSubmitting] = useState(false); const onClose = () => { dispatch(closeModal('JOIN_EVENT')); }; const handleChange: React.ChangeEventHandler = e => { setParticipationMessage(e.target.value); }; const handleSubmit = () => { setIsSubmitting(true); dispatch(joinEvent(statusId, participationMessage))?.then(() => { onClose(); }).catch(() => {}); }; const handleKeyDown: React.KeyboardEventHandler = e => { if (e.key === 'Enter' && (e.ctrlKey || e.metaKey)) { handleSubmit(); } }; return ( } onClose={onClose} confirmationAction={handleSubmit} confirmationText={intl.formatMessage(messages.join)} confirmationDisabled={isSubmitting} >