Git-Auto-Deploy / web /src /components /atomic /IconButton.vue
AUXteam's picture
Upload folder using huggingface_hub
8d21f7c verified
<template>
<router-link v-if="to" :to="to" :title="title" :aria-label="title" class="icon-button h-8 w-8">
<slot>
<Icon v-if="icon" :name="icon" />
</slot>
</router-link>
<a
v-else-if="href"
:href="href"
:title="title"
:aria-label="title"
class="icon-button"
target="_blank"
rel="noopener noreferrer"
>
<slot>
<Icon v-if="icon" :name="icon" />
</slot>
</a>
<button v-else :disabled="disabled" class="icon-button" type="button" :title="title" :aria-label="title">
<slot>
<Icon v-if="icon" :name="icon" />
</slot>
<div v-if="isLoading" class="absolute top-0 right-0 bottom-0 left-0 flex items-center justify-center">
<Icon name="spinner" class="animate-spin" />
</div>
</button>
</template>
<script lang="ts" setup>
import type { RouteLocationRaw } from 'vue-router';
import Icon from '~/components/atomic/Icon.vue';
import type { IconNames } from '~/components/atomic/Icon.vue';
defineProps<{
icon?: IconNames;
disabled?: boolean;
to?: RouteLocationRaw;
isLoading?: boolean;
title?: string;
href?: string;
}>();
</script>
<style scoped>
@reference '~/tailwind.css';
.icon-button {
@apply hover:bg-wp-control-neutral-100 dark:hover:bg-wp-control-neutral-300 relative flex shrink-0 cursor-pointer items-center justify-center overflow-hidden rounded-md bg-transparent px-1 py-1 disabled:cursor-not-allowed disabled:opacity-50;
@apply in-[.border-wp-background-400]:hover:bg-wp-control-neutral-200;
}
</style>