2023-07-12 22:42:21 +03:00
|
|
|
#!/bin/bash
|
2023-07-13 02:45:53 +03:00
|
|
|
# noter 1.0.2 - @k@layer8.space - mit
|
2023-07-12 22:42:21 +03:00
|
|
|
|
|
|
|
nlog() {
|
|
|
|
local ORANGE='\033[0;33m'
|
|
|
|
local NO_COLOR='\033[0m'
|
|
|
|
echo -e "${ORANGE}[noter] | ${1} ${NO_COLOR}"
|
|
|
|
}
|
|
|
|
|
|
|
|
generate_note_html() {
|
|
|
|
local note_date="$(date -d "$(basename "$1" .txt)" +"%B %d, %Y")"
|
|
|
|
echo "<div class='note'>"
|
|
|
|
echo "<h3>$note_date</h3>"
|
|
|
|
echo "<pre>$(cat "$1")</pre>"
|
|
|
|
echo "</div>"
|
|
|
|
}
|
|
|
|
|
|
|
|
if [ ! -d "notes" ]; then
|
|
|
|
nlog "Error: 'notes' folder not found!"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
notecount=$(find notes -name "*.txt" ! -empty | wc -l)
|
|
|
|
|
|
|
|
# Create HTML file
|
|
|
|
output_file="notes.html"
|
|
|
|
echo "<!DOCTYPE html>
|
|
|
|
<html>
|
|
|
|
<head>
|
2023-07-13 02:45:53 +03:00
|
|
|
<meta charset='utf-8'>
|
2023-07-12 22:42:21 +03:00
|
|
|
<title>$notecount notes | noter</title>
|
|
|
|
<meta property='og:title' content='noter | simple notes with bash' />
|
|
|
|
<meta property='og:description' content='noter | view & share your notes' />
|
|
|
|
<meta property='og:type' content='website' />
|
|
|
|
<meta property='og:generator' content='noter' />
|
|
|
|
<!-- those who seek, shall see - but thy shall be prepared... -->
|
|
|
|
<link rel='icon' type='image/png' href='
|
|
|
|
<meta name='last-generated' content='$(date +"%Y-%m-%d %H:%M:%S")' />
|
|
|
|
<style>
|
|
|
|
body {
|
|
|
|
background-color: #0f0f0f;
|
|
|
|
color: #fff;
|
|
|
|
font-family: Arial, sans-serif;
|
|
|
|
display: flex;
|
|
|
|
align-items: center;
|
|
|
|
justify-content: center;
|
|
|
|
height: 100%;
|
|
|
|
margin: 0;
|
|
|
|
}
|
|
|
|
.container {
|
|
|
|
max-width: 800px;
|
|
|
|
padding: 20px;
|
|
|
|
}
|
|
|
|
.note {
|
|
|
|
background-color: #181717;
|
|
|
|
padding: 10px;
|
|
|
|
margin-bottom: 20px;
|
|
|
|
}
|
|
|
|
h1 {
|
|
|
|
text-align: center;
|
|
|
|
}
|
|
|
|
h3 {
|
|
|
|
color: #fff;
|
|
|
|
}
|
|
|
|
pre {
|
|
|
|
color: #fff;
|
|
|
|
white-space: pre-wrap;
|
|
|
|
}
|
|
|
|
.back-to-top {
|
|
|
|
text-align: right;
|
|
|
|
margin-top: 20px;
|
|
|
|
}
|
|
|
|
.last-updated {
|
|
|
|
text-align: right;
|
|
|
|
margin-bottom: 20px;
|
|
|
|
color: #888;
|
|
|
|
font-size: 12px;
|
|
|
|
}
|
|
|
|
</style>
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<div class='container'><h1>notes</h1>" >"$output_file"
|
|
|
|
|
|
|
|
# loop for every note in notes
|
|
|
|
nlog "generating page..."
|
|
|
|
for file in $(ls -r notes/*.txt); do
|
|
|
|
nlog "processing: $file"
|
|
|
|
if [ -f "$file" ] && [ -s "$file" ]; then
|
|
|
|
generate_note_html "$file" >>"$output_file"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
# bottom navigation
|
2023-07-13 02:45:53 +03:00
|
|
|
echo "<div class='generated-with'>generated with <a href='https://git.sr.ht/~koutsie/noter'>noter</a></div>" >>"$output_file"
|
2023-07-12 22:42:21 +03:00
|
|
|
echo "<div class='back-to-top'><a href='#'>Back to Top</a></div>" >>"$output_file"
|
2023-07-13 02:45:53 +03:00
|
|
|
echo "<div class='last-updated'>last Updated: $(date +"%Y-%m-%d %H:%M:%S")</div>" >>"$output_file"
|
2023-07-12 22:42:21 +03:00
|
|
|
|
|
|
|
echo "</div>
|
|
|
|
</body>
|
|
|
|
</html>" >>"$output_file"
|
|
|
|
|
|
|
|
nlog "Done, please see: $output_file."
|