mirror of
https://github.com/CorentinTh/it-tools.git
synced 2025-04-25 17:26:15 -04:00
38 lines
960 B
Vue
38 lines
960 B
Vue
<script setup lang="ts">
|
|
import { useToolStore } from '@/tools/tools.store';
|
|
import type { Tool } from '@/tools/tools.types';
|
|
|
|
const props = defineProps<{ tool: Tool }>();
|
|
|
|
const toolStore = useToolStore();
|
|
|
|
const { tool } = toRefs(props);
|
|
|
|
const isFavorite = computed(() => toolStore.isToolFavorite({ tool }));
|
|
const buttonType = computed(() => (isFavorite.value ? 'primary' : 'default'));
|
|
|
|
function toggleFavorite(event: MouseEvent) {
|
|
event.preventDefault();
|
|
|
|
if (toolStore.isToolFavorite({ tool })) {
|
|
toolStore.removeToolFromFavorites({ tool });
|
|
return;
|
|
}
|
|
|
|
toolStore.addToolToFavorites({ tool });
|
|
}
|
|
</script>
|
|
|
|
<template>
|
|
<c-tooltip :tooltip="isFavorite ? $t('favoriteButton.remove') : $t('favoriteButton.add') ">
|
|
<c-button
|
|
variant="text"
|
|
circle
|
|
:type="buttonType"
|
|
:style="{ opacity: isFavorite ? 1 : 0.2 }"
|
|
@click="toggleFavorite"
|
|
>
|
|
<icon-mdi-heart />
|
|
</c-button>
|
|
</c-tooltip>
|
|
</template>
|