all repos — archive/homestead @ 9937c2a51ad9944da0239ebd7f777e5d6d8233d4

My future indieweb platform

fix: Add missing doctype via stream concat

rheo appears to be stripping it out
Alan Pearce alan@alanpearce.eu
Fri, 30 Jun 2017 19:09:30 +0200
commit

9937c2a51ad9944da0239ebd7f777e5d6d8233d4

parent

31f441ff32ab9f52fc80d0835bdd074554587ef6

3 files changed, 42 insertions(+), 28 deletions(-)

jump to
M src/responders.jssrc/responders.js
@@ -4,6 +4,7 @@ const h = require("highland"); const fs = require("fs");
 const rheo = require("rheo");
 const indent = require("indent-string");
+const PassThrough = require("stream").PassThrough;
 
 const toLines = string =>
   string.split("\n").map((s, i, arr) => (i === arr.length - 1 ? s : s + "\n"));
@@ -25,6 +26,10 @@ const content = toLines(     indentForTemplate(getTemplate(template), indentLevel)
   );
   return () => h(content);
+}
+
+function prependDoctype(stream) {
+  return h(["<!DOCTYPE html>"]).concat(stream).pipe(new PassThrough());
 }
 
 const templates = {
@@ -63,40 +68,47 @@ indentForTemplate, 
   home(ctx, config, postsStream) {
     ctx.type = "html";
-    ctx.body = templates
-      .layout()
-      .pipe(rheo())
-      .outer("main", showPage("home"))
-      .inner(".posts", function(postsTemplate) {
-        return postsStream.pipe(postsTemplate.map(renderPostListItem(ctx)));
-      })
-      .pipe(setTitle(config.site.title))
-      .render();
+
+    ctx.body = prependDoctype(
+      templates
+        .layout()
+        .pipe(rheo())
+        .outer("main", showPage("home"))
+        .inner(".posts", function(postsTemplate) {
+          return postsStream.pipe(postsTemplate.map(renderPostListItem(ctx)));
+        })
+        .pipe(setTitle(config.site.title))
+        .render()
+    );
   },
 
   post(ctx, config, post) {
     ctx.type = "html";
-    ctx.body = templates
-      .layout()
-      .pipe(rheo())
-      .outer("main", showPage("post"))
-      .inner("article h1", rheo(post.data.get("title")))
-      .outer("article main", rheo(post.body))
-      .pipe(setTitle(config.site.title, post.data.get("title")))
-      .render();
+    ctx.body = prependDoctype(
+      templates
+        .layout()
+        .pipe(rheo())
+        .outer("main", showPage("post"))
+        .inner("article h1", rheo(post.data.get("title")))
+        .outer("article main", rheo(post.body))
+        .pipe(setTitle(config.site.title, post.data.get("title")))
+        .render()
+    );
   },
 
   taxon(ctx, config, taxonItems) {
     ctx.type = "html";
-    ctx.body = templates
-      .layout()
-      .pipe(rheo())
-      .outer("main", showPage("taxon"))
-      .inner("h1", rheo(config.site.title))
-      .inner(".posts", function(postsTemplate) {
-        return taxonItems.pipe(postsTemplate.map(renderPostListItem(ctx)));
-      })
-      .pipe(setTitle(config.site.title))
-      .render();
+    ctx.body = prependDoctype(
+      templates
+        .layout()
+        .pipe(rheo())
+        .outer("main", showPage("taxon"))
+        .inner("h1", rheo(config.site.title))
+        .inner(".posts", function(postsTemplate) {
+          return taxonItems.pipe(postsTemplate.map(renderPostListItem(ctx)));
+        })
+        .pipe(setTitle(config.site.title))
+        .render()
+    );
   }
 };
M src/templates/layout.htmlsrc/templates/layout.html
@@ -1,4 +1,4 @@-<!doctype html>
+<!DOCTYPE html>
 <html lang="en">
   <head>
     <meta charset="utf-8"/>
M test/app.test.jstest/app.test.js
@@ -18,6 +18,7 @@ test("homepage", t => {   return request(app.listen())
     .get("/")
     .expect(200)
+    .expect(/^<!DOCTYPE html>/)
     .then(parseResponse)
     .then($ => {
       t.is($("head > title").text(), config.site.title);
@@ -30,6 +31,7 @@ test("post", t => {   return request(app.listen())
     .get("/post/testfile")
     .expect(200)
+    .expect(/^<!DOCTYPE html>/)
     .then(parseResponse)
     .then($ => {
       t.is($("article h1").text(), "This is a test");