Auto-complete input values from server search results.
Перейти к файлу
Kristján Oddsson a426734cd7
Merge pull request #49 from github/update-dependencies
Update developer dependencies
2021-04-26 15:51:05 +01:00
.github/workflows Simplify workflows 2020-06-04 12:13:03 -04:00
examples Rename browser.js to bundle.js 2020-04-30 12:59:14 -04:00
src Add return type defs= 2020-06-04 12:18:58 -04:00
test Convert to TypeScript 2020-05-20 18:24:33 -04:00
.eslintrc.json Set eslint config as root 2021-04-26 09:52:42 +01:00
.gitignore Initial <auto-complete> element 2018-04-11 13:47:25 -06:00
CODEOWNERS Create CODEOWNERS 2020-03-10 08:57:35 +00:00
LICENSE Initial <auto-complete> element 2018-04-11 13:47:25 -06:00
README.md Rename browser.js to bundle.js 2020-04-30 12:59:14 -04:00
package-lock.json Update test and build tools 2021-04-26 09:52:01 +01:00
package.json Update test and build tools 2021-04-26 09:52:01 +01:00
rollup.config.js Convert to TypeScript 2020-05-20 18:24:33 -04:00
tsconfig.json Convert to TypeScript 2020-05-20 18:24:33 -04:00

README.md

<auto-complete> element

Auto-complete input values from server search results.

Installation

$ npm install --save @github/auto-complete-element

Usage

Script

Import as ES modules:

import '@github/auto-complete-element'

With a script tag:

<script type="module" src="./node_modules/@github/auto-complete-element/dist/bundle.js">

Markup

<auto-complete src="/users/search" for="users-popup">
  <input type="text">
  <ul id="users-popup"></ul>
</auto-complete>

The server response should include the items that matched the search query.

<li role="option">Hubot</li>
<li role="option">Bender</li>
<li role="option">BB-8</li>
<li role="option" aria-disabled="true">R2-D2 (powered down)</li>

The data-autocomplete-value attribute can be used to define the value for an item whose display text needs to be different:

<li role="option" data-autocomplete-value="bb8">BB-8 (astromech)</li>

Attributes

  • open is true when the auto-complete result list is visible
  • value is the selected value from the list or the empty string when cleared

Events

Network request lifecycle events

Request lifecycle events are dispatched on the <auto-complete> element. These events do not bubble.

  • loadstart - The server fetch has started.
  • load - The network request completed successfully.
  • error - The network request failed.
  • loadend - The network request has completed.

Network events are useful for displaying progress states while the request is in-flight.

const completer = document.querySelector('auto-complete')
const container = completer.parentElement
completer.addEventListener('loadstart', () => container.classList.add('is-loading'))
completer.addEventListener('loadend', () => container.classList.remove('is-loading'))
completer.addEventListener('load', () => container.classList.add('is-success'))
completer.addEventListener('error', () => container.classList.add('is-error'))

Auto-complete events

auto-complete-change is dispatched after a value is selected. In event.detail you can find:

  • relatedTarget: The HTMLInputElement controlling the auto-complete result list.
completer.addEventListener('auto-complete-change', function(event) {
  console.log('Auto-completed value chosen or cleared', completer.value)
  console.log('Related input element', event.relatedTarget)
})

Browser support

Browsers without native custom element support require a polyfill.

  • Chrome
  • Firefox
  • Safari
  • Microsoft Edge

Development

npm install
npm test

License

Distributed under the MIT license. See LICENSE for details.