"use client";
import React, { useState } from "react";
import ReCAPTCHA from "react-google-recaptcha";
import axios from "axios";
export default function ContactFloat() {
const [open, setOpen] = useState(false);
const [showChat, setShowChat] = useState(false);
const [showSocial, setShowSocial] = useState(false);
/** Contact actions */
const extraIcons = [
{
href: "tel:647-722-3434",
src: "/assets/images/icons/call.webp",
label: "Call",
newTab: true,
},
{
action: () => setShowChat(true),
src: "/assets/images/chat.webp",
label: "Chat",
},
{
href: "https://wa.me/14379934477",
src: "/assets/images/icons/WhatsApp.svg.webp",
label: "WhatsApp",
newTab: true,
},
{
href: "https://www.instagram.com/elrapharehab/",
src: "/assets/images/insta.webp",
label: "Instagram",
newTab: true,
},
{
href: "https://www.facebook.com/ELRaphaRehabCenter/",
src: "/assets/images/fb.webp",
label: "Facebook",
newTab: true,
},
];
/** Social media list shown on Share click */
const socialIcons = [
{
href: "https://www.instagram.com/elrapharehab/",
iconClass: "icon-4",
label: "Instagram",
},
{
href: "https://www.facebook.com/ELRaphaRehabCenter/",
iconClass: "icon-7",
label: "Facebook",
},
];
return (
<>
{/* Floating Contact Buttons */}
{open && (
{extraIcons.map((icon, i) =>
icon.href ? (
) : (
)
)}
)}
{showSocial && (
{socialIcons.map((icon, i) => (
))}
)}
{showChat && setShowChat(false)} />}
>
);
}
function ChatForm({ onClose }) {
const [formData, setFormData] = useState({
username: "",
// lname: "",
email: "",
phone: "",
service: "",
message: "",
});
const [formErrors, setFormErrors] = useState({});
const [captchaToken, setCaptchaToken] = useState(null);
const [alert, setAlert] = useState({ show: false, type: "", message: "" });
const handleChange = (e) => {
const { name, value } = e.target;
setFormData((prev) => ({ ...prev, [name]: value }));
};
const handleCaptchaChange = (token) => {
// console.log("ReCAPTCHA token:", token);
setCaptchaToken(token);
};
const handleSubmit = async (e) => {
e.preventDefault();
// console.log("Form submitted:", formData);
const errors = {};
if (!formData.username.trim()) errors.username = "First Name is required.";
// if (!formData.lname.trim()) errors.lname = "Last Name is required.";
if (!formData.email.trim()) errors.email = "Email is required.";
if (!formData.phone.trim()) errors.phone = "Phone is required.";
if (!formData.service.trim()) errors.service = "Please select a service.";
if (!formData.message.trim()) errors.message = "Message is required.";
// if (!captchaToken) errors.captcha = "Please verify the CAPTCHA.";
setFormErrors(errors);
if (Object.keys(errors).length > 0) {
// console.log("Form validation errors:", errors);
return;
}
const emailData = {
name: formData.username,
phone: formData.phone,
email: formData.email,
subject: formData.service,
message: `Service: ${formData.service}
Message: ${formData.message}`,
to: "bloor@rapharehab.ca",
senderName: "Rapha Rehab Contact Page",
recaptchaToken: captchaToken,
};
try {
const res = await axios.post(
"https://mailserver.metatronnest.com/send",
emailData,
{ headers: { "Content-Type": "application/json" } }
);
setAlert({
show: true,
type: "success",
message: res?.data?.message || "Message sent successfully!",
});
setFormData({ username: "", email: "", phone: "", service: "", message: "" });
setCaptchaToken(null);
setFormErrors({});
} catch (error) {
setAlert({
show: true,
type: "danger",
message: "Failed to send message. Please try again later.",
});
}
};
return (
Chat with Us
{alert.show && (
{alert.message}
)}
);
}