Files
gpx.studio/website/src/lib/components/Export.svelte

72 lines
1.9 KiB
Svelte
Raw Normal View History

2024-06-28 15:43:57 +02:00
<script lang="ts">
import { Button } from '$lib/components/ui/button';
import { Dialog } from 'bits-ui';
import {
currentTool,
exportAllFiles,
exportSelectedFiles,
ExportState,
exportState
} from '$lib/stores';
import { fileObservers } from '$lib/db';
2024-07-11 18:42:49 +02:00
import { Download } from 'lucide-svelte';
2024-06-28 15:43:57 +02:00
import { _ } from 'svelte-i18n';
import { selection } from './file-list/Selection';
let open = false;
$: if ($exportState !== ExportState.NONE) {
open = true;
$currentTool = null;
}
</script>
<Dialog.Root
bind:open
onOpenChange={(isOpen) => {
if (!isOpen) {
$exportState = ExportState.NONE;
}
}}
>
<Dialog.Trigger class="hidden" />
<Dialog.Portal>
<Dialog.Content
class="fixed left-[50%] top-[50%] z-50 w-fit max-w-full translate-x-[-50%] translate-y-[-50%] flex flex-col items-center gap-2 border bg-background p-3 shadow-lg rounded-md"
>
2024-06-28 17:57:05 +02:00
<div class="flex flex-row items-center gap-4 border rounded-md p-2">
<span>⚠️</span>
<span class="max-w-96 text-sm">
{$_('menu.support_message')}
</span>
</div>
<div class="w-full flex flex-row flex-wrap gap-2">
<Button class="bg-support grow" href="https://ko-fi.com/gpxstudio" target="_blank">
2024-06-28 15:43:57 +02:00
{$_('menu.support_button')}
<span class="ml-2">🙏</span>
</Button>
<Button
variant="outline"
2024-06-28 17:57:05 +02:00
class="grow"
2024-06-28 15:43:57 +02:00
on:click={() => {
if ($exportState === ExportState.SELECTION) {
exportSelectedFiles();
} else if ($exportState === ExportState.ALL) {
exportAllFiles();
}
open = false;
$exportState = ExportState.NONE;
}}
>
<Download size="16" class="mr-1" />
{#if $fileObservers.size === 1 || ($exportState === ExportState.SELECTION && $selection.size === 1)}
{$_('menu.download_file')}
{:else}
{$_('menu.download_files')}
{/if}
</Button>
</div>
</Dialog.Content>
</Dialog.Portal>
</Dialog.Root>