diff --git a/client/components/ui/MultiSelect.vue b/client/components/ui/MultiSelect.vue index c655312a..26c85bbd 100644 --- a/client/components/ui/MultiSelect.vue +++ b/client/components/ui/MultiSelect.vue @@ -11,7 +11,7 @@ {{ item }} - + @@ -54,7 +54,7 @@ export default { menuDisabled: { type: Boolean, default: false - }, + } }, data() { return { @@ -140,7 +140,7 @@ export default { } this.recalcScroll() return - } else if (event.key === 'Enter') { + } else if (event.key === 'Enter') { if (this.selectedMenuItemIndex !== null) { this.clickedOption(event, items[this.selectedMenuItemIndex]) } else { @@ -154,6 +154,15 @@ export default { this.typingTimeout = setTimeout(() => { this.search() }, 100) + this.setInputWidth() + }, + setInputWidth() { + setTimeout(() => { + var value = this.$refs.input.value + var len = value.length * 7 + 24 + this.$refs.input.style.width = len + 'px' + this.recalcMenuPos() + }, 50) }, recalcScroll() { if (!this.menu) return @@ -261,7 +270,10 @@ export default { e.stopPropagation() e.preventDefault() } - if (this.$refs.input) this.$refs.input.focus() + if (this.$refs.input) { + this.$refs.input.style.width = '24px' + this.$refs.input.focus() + } var newSelected = null if (this.selected.includes(itemValue)) { @@ -315,7 +327,8 @@ export default { this.clickedOption(null, matchesItem) } else { this.insertNewItem(this.textInput) - } + } + if (this.$refs.input) this.$refs.input.style.width = '24px' }, scroll() { this.recalcMenuPos() diff --git a/client/components/ui/MultiSelectQueryInput.vue b/client/components/ui/MultiSelectQueryInput.vue index f8d7d456..d671e29d 100644 --- a/client/components/ui/MultiSelectQueryInput.vue +++ b/client/components/ui/MultiSelectQueryInput.vue @@ -14,7 +14,7 @@
add
- + @@ -155,7 +155,16 @@ export default { clearTimeout(this.typingTimeout) this.typingTimeout = setTimeout(() => { this.search() - }, 250) + }, 250) + this.setInputWidth() + }, + setInputWidth() { + setTimeout(() => { + var value = this.$refs.input.value + var len = value.length * 7 + 24 + this.$refs.input.style.width = len + 'px' + this.recalcMenuPos() + }, 50) }, recalcScroll() { if (!this.menu) return @@ -266,7 +275,10 @@ export default { e.stopPropagation() e.preventDefault() } - if (this.$refs.input) this.$refs.input.focus() + if (this.$refs.input) { + this.$refs.input.style.width = '24px' + this.$refs.input.focus() + } let newSelected = null if (this.getIsSelected(item.id)) { @@ -331,6 +343,7 @@ export default { name: this.textInput }) } + if (this.$refs.input) this.$refs.input.style.width = '24px' }, scroll() { this.recalcMenuPos()