2018-07-12 10:21:42 -05:00
|
|
|
"use strict";
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// P A C K A G E S
|
|
|
|
|
2018-08-28 18:57:18 -05:00
|
|
|
import decamelize from "decamelize";
|
|
|
|
import exists from "fs-exists-sync";
|
|
|
|
import fm from "front-matter";
|
|
|
|
import fs from "graceful-fs";
|
|
|
|
import html from "choo/html";
|
2018-08-30 16:53:52 -05:00
|
|
|
import path from "path";
|
2018-08-28 18:57:18 -05:00
|
|
|
import { require as local } from "app-root-path";
|
|
|
|
import raw from "choo/html/raw";
|
|
|
|
|
|
|
|
// V A R I A B L E S
|
|
|
|
|
2018-07-20 11:57:25 -04:00
|
|
|
const numberRegex = /^[0-9]/g;
|
2018-07-13 13:03:21 -05:00
|
|
|
|
2018-07-12 10:21:42 -05:00
|
|
|
const md = require("markdown-it")({
|
|
|
|
html: true,
|
|
|
|
typographer: true
|
2018-08-28 18:57:18 -05:00
|
|
|
}).use(local("app/modules/markdown-it-sup"))
|
2018-07-20 11:57:25 -04:00
|
|
|
.use(require("markdown-it-anchor"), {
|
|
|
|
slugify: stringToSlugify => {
|
|
|
|
let finalString = stringToSlugify
|
|
|
|
.toLowerCase()
|
|
|
|
.replace(/\s\/\s/g, "-")
|
|
|
|
.replace(/\s/g, "-")
|
|
|
|
.replace(/%/g, "")
|
|
|
|
.replace(/\(/g, "")
|
|
|
|
.replace(/\)/g, "")
|
|
|
|
.replace(/,/g, "");
|
|
|
|
|
|
|
|
if (finalString.match(numberRegex)) finalString = `_${finalString}`;
|
|
|
|
return finalString;
|
|
|
|
}
|
|
|
|
})
|
2018-07-13 13:03:21 -05:00
|
|
|
.use(require("markdown-it-wikilinks")({
|
|
|
|
makeAllLinksAbsolute: true,
|
|
|
|
baseURL: "/glossary#",
|
|
|
|
uriSuffix: "",
|
|
|
|
htmlAttributes: {
|
|
|
|
class: "wikilink"
|
|
|
|
}
|
|
|
|
}));
|
|
|
|
|
2018-07-12 10:21:42 -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-08-28 18:57:18 -05:00
|
|
|
module.exports = exports = (state, emit) => { // eslint-disable-line
|
2018-07-30 12:30:50 -05:00
|
|
|
let path;
|
|
|
|
|
|
|
|
if (state.route === "resources/*") path = `resources/${state.params.wildcard}`;
|
|
|
|
else path = state.params.wildcard;
|
2018-07-12 10:21:42 -05:00
|
|
|
|
2018-07-13 13:03:21 -05:00
|
|
|
if (!fs.existsSync(`./documents/${path}.md`)) {
|
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">
|
|
|
|
<h1 class="page__header__title" itemprop="name headline">404</h1>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</header>
|
|
|
|
|
|
|
|
<section class="page__content" itemprop="articleBody">
|
|
|
|
<div class="inner-wrap">
|
2018-07-12 16:33:54 -05:00
|
|
|
<p>The page you are looking for does not exist.</p>
|
2018-07-12 10:21:42 -05:00
|
|
|
</div>
|
|
|
|
</section>
|
|
|
|
</article>
|
|
|
|
`;
|
|
|
|
}
|
|
|
|
|
2018-07-13 13:03:21 -05:00
|
|
|
const markdownFile = fs.readFileSync(`./documents/${path}.md`, "utf-8");
|
2018-07-12 10:21:42 -05:00
|
|
|
const markdownFileDetails = fm(markdownFile);
|
2018-08-24 16:58:04 -05:00
|
|
|
const renderedMarkdown = md.render(markdownFileDetails.body);
|
|
|
|
const updatedMarkdown = partialFinder(renderedMarkdown);
|
2018-07-26 17:18:26 -05:00
|
|
|
let newMetadata = "";
|
|
|
|
if (markdownFileDetails.attributes.meta) newMetadata = markdownFileDetails.attributes.meta;
|
2018-07-12 10:21:42 -05:00
|
|
|
|
2018-07-16 17:06:37 -04:00
|
|
|
let pageScript = "";
|
2018-08-30 16:53:52 -05:00
|
|
|
if (path === "glossary") pageScript = "<script>" + fs.readFileSync("./app/components/client/glossary-scripts.js", "utf-8") + "</script>";
|
|
|
|
if (path === "overview") pageScript = "<script>" + fs.readFileSync("./app/components/client/ecosystem-scripts.js", "utf-8") + "</script>";
|
|
|
|
if (path === "tour") pageScript = "<script>" + fs.readFileSync("./app/components/client/tour-scripts.js", "utf-8") + "</script>";
|
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">
|
|
|
|
<h1 class="page__header__title" itemprop="name headline">${markdownFileDetails.attributes.title}</h1>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</header>
|
|
|
|
|
|
|
|
<section class="page__content" itemprop="articleBody">
|
|
|
|
<div class="inner-wrap">
|
2018-08-24 16:58:04 -05:00
|
|
|
${raw(updatedMarkdown)}
|
2018-07-16 17:06:37 -04:00
|
|
|
${raw(pageScript)}
|
2018-07-26 17:18:26 -05:00
|
|
|
${newMetadata.length ? raw(updateMetadata(newMetadata)) : ""}
|
2018-07-12 10:21:42 -05:00
|
|
|
</div>
|
|
|
|
</section>
|
|
|
|
</article>
|
|
|
|
`;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
2018-07-26 17:18:26 -05:00
|
|
|
// H E L P E R S
|
|
|
|
|
|
|
|
function createMetaTags(metaObject) {
|
|
|
|
/**
|
|
|
|
NOTE:
|
|
|
|
For Markdown files, the custom yaml should look like this:
|
|
|
|
|
|
|
|
meta:
|
2018-08-24 17:30:58 -05:00
|
|
|
- description: Description goes here
|
2018-07-26 17:18:26 -05:00
|
|
|
|
|
|
|
This does not currently work with parameters like "og:image"
|
|
|
|
// https://github.com/lbryio/lbry.tech/issues/30
|
|
|
|
*/
|
|
|
|
|
|
|
|
let html = "";
|
|
|
|
|
|
|
|
for (const metaProperty in metaObject) {
|
|
|
|
html += `document.getElementsByTagName("meta")["${metaProperty}"].content = "${metaObject[metaProperty]}";\n`;
|
|
|
|
}
|
|
|
|
|
|
|
|
return html;
|
|
|
|
}
|
2018-07-12 10:21:42 -05:00
|
|
|
|
|
|
|
function partialFinder(markdownBody) {
|
|
|
|
const regexToFindPartials = /<\w+\/>/g;
|
|
|
|
const partials = markdownBody.match(regexToFindPartials);
|
|
|
|
|
2018-07-13 11:28:24 -05:00
|
|
|
if (!partials) return markdownBody;
|
2018-07-12 10:21:42 -05:00
|
|
|
|
|
|
|
for (const partial of partials) {
|
|
|
|
const filename = decamelize(partial, "-").replace("<", "").replace("/>", "");
|
2018-08-30 16:53:52 -05:00
|
|
|
const fileExistsTest = exists(`./app/components/${filename}.js`); // `local` results in error if used here and file !exist
|
2018-07-12 10:21:42 -05:00
|
|
|
|
|
|
|
if (fileExistsTest) {
|
2018-08-30 16:53:52 -05:00
|
|
|
const partialFunction = require(path.join(__dirname, "..", `./components/${filename}.js`));
|
2018-07-12 10:21:42 -05:00
|
|
|
|
2018-08-24 17:30:58 -05:00
|
|
|
if (filename === "ecosystem" || filename === "feature-links") {
|
|
|
|
const neatPartial = new partialFunction;
|
|
|
|
markdownBody = markdownBody.replace(partial, neatPartial.render());
|
2018-07-12 10:21:42 -05:00
|
|
|
}
|
|
|
|
|
2018-08-30 16:53:52 -05:00
|
|
|
else if (filename === "glossary-toc") markdownBody = markdownBody.replace(partial, partialFunction);
|
|
|
|
|
|
|
|
else markdownBody = markdownBody.replace(partial, partialFunction.default());
|
2018-07-12 10:21:42 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-24 16:58:04 -05:00
|
|
|
return markdownBody;
|
2018-07-12 10:21:42 -05:00
|
|
|
}
|
2018-07-26 17:18:26 -05:00
|
|
|
|
|
|
|
function updateMetadata(metadataDetails) {
|
|
|
|
const generatedMetadata = [];
|
|
|
|
|
|
|
|
for (const metadataDetail of metadataDetails) {
|
|
|
|
generatedMetadata.push(createMetaTags(metadataDetail));
|
|
|
|
}
|
|
|
|
|
2018-08-24 16:58:04 -05:00
|
|
|
return html`
|
|
|
|
<script>${generatedMetadata.join("")}</script>
|
2018-07-26 17:18:26 -05:00
|
|
|
`;
|
|
|
|
}
|