-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathloadProjects.js
43 lines (35 loc) · 1.59 KB
/
loadProjects.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
document.addEventListener("DOMContentLoaded", async function () {
const projectListContainer = document.getElementById("project-list");
try {
// Fetch projects from lambda & dynamo
const response = await fetch("https://niiy5egpuc4p2dcnmcpulfj3ua0eblai.lambda-url.us-east-1.on.aws?is_project=true");
if (!response.ok) {
throw new Error("Failed to fetch projects");
}
const projects = await response.json();
projectListContainer.innerHTML = "";
// Loop through projects and create HTML elements
projects.forEach(project => {
const projectElement = document.createElement("div");
projectElement.classList.add("project");
projectElement.innerHTML = `
<h3>
<a href="${project.link}" target="_blank" rel="noopener noreferrer">
${project.project_name}
</a>
</h3>
<p>${project.text}</p>
<br>
`;
if (project.application_link !== "closed") {
projectElement.innerHTML += `<p><b>Apply:</b> <a href="${project.application_link}" target="_blank" rel="noopener noreferrer">Click Here</a></p>`
} else {
projectElement.innerHTML += `<p><b>Apply:</b> Applications closed.</p>`
}
projectListContainer.appendChild(projectElement);
});
} catch (error) {
console.error("Error loading projects:", error);
projectListContainer.innerHTML = "<p>Failed to load projects.</p>";
}
});