owntone-server/web-src/src/components/ControlDropdown.vue

67 lines
1.3 KiB
Vue
Raw Normal View History

<template>
<div
v-click-away="onClickOutside"
class="dropdown"
:class="{ 'is-active': is_active }"
>
<div class="dropdown-trigger">
<button
class="button"
aria-haspopup="true"
aria-controls="dropdown"
@click="is_active = !is_active"
>
2022-05-20 07:44:22 -04:00
<span v-text="option.name" />
<mdicon class="icon" name="chevron-down" size="16" />
</button>
</div>
<div id="dropdown" class="dropdown-menu" role="menu">
<div class="dropdown-content">
<a
v-for="o in options"
:key="o.id"
class="dropdown-item"
:class="{ 'is-active': value === o.id }"
@click="select(o)"
v-text="o.name"
/>
</div>
</div>
</div>
</template>
<script>
export default {
name: 'ControlDropdown',
props: ['value', 'options'],
emits: ['update:value'],
data() {
return {
is_active: false
}
},
2022-05-20 07:44:22 -04:00
computed: {
option: {
get() {
return this.options.find((option) => option.id === this.value)
2022-05-20 07:44:22 -04:00
}
}
},
methods: {
onClickOutside(event) {
this.is_active = false
},
select(option) {
this.is_active = false
this.$emit('update:value', option.id)
}
}
}
</script>
<style></style>