Skip to content

Latest commit

 

History

History
88 lines (67 loc) · 1.48 KB

readme.md

File metadata and controls

88 lines (67 loc) · 1.48 KB

vue-suggest

An inline typeahead component for Vue.js

Requirements

  • vue
  • vue-resource

Example

demo

Usage

<template>
  <div>
    <suggest
      name="country" 
      param="query" 
      url="/api/countries" 
      v-bind:format="formatCountries"
      v-bind:onSuggest="handleOnSuggest"/>
    <input 
      type="hidden" 
      v-model="countryId"/>
  </div>
</template>
<script>
export default {
  data () {
    return {
      countryId: null
    }
  },
  methods: {
    formatCountries (data) {
      return data.map((country) => {
        return {
          id: country.uuid,
          name: country.iso
      })      
    },
    handleOnSuggest (country) {
      this.countryId = country.id
    }
  }
}
</script>
<style>
suggest-wrapper {
  .suggest-results {
    padding: .5rem 0;
  }
} 
</style>

Arguments

name: (required) The name of the html input.

url: (required) The url that will be called on keyup.

param: (optional) The query parameter key used in the url on keyup.

onResponse: (optional) Callback for formatting suggestions.

onSuggestion: (optional) Callback that will be triggered when a suggestion is complete.

Events

Tab: Input the current suggestion.

Return: Input the current suggestion.

Up Arrow: Show the previous suggestion.

Right Arrow: Input the current suggestion.

Down Arrow: Show the next suggestion.