UNPKG

alpaca

Version:

Alpaca provides the easiest and fastest way to generate interactive forms for the web and mobile devices. It runs simply as HTML5 or more elaborately using Bootstrap, jQuery Mobile or jQuery UI. Alpaca uses Handlebars to process JSON schema and provide

94 lines (82 loc) 2.68 kB
jQuery(function(){ // Track downloads $('#download-master').click(function(){ _trackEvent('Downloads', 'master'); }); }); jQuery(document).ready(function($) { /* Docs scrollspy */ $('body').scrollspy({ target: '.bs-sidebar', offset: 0 }) $(window).on('load', function () { $('body').scrollspy('refresh') }) // back to top setTimeout(function () { var $sideBar = $('.bs-sidebar') $sideBar.affix({ offset: { top: function () { var offsetTop = $sideBar.offset().top var sideBarMargin = parseInt($sideBar.children(0).css('margin-top'), 10) return (this.top = offsetTop - sideBarMargin) } , bottom: function () { return (this.bottom = $('.bs-footer').outerHeight(true)) } } }) }, 100) /* Run examples */ $('.token-example-field').tokenfield(); $('#tokenfield-1').tokenfield({ autocomplete: { source: ['red','blue','green','yellow','violet','brown','purple','black','white'], delay: 100 }, showAutocompleteOnFocus: true, delimiter: [',',' ', '-', '_'] }); var engine = new Bloodhound({ local: [{value: 'red'}, {value: 'blue'}, {value: 'green'} , {value: 'yellow'}, {value: 'violet'}, {value: 'brown'}, {value: 'purple'}, {value: 'black'}, {value: 'white'}], datumTokenizer: function(d) { return Bloodhound.tokenizers.whitespace(d.value); }, queryTokenizer: Bloodhound.tokenizers.whitespace }); engine.initialize(); $('#tokenfield-typeahead').tokenfield({ typeahead: [null, { source: engine.ttAdapter() }] }); $('#tokenfield-2') .on('tokenfield:createtoken', function (e) { var data = e.attrs.value.split('|') e.attrs.value = data[1] || data[0] e.attrs.label = data[1] ? data[0] + ' (' + data[1] + ')' : data[0] }) .on('tokenfield:createdtoken', function (e) { // Über-simplistic e-mail validation var re = /\S+@\S+\.\S+/ var valid = re.test(e.attrs.value) if (!valid) { $(e.relatedTarget).addClass('invalid') } }) .on('tokenfield:edittoken', function (e) { if (e.attrs.label !== e.attrs.value) { var label = e.attrs.label.split(' (') e.attrs.value = label[0] + '|' + e.attrs.value } }) .on('tokenfield:removedtoken', function (e) { if (e.attrs.length > 1) { var values = $.map(e.attrs, function (attrs) { return attrs.value }); alert(e.attrs.length + ' tokens removed! Token values were: ' + values.join(', ')) } else { alert('Token removed! Token value was: ' + e.attrs.value) } }) .tokenfield() });