mirror of
https://github.com/VueFileManager/vuefilemanager.git
synced 2026-04-19 00:22:15 +00:00
vue components refactoring
This commit is contained in:
41
resources/js/components/UI/BarChart/Bar.vue
Normal file
41
resources/js/components/UI/BarChart/Bar.vue
Normal file
@@ -0,0 +1,41 @@
|
||||
<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>
|
||||
19
resources/js/components/UI/BarChart/BarChart.vue
Normal file
19
resources/js/components/UI/BarChart/BarChart.vue
Normal file
@@ -0,0 +1,19 @@
|
||||
<template>
|
||||
<div
|
||||
class="grid h-20 grid-flow-col items-end gap-1 sm:h-28 sm:gap-2 lg:flex lg:items-end lg:justify-between lg:gap-0"
|
||||
>
|
||||
<!--Data bar-->
|
||||
<Bar v-for="(item, i) in data" :key="i" :bar="item" />
|
||||
</div>
|
||||
</template>
|
||||
<script>
|
||||
import Bar from './Bar'
|
||||
|
||||
export default {
|
||||
name: 'BarChart',
|
||||
props: ['color', 'data'],
|
||||
components: {
|
||||
Bar,
|
||||
},
|
||||
}
|
||||
</script>
|
||||
Reference in New Issue
Block a user