File size: 6,981 Bytes
8b105ad 051fc03 8b105ad 051fc03 8b105ad |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 |
const { checkAndRefreshAccessToken } = require('../utils/refreshToken');
const { checkExistingContactRequest, insertContactRequest } = require('../utils/contactRequestDB');
const fetch = require('node-fetch');
const { sendEmail } = require('../utils/sendEmail');
//Getting Vapi Usage Flag (Whether to use or not)
const { useVapi} = require("../config");
const assistant_url = 'https://api.vapi.ai/call';
const submitContactForm = async (req, res) => {
const { name, email, phone, subject, message, consent, policyVersion } = req.body;
console.log('Received contact form submission:', req.body);
if (!name || !email || !phone || !subject || !message) {
return res.status(400).send({ error: 'All fields are required.' });
}
await checkAndRefreshAccessToken();
const existingRequest = await checkExistingContactRequest(name, email, subject);
if (existingRequest) {
console.log("Your contact request with the same subject is in queue");
return res.status(400).send({ error: 'Your contact request with the same subject is in queue' });
}
await insertContactRequest(name, email, phone, subject, message, consent, policyVersion);
console.log('Contact request added successfully');
try{
// ๐น Email to User
const userEmailSubject = `Contact Form Submission: ${subject}`;
const userEmailContent = `
<div style="font-family: Arial, sans-serif; color: #333;">
<center><img src="https://drive.google.com/thumbnail?id=17oMmzl_mTNvohvLhSWHbb_XNPfCC8KaO" alt="Genomatics Logo" height="150px"></center>
<h2 style="color: #0056b3;">Hello ${name},</h2>
<p>Thank you for reaching out to us! We have received your message and will get back to you soon.</p>
<p><strong>Your Submitted Information:</strong></p>
<p><strong>Name:</strong> ${name}</p>
<p><strong>Email:</strong> ${email}</p>
<p><strong>Subject:</strong> ${subject}</p>
<p><strong>Message:</strong></p>
<p>${message}</p>
<p>We appreciate your interest and are excited to help you. If you have any immediate questions, please feel free to reply to this email directly.</p>
<p style="margin-top: 20px;">Best regards,</p>
<p><strong>The Genomatics Team</strong></p>
<hr style="border: 0; height: 1px; background: #ddd; margin: 20px 0;">
<p style="font-size: 12px; color: #666;">
This email was sent in response to your contact form submission on the Genomatics platform.
</p>
<!-- Social Media Links Section -->
<div style="margin-top: 30px; text-align: center; display: flex; justify-content: center; align-items: center;">
<p>Follow us on social media:</p>
<a href="https://x.com/" target="_blank" style="margin: 0 10px;">
<img src="https://uxwing.com/wp-content/themes/uxwing/download/brands-and-social-media/x-social-media-white-icon.png" alt="Twitter" width="20" height="20" style="border-radius: 50%; background-color: #3A61B9; padding: 5px;">
</a>
<a href="https://www.linkedin.com/company/genomatics" target="_blank" style="margin: 0 10px;">
<img src="https://img.icons8.com/?size=100&id=102748&format=png&color=FFFFFF" alt="LinkedIn" width="20" height="20" style="border-radius: 50%; background-color: #3A61B9; padding: 5px;">
</a>
</div>
</div>`;
await sendEmail(email, userEmailSubject, userEmailContent);
console.log("Confirmation email sent to user");
// ๐น Email to Team
const teamEmail = process.env.TEAM_MAIL_IDS;
const teamEmailSubject = `New Contact Form Submission: ${subject}`;
const teamEmailContent = `
<div style="font-family: Arial, sans-serif; color: #333; line-height: 1.6;">
<center><img src="https://drive.google.com/thumbnail?id=17oMmzl_mTNvohvLhSWHbb_XNPfCC8KaO" alt="Genomatics Logo" height="150px"></center>
<h2 style="color: #0056b3;">๐ฉ New Contact Request Received</h2>
<p>Dear Team,</p>
<p>A new contact form with some general enquiry/request has been submitted. Details are as follows:</p>
<table style="width: 100%; border-collapse: collapse;">
<tr><td style="padding: 8px; font-weight: bold;">Name:</td><td style="padding: 8px;">${name}</td></tr>
<tr><td style="padding: 8px; font-weight: bold;">Email:</td><td style="padding: 8px;">${email}</td></tr>
<tr><td style="padding: 8px; font-weight: bold;">Phone:</td><td style="padding: 8px;">${phone}</td></tr>
<tr><td style="padding: 8px; font-weight: bold;">Subject:</td><td style="padding: 8px;">${subject}</td></tr>
<tr><td style="padding: 8px; font-weight: bold;">Message:</td><td style="padding: 8px;">${message}</td></tr>
</table>
<p>Please follow up with the requester accordingly.</p>
<p style="margin-top: 20px;">Best regards,</p>
<p><strong>Genomatics System</strong></p>
</div>`;
await sendEmail(teamEmail, teamEmailSubject, teamEmailContent);
console.log("Notification email sent to team");
res.status(200).send({ message: 'Contact message sent successfully!' });
} catch (error) {
console.error('Unable to send Contact request confirmation email, however request registered successfully!', error);
res.status(200).send({ error: 'Unable to send Contact request confirmation email, however request registered successfully!' });
}
// ๐น Vapi AI Call
const curr_time = new Date().toLocaleDateString('en-GB').replace(/\//g, '-');
const postData = {
"name": `${phone}_${curr_time}_CRC`,
"assistantId": process.env.CONTACT_ASSISTANT_ID,
"assistantOverrides": {
"variableValues": {
"name": name,
"subject": subject,
"comments": message
}
},
"customer": { "number": phone },
"phoneNumberId": process.env.PHONE_NUMBER_ID
};
if(useVapi){
fetch(assistant_url, {
method: 'POST',
headers: {
'Content-Type': 'application/json',
'Authorization': `Bearer ${process.env.VAPI_KEY}`
},
body: JSON.stringify(postData)
})
.then(response => response.json())
.then(data => console.log('Vapi AI Call Success:', data))
.catch(error => console.error('Vapi AI Call Error:', error));
}
};
module.exports = { submitContactForm }; |