lbry.tech/views/pages/api.js

114 lines
3.1 KiB
JavaScript
Raw Normal View History

2018-08-01 00:10:10 +02:00
"use strict";
// P A C K A G E S
const dedent = require("dedent");
const fetch = require("make-fetch-happen").defaults({ cacheManager: "./cache" });
2018-08-02 00:18:39 +02:00
const fs = require("graceful-fs");
2018-08-01 00:10:10 +02:00
const html = require("choo-async/html");
const raw = require("nanohtml/raw");
// V A R I A B L E
const apiFileLink = process.env.NODE_ENV === "development" ?
"https://rawgit.com/lbryio/lbry/master/docs/api.json" :
"https://cdn.rawgit.com/lbryio/lbry/5b3103e4/docs/api.json"
;
2018-08-02 00:18:39 +02:00
const apiScripts = "<script>" + fs.readFileSync("./views/partials/api-scripts.js", "utf-8") + "</script>";
2018-08-01 00:10:10 +02:00
// E X P O R T
module.exports = exports = () => async () => parseApiFile().then(response => html`
<div class="__slate">
<aside class="api__toc">
<div class="api__toc__search">
<input class="api__toc__search__field" id="input-search" placeholder="Search" type="search"/>
<div class="api__toc__search__clear" id="clear-search" title="Clear search query">&times;</div>
<ul class="api__toc__search__results"></ul>
</div>
<ul class="api__toc__items" id="toc" role="navigation">${raw(createApiSidebar(response).join(""))}</ul>
</aside>
<section class="api__content" id="toc-content">${raw(createApiContent(response).join(""))}</section>
</div>
2018-08-02 00:18:39 +02:00
${raw(apiScripts)}
2018-08-01 00:10:10 +02:00
`);
// H E L P E R S
function createApiContent(apiDetails) {
const apiContent = [];
for (const apiDetail of apiDetails) {
const apiDetailsReturns = JSON.parse(JSON.stringify(apiDetail.returns));
2018-08-02 00:18:39 +02:00
apiContent.push(`
2018-08-01 00:10:10 +02:00
<div class="api__content__body">
2018-08-02 00:18:39 +02:00
<h2 id="${apiDetail.name}">${apiDetail.name}</h2>
2018-08-01 00:10:10 +02:00
<p>${apiDetail.description}</p>
<h3>Returns</h3>
<pre><code>${dedent(apiDetailsReturns)}</code></pre>
${apiDetail.arguments.length ? `<h3>Arguments</h3><ul class="api__content__body__arguments">${renderArguments(apiDetail.arguments).join("")}</ul>` : ""}\n
2018-08-01 00:10:10 +02:00
</div>
<div class="api__content__example">
<pre><code>// example(s) for ${apiDetail.name} to come later</code></pre>
</div>
`);
}
return apiContent;
}
function createApiSidebar(apiDetails) {
const apiSidebar = [];
for (const apiDetail of apiDetails) {
apiSidebar.push(`
<li class="api__toc__item">
<a href="#${apiDetail.name}" title="Go to ${apiDetail.name} section">
${apiDetail.name}
</a>
</li>
`);
}
return apiSidebar;
}
function parseApiFile() {
return fetch(apiFileLink).then(() => fetch(apiFileLink, {
cache: "no-cache" // forces a conditional request
})).then(res => res.json().then(body => body)); // res.status 304 = cache validated
}
function renderArguments(args) {
const argumentContent = [];
for (const arg of args) {
argumentContent.push(`
<li class="api__content__body__argument">
2018-08-01 18:49:22 +02:00
<div class="left">
2018-08-01 00:10:10 +02:00
<strong>${arg.name}</strong><br/>
${arg.is_required === true ? "" : "<span>optional</span>" }<span>${arg.type}</span>
</div>
<div class="right">${arg.description.replace(/</g, "&lt;").replace(/>/g, "&gt;")}</div>
2018-08-01 00:10:10 +02:00
</li>
`);
}
return argumentContent;
}