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

fix(web): use fallback image if shared asset isn't resized (#11704)

* fix(web): use fallback image if shared asset isn't resized

* remove test-data index file
This commit is contained in:
Michel Heusschen 2024-08-11 21:43:07 +02:00 committed by GitHub
parent 9ed04588b8
commit 30aa2c9b82
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
5 changed files with 21 additions and 22 deletions

View file

@ -1,5 +1,5 @@
import { sdkMock } from '$lib/__mocks__/sdk.mock'; import { sdkMock } from '$lib/__mocks__/sdk.mock';
import { albumFactory } from '@test-data'; import { albumFactory } from '@test-data/factories/album-factory';
import '@testing-library/jest-dom'; import '@testing-library/jest-dom';
import { fireEvent, render, waitFor, type RenderResult } from '@testing-library/svelte'; import { fireEvent, render, waitFor, type RenderResult } from '@testing-library/svelte';
import { init, register, waitLocale } from 'svelte-i18n'; import { init, register, waitLocale } from 'svelte-i18n';

View file

@ -1,6 +1,6 @@
import AlbumCover from '$lib/components/album-page/album-cover.svelte'; import AlbumCover from '$lib/components/album-page/album-cover.svelte';
import { getAssetThumbnailUrl } from '$lib/utils'; import { getAssetThumbnailUrl } from '$lib/utils';
import { albumFactory } from '@test-data'; import { albumFactory } from '@test-data/factories/album-factory';
import { render } from '@testing-library/svelte'; import { render } from '@testing-library/svelte';
vi.mock('$lib/utils'); vi.mock('$lib/utils');

View file

@ -1,19 +1,16 @@
import ShareCover from '$lib/components/sharedlinks-page/covers/share-cover.svelte'; import ShareCover from '$lib/components/sharedlinks-page/covers/share-cover.svelte';
import { getAssetThumbnailUrl } from '$lib/utils'; import { getAssetThumbnailUrl } from '$lib/utils';
import type { SharedLinkResponseDto } from '@immich/sdk'; import { albumFactory } from '@test-data/factories/album-factory';
import { albumFactory } from '@test-data'; import { assetFactory } from '@test-data/factories/asset-factory';
import { render } from '@testing-library/svelte'; import { sharedLinkFactory } from '@test-data/factories/shared-link-factory';
import { render, screen } from '@testing-library/svelte';
vi.mock('$lib/utils'); vi.mock('$lib/utils');
describe('ShareCover component', () => { describe('ShareCover component', () => {
it('renders an image when the shared link is an album', () => { it('renders an image when the shared link is an album', () => {
const component = render(ShareCover, { const component = render(ShareCover, {
link: { link: sharedLinkFactory.build({ album: albumFactory.build({ albumName: '123' }) }),
album: albumFactory.build({
albumName: '123',
}),
} as SharedLinkResponseDto,
preload: false, preload: false,
class: 'text', class: 'text',
}); });
@ -26,13 +23,7 @@ describe('ShareCover component', () => {
it('renders an image when the shared link is an individual share', () => { it('renders an image when the shared link is an individual share', () => {
vi.mocked(getAssetThumbnailUrl).mockReturnValue('/asdf'); vi.mocked(getAssetThumbnailUrl).mockReturnValue('/asdf');
const component = render(ShareCover, { const component = render(ShareCover, {
link: { link: sharedLinkFactory.build({ assets: [assetFactory.build({ id: 'someId' })] }),
assets: [
{
id: 'someId',
},
],
} as SharedLinkResponseDto,
preload: false, preload: false,
class: 'text', class: 'text',
}); });
@ -46,9 +37,7 @@ describe('ShareCover component', () => {
it('renders an image when the shared link has no album or assets', () => { it('renders an image when the shared link has no album or assets', () => {
const component = render(ShareCover, { const component = render(ShareCover, {
link: { link: sharedLinkFactory.build(),
assets: [],
} as unknown as SharedLinkResponseDto,
preload: false, preload: false,
class: 'text', class: 'text',
}); });
@ -57,4 +46,15 @@ describe('ShareCover component', () => {
expect(img.getAttribute('loading')).toBe('lazy'); expect(img.getAttribute('loading')).toBe('lazy');
expect(img.className).toBe('z-0 rounded-xl object-cover text'); expect(img.className).toBe('z-0 rounded-xl object-cover text');
}); });
it('renders fallback image when asset is not resized', () => {
const link = sharedLinkFactory.build({ assets: [assetFactory.build({ resized: false })] });
render(ShareCover, {
link: link,
preload: false,
});
const img = screen.getByTestId<HTMLImageElement>('album-image');
expect(img.alt).toBe('unnamed_share');
});
}); });

View file

@ -15,7 +15,7 @@
<div class="relative aspect-square shrink-0"> <div class="relative aspect-square shrink-0">
{#if link?.album} {#if link?.album}
<AlbumCover album={link.album} class={className} {preload} /> <AlbumCover album={link.album} class={className} {preload} />
{:else if link.assets[0]} {:else if link.assets[0]?.resized}
<AssetCover <AssetCover
alt={$t('individual_share')} alt={$t('individual_share')}
class={className} class={className}

View file

@ -1 +0,0 @@
export * from './factories/album-factory';