├── README.md ├── css └── multisuggest-plugin.css ├── demo.html └── js └── multisuggest-plugin.js /README.md: -------------------------------------------------------------------------------- 1 | Bootstrap Multi-Suggest Typeahead 2 | ================================= 3 | 4 | Extends the default [Bootstrap Typeahead](http://twitter.github.com/bootstrap/javascript.html#typeahead) component to support: 5 | 6 | * __multiple datasources__ 7 | * data from __Backbone.js Collections__, __RESTful services__ (AJAX/JSON), and __static arrays__ 8 | * __dynamic filtering__ 9 | * custom, per-datasource __list formatters__ 10 | * separate __visible & hidden select values__ 11 | * __minimum number of characters__ before a search is performed 12 | 13 | _Brought to you by the friendly folks at [ACT.md](http://act.md)_ 14 | 15 | Live Demo 16 | --------- 17 | 18 | [View the live demo](http://htmlpreview.github.com/?https://github.com/rroppolo/bootstrap-multisuggestplugin/blob/master/demo.html) 19 | 20 | 21 | Installation 22 | ------------ 23 | 24 | 1. Include `multisuggest-plugin.js` 25 | 1. Include `multisuggest-plugin.css` 26 | 1. Enable the multi-suggest typeahead on any text input: 27 | 28 | ```javscript 29 | $('input.foo').multisuggest(options); 30 | ``` 31 | 32 | Options 33 | ------- 34 | 35 | The plugin accepts options as single object argument. Supported options are: 36 | 37 | * __sources__: an array of data sources 38 | * __type__: one of 'backbone.collection', 'url', or 'array' 39 | * __data__: either the Backbone Collection object, URL string, or Array object 40 | * __filter__: function to filter the data by a search query term and return the filtered data (for Collections and Arrays) 41 | * __listFormatter__: function to format the items into HTML as they will appear in the dropdown, e.g. `function(item, term) { ... }` 42 | * __inputFormatter__: function to format the items into text as they will appear in the input field when selected, e.g. `function(item) { ... }` 43 | * __valueAttribute__: function which takes an item from the data set and returns the 'value' to be submitted (stored in a hidden input field), e.g. `function(item) { ... }` 44 | * __headher__: String of text to appear as the heading of the data source in the menu of results 45 | * __queryParam__: When using the `url` type, this field indicates the query parameter used to pass the search string 46 | * __resultsProcessor__: When using the `url` type, a function to process the JSON results returned by the AJAX request, e.g. `function(data) { ... }` 47 | * __maxEntries__: optional maximum number of results to show for this data source 48 | * __link__: optional link HTML to show at the bottom of the menu, e.g. `Enter new item...` 49 | * __linkHandler__: listner function that is invoked when the link is selected 50 | * __loadingIconClass__: CSS class for the loading icon, which is displayed during `url`-type AJAX requests 51 | * __noResultsText__: custom text to display when no search results are found 52 | * __enableDropdownMode__: boolean parameter indicating whether the input can be expanded as a standard dropdown in addition to the typeahead functionality. Dropdown mode will render only static data sources. 53 | * __delay__: optional number of milliseconds to delay typeahead searches 54 | * __minLength__: optional minimum number of characters needed before performing a typeahead search 55 | 56 | See the [live demo](http://htmlpreview.github.com/?https://github.com/rroppolo/bootstrap-multisuggestplugin/blob/master/demo.html) for fully qualified examples. 57 | 58 | Default Value 59 | -------------- 60 | 61 | The plugin accepts a default value from the text input through the value and data-value attributes. 62 | * __value__: the display value, displayed as the selected item in the input field 63 | * __data-value__: the real value to be submitted 64 | 65 | ```html 66 | 67 | ``` 68 | 69 | Contributing 70 | ------------ 71 | 72 | 1. Fork the repository 73 | 1. Create your feature branch, `git checkout -b my-feature` 74 | 1. Commit your changes, `git commit -am 'Description of my new feature'` 75 | 1. Push to the branch, `git push origin my-feature` 76 | 1. Create a new pull request 77 | -------------------------------------------------------------------------------- /css/multisuggest-plugin.css: -------------------------------------------------------------------------------- 1 | input.msuggest-input-dropdown { 2 | background-image: url(); 3 | background-repeat: no-repeat; 4 | background-position: right center; 5 | padding-right: 23px; 6 | } 7 | 8 | .msuggest-loading { 9 | height: 60px; 10 | background-image: url(); 11 | background-repeat: no-repeat; 12 | background-position: 50% 50%; 13 | } 14 | 15 | input.msuggest-selected { 16 | text-decoration: underline; 17 | } 18 | 19 | .msuggest-header, 20 | .msuggest-link a, 21 | .msuggest-ellip span { 22 | color: #666; 23 | padding:5px 20px; 24 | } 25 | 26 | .msuggest-header { 27 | text-transform: uppercase; 28 | font-size: 12px; 29 | } 30 | 31 | .msuggest-link { 32 | padding-bottom:10px; 33 | } 34 | 35 | .msuggest-link a { 36 | text-decoration: underline; 37 | } 38 | 39 | .input-append .disabled.active, 40 | .input-prepend .disabled.active, 41 | .input-append .msuggest-header.active, 42 | .input-prepend .msuggest-header.active { 43 | background-color: #FFFFFF; 44 | border-color: inherit; 45 | background: none; 46 | } 47 | 48 | .dropdown-menu > li.disabled > a:hover, 49 | .dropdown-menu > li.disabled > a:focus, 50 | .dropdown-menu > .disabled.active > a, 51 | .dropdown-menu > .disabled.active > a:hover, 52 | .dropdown-menu > .disabled.active > a:focus { 53 | background-color: #ffffff; 54 | background: none; 55 | } 56 | 57 | .msuggest-menu img { 58 | margin-right: 3px; 59 | width: 25px; 60 | height: 25px; 61 | } 62 | -------------------------------------------------------------------------------- /demo.html: -------------------------------------------------------------------------------- 1 | 2 | 3 |
4 | 5 | 6 |The multiple-datasource typeahead plugin for Twitter Bootstrap.
29 | 30 | 31 | 32 | 33 |Sorry, not a live example. But it works, trust us.
51 |52 | $('input[name="ofYourChoice"]').multisuggest({ 53 | sources: [ 54 | { 55 | data: "/api/users", 56 | queryParam: "text", 57 | type: "url", 58 | listFormatter: function(item, term) { 59 | var compiled = _.template("<% if (thumb) { print('<img src="../' + thumb + '">') } %><% print(hl(name.first)) %> <% print(hl(name.last)) %><% if (name.suffix) { print(', ' + name.suffix)} %><br /><small><% print(hl(organization.name)) %></small>"); 60 | return compiled({ 61 | hl: $.proxy($.fn.usersuggest.highlighter, this, term), 62 | organization: item.profile.organization, 63 | name: item.profile.name, 64 | thumb: item.profile.thumbnail 65 | }); 66 | }, 67 | inputFormatter: function(item) { 68 | var compiled = _.template("<%= first %> <%= last %>"); 69 | return compiled(item.profile.name); 70 | }, 71 | valueAttribute: function(item) { 72 | return item.profile.id; 73 | }, 74 | resultsProcessor: function(data) { 75 | return data.users; 76 | }, 77 | header: "Users", 78 | maxEntries: 5 79 | } 80 | ], 81 | link: '<a tabFocus="0" href="#">Invite a new user</a>', 82 | linkHandler: function() { 83 | // show invitation form 84 | }, 85 | loadingIconClass: "usuggest-loading", 86 | noResultsText: "No matching users.", 87 | enableDropdownMode: true, 88 | delay: 300, 89 | minLength: 2 90 | }); 91 |92 | 93 |