mirror of
https://github.com/wukko/cobalt.git
synced 2024-11-15 04:39:58 +00:00
web: add support for dubbed youtube audio tracks
This commit is contained in:
parent
1373d16286
commit
ea2dd5bb35
6 changed files with 121 additions and 17 deletions
|
@ -56,9 +56,10 @@
|
||||||
"audio.bitrate.kbps": "kb/s",
|
"audio.bitrate.kbps": "kb/s",
|
||||||
"audio.bitrate.description": "bitrate is applied only when converting audio to a lossy format. cobalt can't improve the source audio quality, so choosing a bitrate over 128kbps may inflate the file size with no audible difference. perceived quality may vary by format.",
|
"audio.bitrate.description": "bitrate is applied only when converting audio to a lossy format. cobalt can't improve the source audio quality, so choosing a bitrate over 128kbps may inflate the file size with no audible difference. perceived quality may vary by format.",
|
||||||
|
|
||||||
"audio.youtube.dub": "youtube",
|
"audio.youtube.dub": "youtube audio track",
|
||||||
"audio.youtube.dub.title": "use browser language for dubbed videos",
|
"audio.youtube.dub.title": "audio track language",
|
||||||
"audio.youtube.dub.description": "works even if cobalt isn't translated to your language.",
|
"audio.youtube.dub.description": "if selected language isn't available, original will be used instead.",
|
||||||
|
"youtube.dub.original": "original",
|
||||||
|
|
||||||
"audio.tiktok.original": "tiktok",
|
"audio.tiktok.original": "tiktok",
|
||||||
"audio.tiktok.original.title": "download original sound",
|
"audio.tiktok.original.title": "download original sound",
|
||||||
|
|
|
@ -22,7 +22,7 @@ const request = async (url: string) => {
|
||||||
audioBitrate: getSetting("save", "audioBitrate"),
|
audioBitrate: getSetting("save", "audioBitrate"),
|
||||||
audioFormat: getSetting("save", "audioFormat"),
|
audioFormat: getSetting("save", "audioFormat"),
|
||||||
tiktokFullAudio: getSetting("save", "tiktokFullAudio"),
|
tiktokFullAudio: getSetting("save", "tiktokFullAudio"),
|
||||||
youtubeDubBrowserLang: getSetting("save", "youtubeDubBrowserLang"),
|
youtubeDubLang: getSetting("save", "youtubeDubLang"),
|
||||||
|
|
||||||
youtubeVideoCodec: getSetting("save", "youtubeVideoCodec"),
|
youtubeVideoCodec: getSetting("save", "youtubeVideoCodec"),
|
||||||
videoQuality: getSetting("save", "videoQuality"),
|
videoQuality: getSetting("save", "videoQuality"),
|
||||||
|
|
|
@ -25,7 +25,7 @@ const defaultSettings: CobaltSettings = {
|
||||||
twitterGif: true,
|
twitterGif: true,
|
||||||
videoQuality: "1080",
|
videoQuality: "1080",
|
||||||
youtubeVideoCodec: "h264",
|
youtubeVideoCodec: "h264",
|
||||||
youtubeDubBrowserLang: false,
|
youtubeDubLang: "original",
|
||||||
youtubeHLS: false,
|
youtubeHLS: false,
|
||||||
},
|
},
|
||||||
privacy: {
|
privacy: {
|
||||||
|
|
95
web/src/lib/settings/youtube-lang.ts
Normal file
95
web/src/lib/settings/youtube-lang.ts
Normal file
|
@ -0,0 +1,95 @@
|
||||||
|
export const youtubeLanguages = [
|
||||||
|
"original",
|
||||||
|
"af",
|
||||||
|
"am",
|
||||||
|
"ar",
|
||||||
|
"as",
|
||||||
|
"az",
|
||||||
|
"be",
|
||||||
|
"bg",
|
||||||
|
"bn",
|
||||||
|
"bs",
|
||||||
|
"ca",
|
||||||
|
"cs",
|
||||||
|
"da",
|
||||||
|
"de",
|
||||||
|
"el",
|
||||||
|
"en",
|
||||||
|
"es",
|
||||||
|
"et",
|
||||||
|
"eu",
|
||||||
|
"fa",
|
||||||
|
"fi",
|
||||||
|
"fil",
|
||||||
|
"fr",
|
||||||
|
"gl",
|
||||||
|
"gu",
|
||||||
|
"hi",
|
||||||
|
"hr",
|
||||||
|
"hu",
|
||||||
|
"hy",
|
||||||
|
"id",
|
||||||
|
"is",
|
||||||
|
"it",
|
||||||
|
"iw",
|
||||||
|
"ja",
|
||||||
|
"ka",
|
||||||
|
"kk",
|
||||||
|
"km",
|
||||||
|
"kn",
|
||||||
|
"ko",
|
||||||
|
"ky",
|
||||||
|
"lo",
|
||||||
|
"lt",
|
||||||
|
"lv",
|
||||||
|
"mk",
|
||||||
|
"ml",
|
||||||
|
"mn",
|
||||||
|
"mr",
|
||||||
|
"ms",
|
||||||
|
"my",
|
||||||
|
"no",
|
||||||
|
"ne",
|
||||||
|
"nl",
|
||||||
|
"or",
|
||||||
|
"pa",
|
||||||
|
"pl",
|
||||||
|
"pt",
|
||||||
|
"ro",
|
||||||
|
"ru",
|
||||||
|
"si",
|
||||||
|
"sk",
|
||||||
|
"sl",
|
||||||
|
"sq",
|
||||||
|
"sr",
|
||||||
|
"sv",
|
||||||
|
"sw",
|
||||||
|
"ta",
|
||||||
|
"te",
|
||||||
|
"th",
|
||||||
|
"tr",
|
||||||
|
"uk",
|
||||||
|
"ur",
|
||||||
|
"uz",
|
||||||
|
"vi",
|
||||||
|
"zh-CN",
|
||||||
|
"zh-HK",
|
||||||
|
"zh-TW",
|
||||||
|
"zu"
|
||||||
|
] as const;
|
||||||
|
|
||||||
|
export const namedYoutubeLanguages = () => {
|
||||||
|
return youtubeLanguages.reduce((obj, lang) => {
|
||||||
|
const intlName = new Intl.DisplayNames([lang], { type: 'language' }).of(lang);
|
||||||
|
|
||||||
|
let name = `${intlName} (${lang})`;
|
||||||
|
if (lang === "original") {
|
||||||
|
name = lang;
|
||||||
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
...obj,
|
||||||
|
[lang]: name,
|
||||||
|
};
|
||||||
|
}, {}) as Record<typeof youtubeLanguages[number], string>;
|
||||||
|
}
|
|
@ -1,5 +1,6 @@
|
||||||
import languages from '$i18n/languages.json';
|
import languages from "$i18n/languages.json";
|
||||||
import type { RecursivePartial } from './generic';
|
import { youtubeLanguages } from "$lib/settings/youtube-lang";
|
||||||
|
import type { RecursivePartial } from "$lib/types/generic";
|
||||||
|
|
||||||
export const themeOptions = ["auto", "light", "dark"] as const;
|
export const themeOptions = ["auto", "light", "dark"] as const;
|
||||||
export const audioBitrateOptions = ["320", "256", "128", "96", "64", "8"] as const;
|
export const audioBitrateOptions = ["320", "256", "128", "96", "64", "8"] as const;
|
||||||
|
@ -47,7 +48,7 @@ type CobaltSettingsSave = {
|
||||||
twitterGif: boolean,
|
twitterGif: boolean,
|
||||||
videoQuality: typeof videoQualityOptions[number],
|
videoQuality: typeof videoQualityOptions[number],
|
||||||
youtubeVideoCodec: typeof youtubeVideoCodecOptions[number],
|
youtubeVideoCodec: typeof youtubeVideoCodecOptions[number],
|
||||||
youtubeDubBrowserLang: boolean,
|
youtubeDubLang: typeof youtubeLanguages[number],
|
||||||
youtubeHLS: boolean,
|
youtubeHLS: boolean,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import settings from "$lib/state/settings";
|
import settings from "$lib/state/settings";
|
||||||
import { t } from "$lib/i18n/translations";
|
import { t } from "$lib/i18n/translations";
|
||||||
|
import { namedYoutubeLanguages, youtubeLanguages } from "$lib/settings/youtube-lang";
|
||||||
|
|
||||||
import { audioFormatOptions, audioBitrateOptions } from "$lib/types/settings";
|
import { audioFormatOptions, audioBitrateOptions } from "$lib/types/settings";
|
||||||
|
|
||||||
|
@ -8,6 +9,9 @@
|
||||||
import Switcher from "$components/buttons/Switcher.svelte";
|
import Switcher from "$components/buttons/Switcher.svelte";
|
||||||
import SettingsButton from "$components/buttons/SettingsButton.svelte";
|
import SettingsButton from "$components/buttons/SettingsButton.svelte";
|
||||||
import SettingsToggle from "$components/buttons/SettingsToggle.svelte";
|
import SettingsToggle from "$components/buttons/SettingsToggle.svelte";
|
||||||
|
import SettingsDropdown from "$components/settings/SettingsDropdown.svelte";
|
||||||
|
|
||||||
|
const displayLangs = namedYoutubeLanguages();
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<SettingsCategory sectionId="format" title={$t("settings.audio.format")}>
|
<SettingsCategory sectionId="format" title={$t("settings.audio.format")}>
|
||||||
|
@ -42,6 +46,18 @@
|
||||||
</Switcher>
|
</Switcher>
|
||||||
</SettingsCategory>
|
</SettingsCategory>
|
||||||
|
|
||||||
|
<SettingsCategory sectionId="youtube" title={$t("settings.audio.youtube.dub")}>
|
||||||
|
<SettingsDropdown
|
||||||
|
title={$t("settings.audio.youtube.dub.title")}
|
||||||
|
description={$t("settings.audio.youtube.dub.description")}
|
||||||
|
items={displayLangs}
|
||||||
|
settingContext="save"
|
||||||
|
settingId="youtubeDubLang"
|
||||||
|
selectedOption={$settings.save.youtubeDubLang}
|
||||||
|
selectedTitle={displayLangs[$settings.save.youtubeDubLang]}
|
||||||
|
/>
|
||||||
|
</SettingsCategory>
|
||||||
|
|
||||||
<SettingsCategory
|
<SettingsCategory
|
||||||
sectionId="tiktok"
|
sectionId="tiktok"
|
||||||
title={$t("settings.audio.tiktok.original")}
|
title={$t("settings.audio.tiktok.original")}
|
||||||
|
@ -53,12 +69,3 @@
|
||||||
description={$t("settings.audio.tiktok.original.description")}
|
description={$t("settings.audio.tiktok.original.description")}
|
||||||
/>
|
/>
|
||||||
</SettingsCategory>
|
</SettingsCategory>
|
||||||
|
|
||||||
<SettingsCategory sectionId="youtube" title={$t("settings.audio.youtube.dub")}>
|
|
||||||
<SettingsToggle
|
|
||||||
settingContext="save"
|
|
||||||
settingId="youtubeDubBrowserLang"
|
|
||||||
title={$t("settings.audio.youtube.dub.title")}
|
|
||||||
description={$t("settings.audio.youtube.dub.description")}
|
|
||||||
/>
|
|
||||||
</SettingsCategory>
|
|
||||||
|
|
Loading…
Reference in a new issue