-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
57 lines (48 loc) · 1.78 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
let postsContainer = document.getElementById("posts");
let copyright = document.getElementById("copyright");
copyright.innerHTML = "© 2023 - " + new Date().getFullYear() +
" Cameron Seid<br/>me @ deltaryz.com";
// grab the posts json from the server
// (this should be automatically updated frequently)
fetch("posts.json")
.then((response) => response.json())
.then((data) => {
// iterate through each entry
data.forEach((element) => {
// create panel element
let panelDiv = document.createElement("div");
panelDiv.className = "mui-panel";
// create title element
let title = document.createElement("h1");
title.className = "header";
title.textContent = element.title;
// create date element
let date = document.createElement("h3");
date.className = "date";
date.textContent = element.date.slice(0, 10);
// create preview of content
let preview = document.createElement("p");
// for styling
preview.className = "preview";
// trim to only a few sentences
const sentenceRegex = /[^.!?]+[.!?]+/g;
const sentences = element.text.match(sentenceRegex);
preview.textContent = sentences.slice(0, 7).join(" ");
// create button element
let a = document.createElement("a");
a.href = element.url;
let button = document.createElement("button");
button.className = "mui-btn mui-btn--primary mui-btn--raised";
button.textContent = "Read More";
a.appendChild(button);
// put it all together
panelDiv.appendChild(title);
panelDiv.appendChild(date);
panelDiv.appendChild(preview);
panelDiv.appendChild(a);
postsContainer.appendChild(panelDiv);
});
})
.catch((error) => {
console.error("Error:", error);
});