diff --git a/src/components/autocomplete/AutoComplete.d.ts b/src/components/autocomplete/AutoComplete.d.ts index 558c40c7d..ade331931 100755 --- a/src/components/autocomplete/AutoComplete.d.ts +++ b/src/components/autocomplete/AutoComplete.d.ts @@ -10,6 +10,7 @@ interface AutoCompleteProps { scrollHeight?: string; dropdown?: boolean; dropdownMode?: string; + autoHighlight?: boolean; multiple?: boolean; minLength?: number; delay?: number; diff --git a/src/components/autocomplete/AutoComplete.vue b/src/components/autocomplete/AutoComplete.vue index eeb8b528a..71b44c844 100755 --- a/src/components/autocomplete/AutoComplete.vue +++ b/src/components/autocomplete/AutoComplete.vue @@ -86,6 +86,10 @@ export default { type: String, default: 'blank' }, + autoHighlight: { + type: Boolean, + default: false + }, multiple: { type: Boolean, default: false @@ -321,6 +325,10 @@ export default { }, showOverlay() { this.overlayVisible = true; + + setTimeout(()=>{ + this.autoHighlightFirstItem() + },200) }, hideOverlay() { this.overlayVisible = false; @@ -345,7 +353,6 @@ export default { query: query }); }, - onInputClicked(event) { if(this.completeOnFocus) { this.search(event, '', 'click'); @@ -384,10 +391,16 @@ export default { onBlur() { this.focused = false; }, + autoHighlightFirstItem() { + if (this.autoHighlight && this.suggestions && this.suggestions.length) { + const itemToHighlight = this.overlay.firstElementChild.firstElementChild + DomHandler.addClass(itemToHighlight, 'p-highlight') + } + }, onKeyDown(event) { if (this.overlayVisible) { let highlightItem = DomHandler.findSingle(this.overlay, 'li.p-highlight'); - + switch(event.which) { //down case 40: diff --git a/src/views/autocomplete/AutoCompleteDoc.vue b/src/views/autocomplete/AutoCompleteDoc.vue index 96b0fba95..1dc9f0ebb 100755 --- a/src/views/autocomplete/AutoCompleteDoc.vue +++ b/src/views/autocomplete/AutoCompleteDoc.vue @@ -187,6 +187,12 @@ export default {