Compare commits

..

5 Commits

Author SHA1 Message Date
fd97d589d4 added file size 2022-05-13 15:33:29 +02:00
632fc05f85 improved default opener 2022-05-13 15:28:25 +02:00
776719cf45 set title to filename 2022-05-13 15:09:04 +02:00
981d63c6df added 404 page 2022-05-13 15:01:33 +02:00
a4593c9d5c added Makefile 2022-05-13 11:58:32 +02:00
6 changed files with 89 additions and 12 deletions

1
.gitignore vendored
View File

@@ -1,2 +1,3 @@
/node_modules/ /node_modules/
/public/build/ /public/build/
/build/

18
Makefile Normal file
View File

@@ -0,0 +1,18 @@
BINARY = s3share
BUILD_DIR = build
.PHONY: all
all: clean build
.PHONY:build
build: $(BUILD_DIR)/$(BINARY) $(BUILD_DIR)/public
$(BUILD_DIR)/$(BINARY):
go build -o $(BUILD_DIR)/$(BINARY) cmd/s3share.go
$(BUILD_DIR)/public:
npm run build && cp -r public/ $(BUILD_DIR)/public
.PHONY:clean
clean:
rm -rf $(BUILD_DIR) && rm -rf public/build/

View File

@@ -1,17 +1,26 @@
<script lang="ts"> <script lang="ts">
import { onMount } from "svelte";
import getComponentForShare from "./contentType"; import getComponentForShare from "./contentType";
import NotFound from "./NotFound.svelte";
import sizeToReadable from "./sizeToReadable";
const regex = /filename="(.*)"/gm; const regex = /filename="(.*)"/gm;
const slug = window.location.pathname.split("/").pop(); const slug = window.location.pathname.split("/").pop();
let component = null; let notFound = false;
let contentType: string; let contentType: string;
let filename: string; let filename: string;
let fileSize: number = 0;
async function getFileHeadAndComponent() { async function getFileHead() {
const res = await fetch(`/s/${slug}`,{method:"HEAD"}); const res = await fetch(`/s/${slug}`,{method:"HEAD"});
if (res.status === 404){
notFound = true;
return;
}
contentType = res.headers.get("Content-Type"); contentType = res.headers.get("Content-Type");
fileSize = parseInt(res.headers.get("Content-Length"));
let match; let match;
while ((match = regex.exec(res.headers.get("Content-Disposition"))) !== null) { while ((match = regex.exec(res.headers.get("Content-Disposition"))) !== null) {
@@ -22,18 +31,29 @@
filename = match[1]; filename = match[1];
} }
return getComponentForShare(contentType,filename); document.title = filename;
} }
</script> </script>
<div class="dl"> {#if !notFound}
<a href="/s/{slug}">Download</a> <div class="dl">
</div> <a href="/s/{slug}">Download ({sizeToReadable(fileSize)})</a>
</div>
{/if}
<main> <main>
{#await getFileHeadAndComponent()} {#await getFileHead()}
Loading data... Loading data...
{:then v } {:then}
<svelte:component this={v.default} slug={slug} contentType={contentType} filename={filename} />
{#if notFound}
<NotFound />
{:else}
{#await getComponentForShare(contentType, filename)}
Loading component...
{:then v}
<svelte:component this={v.default} slug={slug} contentType={contentType} filename={filename} />
{/await}
{/if}
{/await} {/await}
</main> </main>

12
web/NotFound.svelte Normal file
View File

@@ -0,0 +1,12 @@
<script lang="ts">
</script>
<p>Share not found</p>
<style>
p{
color: var(--color-secondary);
font-size: 3rem;
}
</style>

View File

@@ -5,5 +5,21 @@
</script> </script>
<div> <div>
Default opener <header>{filename}</header>
<main>
Unable to preview this share.
</main>
</div> </div>
<style>
header{
font-size: 3rem;
color: var(--color-secondary);
text-align: center;
}
main{
color: var(--color-secondary);
font-size: 1.5rem;
}
</style>

10
web/sizeToReadable.ts Normal file
View File

@@ -0,0 +1,10 @@
function sizeToReadable(size: number): string {
if (size == 0)
return "0 B"
const i = Math.floor(Math.log(size) / Math.log(1024))
const num = (size / Math.pow(1024, i))
return (num.toFixed(1).endsWith("0")?num.toFixed(0):num.toFixed(1)) + " " + ["B", "kB", "MB", "GB", "TB"][i]
}
export default sizeToReadable