all repos — archive/homestead @ 6b02186505264dc5a05a74bce1f9dcc3f91d08e1

My future indieweb platform

refactor: Separate templates into layout/body
Alan Pearce alan@alanpearce.eu
Sat, 24 Jun 2017 12:11:46 +0200
commit

6b02186505264dc5a05a74bce1f9dcc3f91d08e1

parent

f9fd0d795fb7bff10cb759f2300200d50b0fbab3

M src/index.jssrc/index.js
@@ -20,12 +20,21 @@ const Posts = require('./modules/posts.js')
 const posts = Posts.getFolder(config.posts.folder)
 
-const index = () => fs.createReadStream(`${__dirname}/templates/index.html`)
+const templateReader = template => () =>
+  fs.createReadStream(`${__dirname}/templates/${template}.html`)
+const templates = {
+  layout: templateReader('layout'),
+  home: templateReader('home'),
+  post: templateReader('post'),
+  taxon: templateReader('taxon')
+}
 
 function setTitle (pageTitle) {
-  return rheo.template(s =>
-    s.inner('title', rheo((pageTitle ? ' · ' : '') + config.site.title))
-  )
+  return rheo.template(function (s) {
+    return s
+      .inner('title', rheo((pageTitle ? ' · ' : '') + config.site.title))
+      .inner('body header h1', rheo(config.site.title))
+  })
 }
 
 function renderPostListItem (template, [, post]) {
@@ -38,13 +47,19 @@ function toArrayStream (iterator) {   return streamify(Array.from(iterator.entries()))
 }
 
+function showPage (name) {
+  return function (els) {
+    return rheo(templates[name]())
+  }
+}
+
 const postsStream = toArrayStream(posts)
 router.get('home', '/', async function (ctx, next) {
   ctx.set('Content-Type', 'text/html')
-  ctx.body = index()
+  ctx.body = templates
+    .layout()
     .pipe(rheo())
-    .inner('body', pages => pages.find('main.homepage'))
-    .inner('h1', rheo(config.site.title))
+    .outer('main', showPage('home'))
     .inner('.posts', function (postsTemplate) {
       return postsStream.pipe(postsTemplate.map(renderPostListItem))
     })
@@ -58,9 +73,10 @@ const post = posts.get(ctx.params.filename)   post.body = Posts.render(post)
 
   ctx.set('Content-Type', 'text/html')
-  ctx.body = index()
+  ctx.body = templates
+    .layout()
     .pipe(rheo())
-    .inner('body', pages => pages.find('main.post'))
+    .inner('main', showPage('post'))
     .inner('article h1', rheo(post.data.get('title')))
     .inner('article main', rheo(post.body))
     .pipe(setTitle())
@@ -78,9 +94,10 @@ `Could not find ${term} ${value}`     )
 
     ctx.set('Content-Type', 'text/html')
-    ctx.body = index()
+    ctx.body = templates
+      .layout()
       .pipe(rheo())
-      .inner('body', pages => pages.find('main.taxon'))
+      .inner('main', showPage('taxon'))
       .inner('h1', rheo(config.site.title))
       .inner('.posts', function (postsTemplate) {
         return toArrayStream(items.get(value)).pipe(
A src/templates/home.html
@@ -0,0 +1,7 @@+<main class="home">
+  <ul class="posts">
+    <li class="post">
+      <a href="/">Test post please ignore</a>
+    </li>
+  </ul>
+</main>
D src/templates/index.html
@@ -1,36 +0,0 @@-<!doctype html>
-<html lang="en">
-  <head>
-    <meta charset="utf-8"/>
-    <title></title>
-  </head>
-  <body>
-    <main class="homepage">
-      <h1>hello world</h1>
-
-      <ul class="posts">
-        <li class="post">
-          <a href="/">Test post please ignore</a>
-        </li>
-      </ul>
-    </main>
-    <main class="post">
-      <article>
-        <h1>post title</h1>
-        <main>
-          Fringilla ut morbi tincidunt augue interdum velit euismod!
-          Interdum velit laoreet id donec ultrices tincidunt arcu, non
-          sodales neque sodales ut etiam sit amet nisl purus, in
-          mollis nunc sed. 
-        </main>
-      </article>
-    </main>
-    <main class="taxon">
-      <ul class="posts">
-        <li class="post">
-          <a href="/">Test post please ignore</a>
-        </li>
-      </ul>
-    </main>
-  </body>
-</html>
A src/templates/layout.html
@@ -0,0 +1,13 @@+<!doctype html>
+<html lang="en">
+  <head>
+    <meta charset="utf-8"/>
+    <title></title>
+  </head>
+  <body>
+    <header>
+      <h1>hello world</h1>
+    </header>
+    <main></main>
+  </body>
+</html>
A src/templates/post.html
@@ -0,0 +1,11 @@+<main class="post">
+  <article>
+    <h1>post title</h1>
+    <main>
+      Fringilla ut morbi tincidunt augue interdum velit euismod!
+      Interdum velit laoreet id donec ultrices tincidunt arcu, non
+      sodales neque sodales ut etiam sit amet nisl purus, in
+      mollis nunc sed.
+    </main>
+  </article>
+</main>
A src/templates/taxon.html
@@ -0,0 +1,7 @@+<main class="taxon">
+  <ul class="posts">
+    <li class="post">
+      <a href="/">Test post please ignore</a>
+    </li>
+  </ul>
+</main>