mirror of
https://github.com/immich-app/immich.git
synced 2025-06-23 15:30:51 -04:00
* First test * Added translation using Weblate (French) * Translated using Weblate (German) Currently translated at 100.0% (4 of 4 strings) Translation: immich/web Translate-URL: http://familie-mach.net/projects/immich/web/de/ * Translated using Weblate (French) Currently translated at 100.0% (4 of 4 strings) Translation: immich/web Translate-URL: http://familie-mach.net/projects/immich/web/fr/ * Further testing * Further testing * Translated using Weblate (German) Currently translated at 100.0% (18 of 18 strings) Translation: immich/web Translate-URL: http://familie-mach.net/projects/immich/web/de/ * Further work * Update string file. * More strings * Automatically changed strings * Add automatically translated german file for testing purposes * Fix merge-face-selector component * Make server stats strings uppercase * Fix uppercase string * Fix some strings in jobs-panel * Fix lower and uppercase strings. Add a few additional string. Fix a few unnecessary replacements * Update german test translations * Fix typo in locales file * Change string keys * Extract more strings * Extract and replace some more strings * Update testtranslationfile * Change translation keys * Fix rebase errors * Fix one more rebase error * Remove german translation file * Co-authored-by: Daniel Dietzler <danieldietzler@users.noreply.github.com> * chore: clean up translations * chore: add new line * fix formatting * chore: fixes * fix: loading and tests --------- Co-authored-by: root <root@Blacki> Co-authored-by: admin <admin@example.com> Co-authored-by: Jason Rasmussen <jrasm91@gmail.com> Co-authored-by: Daniel Dietzler <mail@ddietzler.dev>
136 lines
3.8 KiB
Svelte
136 lines
3.8 KiB
Svelte
<script lang="ts">
|
|
import CircleIconButton from '$lib/components/elements/buttons/circle-icon-button.svelte';
|
|
import ProgressBar, { ProgressBarStatus } from '$lib/components/shared-components/progress-bar/progress-bar.svelte';
|
|
import SlideshowSettings from '$lib/components/slideshow-settings.svelte';
|
|
import { SlideshowNavigation, slideshowStore } from '$lib/stores/slideshow.store';
|
|
import { mdiChevronLeft, mdiChevronRight, mdiClose, mdiCog, mdiFullscreen, mdiPause, mdiPlay } from '@mdi/js';
|
|
import { onDestroy, onMount } from 'svelte';
|
|
import { fly } from 'svelte/transition';
|
|
import { t } from 'svelte-i18n';
|
|
|
|
export let isFullScreen: boolean;
|
|
export let onNext = () => {};
|
|
export let onPrevious = () => {};
|
|
export let onClose = () => {};
|
|
export let onSetToFullScreen = () => {};
|
|
|
|
const { restartProgress, stopProgress, slideshowDelay, showProgressBar, slideshowNavigation } = slideshowStore;
|
|
|
|
let progressBarStatus: ProgressBarStatus;
|
|
let progressBar: ProgressBar;
|
|
let showSettings = false;
|
|
let showControls = true;
|
|
let timer: NodeJS.Timeout;
|
|
let isOverControls = false;
|
|
|
|
let unsubscribeRestart: () => void;
|
|
let unsubscribeStop: () => void;
|
|
|
|
const setCursorStyle = (style: string) => {
|
|
document.body.style.cursor = style;
|
|
};
|
|
|
|
const stopControlsHideTimer = () => {
|
|
clearTimeout(timer);
|
|
setCursorStyle('');
|
|
};
|
|
|
|
const showControlBar = () => {
|
|
showControls = true;
|
|
stopControlsHideTimer();
|
|
hideControlsAfterDelay();
|
|
};
|
|
|
|
const hideControlsAfterDelay = () => {
|
|
timer = setTimeout(() => {
|
|
if (!isOverControls) {
|
|
showControls = false;
|
|
setCursorStyle('none');
|
|
}
|
|
}, 10_000);
|
|
};
|
|
|
|
onMount(() => {
|
|
hideControlsAfterDelay();
|
|
unsubscribeRestart = restartProgress.subscribe((value) => {
|
|
if (value) {
|
|
progressBar.restart(value);
|
|
}
|
|
});
|
|
|
|
unsubscribeStop = stopProgress.subscribe((value) => {
|
|
if (value) {
|
|
progressBar.restart(false);
|
|
stopControlsHideTimer();
|
|
}
|
|
});
|
|
});
|
|
|
|
onDestroy(() => {
|
|
if (unsubscribeRestart) {
|
|
unsubscribeRestart();
|
|
}
|
|
|
|
if (unsubscribeStop) {
|
|
unsubscribeStop();
|
|
}
|
|
});
|
|
|
|
const handleDone = () => {
|
|
if ($slideshowNavigation === SlideshowNavigation.AscendingOrder) {
|
|
onPrevious();
|
|
return;
|
|
}
|
|
onNext();
|
|
};
|
|
</script>
|
|
|
|
<svelte:window on:mousemove={showControlBar} />
|
|
|
|
{#if showControls}
|
|
<div
|
|
class="m-4 flex gap-2"
|
|
on:mouseenter={() => (isOverControls = true)}
|
|
on:mouseleave={() => (isOverControls = false)}
|
|
transition:fly={{ duration: 150 }}
|
|
role="navigation"
|
|
>
|
|
<CircleIconButton buttonSize="50" icon={mdiClose} on:click={onClose} title={$t('exit_slideshow')} />
|
|
|
|
<CircleIconButton
|
|
buttonSize="50"
|
|
icon={progressBarStatus === ProgressBarStatus.Paused ? mdiPlay : mdiPause}
|
|
on:click={() => (progressBarStatus === ProgressBarStatus.Paused ? progressBar.play() : progressBar.pause())}
|
|
title={progressBarStatus === ProgressBarStatus.Paused ? $t('play') : $t('pause')}
|
|
/>
|
|
<CircleIconButton buttonSize="50" icon={mdiChevronLeft} on:click={onPrevious} title={$t('previous')} />
|
|
<CircleIconButton buttonSize="50" icon={mdiChevronRight} on:click={onNext} title={$t('next')} />
|
|
<CircleIconButton
|
|
buttonSize="50"
|
|
icon={mdiCog}
|
|
on:click={() => (showSettings = !showSettings)}
|
|
title={$t('next')}
|
|
/>
|
|
{#if !isFullScreen}
|
|
<CircleIconButton
|
|
buttonSize="50"
|
|
icon={mdiFullscreen}
|
|
on:click={onSetToFullScreen}
|
|
title={$t('set_slideshow_to_fullscreen')}
|
|
/>
|
|
{/if}
|
|
</div>
|
|
{/if}
|
|
{#if showSettings}
|
|
<SlideshowSettings onClose={() => (showSettings = false)} />
|
|
{/if}
|
|
|
|
<ProgressBar
|
|
autoplay
|
|
hidden={!$showProgressBar}
|
|
duration={$slideshowDelay}
|
|
bind:this={progressBar}
|
|
bind:status={progressBarStatus}
|
|
on:done={handleDone}
|
|
/>
|