1
0
Fork 0
mirror of https://github.com/immich-app/immich.git synced 2025-01-06 03:46:47 +01:00

fix(web): show icons for empty album (#2604)

This commit is contained in:
Michel Heusschen 2023-05-29 20:58:09 +02:00 committed by GitHub
parent e7122d7a72
commit 3d505e425d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 41 additions and 34 deletions

View file

@ -15,9 +15,9 @@
import { AlbumResponseDto, api, ThumbnailFormat, UserResponseDto } from '@api'; import { AlbumResponseDto, api, ThumbnailFormat, UserResponseDto } from '@api';
import { createEventDispatcher, onMount } from 'svelte'; import { createEventDispatcher, onMount } from 'svelte';
import DotsVertical from 'svelte-material-icons/DotsVertical.svelte'; import DotsVertical from 'svelte-material-icons/DotsVertical.svelte';
import CircleIconButton from '../elements/buttons/circle-icon-button.svelte';
import noThumbnailUrl from '$lib/assets/no-thumbnail.png'; import noThumbnailUrl from '$lib/assets/no-thumbnail.png';
import { locale } from '$lib/stores/preferences.store'; import { locale } from '$lib/stores/preferences.store';
import IconButton from '../elements/buttons/icon-button.svelte';
export let album: AlbumResponseDto; export let album: AlbumResponseDto;
export let isSharingView = false; export let isSharingView = false;
@ -82,7 +82,9 @@
on:click|stopPropagation|preventDefault={showAlbumContextMenu} on:click|stopPropagation|preventDefault={showAlbumContextMenu}
data-testid="context-button-parent" data-testid="context-button-parent"
> >
<CircleIconButton logo={DotsVertical} size={'20'} /> <IconButton color="overlay-primary">
<DotsVertical size="20" />
</IconButton>
</div> </div>
{/if} {/if}
@ -115,7 +117,10 @@
{album.assetCount.toLocaleString($locale)} {album.assetCount.toLocaleString($locale)}
{album.assetCount == 1 ? `item` : `items`} {album.assetCount == 1 ? `item` : `items`}
</p> </p>
<p>·</p>
{#if isSharingView || album.shared}
<p>·</p>
{/if}
{#if isSharingView} {#if isSharingView}
{#await getAlbumOwnerInfo() then albumOwner} {#await getAlbumOwnerInfo() then albumOwner}

View file

@ -4,7 +4,6 @@
import { albumAssetSelectionStore } from '$lib/stores/album-asset-selection.store'; import { albumAssetSelectionStore } from '$lib/stores/album-asset-selection.store';
import { downloadAssets } from '$lib/stores/download'; import { downloadAssets } from '$lib/stores/download';
import { locale } from '$lib/stores/preferences.store'; import { locale } from '$lib/stores/preferences.store';
import { clickOutside } from '$lib/utils/click-outside';
import { openFileUploadDialog } from '$lib/utils/file-uploader'; import { openFileUploadDialog } from '$lib/utils/file-uploader';
import { import {
AlbumResponseDto, AlbumResponseDto,
@ -376,16 +375,14 @@
</svelte:fragment> </svelte:fragment>
<svelte:fragment slot="trailing"> <svelte:fragment slot="trailing">
{#if album.assetCount > 0} {#if !isCreatingSharedAlbum}
{#if !sharedLink} {#if !sharedLink}
<CircleIconButton <CircleIconButton
title="Add Photos" title="Add Photos"
on:click={() => (isShowAssetSelection = true)} on:click={() => (isShowAssetSelection = true)}
logo={FileImagePlusOutline} logo={FileImagePlusOutline}
/> />
{/if} {:else if sharedLink?.allowUpload}
{#if sharedLink?.allowUpload}
<CircleIconButton <CircleIconButton
title="Add Photos" title="Add Photos"
on:click={() => openFileUploadDialog(album.id, sharedLink?.key)} on:click={() => openFileUploadDialog(album.id, sharedLink?.key)}
@ -393,7 +390,6 @@
/> />
{/if} {/if}
<!-- Share and remove album -->
{#if isOwned} {#if isOwned}
<CircleIconButton <CircleIconButton
title="Share" title="Share"
@ -402,7 +398,9 @@
/> />
<CircleIconButton title="Remove album" on:click={removeAlbum} logo={DeleteOutline} /> <CircleIconButton title="Remove album" on:click={removeAlbum} logo={DeleteOutline} />
{/if} {/if}
{/if}
{#if album.assetCount > 0 && !isCreatingSharedAlbum}
{#if !isPublicShared || (isPublicShared && sharedLink?.allowDownload)} {#if !isPublicShared || (isPublicShared && sharedLink?.allowDownload)}
<CircleIconButton <CircleIconButton
title="Download" title="Download"
@ -412,29 +410,31 @@
{/if} {/if}
{#if !isPublicShared && isOwned} {#if !isPublicShared && isOwned}
<div use:clickOutside on:outclick={() => (isShowAlbumOptions = false)}> <CircleIconButton
<CircleIconButton title="Album options"
title="Album options" on:click={showAlbumOptionsMenu}
on:click={showAlbumOptionsMenu} logo={DotsVertical}
logo={DotsVertical} >
>{#if isShowAlbumOptions} {#if isShowAlbumOptions}
<ContextMenu {...contextMenuPosition}> <ContextMenu
<MenuOption {...contextMenuPosition}
on:click={() => { on:outclick={() => (isShowAlbumOptions = false)}
isShowThumbnailSelection = true; >
isShowAlbumOptions = false; <MenuOption
}} on:click={() => {
text="Set album cover" isShowThumbnailSelection = true;
/> isShowAlbumOptions = false;
</ContextMenu> }}
{/if} text="Set album cover"
</CircleIconButton> />
</div> </ContextMenu>
{/if}
</CircleIconButton>
{/if} {/if}
{/if}
{#if isPublicShared} {#if isPublicShared}
<ThemeButton /> <ThemeButton />
{/if}
{/if} {/if}
{#if isCreatingSharedAlbum && album.sharedUsers.length == 0} {#if isCreatingSharedAlbum && album.sharedUsers.length == 0}

View file

@ -9,7 +9,8 @@
| 'green' | 'green'
| 'gray' | 'gray'
| 'transparent-gray' | 'transparent-gray'
| 'dark-gray'; | 'dark-gray'
| 'overlay-primary';
export type Size = 'icon' | 'link' | 'sm' | 'base' | 'lg'; export type Size = 'icon' | 'link' | 'sm' | 'base' | 'lg';
export type Rounded = 'lg' | '3xl' | 'full' | false; export type Rounded = 'lg' | '3xl' | 'full' | false;
export type Shadow = 'md' | false; export type Shadow = 'md' | false;
@ -38,9 +39,10 @@
green: 'bg-lime-600 text-white enabled:hover:bg-lime-500', green: 'bg-lime-600 text-white enabled:hover:bg-lime-500',
gray: 'bg-gray-500 dark:bg-gray-200 enabled:hover:bg-gray-500/75 enabled:dark:hover:bg-gray-200/80 text-white dark:text-immich-dark-gray', gray: 'bg-gray-500 dark:bg-gray-200 enabled:hover:bg-gray-500/75 enabled:dark:hover:bg-gray-200/80 text-white dark:text-immich-dark-gray',
'transparent-gray': 'transparent-gray':
'dark:text-immich-dark-fg enabled:hover:bg-immich-primary/5 enabled:hover:text-gray-700 enabled:hover:dark:text-immich-dark-fg enabled:dark:hover:bg-immich-dark-primary/25 ', 'dark:text-immich-dark-fg enabled:hover:bg-immich-primary/5 enabled:hover:text-gray-700 enabled:hover:dark:text-immich-dark-fg enabled:dark:hover:bg-immich-dark-primary/25',
'dark-gray': 'dark-gray':
'dark:border-immich-dark-gray dark:bg-gray-500 enabled:dark:hover:bg-immich-dark-primary/50 enabled:hover:bg-immich-primary/10 dark:text-white' 'dark:border-immich-dark-gray dark:bg-gray-500 enabled:dark:hover:bg-immich-dark-primary/50 enabled:hover:bg-immich-primary/10 dark:text-white',
'overlay-primary': 'text-gray-500 enabled:hover:bg-gray-100'
}; };
const sizeClasses: Record<Size, string> = { const sizeClasses: Record<Size, string> = {

View file

@ -1,5 +1,5 @@
<script lang="ts" context="module"> <script lang="ts" context="module">
export type Color = 'transparent-primary' | 'transparent-gray'; export type Color = 'transparent-primary' | 'transparent-gray' | 'overlay-primary';
</script> </script>
<script lang="ts"> <script lang="ts">