82 lines
2.2 KiB
JavaScript
82 lines
2.2 KiB
JavaScript
|
const fs = require('fs');
|
||
|
|
||
|
const filePath = '/srv/www/htdocs/blog/index.html';
|
||
|
const blogs = require("/srv/www/htdocs/blog/blogs.js")
|
||
|
|
||
|
function escapeQuotes(value) {
|
||
|
return value.replace(/["'&<>]/g, function (char) {
|
||
|
switch (char) {
|
||
|
case '"':
|
||
|
return """;
|
||
|
case "'":
|
||
|
return "'";
|
||
|
case "&":
|
||
|
return "&";
|
||
|
case "<":
|
||
|
return "<";
|
||
|
case ">":
|
||
|
return ">";
|
||
|
default:
|
||
|
return char;
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
console.log(blogs)
|
||
|
|
||
|
let linksText = "<a href='blogs/all.html'>ALL POSTS</a>"
|
||
|
|
||
|
let dateObject
|
||
|
let month
|
||
|
let year
|
||
|
|
||
|
let oldMonth = "blibidy blob"
|
||
|
let oldYear = "bloopy aw"
|
||
|
|
||
|
for (let page = blogs.length - 1; page >= 0; page--) {
|
||
|
dateObject = new Date(blogs[page][2])
|
||
|
month = dateObject.toLocaleString('en-US', {month: 'long'});
|
||
|
year = dateObject.getFullYear()
|
||
|
const dayOfWeek = dateObject.toLocaleString('en-US', { weekday: 'long' }); // 'long' returns the full day name
|
||
|
const dayOfMonth = dateObject.getDate();
|
||
|
console.log(month, year, dayOfMonth, dayOfWeek)
|
||
|
|
||
|
|
||
|
|
||
|
if (month != oldMonth) {
|
||
|
linksText += (`<h4>${month} ${year}</h4>`)
|
||
|
}
|
||
|
|
||
|
linksText += (`<li class="indent">• ${dayOfWeek} ${dayOfMonth}: <a href='blogs/${page}.html'>${escapeQuotes(blogs[page][0])}</a></li>`)
|
||
|
|
||
|
oldYear = year
|
||
|
oldMonth = month
|
||
|
}
|
||
|
|
||
|
// Step 2: Read the HTML file
|
||
|
fs.readFile(filePath, 'utf8', (err, data) => {
|
||
|
if (err) {
|
||
|
console.error(err);
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
// Step 3: Identify the target div
|
||
|
const targetDivId = 'links';
|
||
|
|
||
|
// Step 4: Create the new content (e.g., a paragraph element)
|
||
|
const newContent = linksText
|
||
|
|
||
|
// Step 5: Replace the existing content in the target div
|
||
|
const regex = new RegExp(`<div id="${targetDivId}">([\\s\\S]*?)<\/div>`);
|
||
|
const updatedData = data.replace(regex, `<div id="${targetDivId}">${newContent}</div>`);
|
||
|
|
||
|
// Step 6: Save the updated content back to the file
|
||
|
fs.writeFile(filePath, updatedData, 'utf8', (err) => {
|
||
|
if (err) {
|
||
|
console.error(err);
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
console.log('Content replaced successfully in ', filePath);
|
||
|
});
|
||
|
});
|