Files
vuefilemanager/resources/js/components/UI/Bar.vue
2022-03-15 16:51:33 +01:00

42 lines
1.5 KiB
Vue

<template>
<div
class="relative flex items-center justify-center block cursor-pointer lg:mx-1 lg:w-2 2xl:w-3"
:style="{ height: bar.percentage > 0 ? bar.percentage + '%' : '8px' }"
@mouseover="isVisible = true"
@mouseleave="isVisible = false"
>
<div
v-if="isVisible || bar.percentage === 85.5"
class="absolute -top-4 z-10 -translate-y-full transform rounded-lg bg-gray-800 py-2 px-3 shadow-lg dark:bg-white"
>
<b class="mb-2 block whitespace-nowrap text-xs text-white dark:text-gray-800">
{{ bar.created_at }}
</b>
<div class="flex items-center pb-1">
<span class="bg-theme mr-2 block h-3 w-3 rounded"></span>
<b class="whitespace-nowrap text-xs text-white dark:text-gray-800">
{{ bar.amount }}
</b>
</div>
<div class="absolute -bottom-2.5 left-0 right-0 mx-auto inline-block w-[17px] overflow-hidden">
<div class="h-3 w-3 origin-top-left -rotate-45 transform bg-gray-800 dark:bg-white"></div>
</div>
</div>
<span
class="block h-full w-full rounded-lg"
:class="{'bg-theme': bar.percentage > 0, 'dark:bg-gray-700 bg-gray-200': bar.percentage === 0}"
></span>
</div>
</template>
<script>
export default {
name: 'Bar',
props: ['bar'],
data() {
return {
isVisible: false,
}
},
}
</script>