mirror of
https://github.com/frappe/books.git
synced 2024-12-27 12:42:44 +00:00
51 lines
1.1 KiB
Vue
51 lines
1.1 KiB
Vue
<template>
|
|
<div class="dropdown show" ref="dropdownMenu" v-on-outside-click="hideDropdown">
|
|
<button
|
|
:id="_uid"
|
|
class="btn btn-sm btn-light dropdown-toggle"
|
|
aria-haspopup="true"
|
|
:aria-expanded="isShown ? 'true' : 'false'"
|
|
@click="isShown = !isShown"
|
|
>
|
|
{{ label }}
|
|
</button>
|
|
<div :class="['dropdown-menu dropdown-menu-right', isShown ? 'show' : '']" :aria-labelledby="_uid">
|
|
<a
|
|
href="#"
|
|
class="dropdown-item"
|
|
v-for="option in options"
|
|
:key="option.label"
|
|
@click.prevent="option.handler"
|
|
>
|
|
{{ option.label }}
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
<script>
|
|
export default {
|
|
props: ['label', 'options'],
|
|
data() {
|
|
return {
|
|
isShown: false
|
|
};
|
|
},
|
|
methods: {
|
|
hideDropdown() {
|
|
this.isShown = false;
|
|
}
|
|
}
|
|
};
|
|
</script>
|
|
<style lang="scss">
|
|
@import '../styles/variables.scss';
|
|
$dropdown-link-active-bg: $gray-300;
|
|
|
|
.dropdown-item {
|
|
&.active,
|
|
&:active {
|
|
@include gradient-bg($dropdown-link-active-bg);
|
|
}
|
|
}
|
|
</style>
|