mirror of
https://github.com/immich-app/immich.git
synced 2025-12-23 01:11:36 +03:00
* Add Exif-Rating * Integrate star rating as own component * Add e2e tests for rating and validation * Rename component and async handleChangeRating * Display rating can be enabled in app settings * Correct i18n reference Co-authored-by: Michel Heusschen <59014050+michelheusschen@users.noreply.github.com> * Star rating: change from slider to buttons * Star rating for clarity * Design updates. * Renaming and code optimization * chore: clean up * chore: e2e formatting * light mode border and default value --------- Co-authored-by: Christoph Suter <christoph@suter-burri.ch> Co-authored-by: Michel Heusschen <59014050+michelheusschen@users.noreply.github.com> Co-authored-by: Mert <101130780+mertalev@users.noreply.github.com> Co-authored-by: Jason Rasmussen <jrasm91@gmail.com> Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
28 lines
973 B
Svelte
28 lines
973 B
Svelte
<script lang="ts">
|
|
import { handleError } from '$lib/utils/handle-error';
|
|
import { updateAsset, type AssetResponseDto } from '@immich/sdk';
|
|
import { t } from 'svelte-i18n';
|
|
import StarRating from '$lib/components/shared-components/star-rating.svelte';
|
|
import { handlePromiseError, isSharedLink } from '$lib/utils';
|
|
import { preferences } from '$lib/stores/user.store';
|
|
|
|
export let asset: AssetResponseDto;
|
|
export let isOwner: boolean;
|
|
|
|
$: rating = asset.exifInfo?.rating || 0;
|
|
|
|
const handleChangeRating = async (rating: number) => {
|
|
try {
|
|
await updateAsset({ id: asset.id, updateAssetDto: { rating } });
|
|
} catch (error) {
|
|
handleError(error, $t('errors.cant_apply_changes'));
|
|
}
|
|
};
|
|
</script>
|
|
|
|
{#if !isSharedLink() && $preferences?.rating?.enabled}
|
|
<section class="relative flex px-4 pt-2">
|
|
<StarRating {rating} readOnly={!isOwner} onRating={(rating) => handlePromiseError(handleChangeRating(rating))} />
|
|
</section>
|
|
{/if}
|