;
var $select_state: JQuery;
var $select_city: JQuery;
$select_state = $('#select-state').selectize({
onChange: function(value) {
if (!value.length) return;
select_city.disable();
select_city.clearOptions();
select_city.load(function(callback) {
xhr && xhr.abort();
xhr = $.ajax({
url: 'http://www.corsproxy.com/api.sba.gov/geodata/primary_city_links_for_state_of/' + value + '.json',
success: function(results) {
select_city.enable();
callback(results);
},
error: function() {
callback();
}
})
});
}
});
$select_city = $('#select-city').selectize({
valueField: 'name',
labelField: 'name',
searchField: ['name']
});
select_city = $select_city[0].selectize;
select_state = $select_state[0].selectize;
select_city.disable();
// Confirm example
// --------------------------------------------------------------------------------------------------------------------
$('#input-tags').selectize({
delimiter: ',',
persist: false,
onDelete: function(values) {
return confirm(values.length > 1 ? 'Are you sure you want to remove these ' + values.length + ' items?' : 'Are you sure you want to remove "' + values[0] + '"?');
}
});
// Contacts example
// --------------------------------------------------------------------------------------------------------------------
interface Person {
first_name: string;
last_name: string;
email: string;
}
var REGEX_EMAIL = '([a-z0-9!#$%&\'*+/=?^_`{|}~-]+(?:\.[a-z0-9!#$%&\'*+/=?^_`{|}~-]+)*@' +
'(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?)';
var formatPerson = (name: Person) => {
return $.trim((name.first_name || '') + ' ' + (name.last_name || ''));
};
$('#select-to').selectize({
persist: false,
maxItems: null,
valueField: 'email',
labelField: 'name',
searchField: ['first_name', 'last_name', 'email'],
sortField: [
{field: 'first_name', direction: 'asc'},
{field: 'last_name', direction: 'asc'}
],
options: [
{email: 'nikola@tesla.com', first_name: 'Nikola', last_name: 'Tesla'},
{email: 'brian@thirdroute.com', first_name: 'Brian', last_name: 'Reavis'},
{email: 'someone@gmail.com'}
],
render: {
item: function(item: Person, escape: (input: any) => string) {
var name = formatPerson(item);
return '' +
(name ? '' + escape(name) + '' : '') +
(item.email ? '' + escape(item.email) + '' : '') +
'
';
},
option: function(item: Person, escape: (input: any) => string) {
var name = formatPerson(item);
var label = name || item.email;
var caption = name ? item.email : null;
return '' +
'' + escape(label) + '' +
(caption ? '' + escape(caption) + '' : '') +
'
';
}
},
createFilter: function(input: string) {
var regexpA = new RegExp('^' + REGEX_EMAIL + '$', 'i');
var regexpB = new RegExp('^([^<]*)\<' + REGEX_EMAIL + '\>$', 'i');
return regexpA.test(input) || regexpB.test(input);
},
create: function(input: string): any {
if ((new RegExp('^' + REGEX_EMAIL + '$', 'i')).test(input)) {
return {email: input};
}
var match = input.match(new RegExp('^([^<]*)\<' + REGEX_EMAIL + '\>$', 'i'));
if (match) {
var name = $.trim(match[1]);
var pos_space = name.indexOf(' ');
var first_name = name.substring(0, pos_space);
var last_name = name.substring(pos_space + 1);
return {
email: match[2],
first_name: first_name,
last_name: last_name
};
}
alert('Invalid email address.');
return false;
}
});
// Create filter example
// --------------------------------------------------------------------------------------------------------------------
$('#select-words-regex').selectize({
create: true,
createFilter: $('#regex').val()
});
$('#select-words-length').selectize({
create: true,
createFilter: function(input: string) { return input.length >= parseInt($('#length').val(), 10); }
});
var unique: Selectize.IApi = $('#select-words-unique').selectize({
create: true,
createFilter: function(input: string) {
input = input.toLowerCase();
return $.grep( unique.getValue(), function(value) {
return value.toLowerCase() === input;
}).length == 0;
}
})[0].selectize;
// Customization example
// --------------------------------------------------------------------------------------------------------------------
interface Link {
title: string;
url: string;
}
$('#select-links').selectize({
// NOTE ( https://github.com/borisyankov/DefinitelyTyped/pull/5590 ) theme: 'links',
maxItems: null,
valueField: 'id',
searchField: 'title',
options: [
{id: 1, title: 'DIY', url: 'https://diy.org'},
{id: 2, title: 'Google', url: 'http://google.com'},
{id: 3, title: 'Yahoo', url: 'http://yahoo.com'},
],
render: {
option: function(data: Link, escape: (input: any) => string) {
return '' +
'' + escape(data.title) + '' +
'' + escape(data.url) + '' +
'
';
},
item: function(data: Link, escape: (input: any) => string) {
return '';
}
},
create: function(input: string) {
return {
id: 0,
title: input,
url: '#'
};
}
});
// Events
// --------------------------------------------------------------------------------------------------------------------
var eventHandler = function(name: string) {
return function() {
console.log(name, arguments);
$('#log').append('' + name + '
');
};
};
var $select = $('#select-state').selectize({
create : true,
onChange : eventHandler('onChange'),
onItemAdd : eventHandler('onItemAdd'),
onItemRemove : eventHandler('onItemRemove'),
onOptionAdd : eventHandler('onOptionAdd'),
onOptionRemove : eventHandler('onOptionRemove'),
onDropdownOpen : eventHandler('onDropdownOpen'),
onDropdownClose : eventHandler('onDropdownClose'),
onInitialize : eventHandler('onInitialize'),
});
// Github example
// --------------------------------------------------------------------------------------------------------------------
interface Repository {
fork: string;
name: string;
description: string;
language: string;
watchers: number;
forks: string;
username: string;
}
$('#select-repo').selectize({
valueField: 'url',
labelField: 'name',
searchField: 'name',
options: [],
create: false,
render: {
option: function(item: Repository, escape: (input: any) => string) {
return '' +
'
' +
'' + escape(item.name) + '' +
'' + escape(item.username) + '' +
'' +
'
' + escape(item.description) + '' +
'
' +
'
';
}
},
score: function(search) {
var score = this.getScoreFunction(search);
return function(item: Repository) {
return score(item) * (1 + Math.min(item.watchers / 100, 1));
};
},
load: function(query, callback) {
if (!query.length) return callback();
$.ajax({
url: 'https://api.github.com/legacy/repos/search/' + encodeURIComponent(query),
type: 'GET',
error: function() {
callback();
},
success: function(res) {
callback(res.repositories.slice(0, 10));
}
});
}
});
// Lock example
// --------------------------------------------------------------------------------------------------------------------
$('select').selectize({create: true});
$('#select-locked-empty')[0].selectize.lock();
$('#select-locked-single')[0].selectize.lock();
$('#select-locked')[0].selectize.lock();
// Movies example
// --------------------------------------------------------------------------------------------------------------------
$('#select-movie').selectize({
valueField: 'title',
labelField: 'title',
searchField: 'title',
options: [],
create: false,
render: {
option: function(item, escape) {
var actors: any[] = [];
for (var i = 0, n = item.abridged_cast.length; i < n; i++) {
actors.push('' + escape(item.abridged_cast[i].name) + '');
}
return '' +
'
 + ')
' +
'
' +
'' + escape(item.title) + '' +
'' +
'
' + escape(item.synopsis || 'No synopsis available at this time.') + '' +
'
' + (actors.length ? 'Starring ' + actors.join(', ') : 'Actors unavailable') + '' +
'
';
}
},
load: function(query, callback) {
if (!query.length) return callback();
$.ajax({
url: 'http://api.rottentomatoes.com/api/public/v1.0/movies.json',
type: 'GET',
dataType: 'jsonp',
data: {
q: query,
page_limit: 10,
apikey: '3qqmdwbuswut94jv4eua3j85'
},
error: function() {
callback();
},
success: function(res) {
console.log(res.movies);
callback(res.movies);
}
});
}
});
// Optgroups
// --------------------------------------------------------------------------------------------------------------------
$("#select-car").selectize({
options: [
{id: 'avenger', make: 'dodge', model: 'Avenger'},
{id: 'caliber', make: 'dodge', model: 'Caliber'},
{id: 'caravan-grand-passenger', make: 'dodge', model: 'Caravan Grand Passenger'},
{id: 'challenger', make: 'dodge', model: 'Challenger'},
{id: 'ram-1500', make: 'dodge', model: 'Ram 1500'},
{id: 'viper', make: 'dodge', model: 'Viper'},
{id: 'a3', make: 'audi', model: 'A3'},
{id: 'a6', make: 'audi', model: 'A6'},
{id: 'r8', make: 'audi', model: 'R8'},
{id: 'rs-4', make: 'audi', model: 'RS 4'},
{id: 's4', make: 'audi', model: 'S4'},
{id: 's8', make: 'audi', model: 'S8'},
{id: 'tt', make: 'audi', model: 'TT'},
{id: 'avalanche', make: 'chevrolet', model: 'Avalanche'},
{id: 'aveo', make: 'chevrolet', model: 'Aveo'},
{id: 'cobalt', make: 'chevrolet', model: 'Cobalt'},
{id: 'silverado', make: 'chevrolet', model: 'Silverado'},
{id: 'suburban', make: 'chevrolet', model: 'Suburban'},
{id: 'tahoe', make: 'chevrolet', model: 'Tahoe'},
{id: 'trail-blazer', make: 'chevrolet', model: 'TrailBlazer'},
],
optgroups: [
{id: 'dodge', name: 'Dodge'},
{id: 'audi', name: 'Audi'},
{id: 'chevrolet', name: 'Chevrolet'}
],
labelField: 'model',
valueField: 'id',
optgroupField: 'make',
optgroupLabelField: 'name',
optgroupValueField: 'id',
optgroupOrder: ['chevrolet', 'dodge', 'audi'],
searchField: ['model'],
plugins: ['optgroup_columns'],
openOnFocus: false
});