I would like to find the venue (from foursquare API) for the city that i choose the name for (from geonames), but unfortunately it doesn't work. I can see that its uploading the names from geonames but the result for venue doesn't appear.
<script type="text/javascript">
$(function() {
function log( message ) {
$( "<div>" ).text( message ).prependTo( "#log" );
$( "#log" ).scrollTop( 0 );
}
$( "#muni" ).autocomplete({
source: function( request, response ) {
$.ajax({
url: "http://ws.geonames.org/searchJSON",
dataType: "jsonp",
data: {
featureClass: "P",
style: "full",
maxRows: 15,
name_startsWith: request.term
},
success: function( data ) {
response( $.map( data.geonames, function( item ) {
return {
label: item.name + (item.adminName1 ? ", " + item.adminName1 : "") + ", " + item.countryName,
value: item.name + ", " + item.countryName
}
}));
}
});
},
minLength: 2,
select: function( event, ui ) {
log( ui.item ?
"Selected: " + ui.item.label :
"Nothing selected, input was " + this.value);
$.ajax({
url : "https://api.foursquare.com/v2/venues/search?client_id=xxx&client_secret=xxx&v=20131212&format=JSONP&callback=x&limit=1&near=" + ui.item.value,
dataType : "jsonp",
success : function(parsed_json) {
$("#name").text(parsed_json.response.venues.name);
$("#direccion").text(parsed_json['response']['venues']['location']['address']);
$("#postcode").text(parsed_json['response']['venues']['location']['postalCode']);
$("#city").text(parsed_json['response']['venues']['location']['city']);
$("#country").text(parsed_json['response']['venues']['location']['country']);
}
});
},
open: function() {
$( this ).removeClass( "ui-corner-all" ).addClass( "ui-corner-top" );
},
close: function() {
$( this ).removeClass( "ui-corner-top" ).addClass( "ui-corner-all" );
}
});
});
function getInfo(){
$.ajax({
url : "https://api.foursquare.com/v2/venues/search?client_id=xxx&client_secret=xxx&v=20131212&format=JSONP&callback=x&limit=1&near=" + $("#muni").val(),
dataType : "jsonp",
success : function(parsed_json) {
$("#name").text(parsed_json.response.venues.name);
$("#direccion").text(parsed_json['response']['venues']['location']['address']);
$("#postcode").text(parsed_json['response']['venues']['location']['postalCode']);
$("#city").text(parsed_json['response']['venues']['location']['city']);
$("#country").text(parsed_json['response']['venues']['location']['country']);
}
});
}
</script>
and then...
<input type="text" id="muni"></input>
<p onclick="getInfo()">Get all info about venue</p>
<table id="t">
<tr>
<th>Venue name</th>
<th>Venue location-<br>address</th>
<th>Venue location-<br>postcode</th>
<th>Venue location-<br>city</th>
<th>Venue location-<br>country</th>
</tr>
<tr>
<td id="name"></td>
<td id="direccion"></td>
<td id="postcode"></td>
<td id="city"></td>
<td id="country"></td>
</tr>
</table>
Thanks!
You aren't parsing correctly. There is no venues object in the JSON returned according to the testing console in 4square API. This is how I parse it, and it's working:
var index;
var obj = jQuery.parseJSON( parsed_json);
for(index = 0; index < obj.response.groups[0].items.length ; index++)
{
console.log('id: ' + obj.response.groups[0].items[index].venue.id );
console.log('Addr: ' + obj.response.groups[0].items[index].venue.location.address );
console.log('ZIP Code: ' + obj.response.groups[0].items[index].venue.location.postalCode );
console.log('City: ' + obj.response.groups[0].items[index].venue.location.city );
console.log('Country: ' + obj.response.groups[0].items[index].venue.location.country );
}
Hope it helps