lbry.tech/app/views/redirect.js

110 lines
2.6 KiB
JavaScript
Raw Normal View History

2018-07-12 10:21:42 -05:00
"use strict";
2018-11-30 14:46:22 -06:00
// I M P O R T S
2018-07-12 10:21:42 -05:00
2018-10-11 17:16:11 -05:00
import fm from "front-matter";
2018-08-28 18:57:18 -05:00
import fs from "graceful-fs";
import html from "choo/html";
import raw from "choo/html/raw";
2018-10-10 12:56:35 -05:00
// U T I L S
import markdown from "~component/markdown";
2019-01-18 12:15:17 -06:00
import page404 from "./404";
2018-07-12 10:21:42 -05:00
2018-10-01 15:47:10 -05:00
2018-07-13 16:58:24 -05:00
// E X P O R T
2018-07-12 10:21:42 -05:00
2018-11-30 14:46:22 -06:00
export default (state, emit) => { // eslint-disable-line
2019-01-30 16:15:10 -06:00
const partialPath = state.route === "resources/*" ?
`resources/${state.params.wildcard}` :
state.params.wildcard;
const path = `./documents/${partialPath}.md`;
2018-07-12 10:21:42 -05:00
2018-10-11 17:10:32 -05:00
if (!fs.existsSync(path))
2019-01-18 12:15:17 -06:00
return page404();
2018-07-12 10:21:42 -05:00
const markdownFile = fs.readFileSync(path, "utf-8");
2018-07-12 10:21:42 -05:00
const markdownFileDetails = fm(markdownFile);
2019-02-18 14:59:27 -06:00
const title = markdownFileDetails.attributes.title;
const description = markdownFileDetails.attributes.description || "";
if (markdownFileDetails.attributes.meta) {
const customMetadata = {};
for (const key in markdownFileDetails.attributes.meta) {
2019-07-10 12:34:19 -05:00
if (Object.prototype.hasOwnProperty.call(markdownFileDetails.attributes.meta, key)) {
customMetadata[Object.keys(markdownFileDetails.attributes.meta[key])[0]] =
markdownFileDetails.attributes.meta[key][Object.keys(markdownFileDetails.attributes.meta[key])[0]];
}
}
state.lbry = customMetadata;
}
2018-07-12 10:21:42 -05:00
2019-02-18 14:59:27 -06:00
// below is evil, I just inherited it -- Jeremy
state.lbry = {
title: title,
description: description
};
// below should be refactored into components
2018-07-16 17:06:37 -04:00
let pageScript = "";
2018-10-06 15:53:01 -05:00
2019-01-31 09:35:20 -06:00
switch(true) {
2019-02-04 17:42:52 -06:00
case partialPath === "developer-program":
pageScript = renderClientScript("devprogram-scripts");
break;
2019-01-31 09:35:20 -06:00
case partialPath === "glossary":
2019-02-04 17:42:52 -06:00
pageScript = renderClientScript("glossary-scripts");
2019-01-31 09:35:20 -06:00
break;
case partialPath === "overview":
2019-02-04 17:42:52 -06:00
pageScript = renderClientScript("ecosystem-scripts");
2019-01-31 09:35:20 -06:00
break;
case partialPath === "playground":
2019-02-04 17:42:52 -06:00
pageScript = renderClientScript("playground-scripts");
2019-01-31 09:35:20 -06:00
break;
default:
break;
}
2018-07-12 10:21:42 -05:00
return html`
<article class="page" itemtype="http://schema.org/BlogPosting">
<header class="page__header">
<div class="page__header-wrap">
<div class="inner-wrap">
2019-02-15 11:50:56 -05:00
<h1 class="page__header__title" itemprop="name headline">${title}</h1>
2018-07-12 10:21:42 -05:00
</div>
</div>
</header>
<section class="page__content" itemprop="articleBody">
<div class="inner-wrap">
${markdown(path)}
2018-07-16 17:06:37 -04:00
${raw(pageScript)}
2018-07-12 10:21:42 -05:00
</div>
</section>
</article>
`;
};
2019-02-04 17:42:52 -06:00
// H E L P E R
function renderClientScript(clientScriptFileName) {
return `
<script>
${fs.readFileSync((`${process.cwd()}/app/components/client/${clientScriptFileName}.js`), "utf-8")}
</script>
`;
}