feat(web/homepage): Add templating for entries on the homepage

Adds the actual insertion of entries into the homepage, subtly
colour-coding different types of entries.
This commit is contained in:
Vincent Ambo 2020-02-09 00:02:10 +00:00
parent 39854d71b2
commit 75969d886d
3 changed files with 91 additions and 32 deletions

View file

@ -30,25 +30,37 @@ let
postToEntry = defun [ web.blog.post entry ] (post: { postToEntry = defun [ web.blog.post entry ] (post: {
class = "blog"; class = "blog";
title = "Blog: " + post.title; title = post.title;
url = "/blog/${post.key}"; url = "/blog/${post.key}";
date = post.date; date = post.date;
}); });
# TODO(tazjin): add date formatting function formatDate = defun [ int string ] (date: readFile (runCommandNoCC "date" {} ''
date --date='@${toString date}' '+%Y-%m-%d' > $out
''));
formatEntryDate = defun [ entry string ] (entry: entryClass.match entry.class {
blog = "Blog post from ${formatDate entry.date}";
project = "Project from ${formatDate entry.date}";
misc = "Posted on ${formatDate entry.date}";
});
entryToDiv = defun [ entry string ] (entry: '' entryToDiv = defun [ entry string ] (entry: ''
<div class="entry ${entry.class}"> <div class="entry ${entry.class}">
<p class="entry-title">${escape entry.title}</p> <p>
<a class="entry-title" href="${entry.url}">${escape entry.title}</a>
</p>
${ ${
lib.optionalString ((entry ? description) && (entry.description != null)) lib.optionalString ((entry ? description) && (entry.description != null))
"<p class=\"entry-description\">${escape entry.description}</p>" "<p class=\"entry-description\">${escape entry.description}</p>"
} }
<p class="entry-date">${formatEntryDate entry}</p>
</div> </div>
''); '');
index = entries: third_party.writeText "index.html" (lib.concatStrings ( index = entries: third_party.writeText "index.html" (lib.concatStrings (
[ (builtins.readFile ./header.html) ] [ (builtins.readFile ./header.html) ]
++ (map entryToDiv (sort (a: b: a.date < b.date) entries)) ++ (map entryToDiv (sort (a: b: a.date > b.date) entries))
++ [ (builtins.readFile ./footer.html) ] ++ [ (builtins.readFile ./footer.html) ]
)); ));

View file

@ -9,7 +9,7 @@
<body class="dark"> <body class="dark">
<header> <header>
<h1> <h1>
<a class="unstyled-link" href="/">tazjin&#39;s interblag</a> <a class="interblag-title" href="/">tazjin&#39;s interblag</a>
</h1> </h1>
<hr> <hr>
</header> </header>
@ -25,9 +25,11 @@
internet</a>. internet</a>.
</p> </p>
<p> <p>
Below you can find a collection of my projects and blog posts. Below is a collection of
If you'd like to get in touch about anything, send me a mail at my <span class="project">projects</span>, <span class="blog">blog
mail@[this domain] or ping me on IRC or Twitter. posts</span> and some <span class="misc">random things</span> by
me or others. If you'd like to get in touch about anything, send
me a mail at mail@[this domain] or ping me on IRC or Twitter.
</p> </p>
</div> </div>
<div class="entry-container"> <div class="entry-container">

View file

@ -28,7 +28,6 @@
body { body {
margin: 40px auto; margin: 40px auto;
max-width: 650px;
line-height: 1.6; line-height: 1.6;
font-size: 18px; font-size: 18px;
padding: 0 10px; padding: 0 10px;
@ -39,25 +38,14 @@ p, a :not(.uncoloured-link) {
color: inherit; color: inherit;
} }
.entry-container { h1, h2, h3 {
display: flex; line-height: 1.2
flex-direction: row;
flex-wrap: wrap;
} }
.entry { /* Homepage styling */
}
/* Light theme (used for the blog) */
.light {
color: #383838;
}
/* Dark theme (used for the homepage) */
.dark { .dark {
max-width: 800px;
background-color: #181818; background-color: #181818;
color: #e4e4ef; color: #e4e4ef;
} }
@ -66,23 +54,80 @@ p, a :not(.uncoloured-link) {
color: #96a6c8; color: #96a6c8;
} }
h1, h2, h3 { .entry-container {
line-height: 1.2 display: flex;
flex-direction: row;
flex-wrap: wrap;
justify-content: flex-start;
} }
.interblag-title {
text-decoration: none;
}
.entry {
width: 42%;
margin: 5px;
padding-left: 5px;
padding-right: 5px;
border: 2px solid;
border-radius: 5px;
flex-grow: 1;
}
.blog {
color: #268bd2;
border-color: #268bd2;
}
.project {
color: #9e95c7;
border-color: #9e95c7;
}
.misc {
color: #95a99f;
border-color: #95a99f;
}
.entry-title {
color: inherit !important;
font-weight: bold;
text-decoration: none;
}
.entry-date {
font-style: italic;
}
/* Blog styling */
.light {
max-width: 650px;
color: #383838;
}
.blog-title {
color: inherit;
text-decoration: none;
}
.footer { .footer {
text-align: right; text-align: right;
} }
.unstyled-link {
text-decoration: none;
}
.uncoloured-link {
color: inherit;
}
.date { .date {
text-align: right; text-align: right;
font-style: italic; font-style: italic;
float: right; float: right;
} }
.inline { .inline {
display: inline; display: inline;
} }
pre {
min-width: 100%;
/* some code snippets escape to the side, but I don't want to wrap them */
width: max-content;
}