2018-08-28 18:57:18 -05:00
|
|
|
"use strict";
|
|
|
|
|
|
|
|
|
|
|
|
|
2018-11-30 14:46:22 -06:00
|
|
|
// I M P O R T S
|
2018-08-28 18:57:18 -05:00
|
|
|
|
2018-08-29 11:58:55 -05:00
|
|
|
import async from "choo-async";
|
|
|
|
import asyncHtml from "choo-async/html";
|
2018-08-28 18:57:18 -05:00
|
|
|
import choo from "choo";
|
|
|
|
import ssr from "choo-ssr";
|
|
|
|
|
2018-10-10 12:56:35 -05:00
|
|
|
// U T I L S
|
2018-08-28 18:57:18 -05:00
|
|
|
|
2019-04-12 16:17:39 -04:00
|
|
|
import head from "~component/head";
|
|
|
|
import wrapper from "~component/wrapper";
|
2018-08-28 18:57:18 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// P R O G R A M
|
|
|
|
|
|
|
|
function main() {
|
2018-08-29 11:58:55 -05:00
|
|
|
const app = async(choo());
|
|
|
|
|
2018-08-28 18:57:18 -05:00
|
|
|
const page = view => (
|
|
|
|
shell(
|
|
|
|
ssr.head(
|
|
|
|
head,
|
|
|
|
ssr.state()
|
|
|
|
),
|
|
|
|
ssr.body(wrapper(view))
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
app.use(ssr());
|
|
|
|
|
|
|
|
app.route("/", page(require("./views/home")));
|
|
|
|
app.route("/api/*", page(require("./views/api")));
|
2019-01-25 10:36:26 -06:00
|
|
|
app.route("/spec", page(require("./views/spec")));
|
2018-08-28 18:57:18 -05:00
|
|
|
app.route("/*", page(require("./views/redirect")));
|
|
|
|
|
2018-08-29 11:58:55 -05:00
|
|
|
app.mount("html");
|
|
|
|
|
2018-08-28 18:57:18 -05:00
|
|
|
return app;
|
|
|
|
}
|
|
|
|
|
2018-08-29 11:58:55 -05:00
|
|
|
if (typeof window !== "undefined") main();
|
2018-08-28 18:57:18 -05:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// E X P O R T
|
|
|
|
|
|
|
|
module.exports = exports = main;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// H E L P E R
|
|
|
|
|
2018-10-01 15:47:10 -05:00
|
|
|
function shell(head, body) {
|
2018-08-28 18:57:18 -05:00
|
|
|
return (state, emit) => {
|
2018-08-29 11:58:55 -05:00
|
|
|
const bodyPromise = Promise.resolve(body(state, emit));
|
|
|
|
const headPromise = bodyPromise.then(() => head(state, emit)); // resolve `head` once `body` is resolved
|
2018-08-28 18:57:18 -05:00
|
|
|
|
2018-08-29 11:58:55 -05:00
|
|
|
return asyncHtml`
|
2018-08-28 18:57:18 -05:00
|
|
|
<!DOCTYPE html>
|
|
|
|
<html lang="en">
|
2018-08-29 11:58:55 -05:00
|
|
|
${headPromise}
|
|
|
|
${bodyPromise}
|
2018-08-28 18:57:18 -05:00
|
|
|
</html>
|
|
|
|
`;
|
|
|
|
};
|
|
|
|
}
|