Icon search field now focuses when the menu is opened

This commit is contained in:
Stefan Zermatten
2020-05-31 19:18:49 +02:00
parent fb2f1efa72
commit 19f4735412
3 changed files with 11 additions and 84 deletions

View File

@@ -1,79 +0,0 @@
<template lang="html">
<v-autocomplete
v-model="model"
:search-input.sync="searchString"
:items="items"
:loading="!$subReady.searchIcons || isLoading"
item-text="name"
item-value="_id"
label="Search icons"
hide-no-data
@input="input"
>
<template
slot="item"
slot-scope="{ item, tile }"
>
<v-list-tile-avatar>
<svg class="avatar" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path :d="item.shape"/></svg>
</v-list-tile-avatar>
<v-list-tile-content>
<v-list-tile-title v-text="item.name"></v-list-tile-title>
</v-list-tile-content>
</template>
</v-autocomplete>
</template>
<script>
import Icons from '/imports/api/icons/Icons.js';
export default {
data(){ return {
model: this.value,
searchString: null,
serverSearchString: null,
isLoading: false,
}},
props: {
value: String,
},
watch: {
searchString(string){
this.isLoading = true;
this.searchServer(string)
},
value(newValue){
this.model = newValue;
},
},
methods: {
searchServer: _.debounce(function(string){
this.serverSearchString = string;
}, 200),
input(e){
this.$emit('input', e);
}
},
meteor: {
$subscribe: {
searchIcons() {
this.isLoading = false;
return [this.serverSearchString];
},
},
items(){
return Icons.find({}, { sort: [['score', 'desc']] }).fetch();
},
},
}
</script>
<style lang="css" scoped>
.avatar {
width: 100%;
height: 100%;
}
.theme--dark .avatar {
fill: white;
}
</style>

View File

@@ -99,6 +99,17 @@ export default {
searchString: '',
icons: [],
};},
watch: {
menu(value){
if (value){
setTimeout(() => {
if (this.$refs.iconSearchField){
this.$refs.iconSearchField.$children[0].focus();
}
}, 100);
}
},
},
methods: {
search(value, ack){
this.searchString = value;

View File

@@ -7,11 +7,6 @@
column
align-center
>
<v-icon>$vuetify.icons.abacus</v-icon>
<v-input
prepend-icon="$vuetify.icons.abacus"
label="cat"
/>
<upload-btn
title="Metadata JSON"
@file-update="metadataFileChanged"