mirror of
https://github.com/immich-app/immich.git
synced 2025-01-19 18:26:46 +01:00
feat(web): new look option for slideshow (#8924)
feat: new look option for slideshow
This commit is contained in:
parent
a93534fc3c
commit
7d4187962a
3 changed files with 25 additions and 6 deletions
|
@ -14,7 +14,7 @@
|
||||||
import LoadingSpinner from '../shared-components/loading-spinner.svelte';
|
import LoadingSpinner from '../shared-components/loading-spinner.svelte';
|
||||||
import { NotificationType, notificationController } from '../shared-components/notification/notification';
|
import { NotificationType, notificationController } from '../shared-components/notification/notification';
|
||||||
import { getAltText } from '$lib/utils/thumbnail-util';
|
import { getAltText } from '$lib/utils/thumbnail-util';
|
||||||
import { slideshowLookCssMapping, SlideshowState, slideshowStore } from '$lib/stores/slideshow.store';
|
import { SlideshowLook, slideshowLookCssMapping, SlideshowState, slideshowStore } from '$lib/stores/slideshow.store';
|
||||||
|
|
||||||
const { slideshowState, slideshowLook } = slideshowStore;
|
const { slideshowState, slideshowLook } = slideshowStore;
|
||||||
|
|
||||||
|
@ -150,15 +150,24 @@
|
||||||
<div
|
<div
|
||||||
bind:this={element}
|
bind:this={element}
|
||||||
transition:fade={{ duration: haveFadeTransition ? 150 : 0 }}
|
transition:fade={{ duration: haveFadeTransition ? 150 : 0 }}
|
||||||
class="flex h-full select-none place-content-center place-items-center"
|
class="relative h-full select-none"
|
||||||
>
|
>
|
||||||
{#if !imageLoaded}
|
{#if !imageLoaded}
|
||||||
|
<div class="flex h-full items-center justify-center">
|
||||||
<LoadingSpinner />
|
<LoadingSpinner />
|
||||||
|
</div>
|
||||||
{:else}
|
{:else}
|
||||||
<div bind:this={imgElement} class="h-full w-full">
|
<div bind:this={imgElement} class="h-full w-full" transition:fade={{ duration: haveFadeTransition ? 150 : 0 }}>
|
||||||
|
{#if $slideshowState !== SlideshowState.None && $slideshowLook === SlideshowLook.BlurredBackground}
|
||||||
|
<img
|
||||||
|
src={assetData}
|
||||||
|
alt={getAltText(asset)}
|
||||||
|
class="absolute top-0 left-0 -z-10 object-cover h-full w-full blur-lg"
|
||||||
|
draggable="false"
|
||||||
|
/>
|
||||||
|
{/if}
|
||||||
<img
|
<img
|
||||||
bind:this={$photoViewer}
|
bind:this={$photoViewer}
|
||||||
transition:fade={{ duration: haveFadeTransition ? 150 : 0 }}
|
|
||||||
src={assetData}
|
src={assetData}
|
||||||
alt={getAltText(asset)}
|
alt={getAltText(asset)}
|
||||||
class="h-full w-full {$slideshowState === SlideshowState.None
|
class="h-full w-full {$slideshowState === SlideshowState.None
|
||||||
|
|
|
@ -4,7 +4,14 @@
|
||||||
SettingInputFieldType,
|
SettingInputFieldType,
|
||||||
} from '$lib/components/shared-components/settings/setting-input-field.svelte';
|
} from '$lib/components/shared-components/settings/setting-input-field.svelte';
|
||||||
import SettingSwitch from '$lib/components/shared-components/settings/setting-switch.svelte';
|
import SettingSwitch from '$lib/components/shared-components/settings/setting-switch.svelte';
|
||||||
import { mdiArrowDownThin, mdiArrowUpThin, mdiFitToPageOutline, mdiFitToScreenOutline, mdiShuffle } from '@mdi/js';
|
import {
|
||||||
|
mdiArrowDownThin,
|
||||||
|
mdiArrowUpThin,
|
||||||
|
mdiFitToPageOutline,
|
||||||
|
mdiFitToScreenOutline,
|
||||||
|
mdiPanorama,
|
||||||
|
mdiShuffle,
|
||||||
|
} from '@mdi/js';
|
||||||
import { SlideshowLook, SlideshowNavigation, slideshowStore } from '../stores/slideshow.store';
|
import { SlideshowLook, SlideshowNavigation, slideshowStore } from '../stores/slideshow.store';
|
||||||
import Button from './elements/buttons/button.svelte';
|
import Button from './elements/buttons/button.svelte';
|
||||||
import type { RenderedOption } from './elements/dropdown.svelte';
|
import type { RenderedOption } from './elements/dropdown.svelte';
|
||||||
|
@ -23,6 +30,7 @@
|
||||||
const lookOptions: Record<SlideshowLook, RenderedOption> = {
|
const lookOptions: Record<SlideshowLook, RenderedOption> = {
|
||||||
[SlideshowLook.Contain]: { icon: mdiFitToScreenOutline, title: 'Contain' },
|
[SlideshowLook.Contain]: { icon: mdiFitToScreenOutline, title: 'Contain' },
|
||||||
[SlideshowLook.Cover]: { icon: mdiFitToPageOutline, title: 'Cover' },
|
[SlideshowLook.Cover]: { icon: mdiFitToPageOutline, title: 'Cover' },
|
||||||
|
[SlideshowLook.BlurredBackground]: { icon: mdiPanorama, title: 'Blurred background' },
|
||||||
};
|
};
|
||||||
|
|
||||||
const handleToggle = <Type extends SlideshowNavigation | SlideshowLook>(
|
const handleToggle = <Type extends SlideshowNavigation | SlideshowLook>(
|
||||||
|
|
|
@ -16,11 +16,13 @@ export enum SlideshowNavigation {
|
||||||
export enum SlideshowLook {
|
export enum SlideshowLook {
|
||||||
Contain = 'contain',
|
Contain = 'contain',
|
||||||
Cover = 'cover',
|
Cover = 'cover',
|
||||||
|
BlurredBackground = 'blurred-background',
|
||||||
}
|
}
|
||||||
|
|
||||||
export const slideshowLookCssMapping: Record<SlideshowLook, string> = {
|
export const slideshowLookCssMapping: Record<SlideshowLook, string> = {
|
||||||
[SlideshowLook.Contain]: 'object-contain',
|
[SlideshowLook.Contain]: 'object-contain',
|
||||||
[SlideshowLook.Cover]: 'object-cover',
|
[SlideshowLook.Cover]: 'object-cover',
|
||||||
|
[SlideshowLook.BlurredBackground]: 'object-contain',
|
||||||
};
|
};
|
||||||
|
|
||||||
function createSlideshowStore() {
|
function createSlideshowStore() {
|
||||||
|
|
Loading…
Reference in a new issue