Search code examples
jqueryajaxfoursquaregeonames

JQuery & Ajax - geonames autocomplete and requesting info fromfoursquare


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!


Solution

  • 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