feat(web/homepage): Add Nix code to assemble the index page
This is not yet fully functional, but going in the right direction. Some concepts are introduced: * There is a light theme (used for blog entry pages) and a dark theme (used for the homepage itself) * Entries can be either blog posts, projects or miscellaneous things that I want to link people to (possibly with a comment) It might be interesting to add pages that filter to specific types, or some such, which should be relatively easy to do. Note that the layouts of entries are not actually done yet.
This commit is contained in:
parent
7935957938
commit
cce872e397
4 changed files with 86 additions and 1 deletions
|
@ -10,6 +10,55 @@
|
|||
with pkgs;
|
||||
with nix.yants;
|
||||
|
||||
third_party.callPackage ./nginx.nix {
|
||||
let
|
||||
inherit (builtins) readFile replaceStrings sort;
|
||||
inherit (third_party) writeFile runCommandNoCC;
|
||||
|
||||
# The different types of entries on the homepage.
|
||||
entryClass = enum "entryClass" [ "blog" "project" "misc" ];
|
||||
|
||||
# The definition of a single entry.
|
||||
entry = struct "entry" {
|
||||
class = entryClass;
|
||||
title = string;
|
||||
url = string;
|
||||
date = int; # epoch
|
||||
description = option string;
|
||||
};
|
||||
|
||||
escape = replaceStrings [ "<" ">" "&" "'" ] [ "<" ">" "&" "'" ];
|
||||
|
||||
postToEntry = defun [ web.blog.post entry ] (post: {
|
||||
class = "blog";
|
||||
title = "Blog: " + post.title;
|
||||
url = "/blog/${post.key}";
|
||||
date = post.date;
|
||||
});
|
||||
|
||||
# TODO(tazjin): add date formatting function
|
||||
entryToDiv = defun [ entry string ] (entry: ''
|
||||
<div class="entry ${entry.class}">
|
||||
<p class="entry-title">${escape entry.title}</p>
|
||||
${
|
||||
lib.optionalString ((entry ? description) && (entry.description != null))
|
||||
"<p class=\"entry-description\">${escape entry.description}</p>"
|
||||
}
|
||||
</div>
|
||||
'');
|
||||
|
||||
index = entries: third_party.writeText "index.html" (lib.concatStrings (
|
||||
[ (builtins.readFile ./header.html) ]
|
||||
++ (map entryToDiv (sort (a: b: a.date < b.date) entries))
|
||||
++ [ (builtins.readFile ./footer.html) ]
|
||||
));
|
||||
|
||||
homepage = index ((map postToEntry web.blog.posts) ++ (import ./entries.nix));
|
||||
website = runCommandNoCC "website" {} ''
|
||||
mkdir $out
|
||||
cp ${homepage} $out/index.html
|
||||
cp -r ${./static} $out/static
|
||||
'';
|
||||
in third_party.callPackage ./nginx.nix {
|
||||
inherit website;
|
||||
blog = web.blog;
|
||||
}
|
||||
|
|
1
web/homepage/entries.nix
Normal file
1
web/homepage/entries.nix
Normal file
|
@ -0,0 +1 @@
|
|||
[]
|
2
web/homepage/footer.html
Normal file
2
web/homepage/footer.html
Normal file
|
@ -0,0 +1,2 @@
|
|||
</div>
|
||||
</body>
|
33
web/homepage/header.html
Normal file
33
web/homepage/header.html
Normal file
|
@ -0,0 +1,33 @@
|
|||
<!DOCTYPE html>
|
||||
<head><meta charset="utf-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||
<meta name="description" content="tazjin's blog">
|
||||
<link rel="stylesheet" type="text/css" href="static/tazjin.css" media="all">
|
||||
<link rel="alternate" type="application/rss+xml" title="RSS-Feed" href="/rss.xml">
|
||||
<title>tazjin's interblag</title>
|
||||
</head>
|
||||
<body class="dark">
|
||||
<header>
|
||||
<h1>
|
||||
<a class="unstyled-link" href="/">tazjin's interblag</a>
|
||||
</h1>
|
||||
<hr>
|
||||
</header>
|
||||
<div class="introduction">
|
||||
<p>Hello, illuminated visitor.</p>
|
||||
<p>
|
||||
I'm tazjin. Usually you can find
|
||||
me <a href="https://git.tazj.in/about">programming computers</a>
|
||||
using tools such as <a href="https://nixos.org/nix">Nix</a>
|
||||
and <a href="https://www.gnu.org/software/emacs/">Emacs</a>,
|
||||
cuddling <a href="https://twitter.com/edefic">people I love</a>
|
||||
or posting nonsense <a href="https://twitter.com/tazjin">on the
|
||||
internet</a>.
|
||||
</p>
|
||||
<p>
|
||||
Below you can find a collection of my projects and blog posts.
|
||||
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>
|
||||
</div>
|
||||
<div class="entry-container">
|
Loading…
Reference in a new issue