mirror of
https://github.com/imputnet/cobalt.git
synced 2025-07-17 18:58:33 +00:00
make suggested improvements per @wukko
This commit is contained in:
parent
6493b323b3
commit
591903cab3
49
web/src/lib/remux.ts
Normal file
49
web/src/lib/remux.ts
Normal file
@ -0,0 +1,49 @@
|
||||
import mime from "mime";
|
||||
import LibAVWrapper from "$lib/libav";
|
||||
|
||||
let speed;
|
||||
let processedDuration;
|
||||
|
||||
const ff = new LibAVWrapper(progress => {
|
||||
if (progress.out_time_sec) {
|
||||
processedDuration = progress.out_time_sec;
|
||||
}
|
||||
|
||||
if (progress.speed) {
|
||||
speed = progress.speed;
|
||||
}
|
||||
});
|
||||
|
||||
ff.init();
|
||||
|
||||
export const silentRemux = async (file: File) => {
|
||||
if (file instanceof File && !file.type) {
|
||||
file = new File([file], file.name, {
|
||||
type: mime.getType(file.name) ?? undefined,
|
||||
});
|
||||
}
|
||||
|
||||
const render = await ff
|
||||
.render({
|
||||
blob: file,
|
||||
args: ["-c", "copy", "-map", "0"],
|
||||
})
|
||||
.catch((e) => {
|
||||
console.error("uh-oh! render error");
|
||||
console.error(e);
|
||||
});
|
||||
|
||||
if (!render) {
|
||||
return console.log("not a valid file");
|
||||
}
|
||||
|
||||
const filenameParts = file.name.split(".");
|
||||
const filenameExt = filenameParts.pop();
|
||||
|
||||
const filename = `${filenameParts.join(".")} (remux).${filenameExt}`;
|
||||
|
||||
return new File([render], filename, {
|
||||
type: render.type
|
||||
})
|
||||
|
||||
}
|
@ -2,7 +2,7 @@
|
||||
import { onMount } from "svelte";
|
||||
import { goto } from "$app/navigation";
|
||||
|
||||
import ActionButton from "$components/buttons/ActionButton.svelte";
|
||||
import CopyIcon from "$components/misc/CopyIcon.svelte";
|
||||
|
||||
import { t } from "$lib/i18n/translations";
|
||||
import { copyURL } from "$lib/download";
|
||||
@ -40,24 +40,27 @@
|
||||
{#if $settings.advanced.debug}
|
||||
<div id="debug-page">
|
||||
{#each sections as { title, data }, i}
|
||||
<h3>{title}:</h3>
|
||||
<div id="debug-section-title">
|
||||
<h3>{title}</h3>
|
||||
|
||||
<button
|
||||
id="debug-section-copy-button"
|
||||
aria-label={lastCopiedSection === i
|
||||
? $t("button.copied")
|
||||
: $t("button.copy")}
|
||||
on:click={() => {
|
||||
clearTimeout(lastCopiedSectionResetTimeout);
|
||||
lastCopiedSection = i;
|
||||
copyURL(JSON.stringify(data, null, 2));
|
||||
}}
|
||||
>
|
||||
<CopyIcon regularIcon check={lastCopiedSection === i} />
|
||||
</button>
|
||||
</div>
|
||||
|
||||
<div class="json-block subtext">
|
||||
{JSON.stringify(data, null, 2)}
|
||||
</div>
|
||||
|
||||
<ActionButton
|
||||
id="copy-button"
|
||||
click={() => {
|
||||
clearTimeout(lastCopiedSectionResetTimeout);
|
||||
lastCopiedSection = i;
|
||||
copyURL(JSON.stringify(data, null, 2));
|
||||
}}
|
||||
>
|
||||
{lastCopiedSection === i
|
||||
? $t("button.copied")
|
||||
: $t("button.copy")}
|
||||
</ActionButton>
|
||||
{/each}
|
||||
</div>
|
||||
{/if}
|
||||
@ -70,6 +73,32 @@
|
||||
gap: var(--padding);
|
||||
}
|
||||
|
||||
#debug-section-title {
|
||||
display: flex;
|
||||
flex-direction: start;
|
||||
align-items: center;
|
||||
gap: 0.4rem;
|
||||
}
|
||||
|
||||
#debug-section-copy-button {
|
||||
background: transparent;
|
||||
padding: 2px;
|
||||
box-shadow: none;
|
||||
border-radius: 5px;
|
||||
transition: opacity 0.2s;
|
||||
opacity: 0.7;
|
||||
}
|
||||
|
||||
#debug-section-copy-button :global(.copy-animation) {
|
||||
width: 17px;
|
||||
height: 17px;
|
||||
}
|
||||
|
||||
#debug-section-copy-button :global(.copy-animation *) {
|
||||
width: 17px;
|
||||
height: 17px;
|
||||
}
|
||||
|
||||
.json-block {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
|
Loading…
Reference in New Issue
Block a user