mirror of
https://github.com/immich-app/immich.git
synced 2025-12-18 01:11:07 +03:00
* remove import and referenced file * first pass at replacing all CircleIconButtons * fix linting issues * fix combobox formatting issues * fix button context menu coloring * remove circle icon button from search history box * use theme switcher from UI lib * dark mode force the asset viewer icons * fix forced dark mode icons * dark mode memory viewer icons * fix: back button in memory viewer --------- Co-authored-by: Alex <alex.tran1502@gmail.com>
59 lines
1.8 KiB
Svelte
59 lines
1.8 KiB
Svelte
<script lang="ts">
|
|
import { shortcut } from '$lib/actions/shortcut';
|
|
import {
|
|
NotificationType,
|
|
notificationController,
|
|
} from '$lib/components/shared-components/notification/notification';
|
|
import { AssetAction } from '$lib/constants';
|
|
import { handleError } from '$lib/utils/handle-error';
|
|
import { toTimelineAsset } from '$lib/utils/timeline-util';
|
|
import { updateAsset, type AssetResponseDto } from '@immich/sdk';
|
|
import { mdiHeart, mdiHeartOutline } from '@mdi/js';
|
|
import { t } from 'svelte-i18n';
|
|
import type { OnAction } from './action';
|
|
import { IconButton } from '@immich/ui';
|
|
|
|
interface Props {
|
|
asset: AssetResponseDto;
|
|
onAction: OnAction;
|
|
}
|
|
|
|
let { asset, onAction }: Props = $props();
|
|
|
|
const toggleFavorite = async () => {
|
|
try {
|
|
const data = await updateAsset({
|
|
id: asset.id,
|
|
updateAssetDto: {
|
|
isFavorite: !asset.isFavorite,
|
|
},
|
|
});
|
|
|
|
asset = { ...asset, isFavorite: data.isFavorite };
|
|
|
|
onAction({
|
|
type: asset.isFavorite ? AssetAction.FAVORITE : AssetAction.UNFAVORITE,
|
|
asset: toTimelineAsset(asset),
|
|
});
|
|
|
|
notificationController.show({
|
|
type: NotificationType.Info,
|
|
message: asset.isFavorite ? $t('added_to_favorites') : $t('removed_from_favorites'),
|
|
});
|
|
} catch (error) {
|
|
handleError(error, $t('errors.unable_to_add_remove_favorites', { values: { favorite: asset.isFavorite } }));
|
|
}
|
|
};
|
|
</script>
|
|
|
|
<svelte:document use:shortcut={{ shortcut: { key: 'f' }, onShortcut: toggleFavorite }} />
|
|
|
|
<IconButton
|
|
color="secondary"
|
|
shape="round"
|
|
variant="ghost"
|
|
icon={asset.isFavorite ? mdiHeart : mdiHeartOutline}
|
|
aria-label={asset.isFavorite ? $t('unfavorite') : $t('to_favorite')}
|
|
onclick={toggleFavorite}
|
|
/>
|