Skip to content

Instantly share code, notes, and snippets.

@wyattdanger
Created August 26, 2011 03:25
Show Gist options
  • Save wyattdanger/1172608 to your computer and use it in GitHub Desktop.
Save wyattdanger/1172608 to your computer and use it in GitHub Desktop.
(function() {
var __bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; };
$(function() {
var Map, NomsApp, infoBox, nom, textBox;
if (!navigator.geolocation) {
alert('bro you need geolocation');
}
textBox = $('#text');
infoBox = $("#infoBox");
Map = (function() {
function Map() {
this.getLocation = __bind(this.getLocation, this);
var mapOpts, mapStyles, mapType;
mapOpts = {
zoom: 17,
draggable: false,
disableDoubleClickZoom: true,
disableDefaultUI: true,
mapTypeId: google.maps.MapTypeId.ROADMAP,
scrollwheel: false
};
mapStyles = [
{
featureType: "all",
stylers: [
{
saturation: -100
}
]
}
];
mapType = new google.maps.StyledMapType(mapStyles, {
name: 'nom'
});
this.map = new google.maps.Map(document.getElementById('map'), mapOpts);
this.map.mapTypes.set("nom", mapType);
this.map.setMapTypeId("nom");
this.service = new google.maps.places.PlacesService(this.map);
}
Map.prototype.getLocation = function() {
return navigator.geolocation.getCurrentPosition(__bind(function(pos) {
var _ref;
_ref = [pos.coords.latitude, pos.coords.longitude], this.lat = _ref[0], this.lng = _ref[1];
this.location = new google.maps.LatLng(this.lat, this.lng);
return this.setupClient();
}, this), function() {
return textBox.html("Sorry partner. You need to enable HTML5 geolocation to ride this pony.");
});
};
Map.prototype.setupClient = function() {
textBox.html("Finding a place to eat...");
return setTimeout(__bind(function() {
setTimeout(function() {});
window.searchCallbackHandler = this.searchCallbackHandler;
return this.search();
}, this), 1000);
};
Map.prototype.addMarker = function(info) {
var markerOptions;
markerOptions = {
icon: "",
visible: true,
map: this.map,
position: info.geometry.location
};
this.restaurantMarker = new google.maps.Marker(markerOptions);
return this.map.setCenter(info.geometry.location);
};
Map.prototype.search = function() {
if (this.data) {
return nom.draw(this.data);
} else {
return this.service.search({
location: this.location,
radius: 3200,
types: ['restaurant', 'food', 'bar']
}, searchCallbackHandler);
}
};
Map.prototype.searchCallbackHandler = function(data, code) {
this.data = data;
return nom.draw(data);
};
return Map;
})();
NomsApp = (function() {
var phrases;
phrases = ["Nom on some <a>\#{ this.name }</a>, buddy!", "Break bread at <a>\#{ this.name }</a>, brother.", "Chow down at <a>\#{ this.name }</a>, champ!", "Put away some <a>\#{ this.name }</a>, partner!", "Demolish some <a>\#{ this.name }</a>, bro.", "Try out some <a>\#{ this.name }</a>, lil' guy.", "Gobble up some <a>\#{ this.name }</a>, turkey.", "Stuff your face at <a>\#{ this.name }</a>, dude.", "Throw back some <a>\#{ this.name }</a>, boss.", "Chew on some <a>\#{ this.name }</a>, chief.", "Chew on some <a>\#{ this.name }</a>, you animal.", "Chew on some <a>\#{ this.name }</a>, you animal."];
function NomsApp() {
this.draw = __bind(this.draw, this);
this.detailsCallbackHandler = __bind(this.detailsCallbackHandler, this);
var tagline;
textBox.html("Finding your location...");
this.map = new Map;
this.map.getLocation();
this.counter = 0;
tagline = $('h2.tagline');
tagline.css('cursor', 'pointer').click(__bind(function() {
tagline.removeClass("spinner-" + this.counter);
this.counter = (this.counter + 1) % 8;
tagline.addClass("spinner-" + this.counter);
return this.map.getLocation();
}, this));
}
NomsApp.prototype.selectRandom = function(data) {
return data[Math.floor(Math.random(data.total) * data.length)];
};
NomsApp.prototype.template = function(a,b){return function(c,d){return a.replace(/#{([^}]*)}/g,function(a,e){return Function("x","with(x)return "+e).call(c,d||b||{})})}};
NomsApp.prototype.info = function(obj) {
var t;
t = this.template(($('#info')).text());
infoBox.html(t(obj));
return textBox.find('a').attr('href', obj.url);
};
NomsApp.prototype.headline = function(obj) {
var t;
t = this.template(this.selectRandom(phrases));
textBox.html(t(obj));
window.detailsCallbackHandler = this.detailsCallbackHandler;
return this.map.service.getDetails({
reference: obj.reference
}, detailsCallbackHandler);
};
NomsApp.prototype.detailsCallbackHandler = function(info, status) {
nom.info(info);
return this.map.addMarker(info);
};
NomsApp.prototype.draw = function(data) {
var choice;
if (!data.length) {
return textBox.html("Looks like you&rsquo;re in the middle of nowhere, buddy!");
}
choice = this.selectRandom(data);
return this.headline(choice);
};
return NomsApp;
})();
return nom = new NomsApp;
});
}).call(this);
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment