Set place name and website from Google Places API when possible

This commit is contained in:
Michael Hall 2018-04-08 11:59:53 -04:00
parent 933d3285a8
commit 90a5546df7

View file

@ -22,7 +22,7 @@
{% endblock %} {% endblock %}
{% block javascript %} {% block javascript %}
<script type="text/javascript" src="https://maps.googleapis.com/maps/api/js?key={{settings.GOOGLE_MAPS_API_KEY}}"></script> <script type="text/javascript" src="https://maps.googleapis.com/maps/api/js?key={{settings.GOOGLE_MAPS_API_KEY}}&libraries=places"></script>
<script type="text/javascript"> <script type="text/javascript">
/* /*
* jQuery Google Map Plugin 0.2.3 * jQuery Google Map Plugin 0.2.3
@ -55,9 +55,9 @@
}; };
options = $.extend(defaults, options); options = $.extend(defaults, options);
function showPositionHTML(location) { function showPositionHTML(ll, map, google_place_id) {
var geocoder = new google.maps.Geocoder(); var geocoder = new google.maps.Geocoder();
geocoder.geocode({'latLng': location}, function(results, status) { geocoder.geocode({'latLng': ll}, function(results, status) {
if (status == google.maps.GeocoderStatus.OK) { if (status == google.maps.GeocoderStatus.OK) {
if (results[0]) { if (results[0]) {
$('#id_address').val(results[0].formatted_address); $('#id_address').val(results[0].formatted_address);
@ -69,12 +69,18 @@
spr = this.long_name spr = this.long_name
} else if(this.types[0]=="locality"){ } else if(this.types[0]=="locality"){
city = this.long_name city = this.long_name
} else if(this.types[0]=="premise"){
name = this.long_name
} }
}); });
if (name != null && name != "") { $("#id_name").val("")
$("#id_name").val(name); $("#id_name").attr("placeholder", "Searching...")
if (google_place_id != null) {
var places = new google.maps.places.PlacesService(map);
places.getDetails({'placeId': google_place_id},
function(result, status) {
$("#id_name").val(result.name);
$("#id_place_url").val(result.website);
}
);
} }
$.getJSON("/api/find_city/?country="+country+"&spr="+spr+"&city="+city, $.getJSON("/api/find_city/?country="+country+"&spr="+spr+"&city="+city,
function(json) { function(json) {
@ -94,11 +100,11 @@
}); });
if (options.html_lng && options.html_lat) { if (options.html_lng && options.html_lat) {
if (location.lat() != null && location.lng() != null) { if (ll.lat() != null && ll.lng() != null) {
options.html_lat.val(location.lat()); options.html_lat.val(ll.lat());
options.html_lng.val(location.lng()); options.html_lng.val(ll.lng());
if (options.html_tz && options.html_country && options.html_continent) { if (options.html_tz && options.html_country && options.html_continent) {
$.getJSON("http://ws.geonames.org/timezoneJSON?lat=" + location.lat() + "&lng=" + location.lng(), $.getJSON("http://ws.geonames.org/timezoneJSON?lat=" + ll.lat() + "&lng=" + ll.lng(),
function(json) { function(json) {
$(options.html_tz).filter(function() { $(options.html_tz).filter(function() {
return $(this).text() == json.timezoneId; return $(this).text() == json.timezoneId;
@ -126,17 +132,17 @@
} }
function setMarker(map, location) { function setMarker(map, ll, google_place_id) {
var marker = null; var marker = null;
if (options.markers.length) { if (options.markers.length) {
marker = options.markers[0]; marker = options.markers[0];
marker.setPosition(location); marker.setPosition(ll);
marker.setAnimation(google.maps.Animation.DROP); marker.setAnimation(google.maps.Animation.DROP);
} else { } else {
marker = new google.maps.Marker({ marker = new google.maps.Marker({
map: map, map: map,
position: location, position: ll,
draggable: true, draggable: true,
animation: google.maps.Animation.DROP animation: google.maps.Animation.DROP
}); });
@ -145,52 +151,29 @@
} }
options.markers.push(marker); options.markers.push(marker);
google.maps.event.addListener(options.markers[0], 'mouseup', function () { google.maps.event.addListener(options.markers[0], 'mouseup', function () {
showPositionHTML(marker.getPosition()); showPositionHTML(marker.getPosition(), map, google_place_id);
}); });
} }
map.setCenter(location); map.setCenter(ll);
showPositionHTML(marker.getPosition()); showPositionHTML(marker.getPosition(), map, google_place_id);
} }
return $(this).each(function (i, html_element) { return $(this).each(function (i, html_element) {
var map = new google.maps.Map($(html_element)[0], options.mapOptions), map = new google.maps.Map($(html_element)[0], options.mapOptions),
geoCoder = new google.maps.Geocoder(), ll = null;
location = null;
if (options.html_addr) {
options.html_addr.change(function () {
var address = [];
options.html_addr.each(function (i, item) {
address.push(item.value);
});
geoCoder.geocode({address: address.join(' ')}, function (results, status) {
if (status === google.maps.GeocoderStatus.OK) {
setMarker(map, results[0].geometry.location);
}
});
});
}
if (navigator.geolocation) {
navigator.geolocation.getCurrentPosition(function(position) {
var pos = {
lat: position.coords.latitude,
lng: position.coords.longitude
};
map.setCenter(pos);
map.setZoom(12);
}, function() {
handleLocationError(true, infoWindow, map.getCenter());
});
}
google.maps.event.addListener(map, 'click', function (event) { google.maps.event.addListener(map, 'click', function (event) {
if (event.hasOwnProperty('placeId')) {
setMarker(map, event.latLng, event.placeId);
} else {
setMarker(map, event.latLng); setMarker(map, event.latLng);
}
}); });
if (options.html_lat.val() && options.html_lng.val()) { if (options.html_lat.val() && options.html_lng.val()) {
location = new google.maps.LatLng(options.html_lat.val(), options.html_lng.val()); ll = new google.maps.LatLng(options.html_lat.val(), options.html_lng.val());
setMarker(map, location); setMarker(map, ll);
} }
$.getJSON("/api/places/", function(data) { $.getJSON("/api/places/", function(data) {
@ -204,7 +187,7 @@
google.maps.event.addListener(marker, 'click',function(event) { google.maps.event.addListener(marker, 'click',function(event) {
$("#id_id").val(place['id']); $("#id_id").val(place['id']);
$("#id_name").val(place['name']); $("#id_name").val(place['name']);
showPositionHTML(this.position); showPositionHTML(this.position, map);
}); });
} }
return; return;