flaschengeist-frontend/src/components/baruser/SearchBar.vue

82 lines
1.8 KiB
Vue
Raw Normal View History

<template>
2020-01-14 21:01:24 +00:00
<div>
<v-toolbar>
<v-spacer />
<v-toolbar-items>
<v-autocomplete
outlined
return-object
v-model="user"
style="margin-top: 3px"
placeholder="Suche Person"
:items="allUsers"
item-text="fullName"
full-width
2020-01-23 22:25:21 +00:00
:loading="loading"
:search-input.sync="filter"
>
<template v-slot:prepend-inner>
2020-02-16 19:35:13 +00:00
<v-icon>{{ search_person }}</v-icon>
</template>
</v-autocomplete>
2020-01-14 21:01:24 +00:00
<v-btn text @click="addUser">Hinzufügen</v-btn>
2020-02-16 19:35:13 +00:00
<v-btn @click="clickMenu" icon>
<v-icon>{{ menuIcon }}</v-icon>
</v-btn>
2020-01-14 21:01:24 +00:00
</v-toolbar-items>
</v-toolbar>
</div>
</template>
<script>
2020-01-14 21:01:24 +00:00
import { mapGetters, mapActions } from 'vuex'
2020-02-16 19:35:13 +00:00
import { mdiAccountSearch, mdiMenu } from '@mdi/js'
2020-01-14 21:01:24 +00:00
export default {
name: 'SearchBar',
props: {},
data() {
return {
user: null,
filter: '',
2020-02-16 19:35:13 +00:00
search_person: mdiAccountSearch,
menuIcon: mdiMenu
}
2020-01-14 21:01:24 +00:00
},
created() {
this.getAllUsers()
},
methods: {
...mapActions({
getAllUsers: 'barUsers/getAllUsers',
addCreditList: 'barUsers/addCreditList',
2020-02-16 19:35:13 +00:00
setFilter: 'barUsers/setFilter',
activateMenu: 'barUsers/activateMenu',
deactivateMenu: 'barUsers/deactivateMenu'
2020-01-14 21:01:24 +00:00
}),
addUser() {
this.addCreditList(this.user)
this.user = null
2020-02-16 19:35:13 +00:00
},
clickMenu() {
if (this.menu) this.deactivateMenu()
else this.activateMenu()
2020-01-14 21:01:24 +00:00
}
},
computed: {
2020-01-23 22:25:21 +00:00
...mapGetters({
allUsers: 'barUsers/allUsers',
2020-02-16 19:35:13 +00:00
loading: 'barUsers/allUsersLoading',
menu: 'barUsers/menu'
2020-01-23 22:25:21 +00:00
})
},
watch: {
filter(val) {
this.setFilter(val)
}
2020-01-14 21:01:24 +00:00
}
}
</script>
<style scoped></style>