2023-05-24 15:34:43 +03:00
|
|
|
import React, { useEffect, useState } from "react";
|
|
|
|
import PhoneInput from "react-phone-input-2";
|
2023-05-31 08:36:15 +03:00
|
|
|
import "react-phone-input-2/lib/style.css";
|
|
|
|
import { useNavigate, useParams } from "react-router-dom";
|
|
|
|
import Swal from "sweetalert2";
|
|
|
|
import withReactContent from "sweetalert2-react-content";
|
2023-05-24 15:34:43 +03:00
|
|
|
|
2023-05-30 10:10:34 +03:00
|
|
|
import { apiRequest } from "@api/request";
|
2023-05-31 08:36:15 +03:00
|
|
|
|
2023-05-30 10:54:47 +03:00
|
|
|
import { Loader } from "@components/Common/Loader/Loader";
|
2023-05-24 15:34:43 +03:00
|
|
|
|
|
|
|
import "./form.scss";
|
|
|
|
|
|
|
|
const SweetAlert = withReactContent(Swal);
|
|
|
|
|
|
|
|
const Form = () => {
|
|
|
|
const navigate = useNavigate();
|
|
|
|
|
|
|
|
const urlParams = useParams();
|
|
|
|
|
|
|
|
const [status, setStatus] = useState(null);
|
|
|
|
const [data, setData] = useState({
|
|
|
|
email: "",
|
|
|
|
phone: "",
|
|
|
|
comment: "",
|
|
|
|
});
|
|
|
|
const [isFetching, setIsFetching] = useState(false);
|
|
|
|
|
|
|
|
const handleModal = (status) => {
|
|
|
|
SweetAlert.fire({
|
|
|
|
text:
|
2023-05-31 11:24:46 +03:00
|
|
|
// eslint-disable-next-line no-constant-condition
|
2023-05-24 15:34:43 +03:00
|
|
|
status !== 200 || 201 ? "Какие-то неполадки =(" : "Форма отправлена",
|
|
|
|
preConfirm: () =>
|
2023-05-31 11:24:46 +03:00
|
|
|
// eslint-disable-next-line no-constant-condition
|
2023-05-24 15:34:43 +03:00
|
|
|
status !== 200 || 201
|
|
|
|
? () => {
|
|
|
|
setStatus(null);
|
|
|
|
}
|
|
|
|
: () => {
|
|
|
|
setStatus(null);
|
|
|
|
navigate(`/candidate/${urlParams.id}`);
|
|
|
|
},
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
if (status) {
|
|
|
|
handleModal(status);
|
|
|
|
}
|
|
|
|
}, [status]);
|
|
|
|
|
|
|
|
const handleChange = (e) => {
|
|
|
|
const { id, value } = e.target;
|
|
|
|
|
|
|
|
setData((prev) => ({
|
|
|
|
...prev,
|
|
|
|
[id]: value,
|
|
|
|
}));
|
|
|
|
};
|
|
|
|
|
|
|
|
const handleSubmit = (e) => {
|
|
|
|
e.preventDefault();
|
|
|
|
|
|
|
|
setIsFetching(true);
|
|
|
|
const formData = new FormData();
|
|
|
|
formData.append("profile_id", urlParams.id);
|
|
|
|
formData.append("Email", data.email);
|
|
|
|
formData.append("phone", data.phone);
|
|
|
|
formData.append("comment", data.comment);
|
|
|
|
|
|
|
|
apiRequest("/interview-request/create-interview-request", {
|
|
|
|
method: "POST",
|
|
|
|
params: {
|
|
|
|
profile_id: urlParams.id,
|
|
|
|
...data,
|
|
|
|
},
|
|
|
|
}).then((res) => {
|
|
|
|
setStatus(res);
|
|
|
|
setIsFetching(false);
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div className="row">
|
|
|
|
<div className="col-sm-12">
|
|
|
|
<form className="form" id="test">
|
|
|
|
<label htmlFor="email">Емейл:</label>
|
|
|
|
<input
|
|
|
|
onChange={handleChange}
|
|
|
|
id="email"
|
|
|
|
name="Email"
|
|
|
|
type="email"
|
|
|
|
placeholder="Емейл"
|
|
|
|
value={data.email}
|
|
|
|
/>
|
|
|
|
|
|
|
|
<label htmlFor="phone">Номер телефона:</label>
|
|
|
|
<PhoneInput
|
|
|
|
id="phone"
|
|
|
|
name="Phone"
|
|
|
|
country={"ru"}
|
|
|
|
value={data.phone}
|
|
|
|
onChange={(e) =>
|
|
|
|
handleChange({ target: { value: e, id: "phone" } })
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
|
|
|
|
<textarea
|
|
|
|
onChange={handleChange}
|
|
|
|
id="comment"
|
|
|
|
rows="5"
|
|
|
|
cols="40"
|
|
|
|
name="Comment"
|
|
|
|
placeholder="Оставьте комментарий"
|
|
|
|
value={data.comment}
|
|
|
|
></textarea>
|
|
|
|
|
|
|
|
<button onClick={handleSubmit} className="form__btn" type="submit">
|
|
|
|
{isFetching ? <Loader /> : "Отправить"}
|
|
|
|
</button>
|
|
|
|
</form>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default Form;
|