1
0
Fork 0
mirror of https://github.com/immich-app/immich.git synced 2025-01-07 20:36:48 +01:00

feat(web): add preference for thumbnail playback on hover (#7831)

* feat(web): add preference for thumbnail playback on hover

* pr feedback, add user settings behavior setting

* user settings consistency

* rename appearance to app settings

* collapse single trash setting into app settings
This commit is contained in:
Sam Holton 2024-03-11 12:45:01 -04:00 committed by GitHub
parent 84453d2e34
commit b33cb5fe3f
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
5 changed files with 26 additions and 34 deletions

View file

@ -6,6 +6,7 @@
import { getAltText } from '$lib/utils/thumbnail-util'; import { getAltText } from '$lib/utils/thumbnail-util';
import { timeToSeconds } from '$lib/utils/date-time'; import { timeToSeconds } from '$lib/utils/date-time';
import { AssetTypeEnum, ThumbnailFormat, type AssetResponseDto } from '@immich/sdk'; import { AssetTypeEnum, ThumbnailFormat, type AssetResponseDto } from '@immich/sdk';
import { playVideoThumbnailOnHover } from '$lib/stores/preferences.store';
import { import {
mdiArchiveArrowDownOutline, mdiArchiveArrowDownOutline,
mdiCameraBurst, mdiCameraBurst,
@ -194,9 +195,10 @@
<div class="absolute top-0 h-full w-full"> <div class="absolute top-0 h-full w-full">
<VideoThumbnail <VideoThumbnail
url={getAssetFileUrl(asset.id, false, true)} url={getAssetFileUrl(asset.id, false, true)}
enablePlayback={mouseOver} enablePlayback={mouseOver && $playVideoThumbnailOnHover}
curve={selected} curve={selected}
durationInSeconds={timeToSeconds(asset.duration)} durationInSeconds={timeToSeconds(asset.duration)}
playbackOnIconHover
/> />
</div> </div>
{/if} {/if}

View file

@ -4,7 +4,7 @@
import SettingSwitch from '$lib/components/shared-components/settings/setting-switch.svelte'; import SettingSwitch from '$lib/components/shared-components/settings/setting-switch.svelte';
import { fallbackLocale, locales } from '$lib/constants'; import { fallbackLocale, locales } from '$lib/constants';
import { sidebarSettings } from '$lib/stores/preferences.store'; import { sidebarSettings } from '$lib/stores/preferences.store';
import { alwaysLoadOriginalFile } from '$lib/stores/preferences.store'; import { alwaysLoadOriginalFile, playVideoThumbnailOnHover, showDeleteModal } from '$lib/stores/preferences.store';
import { colorTheme, locale } from '$lib/stores/preferences.store'; import { colorTheme, locale } from '$lib/stores/preferences.store';
import { findLocale } from '$lib/utils'; import { findLocale } from '$lib/utils';
import { onMount } from 'svelte'; import { onMount } from 'svelte';
@ -104,6 +104,22 @@
on:toggle={() => ($alwaysLoadOriginalFile = !$alwaysLoadOriginalFile)} on:toggle={() => ($alwaysLoadOriginalFile = !$alwaysLoadOriginalFile)}
/> />
</div> </div>
<div class="ml-4">
<SettingSwitch
title="Play video thumbnail on hover"
subtitle="Play video thumbnail when mouse is hovering over item. Even when disabled, playback can be started by hovering over the play icon."
bind:checked={$playVideoThumbnailOnHover}
on:toggle={() => ($playVideoThumbnailOnHover = !$playVideoThumbnailOnHover)}
/>
</div>
<div class="ml-4">
<SettingSwitch
title="Permanent deletion warning"
subtitle="Show a warning when permanently deleting assets"
bind:checked={$showDeleteModal}
/>
</div>
<div class="ml-4"> <div class="ml-4">
<SettingSwitch <SettingSwitch

View file

@ -1,23 +0,0 @@
<script lang="ts">
import { showDeleteModal } from '$lib/stores/preferences.store';
import { fade } from 'svelte/transition';
import SettingSwitch from '$lib/components/shared-components/settings/setting-switch.svelte';
</script>
<section class="my-4">
<div in:fade={{ duration: 500 }}>
<form autocomplete="off" on:submit|preventDefault>
<div class="ml-4 mt-4 flex flex-col gap-4">
<div class="ml-4">
<SettingSwitch
title="Permanent deletion warning"
subtitle="Show a warning when permanently deleting assets"
bind:checked={$showDeleteModal}
/>
</div>
</div>
</form>
</div>
</section>
<div class="ml-4 mb-4"></div>

View file

@ -6,13 +6,12 @@
import { oauth } from '$lib/utils'; import { oauth } from '$lib/utils';
import { type ApiKeyResponseDto, type AuthDeviceResponseDto } from '@immich/sdk'; import { type ApiKeyResponseDto, type AuthDeviceResponseDto } from '@immich/sdk';
import SettingAccordion from '../shared-components/settings/setting-accordion.svelte'; import SettingAccordion from '../shared-components/settings/setting-accordion.svelte';
import AppearanceSettings from './appearance-settings.svelte'; import AppSettings from './app-settings.svelte';
import ChangePasswordSettings from './change-password-settings.svelte'; import ChangePasswordSettings from './change-password-settings.svelte';
import DeviceList from './device-list.svelte'; import DeviceList from './device-list.svelte';
import MemoriesSettings from './memories-settings.svelte'; import MemoriesSettings from './memories-settings.svelte';
import OAuthSettings from './oauth-settings.svelte'; import OAuthSettings from './oauth-settings.svelte';
import PartnerSettings from './partner-settings.svelte'; import PartnerSettings from './partner-settings.svelte';
import TrashSettings from './trash-settings.svelte';
import UserAPIKeyList from './user-api-key-list.svelte'; import UserAPIKeyList from './user-api-key-list.svelte';
import UserProfileSettings from './user-profile-settings.svelte'; import UserProfileSettings from './user-profile-settings.svelte';
import SettingAccordionState from '../shared-components/settings/setting-accordion-state.svelte'; import SettingAccordionState from '../shared-components/settings/setting-accordion-state.svelte';
@ -26,8 +25,8 @@
</script> </script>
<SettingAccordionState queryParam={QueryParameter.IS_OPEN}> <SettingAccordionState queryParam={QueryParameter.IS_OPEN}>
<SettingAccordion key="appearance" title="Appearance" subtitle="Manage the app appearance"> <SettingAccordion key="app-settings" title="App Settings" subtitle="Manage the app settings">
<AppearanceSettings /> <AppSettings />
</SettingAccordion> </SettingAccordion>
<SettingAccordion key="account" title="Account" subtitle="Manage your account"> <SettingAccordion key="account" title="Account" subtitle="Manage your account">
@ -42,7 +41,7 @@
<DeviceList bind:devices /> <DeviceList bind:devices />
</SettingAccordion> </SettingAccordion>
<SettingAccordion key="memories" title="Memories" subtitle="Manage what you see in your memories."> <SettingAccordion key="memories" title="Memories" subtitle="Manage what you see in your memories">
<MemoriesSettings user={$user} /> <MemoriesSettings user={$user} />
</SettingAccordion> </SettingAccordion>
@ -59,8 +58,4 @@
<SettingAccordion key="sharing" title="Sharing" subtitle="Manage sharing with partners"> <SettingAccordion key="sharing" title="Sharing" subtitle="Manage sharing with partners">
<PartnerSettings user={$user} /> <PartnerSettings user={$user} />
</SettingAccordion> </SettingAccordion>
<SettingAccordion key="trash" title="Trash" subtitle="Manage trash settings">
<TrashSettings />
</SettingAccordion>
</SettingAccordionState> </SettingAccordionState>

View file

@ -96,3 +96,5 @@ export const albumViewSettings = persisted<AlbumViewSettings>('album-view-settin
export const showDeleteModal = persisted<boolean>('delete-confirm-dialog', true, {}); export const showDeleteModal = persisted<boolean>('delete-confirm-dialog', true, {});
export const alwaysLoadOriginalFile = persisted<boolean>('always-load-original-file', false, {}); export const alwaysLoadOriginalFile = persisted<boolean>('always-load-original-file', false, {});
export const playVideoThumbnailOnHover = persisted<boolean>('play-video-thumbnail-on-hover', true, {});