UNPKG

my-anywhere

Version:
100 lines (85 loc) 3.63 kB
import { FileType } from "../consts" import style from "../style" interface Renderer { render: any renderDirectory: any renderToHtml: any } let renderer: Renderer = { render: (data: any = {}) => { let { type, fileMapList, pathList, content } = data if (type === FileType.DIRECTORY) { let html = renderer.renderDirectory({ fileMapList, pathList }) return html } if (type === FileType.NOT_FOUND) { return 'Page 404' } return content }, renderDirectory: ( { pathList = [], fileMapList = [] }: { pathList: any[], fileMapList: any[] }, ) => { if (!pathList.length && !fileMapList.length) { return renderer.renderToHtml() } let title = '' let nav = '' let content = '' if (pathList.length) { title = pathList[pathList.length - 1].relativePath nav = ` <h1> ${pathList .map(({ name, href }: { name: string, href: string }) => { return ` <a href="${href}">${name}</a> /` }) .join('')} </h1> ` } if (fileMapList.length) { content = ` <ul id="files"> ${fileMapList .map(({ name, href, clzName }: { name: string, href: string, clzName: string }) => { return ` <li> <a class="${clzName}" href="${href}"> <span class="name">${name}</span> </a> </li> ` }) .join('')} </ul> ` } return renderer.renderToHtml({ title, nav, content, }) }, renderToHtml: ({ title = '', nav = '', content = '' }: any = {}) => { return ` <html> <head> <meta charset="utf-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no" /> <link rel="icon" href="" type="image/x-icon" /> <title>${title}</title> ${style} </head> <body class="directory"> ${nav} ${content} </body> </html> ` }, } export default renderer