Created
February 27, 2015 22:06
-
-
Save anonymous/e48bb5c52c9a0fcd7198 to your computer and use it in GitHub Desktop.
Place Autocomplete Address Form // source http://jsbin.com/yekavifeva
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<!DOCTYPE html> | |
<html> | |
<head> | |
<title>Place Autocomplete Address Form</title> | |
<meta name="viewport" content="initial-scale=1.0, user-scalable=no"> | |
<meta charset="utf-8"> | |
<style> | |
html, body, #map-canvas { | |
height: 100%; | |
margin: 0px; | |
padding: 0px | |
} | |
</style> | |
<link type="text/css" rel="stylesheet" href="https://fonts.googleapis.com/css?family=Roboto:300,400,500"> | |
<script src="https://maps.googleapis.com/maps/api/js?v=3.exp&signed_in=true&libraries=places"></script> | |
<style> | |
#locationField, #controls { | |
position: relative; | |
width: 480px; | |
} | |
#autocomplete { | |
position: absolute; | |
top: 0px; | |
left: 0px; | |
width: 99%; | |
} | |
.label { | |
text-align: right; | |
font-weight: bold; | |
width: 100px; | |
color: #303030; | |
} | |
#address { | |
border: 1px solid #000090; | |
background-color: #f0f0ff; | |
width: 480px; | |
padding-right: 2px; | |
} | |
#address td { | |
font-size: 10pt; | |
} | |
.field { | |
width: 99%; | |
} | |
.slimField { | |
width: 80px; | |
} | |
.wideField { | |
width: 200px; | |
} | |
#locationField { | |
height: 20px; | |
margin-bottom: 2px; | |
} | |
</style> | |
</head> | |
<body onload="initialize()"> | |
<div id="locationField"> | |
<input id="autocomplete" placeholder="Enter your address" | |
onFocus="geolocate()" type="text"></input> | |
</div> | |
<table id="address"> | |
<tr> | |
<td class="label">Street address</td> | |
<td class="slimField"><input class="field" id="street_number" | |
disabled="true"></input></td> | |
<td class="wideField" colspan="2"><input class="field" id="route" | |
disabled="true"></input></td> | |
</tr> | |
<tr> | |
<td class="label">City</td> | |
<td class="wideField" colspan="3"><input class="field" id="locality" | |
disabled="true"></input></td> | |
</tr> | |
<tr> | |
<td class="label">State</td> | |
<td class="slimField"><input class="field" | |
id="administrative_area_level_1" disabled="true"></input></td> | |
<td class="label">Zip code</td> | |
<td class="wideField"><input class="field" id="postal_code" | |
disabled="true"></input></td> | |
</tr> | |
<tr> | |
<td class="label">Country</td> | |
<td class="wideField" colspan="3"><input class="field" | |
id="country" disabled="true"></input></td> | |
</tr> | |
</table> | |
<div id="map-canvas"></div> | |
<script id="jsbin-javascript"> | |
// This example displays an address form, using the autocomplete feature | |
// of the Google Places API to help users fill in the information. | |
var placeSearch, autocomplete; | |
var componentForm = { | |
street_number: 'short_name', | |
route: 'long_name', | |
locality: 'long_name', | |
administrative_area_level_1: 'short_name', | |
country: 'long_name', | |
postal_code: 'short_name' | |
}; | |
var markers = []; | |
var map; | |
function initialize_map() { | |
var mapOptions = { | |
zoom: 8, | |
center: new google.maps.LatLng(-34.397, 150.644) | |
}; | |
map = new google.maps.Map(document.getElementById('map-canvas'), | |
mapOptions); | |
} | |
google.maps.event.addDomListener(window, 'load', initialize_map); | |
function initialize() { | |
// Create the autocomplete object, restricting the search | |
// to geographical location types. | |
autocomplete = new google.maps.places.Autocomplete( | |
/** @type {HTMLInputElement} */(document.getElementById('autocomplete')), | |
{ types: [] }); | |
// When the user selects an address from the dropdown, | |
// populate the address fields in the form. | |
google.maps.event.addListener(autocomplete, 'place_changed', function() { | |
fillInAddress(); | |
}); | |
} | |
// [START region_fillform] | |
function fillInAddress() { | |
for (var i = 0, marker; marker = markers[i]; i++) { | |
marker.setMap(null); | |
} | |
// Get the place details from the autocomplete object. | |
var place = autocomplete.getPlace(); | |
var places =place; | |
console.log(place); | |
for (var component in componentForm) { | |
document.getElementById(component).value = ''; | |
document.getElementById(component).disabled = false; | |
} | |
// Get each component of the address from the place details | |
// and fill the corresponding field on the form. | |
for (var i = 0; i < place.address_components.length; i++) { | |
var addressType = place.address_components[i].types[0]; | |
if (componentForm[addressType]) { | |
var val = place.address_components[i][componentForm[addressType]]; | |
document.getElementById(addressType).value = val; | |
} | |
} | |
// For each place, get the icon, place name, and location. | |
markers = []; | |
var bounds = new google.maps.LatLngBounds(); | |
var image = { | |
url: place.icon, | |
size: new google.maps.Size(71, 71), | |
origin: new google.maps.Point(0, 0), | |
anchor: new google.maps.Point(17, 34), | |
scaledSize: new google.maps.Size(25, 25) | |
}; | |
// Create a marker for each place. | |
var marker = new google.maps.Marker({ | |
map: map, | |
icon: image, | |
title: place.name, | |
position: place.geometry.location | |
}); | |
console.log(marker); | |
markers = null; | |
markers = []; | |
markers.push(marker); | |
bounds.extend(place.geometry.location); | |
map.panTo(place.geometry.location); | |
map.setZoom(16); | |
//map.fitBounds(bounds); | |
} | |
// [END region_fillform] | |
// [START region_geolocation] | |
// Bias the autocomplete object to the user's geographical location, | |
// as supplied by the browser's 'navigator.geolocation' object. | |
function geolocate() { | |
if (navigator.geolocation) { | |
navigator.geolocation.getCurrentPosition(function(position) { | |
var geolocation = new google.maps.LatLng( | |
position.coords.latitude, position.coords.longitude); | |
var circle = new google.maps.Circle({ | |
center: geolocation, | |
radius: position.coords.accuracy | |
}); | |
autocomplete.setBounds(circle.getBounds()); | |
}); | |
} | |
} | |
// [END region_geolocation] | |
</script> | |
<script id="jsbin-source-javascript" type="text/javascript">// This example displays an address form, using the autocomplete feature | |
// of the Google Places API to help users fill in the information. | |
var placeSearch, autocomplete; | |
var componentForm = { | |
street_number: 'short_name', | |
route: 'long_name', | |
locality: 'long_name', | |
administrative_area_level_1: 'short_name', | |
country: 'long_name', | |
postal_code: 'short_name' | |
}; | |
var markers = []; | |
var map; | |
function initialize_map() { | |
var mapOptions = { | |
zoom: 8, | |
center: new google.maps.LatLng(-34.397, 150.644) | |
}; | |
map = new google.maps.Map(document.getElementById('map-canvas'), | |
mapOptions); | |
} | |
google.maps.event.addDomListener(window, 'load', initialize_map); | |
function initialize() { | |
// Create the autocomplete object, restricting the search | |
// to geographical location types. | |
autocomplete = new google.maps.places.Autocomplete( | |
/** @type {HTMLInputElement} */(document.getElementById('autocomplete')), | |
{ types: [] }); | |
// When the user selects an address from the dropdown, | |
// populate the address fields in the form. | |
google.maps.event.addListener(autocomplete, 'place_changed', function() { | |
fillInAddress(); | |
}); | |
} | |
// [START region_fillform] | |
function fillInAddress() { | |
for (var i = 0, marker; marker = markers[i]; i++) { | |
marker.setMap(null); | |
} | |
// Get the place details from the autocomplete object. | |
var place = autocomplete.getPlace(); | |
var places =place; | |
console.log(place); | |
for (var component in componentForm) { | |
document.getElementById(component).value = ''; | |
document.getElementById(component).disabled = false; | |
} | |
// Get each component of the address from the place details | |
// and fill the corresponding field on the form. | |
for (var i = 0; i < place.address_components.length; i++) { | |
var addressType = place.address_components[i].types[0]; | |
if (componentForm[addressType]) { | |
var val = place.address_components[i][componentForm[addressType]]; | |
document.getElementById(addressType).value = val; | |
} | |
} | |
// For each place, get the icon, place name, and location. | |
markers = []; | |
var bounds = new google.maps.LatLngBounds(); | |
var image = { | |
url: place.icon, | |
size: new google.maps.Size(71, 71), | |
origin: new google.maps.Point(0, 0), | |
anchor: new google.maps.Point(17, 34), | |
scaledSize: new google.maps.Size(25, 25) | |
}; | |
// Create a marker for each place. | |
var marker = new google.maps.Marker({ | |
map: map, | |
icon: image, | |
title: place.name, | |
position: place.geometry.location | |
}); | |
console.log(marker); | |
markers = null; | |
markers = []; | |
markers.push(marker); | |
bounds.extend(place.geometry.location); | |
map.panTo(place.geometry.location); | |
map.setZoom(16); | |
//map.fitBounds(bounds); | |
} | |
// [END region_fillform] | |
// [START region_geolocation] | |
// Bias the autocomplete object to the user's geographical location, | |
// as supplied by the browser's 'navigator.geolocation' object. | |
function geolocate() { | |
if (navigator.geolocation) { | |
navigator.geolocation.getCurrentPosition(function(position) { | |
var geolocation = new google.maps.LatLng( | |
position.coords.latitude, position.coords.longitude); | |
var circle = new google.maps.Circle({ | |
center: geolocation, | |
radius: position.coords.accuracy | |
}); | |
autocomplete.setBounds(circle.getBounds()); | |
}); | |
} | |
} | |
// [END region_geolocation] | |
</script></body> | |
</html> |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// This example displays an address form, using the autocomplete feature | |
// of the Google Places API to help users fill in the information. | |
var placeSearch, autocomplete; | |
var componentForm = { | |
street_number: 'short_name', | |
route: 'long_name', | |
locality: 'long_name', | |
administrative_area_level_1: 'short_name', | |
country: 'long_name', | |
postal_code: 'short_name' | |
}; | |
var markers = []; | |
var map; | |
function initialize_map() { | |
var mapOptions = { | |
zoom: 8, | |
center: new google.maps.LatLng(-34.397, 150.644) | |
}; | |
map = new google.maps.Map(document.getElementById('map-canvas'), | |
mapOptions); | |
} | |
google.maps.event.addDomListener(window, 'load', initialize_map); | |
function initialize() { | |
// Create the autocomplete object, restricting the search | |
// to geographical location types. | |
autocomplete = new google.maps.places.Autocomplete( | |
/** @type {HTMLInputElement} */(document.getElementById('autocomplete')), | |
{ types: [] }); | |
// When the user selects an address from the dropdown, | |
// populate the address fields in the form. | |
google.maps.event.addListener(autocomplete, 'place_changed', function() { | |
fillInAddress(); | |
}); | |
} | |
// [START region_fillform] | |
function fillInAddress() { | |
for (var i = 0, marker; marker = markers[i]; i++) { | |
marker.setMap(null); | |
} | |
// Get the place details from the autocomplete object. | |
var place = autocomplete.getPlace(); | |
var places =place; | |
console.log(place); | |
for (var component in componentForm) { | |
document.getElementById(component).value = ''; | |
document.getElementById(component).disabled = false; | |
} | |
// Get each component of the address from the place details | |
// and fill the corresponding field on the form. | |
for (var i = 0; i < place.address_components.length; i++) { | |
var addressType = place.address_components[i].types[0]; | |
if (componentForm[addressType]) { | |
var val = place.address_components[i][componentForm[addressType]]; | |
document.getElementById(addressType).value = val; | |
} | |
} | |
// For each place, get the icon, place name, and location. | |
markers = []; | |
var bounds = new google.maps.LatLngBounds(); | |
var image = { | |
url: place.icon, | |
size: new google.maps.Size(71, 71), | |
origin: new google.maps.Point(0, 0), | |
anchor: new google.maps.Point(17, 34), | |
scaledSize: new google.maps.Size(25, 25) | |
}; | |
// Create a marker for each place. | |
var marker = new google.maps.Marker({ | |
map: map, | |
icon: image, | |
title: place.name, | |
position: place.geometry.location | |
}); | |
console.log(marker); | |
markers = null; | |
markers = []; | |
markers.push(marker); | |
bounds.extend(place.geometry.location); | |
map.panTo(place.geometry.location); | |
map.setZoom(16); | |
//map.fitBounds(bounds); | |
} | |
// [END region_fillform] | |
// [START region_geolocation] | |
// Bias the autocomplete object to the user's geographical location, | |
// as supplied by the browser's 'navigator.geolocation' object. | |
function geolocate() { | |
if (navigator.geolocation) { | |
navigator.geolocation.getCurrentPosition(function(position) { | |
var geolocation = new google.maps.LatLng( | |
position.coords.latitude, position.coords.longitude); | |
var circle = new google.maps.Circle({ | |
center: geolocation, | |
radius: position.coords.accuracy | |
}); | |
autocomplete.setBounds(circle.getBounds()); | |
}); | |
} | |
} | |
// [END region_geolocation] |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment