Before you reply: this is not as straight foward as you'd expect!
This is php file the "show on map" button puts into the dialog box:
<div id="map_canvas"></div>
<script type="text/javascript">
$(function() {
//google maps stuff
var latlng = new google.maps.LatLng(<?php echo $coords ?>);
var options = {
zoom: 14,
center: latlng,
mapTypeControl: false,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
var map = new google.maps.Map(document.getElementById('map_canvas'), options);
var marker = new google.maps.Marker({
position: new google.maps.LatLng(<?php echo $coords ?>),
map: map
});
})
</script>
I've been trying to load the API before ajaxing in the dialog like this:
$('img.map').click(function(){
var rel = $(this).attr('rel');
$.getScript('http://maps.google.com/maps/api/js?sensor=false', function(){
$.fn.colorbox({
href:rel
})
});
})
this doesn't seem to work :(
i've also tried:
<script src="http://maps.google.com/maps/api/js?sensor=false"></script>
to the ajax file$.getScript('http://maps.google.com/maps/api/js?sensor=false');
on doc.readythe problem the browser seems to be redirected to the api.js file - you see a white screen
Designed to compete with well-established mapping sites, Google Maps uses Ajax to avoid reloading its main page at all (see Figure 1-4). Unlike other mapping web applications, Google Maps enables you to drag the map to move it in various directions.
The API is available for developers that have a free Google Maps API key. Usage of the API is not strictly free, but they do offer $200 of free monthly usage for most users. The pricing scales to fit your particular needs and you are only charged for your API usage.
Stay organized with collections Save and categorize content based on your preferences. Place an interactive map or Street View panorama on your web page with Maps Embed API. Use a simple HTTP request; no JavaScript required.
A web page or application displays a map using the Maps JavaScript API.
This FAQ answer details how to load the Maps API asynchronously, and there is a good example that goes along with it.
Basically, recommend you put your execution code in a named function, then load the Maps API referencing said callback and using the "async" parameter. Or you could use jQuery's getJSON as such:
$.getJSON('http://maps.google.com/maps/api/js?sensor=false&async=2&callback=?', function(){
$.colorbox({
href:rel
})
});
thanks for pointing me in the right direction Andrew, my problem was that the callback in the api request is mandatory for loading the api on demand.
Here is my final jquery code:
//in doc.ready
$('img.map').click(function(){
var rel = $(this).attr('rel');
$('body').data('map_href', rel ).append('<script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false&callback=show_map"></script>');
})
function show_map(){
$.fn.colorbox({
href:$('body').data('map_href')
})
}
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With