refactor: MediaManager structure

This commit is contained in:
Aleksi Lassila
2024-04-09 16:29:00 +03:00
parent 96a1a9ce3e
commit d91da834aa
15 changed files with 58 additions and 84 deletions

View File

@@ -0,0 +1,49 @@
<script lang="ts">
import ButtonGhost from '../Ghosts/ButtonGhost.svelte';
import Button from '../Button.svelte';
import { ChevronRight } from 'radix-icons-svelte';
import { formatSize } from '../../utils.js';
import type { FileResource } from '../../apis/combined-types';
import { scrollIntoView } from '../../selectable';
export let files: Promise<FileResource[]>;
export let handleSelectFile: (file: FileResource) => void;
</script>
<div class="-my-1">
{#await files}
{#each new Array(5) as _, index}
<div class="flex-1 my-1">
<ButtonGhost />
</div>
{/each}
{:then files}
{#each files as file, index}
<div class="flex-1 my-1">
<Button
on:clickOrSelect={() => handleSelectFile(file)}
let:hasFocus
on:enter={scrollIntoView({ vertical: 64 })}
>
<div class="flex items-center w-full">
<div class="flex-1">
{file.relativePath}
</div>
{#if hasFocus}
<div class="flex items-center">
Details
<ChevronRight size={19} class="ml-1" />
</div>
{:else}
<div class="flex items-center text-zinc-400">
{formatSize(file.size || 0)}
</div>
{/if}
</div>
</Button>
</div>
{:else}
<div class="text-sm text-zinc-400">No local files found</div>
{/each}
{/await}
</div>