-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
101 lines (88 loc) · 2.88 KB
/
index.js
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
// ---
const hamMenuBtn = document.querySelector(".header__main-ham-menu-cont");
const smallMenu = document.querySelector(".header__sm-menu");
const headerHamMenuBtn = document.querySelector(".header__main-ham-menu");
const headerHamMenuCloseBtn = document.querySelector(
".header__main-ham-menu-close"
);
const headerSmallMenuLinks = document.querySelectorAll(
".header__sm-menu-link"
);
hamMenuBtn.addEventListener("click", () => {
if (smallMenu.classList.contains("header__sm-menu--active")) {
smallMenu.classList.remove("header__sm-menu--active");
} else {
smallMenu.classList.add("header__sm-menu--active");
}
if (headerHamMenuBtn.classList.contains("d-none")) {
headerHamMenuBtn.classList.remove("d-none");
headerHamMenuCloseBtn.classList.add("d-none");
} else {
headerHamMenuBtn.classList.add("d-none");
headerHamMenuCloseBtn.classList.remove("d-none");
}
});
for (let i = 0; i < headerSmallMenuLinks.length; i++) {
headerSmallMenuLinks[i].addEventListener("click", () => {
smallMenu.classList.remove("header__sm-menu--active");
headerHamMenuBtn.classList.remove("d-none");
headerHamMenuCloseBtn.classList.add("d-none");
});
}
// ---
const headerLogoConatiner = document.querySelector(
".header__logo-container"
);
headerLogoConatiner.addEventListener("click", () => {
location.href = "index.html";
});
async function sendPascalMsg(sendingData) {
try {
const resp = await fetch(
"https://blogvana-backend.onrender.com/api/message/contact-me",
{
method: "POST",
headers: {
"Content-Type": "application/json", // Set the content type to JSON
},
body: JSON.stringify({ sendingData, from: "portfolio" }), // Convert data to JSON string
}
);
if (!resp.ok) {
throw new Error(`HTTP error: ${resp.status}`);
}
const data = await resp.json();
return data;
} catch (error) {
throw error;
}
}
function handleSubmit(event) {
event.preventDefault();
const formData = {
name: document.getElementById("name").value,
email: document.getElementById("email").value,
message: document.getElementById("message").value,
};
const formElement = document.querySelector(".contact__form");
const existingMessageElement = formElement.querySelector(".message");
// Remove existing message if it exists
if (existingMessageElement) {
formElement.removeChild(existingMessageElement);
}
const messageElement = document.createElement("h3");
messageElement.classList.add("message"); // Add a class to identify the message element
sendPascalMsg(formData)
.then((data) => {
// Handle success
messageElement.textContent = "Message sent successfully";
formElement.appendChild(messageElement);
messageElement.classList.add("message_success");
})
.catch((error) => {
// Handle error
messageElement.textContent = "Failed to send message";
formElement.appendChild(messageElement);
messageElement.classList.add("message_failed");
});
}