mirror of
https://github.com/wukko/cobalt.git
synced 2025-01-22 10:46:19 +01:00
web/remux: add bullet points explaining what remux is
This commit is contained in:
parent
152ba6d443
commit
b015af7dde
2 changed files with 80 additions and 35 deletions
|
@ -1,3 +1,8 @@
|
||||||
{
|
{
|
||||||
"description": "remuxing often fixes compatibility issues with old software. it's fast, lossless, and everything is processed on-device."
|
"bullet.purpose.title": "what does remux do?",
|
||||||
|
"bullet.purpose.description": "remux fixes any issues with the file container, such as missing time info. it helps increase compatibility with old software, such as vegas pro and windows media player.",
|
||||||
|
"bullet.explainer.title": "how does it work?",
|
||||||
|
"bullet.explainer.description": "remuxing takes existing codec data and copies it over to a new media container. it's lossless, media data doesn't get re-encoded.",
|
||||||
|
"bullet.privacy.title": "on-device processing",
|
||||||
|
"bullet.privacy.description": "cobalt remuxes files locally. files never leave your device, so processing is nearly instant."
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,6 +10,11 @@
|
||||||
import Skeleton from "$components/misc/Skeleton.svelte";
|
import Skeleton from "$components/misc/Skeleton.svelte";
|
||||||
import DropReceiver from "$components/misc/DropReceiver.svelte";
|
import DropReceiver from "$components/misc/DropReceiver.svelte";
|
||||||
import FileReceiver from "$components/misc/FileReceiver.svelte";
|
import FileReceiver from "$components/misc/FileReceiver.svelte";
|
||||||
|
import BulletExplain from "$components/misc/BulletExplain.svelte";
|
||||||
|
|
||||||
|
import IconRepeat from "@tabler/icons-svelte/IconRepeat.svelte";
|
||||||
|
import IconDevices from "@tabler/icons-svelte/IconDevices.svelte";
|
||||||
|
import IconInfoCircle from "@tabler/icons-svelte/IconInfoCircle.svelte";
|
||||||
|
|
||||||
let draggedOver = false;
|
let draggedOver = false;
|
||||||
let file: File | undefined;
|
let file: File | undefined;
|
||||||
|
@ -40,7 +45,7 @@
|
||||||
|
|
||||||
let processing = false;
|
let processing = false;
|
||||||
|
|
||||||
const ff = new LibAVWrapper(progress => {
|
const ff = new LibAVWrapper((progress) => {
|
||||||
if (progress.out_time_sec) {
|
if (progress.out_time_sec) {
|
||||||
processedDuration = progress.out_time_sec;
|
processedDuration = progress.out_time_sec;
|
||||||
}
|
}
|
||||||
|
@ -62,7 +67,7 @@
|
||||||
speed = undefined;
|
speed = undefined;
|
||||||
processing = true;
|
processing = true;
|
||||||
|
|
||||||
const file_info = await ff.probe(file).catch(e => {
|
const file_info = await ff.probe(file).catch((e) => {
|
||||||
if (e?.message?.toLowerCase().includes("out of memory")) {
|
if (e?.message?.toLowerCase().includes("out of memory")) {
|
||||||
console.error("uh oh! out of memory");
|
console.error("uh oh! out of memory");
|
||||||
console.error(e);
|
console.error(e);
|
||||||
|
@ -105,7 +110,7 @@
|
||||||
totalDuration = Number(file_info.format.duration);
|
totalDuration = Number(file_info.format.duration);
|
||||||
|
|
||||||
if (file instanceof File && !file.type) {
|
if (file instanceof File && !file.type) {
|
||||||
file = new File([ file ], file.name, {
|
file = new File([file], file.name, {
|
||||||
type: mime.getType(file.name) ?? undefined,
|
type: mime.getType(file.name) ?? undefined,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -144,8 +149,8 @@
|
||||||
|
|
||||||
return await downloadFile({
|
return await downloadFile({
|
||||||
file: new File([render], filename, {
|
file: new File([render], filename, {
|
||||||
type: render.type
|
type: render.type,
|
||||||
})
|
}),
|
||||||
});
|
});
|
||||||
} finally {
|
} finally {
|
||||||
processing = false;
|
processing = false;
|
||||||
|
@ -198,7 +203,7 @@
|
||||||
<title>{$t("tabs.remux")} ~ {$t("general.cobalt")}</title>
|
<title>{$t("tabs.remux")} ~ {$t("general.cobalt")}</title>
|
||||||
<meta
|
<meta
|
||||||
property="og:title"
|
property="og:title"
|
||||||
content="{$t("tabs.remux")} ~ {$t("general.cobalt")}"
|
content="{$t('tabs.remux')} ~ {$t('general.cobalt')}"
|
||||||
/>
|
/>
|
||||||
</svelte:head>
|
</svelte:head>
|
||||||
|
|
||||||
|
@ -210,22 +215,41 @@
|
||||||
data-first-focus
|
data-first-focus
|
||||||
data-focus-ring-hidden
|
data-focus-ring-hidden
|
||||||
>
|
>
|
||||||
<FileReceiver
|
<div id="remux-receiver">
|
||||||
bind:draggedOver
|
<FileReceiver
|
||||||
bind:file
|
bind:draggedOver
|
||||||
acceptTypes={["video/*", "audio/*"]}
|
bind:file
|
||||||
acceptExtensions={[
|
acceptTypes={["video/*", "audio/*"]}
|
||||||
"mp4",
|
acceptExtensions={[
|
||||||
"webm",
|
"mp4",
|
||||||
"mp3",
|
"webm",
|
||||||
"ogg",
|
"mp3",
|
||||||
"opus",
|
"ogg",
|
||||||
"wav",
|
"opus",
|
||||||
"m4a",
|
"wav",
|
||||||
]}
|
"m4a",
|
||||||
/>
|
]}
|
||||||
<div class="subtext remux-description">
|
/>
|
||||||
{$t("remux.description")}
|
</div>
|
||||||
|
|
||||||
|
<div id="remux-bullets">
|
||||||
|
<BulletExplain
|
||||||
|
title={$t("remux.bullet.purpose.title")}
|
||||||
|
description={$t("remux.bullet.purpose.description")}
|
||||||
|
icon={IconRepeat}
|
||||||
|
/>
|
||||||
|
|
||||||
|
<BulletExplain
|
||||||
|
title={$t("remux.bullet.explainer.title")}
|
||||||
|
description={$t("remux.bullet.explainer.description")}
|
||||||
|
icon={IconInfoCircle}
|
||||||
|
/>
|
||||||
|
|
||||||
|
<BulletExplain
|
||||||
|
title={$t("remux.bullet.privacy.title")}
|
||||||
|
description={$t("remux.bullet.privacy.description")}
|
||||||
|
icon={IconDevices}
|
||||||
|
/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -263,13 +287,14 @@
|
||||||
|
|
||||||
#remux-open {
|
#remux-open {
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: row;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
max-width: 450px;
|
|
||||||
text-align: center;
|
text-align: center;
|
||||||
gap: 24px;
|
gap: 48px;
|
||||||
transition: transform 0.2s, opacity 0.2s;
|
transition:
|
||||||
|
transform 0.2s,
|
||||||
|
opacity 0.2s;
|
||||||
}
|
}
|
||||||
|
|
||||||
#remux-processing {
|
#remux-processing {
|
||||||
|
@ -278,7 +303,9 @@
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
opacity: 0;
|
opacity: 0;
|
||||||
transform: scale(0.9);
|
transform: scale(0.9);
|
||||||
transition: transform 0.2s, opacity 0.2s;
|
transition:
|
||||||
|
transform 0.2s,
|
||||||
|
opacity 0.2s;
|
||||||
pointer-events: none;
|
pointer-events: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -314,16 +341,29 @@
|
||||||
text-align: center;
|
text-align: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
.remux-description {
|
#remux-receiver {
|
||||||
font-size: 14px;
|
max-width: 450px;
|
||||||
line-height: 1.5;
|
}
|
||||||
|
|
||||||
|
#remux-bullets {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
gap: var(--padding);
|
||||||
|
max-width: 450px;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media screen and (max-width: 920px) {
|
||||||
|
#remux-open {
|
||||||
|
flex-direction: column;
|
||||||
|
gap: var(--padding);
|
||||||
|
}
|
||||||
|
|
||||||
|
#remux-bullets {
|
||||||
|
padding: var(--padding);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@media screen and (max-width: 535px) {
|
@media screen and (max-width: 535px) {
|
||||||
.remux-description {
|
|
||||||
font-size: 12px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.progress-bar {
|
.progress-bar {
|
||||||
width: 350px;
|
width: 350px;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue