Skip to content

pergardebrink/jquery-mentions

 
 

Repository files navigation

jquery-mentions

More stable alternative to podio's jquery.mentionsInput plugin, which is currently unmaintained.

Advantages over jquery.mentionsInput:

  • Many issues are solved
  • Input styles are copied to highlighter automatically
  • Support of both textarea and input tags
  • Hidden-input with markuped text created automatically
  • Uses jQuery UI autocomplete
  • The code is much smaller

Solved issues of jquery.mentionsInput:

  • Adding spaces before mention shows overlay
  • Scrolling to bottom inside textarea moves text, but not highlights
  • Typing email adress activates mentions
  • Inserting same mentions multiple times
  • Prepopulate input with text

Usage

For this plugin to work you need to include jQuery Autocomplete to your page.

var data = [
    {value: 'alex', uid: 'user:1'},
    {value: 'andrew', uid: 'user:2'},
    {value: 'angry birds', uid: 'game:5'},
    {value: 'assault', uid: 'game:3'}
];

$('textarea').mentionsInput({source: data});

Remote datasource:

$('textarea').mentionsInput({source: 'http://example.com'})

Calling a method:

$('textarea').mentionsInput('getValue');
$('textarea').mentionsInput('append', {name: 'alex', uid: 'user:1'});

Options

source

Data source for the autocomplete. See jQuery Autocomplete API for available values.

delay

Delay for autocomplete to start searching. Default value is 0. More info in jQuery Autocomplete API

minLength

The minimum number of characters to trigger autocomplete. More info in jQuery Autocomplete API

trigger

Char which trigger autocomplete, default value is '@'

Methods

setValue(markup)

Replace contents with marked up text. For example 'Hey @[alex](user:1)'

getValue()

Returns marked up value.

append(pieces)

Appends pieces of text to the input. Pieces is an array, containing a text or a mention object. For example ['Hey', {name: 'alex', uid: 'user:1'}]

clear()

Clears value. Note that you must use this method insted of manually clearing value of the input

destroy()

Destroys current instance of the plugin

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • CoffeeScript 95.4%
  • CSS 4.6%