Files
discord-clone/components/DropdownMenu.vue
2023-04-20 21:19:22 -05:00

53 lines
866 B
Vue
Executable File

<template>
<Transition name="pop-in">
<div
v-if="opened"
ref="dropdown"
class="z-[2] absolute m-2 bg-[var(--primary-dark)] w-[calc(100%-1rem)] p-3 rounded text-left"
:class="(inverted) ? 'dropdown-inverse' : 'dropdown'"
>
<slot />
</div>
</Transition>
</template>
<script lang="ts">
export default {
props: {
opened: Boolean,
inverted: Boolean,
},
};
</script>
<style>
.dropdown {
transform-origin: top center;
}
.dropdown-inverse {
transform-origin: bottom center;
}
.dropdown-inverse > div > ul {
flex-direction: column-reverse;
}
.pop-in-enter-active {
animation: pop-in 150ms cubic-bezier(.81, .5, .44, .83);
}
.pop-in-leave-active {
animation: pop-in 150ms reverse cubic-bezier(.81, .5, .44, .83);
}
@keyframes pop-in {
0% {
transform: scale(0);
}
100% {
transform: scale(1);
}
}
</style>