mirror of
https://github.com/aleksilassila/reiverr.git
synced 2026-04-27 03:05:10 +02:00
temp reworked modals to use stackrouter, modals are now *chefs kiss*, removed compstack completely
48 lines
1.4 KiB
Svelte
48 lines
1.4 KiB
Svelte
<script lang="ts">
|
|
import { scrollIntoView } from '$lib/selectable';
|
|
import { ChatBubble, Check } from 'radix-icons-svelte';
|
|
import { ISO_2_LANGUAGES } from '../../utils/iso-2-languages';
|
|
import Button from '../Button/Button.svelte';
|
|
import Dialog from '../Dialog/Dialog.svelte';
|
|
import { useComponentStack } from '../StackRouter/stack-router.store';
|
|
import type { AudioTrack } from './VideoPlayer';
|
|
|
|
const { close } = useComponentStack();
|
|
|
|
export let selectedAudioStreamIndex: number;
|
|
export let audioTracks: AudioTrack[];
|
|
export let selectAudioStream: (index: number) => void;
|
|
export let onClose = () => {};
|
|
</script>
|
|
|
|
<Dialog>
|
|
<div>
|
|
<h1 class="h3 mb-4 flex items-center space-x-4">
|
|
<span>Audio</span>
|
|
<ChatBubble size={32} />
|
|
</h1>
|
|
<div class="flex flex-col space-y-4">
|
|
{#each audioTracks || [] as track}
|
|
<Button
|
|
on:clickOrSelect={() => {
|
|
close();
|
|
onClose();
|
|
if (track.index !== selectedAudioStreamIndex) selectAudioStream(track.index);
|
|
}}
|
|
on:enter={scrollIntoView({ horizontal: 64 })}
|
|
class="relative"
|
|
>
|
|
{#if track.index === selectedAudioStreamIndex}
|
|
<div class="absolute inset-y-0 right-6 flex items-center justify-center">
|
|
<Check size={24} />
|
|
</div>
|
|
{/if}
|
|
<div class="text-left">
|
|
{ISO_2_LANGUAGES[track.language]?.name || track.language}
|
|
</div>
|
|
</Button>
|
|
{/each}
|
|
</div>
|
|
</div>
|
|
</Dialog>
|