140 lines
3.4 KiB
Go
140 lines
3.4 KiB
Go
package html
|
|
|
|
import (
|
|
"fmt"
|
|
"leech/thumbnail"
|
|
"strings"
|
|
|
|
"github.com/dustin/go-humanize"
|
|
)
|
|
|
|
type Entry struct {
|
|
IsDir bool
|
|
Name string
|
|
Size int64
|
|
}
|
|
|
|
func FileListPage(req string, entries []Entry) string {
|
|
header := fmt.Sprintf(`
|
|
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<!-- Stylesheet-->
|
|
<style>
|
|
@import url("https://fonts.googleapis.com/css2?family=DotGothic16&display=swap");
|
|
:root {
|
|
--text-color: #9e5272;
|
|
--text-color-accent: #793a73;
|
|
|
|
--bg-color: #181a1b;
|
|
--bg-sec-color: #f0d8e3;
|
|
|
|
color: var(--text-color);
|
|
}
|
|
body {
|
|
margin: 0;
|
|
position: relative;
|
|
font-family: "DotGothic16", sans-serif;
|
|
font-weight: 400;
|
|
font-style: normal;
|
|
background-color: var(--bg-color);
|
|
background-image: url(/assets/images/logo-64px-padded.png);
|
|
background-blend-mode: difference;
|
|
text-align: center;
|
|
font-size: 32px;
|
|
}
|
|
#content,#footer {
|
|
position: relative;
|
|
display: inline-block;
|
|
min-width: 720px;
|
|
max-width: 1280px;
|
|
width: 100vw;
|
|
}
|
|
|
|
#content {
|
|
min-height: calc(100vh - 256px);
|
|
padding: 128px 32px 32px 32px;
|
|
text-align: center;
|
|
}
|
|
#footer {
|
|
text-align: left;
|
|
}
|
|
a {
|
|
color: var(--text-color);
|
|
text-decoration: none;
|
|
font-size: 32px;
|
|
}
|
|
.entry {
|
|
display: flex;
|
|
}
|
|
.entry-name {
|
|
margin-left: 16px;
|
|
margin-right: auto;
|
|
}
|
|
.entry-icon{
|
|
width: 48px;
|
|
height: 48px;
|
|
}
|
|
#leech {
|
|
image-rendering: pixelated;
|
|
transform-origin: center center;
|
|
height:256px;
|
|
width:auto;
|
|
}
|
|
</style>
|
|
<!-- Title Element-->
|
|
<title>%s | leech.ontake.dev</title>
|
|
<!-- Icon-->
|
|
<link rel="icon" type="image/webp" href="/assets/images/leech.png" />
|
|
<!-- Metadata-->
|
|
<meta property="og:type" content="website" />
|
|
<meta property="og:url" content="https://leech.ontake.dev" />
|
|
<meta property="og:title" content="%s | leech.ontake.dev" />
|
|
<meta name="viewport" content="width=device-width, initial-scale=0.1" />
|
|
<meta http-equiv='Content-Type' content='Type=text/html; charset=utf-8'>
|
|
</head>
|
|
<body>
|
|
<div id="content"><img src="/assets/images/leech.png" id="leech"></img>`, req, req)
|
|
|
|
footer := `</div><div id="footer">powered by leech. ontake. 2024.</div></body></html>`
|
|
|
|
body := ""
|
|
entriesWithParent := []Entry{}
|
|
if req != "" {
|
|
entriesWithParent = append(entriesWithParent, Entry{
|
|
IsDir: true,
|
|
Name: "..",
|
|
Size: -1,
|
|
})
|
|
}
|
|
entriesWithParent = append(entriesWithParent, entries...)
|
|
for _, dirEntry := range entriesWithParent {
|
|
formattedSize := ""
|
|
if dirEntry.Size != -1 {
|
|
formattedSize = humanize.Bytes(uint64(dirEntry.Size))
|
|
}
|
|
|
|
link := "/" + req + "/" + dirEntry.Name
|
|
if dirEntry.Name == ".." {
|
|
splitReq := strings.Split(req, "/")
|
|
link = "/" + strings.Join(splitReq[:len(splitReq)-1], "/")
|
|
}
|
|
if req == "" {
|
|
link = "/" + req + dirEntry.Name
|
|
}
|
|
if !dirEntry.IsDir {
|
|
link = "/serve/" + req + "/" + dirEntry.Name
|
|
}
|
|
icon := "/thumb/" + req + "/" + dirEntry.Name
|
|
|
|
if !thumbnail.IsSupportedFileType(dirEntry.Name) {
|
|
icon = "/assets/images/fileicon.png"
|
|
}
|
|
if dirEntry.IsDir {
|
|
icon = "/assets/images/diricon.png"
|
|
}
|
|
body += fmt.Sprintf(`<a href="%s"><div class="entry"><img class="entry-icon" src="%s"></img><div class="entry-name">%s</div><div class="entry-size">%s</div></div></a>`, link, icon, dirEntry.Name, formattedSize)
|
|
}
|
|
return header + body + footer
|
|
}
|