mirror of
https://github.com/wukko/cobalt.git
synced 2024-11-15 12:50:01 +00:00
web/remux: move drop area and open file button into own components
This commit is contained in:
parent
b33bd39484
commit
3fd05891e6
3 changed files with 82 additions and 74 deletions
35
web/src/components/misc/DragDropArea.svelte
Normal file
35
web/src/components/misc/DragDropArea.svelte
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
<script lang="ts">
|
||||||
|
export let id: string;
|
||||||
|
export let classes = "";
|
||||||
|
|
||||||
|
export let draggedOver = false;
|
||||||
|
export let file: File;
|
||||||
|
|
||||||
|
const dropHandler = async (ev: DragEvent) => {
|
||||||
|
draggedOver = false;
|
||||||
|
ev.preventDefault();
|
||||||
|
|
||||||
|
if (ev?.dataTransfer?.files.length === 1) {
|
||||||
|
file = ev.dataTransfer.files[0];
|
||||||
|
return file;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const dragOverHandler = (ev: DragEvent) => {
|
||||||
|
draggedOver = true;
|
||||||
|
ev.preventDefault();
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<div
|
||||||
|
{id}
|
||||||
|
class={classes}
|
||||||
|
role="region"
|
||||||
|
on:drop={(ev) => dropHandler(ev)}
|
||||||
|
on:dragover={(ev) => dragOverHandler(ev)}
|
||||||
|
on:dragend={() => {
|
||||||
|
draggedOver = false;
|
||||||
|
}}
|
||||||
|
>
|
||||||
|
<slot></slot>
|
||||||
|
</div>
|
29
web/src/components/misc/OpenFileButton.svelte
Normal file
29
web/src/components/misc/OpenFileButton.svelte
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
<script lang="ts">
|
||||||
|
export let file: File;
|
||||||
|
export let draggedOver = false;
|
||||||
|
|
||||||
|
const openFile = async () => {
|
||||||
|
const fileInput = document.createElement("input");
|
||||||
|
fileInput.type = "file";
|
||||||
|
fileInput.accept = "video/*,audio/*";
|
||||||
|
|
||||||
|
fileInput.click();
|
||||||
|
|
||||||
|
fileInput.onchange = async (e: Event) => {
|
||||||
|
const target = e.target as HTMLInputElement;
|
||||||
|
|
||||||
|
if (target.files?.length === 1) {
|
||||||
|
file = target.files[0];
|
||||||
|
return file;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
};
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<button on:click={() => openFile()}>
|
||||||
|
{#if draggedOver}
|
||||||
|
drop the file!
|
||||||
|
{:else}
|
||||||
|
open the file
|
||||||
|
{/if}
|
||||||
|
</button>
|
|
@ -1,96 +1,40 @@
|
||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import FFmpegWrapper from "$lib/ffmpeg";
|
import FFmpegWrapper from "$lib/ffmpeg";
|
||||||
|
|
||||||
import { openURL } from "$lib/download";
|
import { openURL } from "$lib/download";
|
||||||
|
|
||||||
$: draggedOver = false;
|
import DragDropArea from "$components/misc/DragDropArea.svelte";
|
||||||
|
import OpenFileButton from "$components/misc/OpenFileButton.svelte";
|
||||||
|
|
||||||
const dropHandler = async (ev: DragEvent) => {
|
let draggedOver = false;
|
||||||
draggedOver = false;
|
let file: File;
|
||||||
ev.preventDefault();
|
|
||||||
|
|
||||||
if (ev?.dataTransfer?.files.length === 1) {
|
|
||||||
const file = ev.dataTransfer.files[0];
|
|
||||||
|
|
||||||
await render(file);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const dragOverHandler = (ev: DragEvent) => {
|
|
||||||
draggedOver = true;
|
|
||||||
ev.preventDefault();
|
|
||||||
};
|
|
||||||
|
|
||||||
const render = async (file: File) => {
|
|
||||||
const type = file.type.split("/")[0];
|
|
||||||
const format = file.type.split("/")[1];
|
|
||||||
|
|
||||||
if (!["video", "audio"].includes(type)) return;
|
|
||||||
|
|
||||||
const reader = new FileReader();
|
|
||||||
reader.readAsArrayBuffer(file);
|
|
||||||
|
|
||||||
const fileBlob = URL.createObjectURL(
|
|
||||||
new Blob([file], { type: `${type}/${format}` })
|
|
||||||
);
|
|
||||||
|
|
||||||
|
const render = async () => {
|
||||||
const ff = new FFmpegWrapper();
|
const ff = new FFmpegWrapper();
|
||||||
await ff.init();
|
await ff.init();
|
||||||
|
|
||||||
const render = await ff.renderFile({
|
const render = await ff.renderFile({
|
||||||
url: fileBlob,
|
file,
|
||||||
input: {
|
|
||||||
type,
|
|
||||||
format,
|
|
||||||
},
|
|
||||||
output: {
|
|
||||||
type,
|
|
||||||
format,
|
|
||||||
},
|
|
||||||
args: ["-c", "copy"],
|
args: ["-c", "copy"],
|
||||||
});
|
});
|
||||||
|
|
||||||
openURL(render);
|
if (render) {
|
||||||
};
|
openURL(URL.createObjectURL(render));
|
||||||
|
} else {
|
||||||
const openFile = async () => {
|
console.log("not a valid file")
|
||||||
const fileInput = document.createElement("input");
|
|
||||||
fileInput.type = "file";
|
|
||||||
fileInput.accept = "video/*,audio/*";
|
|
||||||
|
|
||||||
fileInput.click();
|
|
||||||
|
|
||||||
fileInput.onchange = async (e: Event) => {
|
|
||||||
const target = e.target as HTMLInputElement;
|
|
||||||
|
|
||||||
if (target.files?.length === 1) {
|
|
||||||
const file = target.files[0];
|
|
||||||
await render(file);
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
};
|
|
||||||
|
$: if (file) {
|
||||||
|
render();
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<div
|
<DragDropArea id="remux-container" bind:draggedOver bind:file>
|
||||||
id="remux-container"
|
<OpenFileButton bind:draggedOver bind:file />
|
||||||
role="region"
|
</DragDropArea>
|
||||||
on:drop={(ev) => dropHandler(ev)}
|
|
||||||
on:dragover={(ev) => dragOverHandler(ev)}
|
|
||||||
on:dragend={() => {
|
|
||||||
draggedOver = false;
|
|
||||||
}}
|
|
||||||
>
|
|
||||||
<button on:click={() => openFile()}>
|
|
||||||
{#if draggedOver}
|
|
||||||
drop the file!
|
|
||||||
{:else}
|
|
||||||
open the file
|
|
||||||
{/if}
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
#remux-container {
|
:global(#remux-container) {
|
||||||
display: flex;
|
display: flex;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
|
|
Loading…
Reference in a new issue