mirror of
https://github.com/devbridge/jQuery-Autocomplete.git
synced 2024-11-09 23:01:00 +00:00
77 lines
3.9 KiB
JavaScript
77 lines
3.9 KiB
JavaScript
/*jslint browser: true, white: true, plusplus: true */
|
|
/*global $, countries */
|
|
|
|
$(function () {
|
|
'use strict';
|
|
|
|
var countriesArray = $.map(countries, function (value, key) { return { value: value, data: key }; });
|
|
|
|
// Setup jQuery ajax mock:
|
|
$.mockjax({
|
|
url: '*',
|
|
responseTime: 2000,
|
|
response: function (settings) {
|
|
var query = settings.data.query,
|
|
queryLowerCase = query.toLowerCase(),
|
|
re = new RegExp('\\b' + $.Autocomplete.utils.escapeRegExChars(queryLowerCase), 'gi'),
|
|
suggestions = $.grep(countriesArray, function (country) {
|
|
// return country.value.toLowerCase().indexOf(queryLowerCase) === 0;
|
|
return re.test(country.value);
|
|
}),
|
|
response = {
|
|
query: query,
|
|
suggestions: suggestions
|
|
};
|
|
|
|
this.responseText = JSON.stringify(response);
|
|
}
|
|
});
|
|
|
|
// Initialize ajax autocomplete:
|
|
$('#autocomplete-ajax').autocomplete({
|
|
// serviceUrl: '/autosuggest/service/url',
|
|
lookup: countriesArray,
|
|
lookupFilter: function(suggestion, originalQuery, queryLowerCase) {
|
|
var re = new RegExp('\\b' + $.Autocomplete.utils.escapeRegExChars(queryLowerCase), 'gi');
|
|
return re.test(suggestion.value);
|
|
},
|
|
onSelect: function(suggestion) {
|
|
$('#selction-ajax').html('You selected: ' + suggestion.value + ', ' + suggestion.data);
|
|
},
|
|
onHint: function (hint) {
|
|
$('#autocomplete-ajax-x').val(hint);
|
|
},
|
|
onInvalidateSelection: function() {
|
|
$('#selction-ajax').html('You selected: none');
|
|
}
|
|
});
|
|
|
|
var nhlTeams = ['Anaheim Ducks', 'Atlanta Thrashers', 'Boston Bruins', 'Buffalo Sabres', 'Calgary Flames', 'Carolina Hurricanes', 'Chicago Blackhawks', 'Colorado Avalanche', 'Columbus Blue Jackets', 'Dallas Stars', 'Detroit Red Wings', 'Edmonton OIlers', 'Florida Panthers', 'Los Angeles Kings', 'Minnesota Wild', 'Montreal Canadiens', 'Nashville Predators', 'New Jersey Devils', 'New Rork Islanders', 'New York Rangers', 'Ottawa Senators', 'Philadelphia Flyers', 'Phoenix Coyotes', 'Pittsburgh Penguins', 'Saint Louis Blues', 'San Jose Sharks', 'Tampa Bay Lightning', 'Toronto Maple Leafs', 'Vancouver Canucks', 'Washington Capitals'];
|
|
var nbaTeams = ['Atlanta Hawks', 'Boston Celtics', 'Charlotte Bobcats', 'Chicago Bulls', 'Cleveland Cavaliers', 'Dallas Mavericks', 'Denver Nuggets', 'Detroit Pistons', 'Golden State Warriors', 'Houston Rockets', 'Indiana Pacers', 'LA Clippers', 'LA Lakers', 'Memphis Grizzlies', 'Miami Heat', 'Milwaukee Bucks', 'Minnesota Timberwolves', 'New Jersey Nets', 'New Orleans Hornets', 'New York Knicks', 'Oklahoma City Thunder', 'Orlando Magic', 'Philadelphia Sixers', 'Phoenix Suns', 'Portland Trail Blazers', 'Sacramento Kings', 'San Antonio Spurs', 'Toronto Raptors', 'Utah Jazz', 'Washington Wizards'];
|
|
var nhl = $.map(nhlTeams, function (team) { return { value: team, data: { category: 'NHL' }}; });
|
|
var nba = $.map(nbaTeams, function (team) { return { value: team, data: { category: 'NBA' } }; });
|
|
var teams = nhl.concat(nba);
|
|
|
|
// Initialize autocomplete with local lookup:
|
|
$('#autocomplete').devbridgeAutocomplete({
|
|
lookup: teams,
|
|
minChars: 1,
|
|
onSelect: function (suggestion) {
|
|
$('#selection').html('You selected: ' + suggestion.value + ', ' + suggestion.data.category);
|
|
},
|
|
showNoSuggestionNotice: true,
|
|
noSuggestionNotice: 'Sorry, no matching results',
|
|
groupBy: 'category'
|
|
});
|
|
|
|
// Initialize autocomplete with custom appendTo:
|
|
$('#autocomplete-custom-append').autocomplete({
|
|
lookup: countriesArray,
|
|
appendTo: '#suggestions-container'
|
|
});
|
|
|
|
// Initialize autocomplete with custom appendTo:
|
|
$('#autocomplete-dynamic').autocomplete({
|
|
lookup: countriesArray
|
|
});
|
|
}); |