my-anywhere
Version:
NodeJs static file server
100 lines (85 loc) • 3.63 kB
text/typescript
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