contenteditable-autocomplete v1.0.2
contenteditable-autocomplete
Add Autocomplete/Typeahead to contenteditable tag
Download / Installation
You can download the latest JS & CSS code here:
- https://unpkg.com/contenteditable-autocomplete/dist/contenteditable-autocomplete.js
- https://unpkg.com/contenteditable-autocomplete/dist/contenteditable-autocomplete.css
Or install via npm
npm install --save contenteditable-autocompleteThe JS code can be required with
var jQuery = require('jquery')
var contenteditableAutocomplete = require('contenteditable-autocomplete')
// init
contenteditableAutocomplete(jQuery)The CSS code lives at node_modules/contenteditable-autocomplete/contenteditable-autocomplete.css
Usage
<!-- load jquery -->
<script src="jquery.js"></script>
<!-- load contenteditable-autocomplete assets -->
<link rel="stylesheet" type="text/css" href="contenteditable-autocomplete.css">
<script src="contenteditable-autocomplete.js"></script>
<!-- The behaviour is initialzied on first interaction -->
<p>
  <strong>Country:</strong>
  <span contenteditable name="country" placeholder="set country" data-autocomplete-spy></span> |
</p>
<p>
  <strong>Countries:</strong>
</p>
<p contenteditable name="countries" placeholder="set countries" data-autocomplete-spy data-autocomplete-multiple></p>Suggestions
To pass suggestions for the autocomplete, listen to the autocomplete:request event
$('[name=country]').on('autocomplete:request', function(event, query, callback) {
  var suggestions = getSuggestionsArrayFor(query);
  callback(suggestions);
})Instead of strings, you can also pass objects with the mandatory properties label and value.
label will be shown as suggestions. When selected, value will be added to the input.
$('name=country').on('autocomplete:request', function(event, query, callback) { callback( {label: 'Germany (Europe)', value: 'Germany'}, {label: 'Thailand (Asia)', value: 'Thailand'}, {label: 'Uruguay (South America)', value: 'Uruguay'} ); })
Select event
To react on when a suggestion has been selected, listen to the autocomplete:select event.
$('[name=country]').on('autocomplete:select', function(event, selected) {
  console.log('selected item:', selected);
})Selected is always an object with label and value properties (see above). Additional
properties passed to suggestions will be passed.
Local Setup
git clone git@github.com:gr2m/contenteditable-autocomplete.git
cd contenteditable-autocomplete
npm installTest
You can start a local dev server with
npm startRun tests with
npm testWhile working on the tests, you can start Selenium / Chrome driver once, and then tests re-run on each save
npm run test:mocha:watchFine Print
The Expandable Input Plugin have been authored by Gregor Martynus, proud member of the Hoodie Community.
License: MIT