Skip to content

Commit

Permalink
V-Autocomplete: hide-no-data also controls opening menu upon item update
Browse files Browse the repository at this point in the history
fixes #4663
  • Loading branch information
Dave Kichler authored and johnleider committed Sep 28, 2018
1 parent c2734cb commit 4d0b4eb
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 17 deletions.
7 changes: 5 additions & 2 deletions src/components/VAutocomplete/VAutocomplete.js
Original file line number Diff line number Diff line change
Expand Up @@ -173,12 +173,15 @@ export default {

this.lazySearch = null
},
items (val) {
items (val, oldVal) {
// If we are focused, the menu
// is not active and items change
// is not active, hide no data is enabled,
// and items change
// User is probably async loading
// items, try to activate the menu
if (
!(oldVal && oldVal.length) &&
this.hideNoData &&
this.isFocused &&
!this.isMenuActive &&
val.length
Expand Down
40 changes: 25 additions & 15 deletions test/unit/components/VAutocomplete/VAutocomplete.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -230,20 +230,6 @@ test('VAutocomplete.js', ({ mount, shallow, compileToFunctions }) => {
await wrapper.vm.$nextTick()

expect(wrapper.vm.isMenuActive).toBe(false)

wrapper.setProps({
items: [
{ text: 'Foo', value: 1 },
{ text: 'Bar', value: 2 }
]
})

await wrapper.vm.$nextTick()

// Once items refresh active will
// be updated to openif already
// focused
expect(wrapper.vm.isMenuActive).toBe(true)
})

it('should change selected index', async () => {
Expand Down Expand Up @@ -719,7 +705,7 @@ test('VAutocomplete.js', ({ mount, shallow, compileToFunctions }) => {
expect(input.element.value).toBe('foo')
})

it('should show menu when items are added and hide-no-data', async () => {
it('should show menu when items are added for the first time and hide-no-data is enabled', async () => {
const wrapper = mount(VAutocomplete, {
propsData: {
hideNoData: true,
Expand All @@ -742,4 +728,28 @@ test('VAutocomplete.js', ({ mount, shallow, compileToFunctions }) => {

expect(wrapper.vm.isMenuActive).toBe(true)
})

it('should not show menu when items are updated and hide-no-data is enabled ', async () => {
const wrapper = mount(VAutocomplete, {
propsData: {
hideNoData: true,
items: [ 'Something first' ]
}
})

const input = wrapper.first('input')

input.trigger('focus')

expect(wrapper.vm.isMenuActive).toBe(false)
expect(wrapper.vm.isFocused).toBe(true)

wrapper.setProps({
items: ['Foo', 'Bar']
})

await wrapper.vm.$nextTick()

expect(wrapper.vm.isMenuActive).toBe(false)
})
})

0 comments on commit 4d0b4eb

Please sign in to comment.