Files
vuefilemanager/resources/js/components/Desktop/PopoverItem.vue
2021-07-23 17:16:42 +02:00

60 lines
913 B
Vue

<template>
<div v-if="isVisible" class="popover-item" :class="side">
<slot></slot>
</div>
</template>
<script>
import {events} from '@/bus'
export default {
name: 'PopoverItem',
props: [
'side',
'name',
],
data() {
return {
isVisible: false,
}
},
mounted() {
events.$on('popover:open', name => {
if (this.name === name) this.isVisible = !this.isVisible
})
events.$on('unClick', () => this.isVisible = false)
}
}
</script>
<style scoped lang="scss">
@import "@assets/vuefilemanager/_variables";
@import "@assets/vuefilemanager/_mixins";
.popover-item {
min-width: 250px;
position: absolute;
z-index: 9;
box-shadow: $shadow;
background: white;
border-radius: 8px;
overflow: hidden;
top: 50px;
&.left {
right: 0;
}
&.right {
left: 0;
}
}
.dark-mode {
.popover-item {
background: $dark_mode_foreground;
}
}
</style>