web/remux: add processing state, clean file, prevent render loop
This commit is contained in:
parent
1fd2b72075
commit
70b300bd71
3 changed files with 44 additions and 7 deletions
|
@ -3,7 +3,7 @@
|
|||
export let classes = "";
|
||||
|
||||
export let draggedOver = false;
|
||||
export let file: File;
|
||||
export let file: File | undefined;
|
||||
|
||||
const dropHandler = async (ev: DragEvent) => {
|
||||
draggedOver = false;
|
||||
|
|
|
@ -4,7 +4,7 @@
|
|||
import Meowbalt from "$components/misc/Meowbalt.svelte";
|
||||
import IconFileUpload from "@tabler/icons-svelte/IconFileUpload.svelte";
|
||||
|
||||
export let file: File;
|
||||
export let file: File | undefined;
|
||||
export let draggedOver = false;
|
||||
export let acceptTypes: string[];
|
||||
export let acceptExtensions: string[];
|
||||
|
|
|
@ -4,25 +4,35 @@
|
|||
import { t } from "$lib/i18n/translations";
|
||||
|
||||
import DropReceiver from "$components/misc/DropReceiver.svelte";
|
||||
import OpenFileButton from "$components/misc/FileReceiver.svelte";
|
||||
import FileReceiver from "$components/misc/FileReceiver.svelte";
|
||||
|
||||
let draggedOver = false;
|
||||
let file: File;
|
||||
let file: File | undefined;
|
||||
|
||||
let processing = false;
|
||||
|
||||
const render = async () => {
|
||||
if (!file || processing) return;
|
||||
|
||||
const ff = new LibAVWrapper();
|
||||
await ff.init();
|
||||
|
||||
processing = true;
|
||||
|
||||
const render = await ff.render({
|
||||
blob: file,
|
||||
args: ["-c", "copy"],
|
||||
});
|
||||
|
||||
processing = false;
|
||||
|
||||
if (render) {
|
||||
openURL(URL.createObjectURL(render));
|
||||
} else {
|
||||
console.log("not a valid file");
|
||||
}
|
||||
|
||||
file = undefined;
|
||||
};
|
||||
|
||||
$: if (file) {
|
||||
|
@ -31,8 +41,8 @@
|
|||
</script>
|
||||
|
||||
<DropReceiver id="remux-container" bind:draggedOver bind:file>
|
||||
<div id="remux-inner">
|
||||
<OpenFileButton
|
||||
<div id="remux-open" class:processing>
|
||||
<FileReceiver
|
||||
bind:draggedOver
|
||||
bind:file
|
||||
acceptTypes={["video/*", "audio/*"]}
|
||||
|
@ -50,6 +60,14 @@
|
|||
{$t("remux.description")}
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div id="remux-processing" class:processing>
|
||||
{#if processing}
|
||||
processing...
|
||||
{:else}
|
||||
done!
|
||||
{/if}
|
||||
</div>
|
||||
</DropReceiver>
|
||||
|
||||
<style>
|
||||
|
@ -60,7 +78,7 @@
|
|||
width: 100%;
|
||||
}
|
||||
|
||||
#remux-inner {
|
||||
#remux-open {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
justify-content: center;
|
||||
|
@ -68,6 +86,25 @@
|
|||
max-width: 450px;
|
||||
text-align: center;
|
||||
gap: 32px;
|
||||
transition: transform 0.2s, opacity 0.2s;
|
||||
}
|
||||
|
||||
#remux-processing {
|
||||
position: absolute;
|
||||
display: flex;
|
||||
opacity: 0;
|
||||
transform: scale(0.9);
|
||||
transition: transform 0.2s, opacity 0.2s;
|
||||
}
|
||||
|
||||
#remux-processing.processing {
|
||||
opacity: 1;
|
||||
transform: none;
|
||||
}
|
||||
|
||||
#remux-open.processing {
|
||||
transform: scale(0.9);
|
||||
opacity: 0;
|
||||
}
|
||||
|
||||
.remux-description {
|
||||
|
|
Loading…
Reference in a new issue