mirror of
https://github.com/elyby/accounts-frontend.git
synced 2025-01-04 11:12:49 +05:30
82abe0a746
Split popups controllers into separate components Implemented storybooks for all project's popups
44 lines
1.4 KiB
TypeScript
44 lines
1.4 KiB
TypeScript
import React, { ComponentType, useCallback, useRef, useState } from 'react';
|
|
import { useSelector } from 'react-redux';
|
|
|
|
import { send as sendFeedback } from 'app/services/api/feedback';
|
|
import { RootState } from 'app/reducers';
|
|
import logger from 'app/services/logger';
|
|
|
|
import ContactFormPopup from './ContactFormPopup';
|
|
import SuccessContactFormPopup from './SuccessContactFormPopup';
|
|
|
|
interface Props {
|
|
onClose?: () => void;
|
|
}
|
|
|
|
const ContactForm: ComponentType<Props> = ({ onClose }) => {
|
|
const userEmail = useSelector((state: RootState) => state.user.email);
|
|
const usedEmailRef = useRef(userEmail); // Use ref to avoid unneeded redraw
|
|
const [isSent, setIsSent] = useState<boolean>(false);
|
|
const onSubmit = useCallback(
|
|
(params: Parameters<typeof sendFeedback>[0]): Promise<void> =>
|
|
sendFeedback(params)
|
|
.then(() => {
|
|
setIsSent(true);
|
|
usedEmailRef.current = params.email;
|
|
})
|
|
.catch((resp) => {
|
|
if (!resp.errors) {
|
|
logger.warn('Error sending feedback', resp);
|
|
}
|
|
|
|
throw resp;
|
|
}),
|
|
[],
|
|
);
|
|
|
|
return isSent ? (
|
|
<SuccessContactFormPopup email={usedEmailRef.current} onClose={onClose} />
|
|
) : (
|
|
<ContactFormPopup initEmail={userEmail} onSubmit={onSubmit} onClose={onClose} />
|
|
);
|
|
};
|
|
|
|
export default ContactForm;
|