diff options
Diffstat (limited to 'web/homepage/default.nix')
-rw-r--r-- | web/homepage/default.nix | 72 |
1 files changed, 0 insertions, 72 deletions
diff --git a/web/homepage/default.nix b/web/homepage/default.nix deleted file mode 100644 index 22380fdea700..000000000000 --- a/web/homepage/default.nix +++ /dev/null @@ -1,72 +0,0 @@ -# Assembles the website index and configures an nginx instance to -# serve it. -# -# The website is made up of a simple header&footer and content -# elements for things such as blog posts and projects. -# -# Content for the blog is in //web/blog instead of here. -{ depot, lib, ... }: - -with depot; -with nix.yants; - -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 = post.title; - url = "/blog/${post.key}"; - date = post.date; - }); - - 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: '' - <a href="${entry.url}" class="entry ${entry.class}"> - <div> - <p class="entry-title">${escape entry.title}</p> - ${ - lib.optionalString ((entry ? description) && (entry.description != null)) - "<p class=\"entry-description\">${escape entry.description}</p>" - } - <p class="entry-date">${formatEntryDate entry}</p> - </div> - </a> - ''); - - 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)); -in runCommandNoCC "website" {} '' - mkdir $out - cp ${homepage} $out/index.html - cp -r ${./static} $out/static -'' |