about summary refs log tree commit diff
path: root/users/wpcarro/website/blog
diff options
context:
space:
mode:
authorWilliam Carroll <wpcarro@gmail.com>2021-12-28T00·06-0400
committerclbot <clbot@tvl.fyi>2021-12-28T00·09+0000
commite107311cb87fc219889f37f0c67cfea22b4a99e7 (patch)
treef52e7b5859eabb14a9cbeb17e68aa741ea9c3348 /users/wpcarro/website/blog
parent52369a11e3dee035b575281c80e2bf9a65546435 (diff)
refactor(wpcarro/website): Prefer substituteAll r/3483
`substituteAll` supports templating with @variables@, which I think really
cleans things up.

Change-Id: Icfad15ac9e174495ba02260d817f7330f1616c6f
Reviewed-on: https://cl.tvl.fyi/c/depot/+/4722
Reviewed-by: wpcarro <wpcarro@gmail.com>
Autosubmit: wpcarro <wpcarro@gmail.com>
Tested-by: BuildkiteCI
Diffstat (limited to 'users/wpcarro/website/blog')
-rw-r--r--users/wpcarro/website/blog/default.nix47
-rw-r--r--users/wpcarro/website/blog/fragments/.skip-subtree0
-rw-r--r--users/wpcarro/website/blog/fragments/post.html8
-rw-r--r--users/wpcarro/website/blog/fragments/posts.html10
4 files changed, 34 insertions, 31 deletions
diff --git a/users/wpcarro/website/blog/default.nix b/users/wpcarro/website/blog/default.nix
index bef06cad7457..713c42a83b33 100644
--- a/users/wpcarro/website/blog/default.nix
+++ b/users/wpcarro/website/blog/default.nix
@@ -6,16 +6,16 @@ let
   inherit (builtins) hasAttr filter readFile;
   inherit (depot.web.blog) post includePost renderPost;
   inherit (depot.users) wpcarro;
-  inherit (pkgs) runCommandNoCC;
 
   config = {
     name = "wpcarro's blog";
     baseUrl = "https://wpcarro.dev/blog";
+    footer = "";
   };
 
   posts = filter includePost (list post (import ./posts.nix));
 
-  rendered = runCommandNoCC "wpcarros-blog" {} ''
+  rendered = pkgs.runCommandNoCC "wpcarros-blog-posts" {} ''
     mkdir -p $out
 
     ${lib.concatStringsSep "\n" (map (post:
@@ -23,41 +23,26 @@ let
     ) posts)}
   '';
 
-  formatDate = date: readFile (runCommandNoCC "date" {} ''
+  formatDate = date: readFile (pkgs.runCommandNoCC "date" {} ''
     date --date='@${toString date}' '+%B %e, %Y' > $out
   '');
 
-  postsList = pkgs.writeText "index.html" ''
-    <div class="max-w-sm md:max-w-prose mx-auto">
-      <section class="pt-8 pb-14">
-        <p class="font-bold pb-4">Personal blog by <a class="font-bold text-blue-600 hover:underline" href="https://wpcarro.dev">wpcarro</a>.</p>
-        <p class="text-gray-500">&gt; Half-baked musings lossily encoded.</p>
-        <p class="text-gray-500">&gt; - misc reviewer</p>
-      </section>
-      <ul>
-        ${lib.concatStringsSep "\n" (map (post: ''
-          <li class="pb-10">
-            <h2 class="text-bold font-2xl ">
-              <a class="font-bold text-blue-600 hover:underline" href="${config.baseUrl}/${post.key}.html">
-                ${post.title}
-              </a>
-            </h2>
-            <p class="text-gray-500">
-              ${formatDate post.date}
-            </p>
-          </li>
-        '') posts)}
-      </ul>
-    </div>
-  '';
+  postsHtml = readFile (pkgs.substituteAll {
+    src = ./fragments/posts.html;
+    postsHtml = lib.concatStringsSep "\n" (map toPostHtml posts);
+  });
+
+  toPostHtml = post: readFile (pkgs.substituteAll {
+    src = ./fragments/post.html;
+    postUrl = "${config.baseUrl}/${post.key}.html";
+    postTitle = post.title;
+    postDate = formatDate post.date;
+  });
 in {
   inherit posts rendered config;
 
-  root = runCommandNoCC "wpcarros-blog" {} ''
+  root = pkgs.runCommandNoCC "wpcarros-blog" {} ''
     mkdir -p $out
-
-    cat ${wpcarro.website.header} \
-        ${postsList} \
-        ${wpcarro.website.addendum} > $out/index.html
+    cp ${wpcarro.website.render postsHtml} $out/index.html
   '';
 }
diff --git a/users/wpcarro/website/blog/fragments/.skip-subtree b/users/wpcarro/website/blog/fragments/.skip-subtree
new file mode 100644
index 000000000000..e69de29bb2d1
--- /dev/null
+++ b/users/wpcarro/website/blog/fragments/.skip-subtree
diff --git a/users/wpcarro/website/blog/fragments/post.html b/users/wpcarro/website/blog/fragments/post.html
new file mode 100644
index 000000000000..44593094ecdf
--- /dev/null
+++ b/users/wpcarro/website/blog/fragments/post.html
@@ -0,0 +1,8 @@
+<li class="pb-6 md:pb-10">
+  <h2 class="text-bold text-xl">
+    <a class="font-bold text-blue-600 hover:underline" href="@postUrl@">
+      @postTitle@
+    </a>
+  </h2>
+  <p class="text-gray-500">@postDate@</p>
+</li>
diff --git a/users/wpcarro/website/blog/fragments/posts.html b/users/wpcarro/website/blog/fragments/posts.html
new file mode 100644
index 000000000000..699b28f366c0
--- /dev/null
+++ b/users/wpcarro/website/blog/fragments/posts.html
@@ -0,0 +1,10 @@
+<div class="max-w-sm md:max-w-prose mx-auto">
+  <section class="pt-8 pb-14">
+    <p class="font-bold pb-3 text-xl">
+      Personal blog by <a class="font-bold text-blue-600 hover:underline" href="https://wpcarro.dev">wpcarro</a>.
+    </p>
+    <p class="text-gray-500">&gt; Half-baked musings lossily encoded.</p>
+    <p class="text-gray-500">&gt; - misc reviewer</p>
+  </section>
+  <ul>@postsHtml@</ul>
+</div>