miru/src/lib/components/ui/button/favorite.svelte
2025-08-31 21:19:24 +02:00

28 lines
996 B
Svelte

<script lang='ts'>
import type { Media } from '$lib/modules/anilist'
import { Heart } from '$lib/components/icons/animated'
import { Button, iconSizes, type Props } from '$lib/components/ui/button'
import { authAggregator, fav } from '$lib/modules/auth'
import { clickwrap, keywrap } from '$lib/modules/navigate'
import { cn } from '$lib/utils'
type $$Props = Props & { media: Media }
let className: $$Props['class'] = ''
export { className as class }
export let media: Media
export let size: NonNullable<$$Props['size']> = 'icon-sm'
export let variant: NonNullable<$$Props['variant']> = 'ghost'
let key = 1
async function toggleFav () {
await authAggregator.toggleFav(media.id)
++key
}
</script>
<Button {size} {variant} class={cn(className, 'animated-icon')} on:click={clickwrap(toggleFav)} on:keydown={keywrap(toggleFav)} on:click={() => ++key}>
<Heart fill={key && fav(media) ? 'currentColor' : 'transparent'} size={iconSizes[size]} />
</Button>