2014-06-23 11:05:06 +09:00
|
|
|
// see: http://stackoverflow.com/questions/1909441/jquery-keyup-delay
|
|
|
|
var delay = (function(){
|
|
|
|
var timer = 0;
|
|
|
|
return function(callback, ms){
|
|
|
|
clearTimeout (timer);
|
|
|
|
timer = setTimeout(callback, ms);
|
|
|
|
};
|
2014-08-13 17:51:38 +09:00
|
|
|
})();
|
|
|
|
|
|
|
|
Meteor.startup(function () {
|
2014-11-24 11:27:07 +09:00
|
|
|
|
2014-08-13 17:51:38 +09:00
|
|
|
Template[getTemplate('search')].helpers({
|
2014-09-30 15:53:36 +09:00
|
|
|
canSearch: function () {
|
2015-01-07 08:22:46 +01:00
|
|
|
return can.view(Meteor.user());
|
2014-09-30 15:53:36 +09:00
|
|
|
},
|
2014-08-13 17:51:38 +09:00
|
|
|
searchQuery: function () {
|
|
|
|
return Session.get("searchQuery");
|
|
|
|
},
|
|
|
|
searchQueryEmpty: function () {
|
|
|
|
return !!Session.get("searchQuery") ? '' : 'empty';
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
Template[getTemplate('search')].events({
|
2015-03-24 16:27:54 -06:00
|
|
|
'keyup .search-field, search .search-field': function(e){
|
|
|
|
console.log("telescope-handler");
|
2014-08-13 17:51:38 +09:00
|
|
|
e.preventDefault();
|
|
|
|
var val = $(e.target).val(),
|
2014-11-30 17:03:30 -08:00
|
|
|
$search = $('.search');
|
|
|
|
if (val === '') {
|
|
|
|
// if search field is empty, just do nothing and show an empty template
|
2014-08-13 17:51:38 +09:00
|
|
|
$search.addClass('empty');
|
|
|
|
Session.set('searchQuery', '');
|
2014-12-03 00:06:00 -08:00
|
|
|
Router.go('search', null, {replaceState: true});
|
2014-11-30 17:03:30 -08:00
|
|
|
} else {
|
|
|
|
$search.removeClass('empty');
|
|
|
|
// if search field is not empty, add a delay to avoid firing new searches for every keystroke
|
2014-08-13 17:51:38 +09:00
|
|
|
delay(function(){
|
|
|
|
Session.set('searchQuery', val);
|
2014-10-03 15:48:32 -06:00
|
|
|
|
|
|
|
// Update the querystring.
|
2014-12-03 00:06:00 -08:00
|
|
|
var opts = {query: {q: val}};
|
2014-10-03 15:48:32 -06:00
|
|
|
// if we're already on the search page, do a replaceState. Otherwise,
|
|
|
|
// just use the pushState default.
|
2014-12-03 00:06:00 -08:00
|
|
|
if(Router.current().route.getName() === 'search') {
|
2014-10-03 15:48:32 -06:00
|
|
|
opts.replaceState = true;
|
|
|
|
}
|
|
|
|
Router.go('search', null, opts);
|
|
|
|
|
2014-08-13 17:51:38 +09:00
|
|
|
}, 700 );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
2014-11-24 11:27:07 +09:00
|
|
|
|
2014-10-03 15:48:32 -06:00
|
|
|
});
|