diff --git a/build/ol3-geocoder-debug.js b/build/ol3-geocoder-debug.js
index c81a0d2..af043c3 100644
--- a/build/ol3-geocoder-debug.js
+++ b/build/ol3-geocoder-debug.js
@@ -1,8 +1,8 @@
/**
* A geocoder extension for OpenLayers 3.
* https://github.com/jonataswalker/ol3-geocoder
- * Version: v2.1.0
- * Built: 2016-06-16T11:50:12-0300
+ * Version: v2.2.0
+ * Built: 2016-07-29T12:53:37-03:00
*/
(function (global, factory) {
@@ -69,6 +69,7 @@
MAPQUEST: 'mapquest',
GOOGLE: 'google',
PHOTON: 'photon',
+ BING: 'bing',
PELIAS: 'pelias'
};
@@ -109,6 +110,8 @@
},
json: function json(url, data) {
var xhr = new XMLHttpRequest(),
+ url_ = '',
+ data_type = '',
when = {},
onload = function () {
if (xhr.status === 200) {
@@ -118,17 +121,65 @@
onerror = function () {
console.info('Cannot XHR ' + JSON.stringify(url));
};
- url = this.encodeUrlXhr(url, data);
- xhr.open('GET', url, true);
- xhr.setRequestHeader('Accept','application/json');
- xhr.onload = onload;
- xhr.onerror = onerror;
- xhr.send(null);
+
+ if(typeof url === 'object') {
+ url_ = url.url;
+ data = url.data;
+ data_type = url.data_type || 'json';
+ } else {
+ url_ = url;
+ }
+
+ url_ = this.encodeUrlXhr(url_, data);
+ if (data_type === 'jsonp') {
+ this.jsonp(url_, url.callbackName, function(data) {
+ when.ready.call(undefined, data);
+ });
+ } else {
+ xhr.open('GET', url_, true);
+ xhr.setRequestHeader('Accept','application/json');
+ xhr.onload = onload;
+ xhr.onerror = onerror;
+ xhr.send(null);
+ }
+
return {
- when: function ( obj ) { when.ready = obj.ready; }
+ when: function (obj) { when.ready = obj.ready; }
};
},
+ jsonp: function jsonp(url, key, callback) {
+ // https://github.com/Fresheyeball/micro-jsonp/blob/master/src/jsonp.js
+ var head = document.head,
+ script = document.createElement('script'),
+ // generate minimally unique name for callback function
+ callbackName = 'f' + Math.round(Math.random() * Date.now());
+
+ // set request url
+ script.setAttribute('src',
+ /* add callback parameter to the url
+ where key is the parameter key supplied
+ and callbackName is the parameter value */
+ (url + (url.indexOf('?') > 0 ? '&' : '?') + key + '=' + callbackName));
+
+ /* place jsonp callback on window,
+ the script sent by the server should call this
+ function as it was passed as a url parameter */
+ window[callbackName] = function(json) {
+ window[callbackName] = undefined;
+
+ // clean up script tag created for request
+ setTimeout(function() {
+ head.removeChild(script);
+ }, 0);
+
+ // hand data back to the user
+ callback(json);
+ };
+
+ // actually make the request
+ head.appendChild(script);
+ },
now: function now() {
// Polyfill for window.performance.now()
// @license http://opensource.org/licenses/MIT
@@ -195,7 +246,7 @@
var this$1 = this;
if (Array.isArray(element)) {
- element.forEach(function ( each ) { this$1.addClass(each, classname) });
+ element.forEach(function (each) { this$1.addClass(each, classname) });
return;
}
@@ -209,9 +260,9 @@
}
},
_addClass: function _addClass(el, c, timeout) {
- // use native if available
var this$1 = this;
+ // use native if available
if (el.classList) {
el.classList.add(c);
} else {
@@ -232,7 +283,7 @@
var this$1 = this;
if (Array.isArray(element)) {
- element.forEach(function ( each ) { this$1.removeClass(each, classname, timeout) });
+ element.forEach(function (each) { this$1.removeClass(each, classname, timeout) });
return;
}
@@ -277,7 +328,7 @@
var this$1 = this;
if (Array.isArray(element)) {
- element.forEach(function ( each ) { this$1.toggleClass(each, classname) });
+ element.forEach(function (each) { this$1.toggleClass(each, classname) });
return;
}
@@ -315,16 +366,17 @@
while(array.length) array.pop();
},
anyMatchInArray: function anyMatchInArray(source, target) {
- return source.some(function ( each ) { return target.indexOf(each) >= 0; });
+ return source.some(function (each) { return target.indexOf(each) >= 0; });
},
everyMatchInArray: function everyMatchInArray(arr1, arr2) {
- return arr2.every(function ( each ) { return arr1.indexOf(each) >= 0; });
+ return arr2.every(function (each) { return arr1.indexOf(each) >= 0; });
},
anyItemHasValue: function anyItemHasValue(obj, has) {
+ var this$1 = this;
if ( has === void 0 ) has = false;
for(var key in obj) {
- if(!this.isEmpty(obj[key])) {
+ if(!this$1.isEmpty(obj[key])) {
has = true;
}
}
@@ -342,7 +394,7 @@
}
},
getChildren: function getChildren(node, tag) {
- return [].filter.call(node.childNodes, function ( el ) { return tag ?
+ return [].filter.call(node.childNodes, function (el) { return tag ?
el.nodeType == 1 && el.tagName.toLowerCase() == tag : el.nodeType == 1; });
},
template: function template(html, row) {
@@ -432,7 +484,7 @@
};
- Photon.prototype.getParameters = function getParameters(options) {
+ Photon.prototype.getParameters = function getParameters (options) {
options.lang = options.lang.toLowerCase();
return {
@@ -446,8 +498,8 @@
};
};
- Photon.prototype.handleResponse = function handleResponse(results) {
- return results.map(function ( result ) { return ({
+ Photon.prototype.handleResponse = function handleResponse (results) {
+ return results.map(function (result) { return ({
lon: result.geometry.coordinates[0],
lat: result.geometry.coordinates[1],
address: {
@@ -482,7 +534,7 @@
};
};
- OpenStreet.prototype.getParameters = function getParameters(options) {
+ OpenStreet.prototype.getParameters = function getParameters (options) {
return {
url: this.settings.url,
params: {
@@ -496,8 +548,8 @@
};
};
- OpenStreet.prototype.handleResponse = function handleResponse(results) {
- return results.map(function ( result ) { return ({
+ OpenStreet.prototype.handleResponse = function handleResponse (results) {
+ return results.map(function (result) { return ({
lon: result.lon,
lat: result.lat,
address: {
@@ -534,7 +586,7 @@
};
};
- MapQuest.prototype.getParameters = function getParameters(options) {
+ MapQuest.prototype.getParameters = function getParameters (options) {
return {
url: this.settings.url,
params: {
@@ -549,8 +601,8 @@
};
};
- MapQuest.prototype.handleResponse = function handleResponse(results) {
- return results.map(function ( result ) { return ({
+ MapQuest.prototype.handleResponse = function handleResponse (results) {
+ return results.map(function (result) { return ({
lon: result.lon,
lat: result.lat,
address: {
@@ -583,7 +635,7 @@
};
};
- Pelias.prototype.getParameters = function getParameters(options) {
+ Pelias.prototype.getParameters = function getParameters (options) {
return {
url: this.settings.url,
params: {
@@ -594,8 +646,8 @@
};
};
- Pelias.prototype.handleResponse = function handleResponse(results) {
- return results.map(function ( result ) { return ({
+ Pelias.prototype.handleResponse = function handleResponse (results) {
+ return results.map(function (result) { return ({
lon: result.geometry.coordinates[0],
lat: result.geometry.coordinates[1],
address: {
@@ -629,7 +681,7 @@
};
};
- Google.prototype.getParameters = function getParameters(options) {
+ Google.prototype.getParameters = function getParameters (options) {
return {
url: this.settings.url,
params: {
@@ -640,7 +692,7 @@
};
};
- Google.prototype.handleResponse = function handleResponse(results) {
+ Google.prototype.handleResponse = function handleResponse (results) {
var name = [
'point_of_interest',
'establishment',
@@ -661,7 +713,7 @@
/*
* @param {Array} details - address_components
*/
- var getDetails = function ( details ) {
+ var getDetails = function (details) {
var parts = {
name: '',
road: '',
@@ -670,7 +722,7 @@
state: '',
country: ''
};
- details.forEach(function ( detail ) {
+ details.forEach(function (detail) {
if(utils.anyMatchInArray(detail.types, name)){
parts.name = detail.long_name;
} else if(utils.anyMatchInArray(detail.types, road)){
@@ -690,7 +742,7 @@
var array = [];
- results.forEach(function ( result ) {
+ results.forEach(function (result) {
var details = getDetails(result.address_components);
if(utils.anyItemHasValue(details)){
array.push({
@@ -715,6 +767,50 @@
return array;
};
+ /**
+ * @class Bing
+ */
+ var Bing = function Bing() {
+ this.settings = {
+ url: '//dev.virtualearth.net/REST/v1/Locations',
+ callbackName: 'jsonp',
+ params: {
+ query: '',
+ key: '',
+ includeNeighborhood: 0,
+ maxResults: 10
+ }
+ };
+ };
+
+ Bing.prototype.getParameters = function getParameters (options) {
+ return {
+ url: this.settings.url,
+ callbackName: this.settings.callbackName,
+ params: {
+ query: options.query,
+ key: options.key,
+ includeNeighborhood:
+ options.includeNeighborhood || this.settings.params.includeNeighborhood,
+ maxResults: options.maxResults || this.settings.params.maxResults
+ }
+ };
+ };
+
+ Bing.prototype.handleResponse = function handleResponse (results) {
+ return results.map(function (result) { return ({
+ lon: result.point.coordinates[1],
+ lat: result.point.coordinates[0],
+ address: {
+ name: result.name
+ },
+ original: {
+ formatted: result.address.formattedAddress,
+ details: result.address
+ }
+ }); });
+ };
+
/**
* @class Nominatim
*/
@@ -729,7 +825,7 @@
this.options = base.options;
this.options.provider = this.options.provider.toLowerCase();
-
+
this.els = this.createControl();
this.container = this.els.container;
this.registered_listeners = {
@@ -743,11 +839,12 @@
this.MapQuest = new MapQuest();
this.Pelias = new Pelias();
this.Google = new Google();
+ this.Bing = new Bing();
return this;
};
- Nominatim.prototype.createControl = function createControl() {
+ Nominatim.prototype.createControl = function createControl () {
var container = utils.createElement([
'div', { classname: namespace + container_class }
], Nominatim.html);
@@ -768,17 +865,17 @@
return elements;
};
- Nominatim.prototype.setListeners = function setListeners() {
- var this$1 = this;
+ Nominatim.prototype.setListeners = function setListeners () {
+ var this$1 = this;
- var openSearch = function () {
+ var openSearch = function () {
if(utils.hasClass(this$1.els.control, namespace + expanded_class)) {
this$1.collapse();
} else {
this$1.expand();
}
},
- query = function ( evt ) {
+ query = function (evt) {
if (evt.keyCode == 13) { //enter key
evt.preventDefault();
var q = utils.htmlEscape(this$1.els.input_search.value);
@@ -789,10 +886,11 @@
this.els.btn_search.addEventListener('click', openSearch, false);
};
- Nominatim.prototype.query = function query(q) {
- var this$1 = this;
+ Nominatim.prototype.query = function query (q) {
+ var this$1 = this;
- var this_ = this,
+ var this_ = this,
+ ajax = {},
options = this.options,
input = this.els.input_search,
provider = this.getProvider({
@@ -807,8 +905,16 @@
this.clearResults();
utils.addClass(input, namespace + loading_class);
- utils.json(provider.url, provider.params).when({
- ready: function ( response ) {
+ ajax.url = provider.url;
+ ajax.data = provider.params;
+
+ if (options.provider === providers.BING) {
+ ajax.data_type = 'jsonp';
+ ajax.callbackName = provider.callbackName;
+ }
+
+ utils.json(ajax).when({
+ ready: function (response) {
if (options.debug) {
console.info(response);
}
@@ -837,7 +943,11 @@
break;
case providers.GOOGLE:
response__ = response.results.length > 0 ?
- this$1.Google.handleResponse(response.results) : undefined;
+ this$1.Google.handleResponse(response.results) : undefined;
+ break;
+ case providers.BING:
+ response__ = response.resourceSets[0].resources.length > 0 ?
+ this$1.Bing.handleResponse(response.resourceSets[0].resources) : undefined;
break;
}
if(response__){
@@ -854,16 +964,16 @@
});
};
- Nominatim.prototype.createList = function createList(response) {
- var this$1 = this;
+ Nominatim.prototype.createList = function createList (response) {
+ var this$1 = this;
- var ul = this.els.result_container;
- response.forEach(function ( row ) {
+ var ul = this.els.result_container;
+ response.forEach(function (row) {
var address_html = this$1.addressTemplate(row.address),
html = '' + address_html + '',
li = utils.createElement('li', html);
- li.addEventListener('click', function ( evt ) {
+ li.addEventListener('click', function (evt) {
evt.preventDefault();
this$1.chosen(row, address_html, row.address, row.original);
}, false);
@@ -872,7 +982,7 @@
});
};
- Nominatim.prototype.chosen = function chosen(place, address_html, address_obj, address_original) {
+ Nominatim.prototype.chosen = function chosen (place, address_html, address_obj, address_original) {
var map = this.Base.getMap();
var coord = ol.proj.transform([parseFloat(place.lon), parseFloat(place.lat)],
'EPSG:4326', map.getView().getProjection());
@@ -905,7 +1015,7 @@
}
};
- Nominatim.prototype.createFeature = function createFeature(coord) {
+ Nominatim.prototype.createFeature = function createFeature (coord) {
var feature = new ol.Feature(new ol.geom.Point(coord));
this.addLayer();
feature.setStyle(this.options.featureStyle);
@@ -913,7 +1023,7 @@
this.getSource().addFeature(feature);
};
- Nominatim.prototype.addressTemplate = function addressTemplate(address) {
+ Nominatim.prototype.addressTemplate = function addressTemplate (address) {
var html = [];
if (address.name) {
html.push(
@@ -941,7 +1051,7 @@
return utils.template(html.join('
'), address);
};
- Nominatim.prototype.getProvider = function getProvider(options) {
+ Nominatim.prototype.getProvider = function getProvider (options) {
var provider;
switch(options.provider) {
@@ -960,14 +1070,17 @@
case providers.PELIAS:
provider = this.Pelias.getParameters(options);
break;
+ case providers.BING:
+ provider = this.Bing.getParameters(options);
+ break;
}
return provider;
};
- Nominatim.prototype.expand = function expand() {
- var this$1 = this;
+ Nominatim.prototype.expand = function expand () {
+ var this$1 = this;
- utils.removeClass(this.els.input_search, namespace + loading_class);
+ utils.removeClass(this.els.input_search, namespace + loading_class);
utils.addClass(this.els.control, namespace + expanded_class);
window.setTimeout(function () {
this$1.els.input_search.focus();
@@ -975,14 +1088,14 @@
this.listenMapClick();
};
- Nominatim.prototype.collapse = function collapse() {
+ Nominatim.prototype.collapse = function collapse () {
this.els.input_search.value = '';
this.els.input_search.blur();
utils.removeClass(this.els.control, namespace + expanded_class);
this.clearResults();
};
- Nominatim.prototype.listenMapClick = function listenMapClick() {
+ Nominatim.prototype.listenMapClick = function listenMapClick () {
if(this.registered_listeners.map_click) {
// already registered
return;
@@ -1002,7 +1115,7 @@
}, false);
};
- Nominatim.prototype.clearResults = function clearResults(collapse) {
+ Nominatim.prototype.clearResults = function clearResults (collapse) {
if(collapse) {
this.collapse();
} else {
@@ -1010,17 +1123,17 @@
}
};
- Nominatim.prototype.getSource = function getSource() {
+ Nominatim.prototype.getSource = function getSource () {
return this.layer.getSource();
};
- Nominatim.prototype.addLayer = function addLayer() {
- var this$1 = this;
+ Nominatim.prototype.addLayer = function addLayer () {
+ var this$1 = this;
- var found = false;
+ var found = false;
var map = this.Base.getMap();
- map.getLayers().forEach(function ( layer ) {
+ map.getLayers().forEach(function (layer) {
if (layer === this$1.layer) found = true;
});
if (!found) {
@@ -1076,20 +1189,21 @@
});
}
+ if ( superclass ) Base.__proto__ = superclass;
Base.prototype = Object.create( superclass && superclass.prototype );
Base.prototype.constructor = Base;
/**
* @return {ol.layer.Vector} Returns the layer created by this control
*/
- Base.prototype.getLayer = function getLayer() {
+ Base.prototype.getLayer = function getLayer () {
return Base.Nominatim.layer;
};
/**
* @return {ol.source.Vector} Returns the source created by this control
*/
- Base.prototype.getSource = function getSource() {
+ Base.prototype.getSource = function getSource () {
return this.getLayer().getSource();
};
diff --git a/build/ol3-geocoder.css b/build/ol3-geocoder.css
index d7a3d7c..92e301a 100644
--- a/build/ol3-geocoder.css
+++ b/build/ol3-geocoder.css
@@ -1,8 +1,8 @@
/**
* A geocoder extension for OpenLayers 3.
* https://github.com/jonataswalker/ol3-geocoder
- * Version: v2.1.0
- * Built: 2016-06-16T11:50:12-0300
+ * Version: v2.2.0
+ * Built: 2016-07-29T12:53:37-03:00
*/
.ol3-geocoder-container {
@@ -75,7 +75,7 @@ ul.ol3-geocoder-result {
.ol3-geocoder-road {
font-size: 0.875rem;
- font-weight: 700;
+ font-weight: 500;
color: #000; }
.ol3-geocoder-city {
diff --git a/build/ol3-geocoder.js b/build/ol3-geocoder.js
index ce70324..f7afdc5 100644
--- a/build/ol3-geocoder.js
+++ b/build/ol3-geocoder.js
@@ -1,8 +1,8 @@
/**
* A geocoder extension for OpenLayers 3.
* https://github.com/jonataswalker/ol3-geocoder
- * Version: v2.1.0
- * Built: 2016-06-16T11:50:12-0300
+ * Version: v2.2.0
+ * Built: 2016-07-29T12:53:37-03:00
*/
-!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define(t):e.Geocoder=t()}(this,function(){"use strict";var e="ol3-geocoder",t="-container",r="-search",n="-btn-search",s="-loading",a="-result",o="-search-expanded",i="-country",l="-city",c="-road",u="ol-control",p="form-geocoder",d="-input-search",m="gcd-input",h={ADDRESSCHOSEN:"addresschosen"},f=[new ol.style.Style({image:new ol.style.Icon({anchor:[.5,1],src:["data:image/png;base64,","iVBORw0KGgoAAAANSUhEUgAAAC0AAAAtCAYAAAA6GuKaAAAABmJLR0QA/wD/AP+gvaeT","AAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH4AQWCiErd9Z21AAABAJJREFUWMPVm","U1oXFUUx3/3zatJx04SDOgiVUMSgrXJwpqIKy26SrKoLjQgCkIFW7otuCvdllbo1q6Epg","vNQvtx710lEFdihwpSjdikJLGJWEhrM9MyX7nPxbypwzBv5n3cqXpgmOHOuff/mzPn3Pf","ueWDBpqZnrPq1M5EUVitZ+9wPvA0cAgaALqAIbAI3gAWt5HbjvCcGXROdmp4RwDDwBfBW","iKmLwKfAqlbSiwvvJAAeAeaBWyGB8f1uAfNT0zMj/jqdjXQd8Ds+sJsguyrAe1rJb6NGX","MQAPgJ8k7QefPOAd7WSl6OAi4jAk8D3cdKqhRngda3k9bDgUSL9NLAO9GPftoEXtZIPrR","WiXyzHwwAbA8WyoFAUFMsCY0JB9wPHwxalGyH3T4RxHByo8MZEgf4+w/ZfDt9lu9n4I5T","MCeBzP8+tQL8KDAZuA7swOljh4yM5JsaKGAPGA0fABzN5sje7+PJyht/WXNxU8O/1dbK2","9ulPWn05tL/CqWP3GR8tUSgKSmVBpVJ9LxQF46MlTh27z9D+SiKdqNCBFw/jwexUnr4eg","xfwx3oe9PUYZqfyGC+eThzo4SCYTNpweLLQtuCMgcOTBTLp4B8XpBMXuqnfroGxkTIi5M","YpRNV/1yTjCQv9oHmkBXu7vRD1/s/1b2+3h+eJSDpxoa83G0w5HisbLqRCrpKClQ2XlON","F0okL/XXTyQ6sbe1h/Y7bNkWEgPU7Lmtbe3CcaDpxoS8CuaYbfcpj7mqmVXE9Ltq5qxnc","VKBjztexBl0Azgd9uZTt4spimlJZkHKqUa29Ug6UyoIri2mWsl2tNM77OlZvmIaBn4B00","6tiRfDSUIk3JwocerlIzz7DTt7hxi9dLGW7+fX2U7huYJQfAeNayduduDX9Cni/3X5sPI","HnVSPtCK9VDj/OZa3krPVbUx++J+y2FNF6tZI71s+IfhR2gNOWgU9rJXeinBUjnxGBF4A","fgWcsAN8DXgE2OnJGbIC/CHxoAXpOK/lRx1sIvn1mKTVirRO377EFnE0IfFYrudXxvkdD","bvcCvwOZGEvkgOeBB0+kwwTU9tIccClmlC8Bubj9vKQNyAPAzxHX8YCDWsnluLpOAmB84","fmIU+e1kstJ2r42OkVH/S5R2G7S0aSCsaFrHU+tZB44F3LaOa1k/l/pTzfZSQ4APwD7Wr","jmgdeA5STAttKjltsLbdwWkhSf1UjXRfxZ4M8WLs9pJe/a0HIsAeMDnQlwOaOVvPufeFD","UJLcH/H27t6EtcBDYTJrLViNdl9ubwLWG4Wv+uDUTWDb/LLlSNzSilVy1qeFYBsYHvOAP","XdBKrtrK5Y5A19lJqo8kTnZi8U6kRy0YY8BNwNgqwP+1/Q09w5giQWRk7AAAAABJRU5Er","kJggg=="].join("")})})],y={OSM:"osm",MAPQUEST:"mapquest",GOOGLE:"google",PHOTON:"photon",PELIAS:"pelias"},g={provider:y.OSM,placeholder:"Search for an address",featureStyle:f,lang:"en-US",limit:5,keepOpen:!1,preventDefault:!1,debug:!1},v={toQueryString:function(e){var t=this;return Object.keys(e).reduce(function(r,n){return r.push("object"==typeof e[n]?t.toQueryString(e[n]):encodeURIComponent(n)+"="+encodeURIComponent(e[n])),r},[]).join("&")},encodeUrlXhr:function(e,t){if(t&&"object"==typeof t){var r=this.toQueryString(t);e+=(/\?/.test(e)?"&":"?")+r}return e},json:function(e,t){var r=new XMLHttpRequest,n={},s=function(){200===r.status&&n.ready.call(void 0,JSON.parse(r.response))},a=function(){console.info("Cannot XHR "+JSON.stringify(e))};return e=this.encodeUrlXhr(e,t),r.open("GET",e,!0),r.setRequestHeader("Accept","application/json"),r.onload=s,r.onerror=a,r.send(null),{when:function(e){n.ready=e.ready}}},now:function(){if("performance"in window==0&&(window.performance={}),Date.now=Date.now||function(){return(new Date).getTime()},"now"in window.performance==0){var e=Date.now();performance.timing&&performance.timing.navigationStart&&(e=performance.timing.navigationStart),window.performance.now=function(){return Date.now()-e}}return window.performance.now()},flyTo:function(e,t,r,n){n=n||2.388657133911758,r=r||500;var s=e.getView(),a=ol.animation.pan({duration:r,source:s.getCenter()}),o=ol.animation.zoom({duration:r,resolution:s.getResolution()});e.beforeRender(a,o),s.setCenter(t),s.setResolution(n)},randomId:function(e){var t=this.now().toString(36);return e?e+t:t},isNumeric:function(e){return/^\d+$/.test(e)},classRegex:function(e){return new RegExp("(^|\\s+) "+e+" (\\s+|$)")},addClass:function(e,t,r){var n=this;if(Array.isArray(e))return void e.forEach(function(e){n.addClass(e,t)});for(var s=Array.isArray(t)?t:t.split(/\s+/),a=s.length;a--;)n.hasClass(e,s[a])||n._addClass(e,s[a],r)},_addClass:function(e,t,r){var n=this;e.classList?e.classList.add(t):e.className=(e.className+" "+t).trim(),r&&this.isNumeric(r)&&window.setTimeout(function(){n._removeClass(e,t)},r)},removeClass:function(e,t,r){var n=this;if(Array.isArray(e))return void e.forEach(function(e){n.removeClass(e,t,r)});for(var s=Array.isArray(t)?t:t.split(/\s+/),a=s.length;a--;)n.hasClass(e,s[a])&&n._removeClass(e,s[a],r)},_removeClass:function(e,t,r){var n=this;e.classList?e.classList.remove(t):e.className=e.className.replace(this.classRegex(t)," ").trim(),r&&this.isNumeric(r)&&window.setTimeout(function(){n._addClass(e,t)},r)},hasClass:function(e,t){return e.classList?e.classList.contains(t):this.classRegex(t).test(e.className)},toggleClass:function(e,t){var r=this;return Array.isArray(e)?void e.forEach(function(e){r.toggleClass(e,t)}):void(e.classList?e.classList.toggle(t):this.hasClass(e,t)?this._removeClass(e,t):this._addClass(e,t))},$:function(e){return e="#"===e[0]?e.substr(1,e.length):e,document.getElementById(e)},isElement:function(e){return"HTMLElement"in window?!!e&&e instanceof HTMLElement:!!e&&"object"==typeof e&&1===e.nodeType&&!!e.nodeName},getAllChildren:function(e,t){return[].slice.call(e.getElementsByTagName(t))},isEmpty:function(e){return!e||0===e.length},emptyArray:function(e){for(;e.length;)e.pop()},anyMatchInArray:function(e,t){return e.some(function(e){return t.indexOf(e)>=0})},everyMatchInArray:function(e,t){return t.every(function(t){return e.indexOf(t)>=0})},anyItemHasValue:function(e,t){void 0===t&&(t=!1);for(var r in e)this.isEmpty(e[r])||(t=!0);return t},removeAllChildren:function(e){for(;e.firstChild;)e.removeChild(e.firstChild)},removeAll:function(e){for(var t;t=e[0];)t.parentNode.removeChild(t)},getChildren:function(e,t){return[].filter.call(e.childNodes,function(e){return t?1==e.nodeType&&e.tagName.toLowerCase()==t:1==e.nodeType})},template:function(e,t){var r=this;return e.replace(/\{ *([\w_-]+) *\}/g,function(e,n){var s=void 0===t[n]?"":t[n];return r.htmlEscape(s)})},htmlEscape:function(e){return String(e).replace(/&/g,"&").replace(//g,">").replace(/"/g,""").replace(/'/g,"'")},mergeOptions:function(e,t){var r={};for(var n in e)r[n]=e[n];for(var s in t)r[s]=t[s];return r},createElement:function(e,t){var r;if(Array.isArray(e)){if(r=document.createElement(e[0]),e[1].id&&(r.id=e[1].id),e[1].classname&&(r.className=e[1].classname),e[1].attr){var n=e[1].attr;if(Array.isArray(n))for(var s=-1;++s-1?e.lang:this.settings.params.lang}}},A.prototype.handleResponse=function(e){return e.map(function(e){return{lon:e.geometry.coordinates[0],lat:e.geometry.coordinates[1],address:{name:e.properties.name,postcode:e.properties.postcode,city:e.properties.city,state:e.properties.state,country:e.properties.country},original:{formatted:e.properties.name,details:e.properties}}})};var w=function(){this.settings={url:"//nominatim.openstreetmap.org/search/",params:{q:"",format:"json",addressdetails:1,limit:10,countrycodes:"","accept-language":"en-US"}}};w.prototype.getParameters=function(e){return{url:this.settings.url,params:{q:e.query,format:"json",addressdetails:1,limit:e.limit||this.settings.params.limit,countrycodes:e.countrycodes||this.settings.params.countrycodes,"accept-language":e.lang||this.settings.params["accept-language"]}}},w.prototype.handleResponse=function(e){return e.map(function(e){return{lon:e.lon,lat:e.lat,address:{name:e.address.neighbourhood||"",road:e.address.road||"",postcode:e.address.postcode,city:e.address.city||e.address.town,state:e.address.state,country:e.address.country},original:{formatted:e.display_name,details:e.address}}})};var C=function(){this.settings={url:"//open.mapquestapi.com/nominatim/v1/search.php",params:{q:"",key:"",format:"json",addressdetails:1,limit:10,countrycodes:"","accept-language":"en-US"}}};C.prototype.getParameters=function(e){return{url:this.settings.url,params:{q:e.query,key:e.key,format:"json",addressdetails:1,limit:e.limit||this.settings.params.limit,countrycodes:e.countrycodes||this.settings.params.countrycodes,"accept-language":e.lang||this.settings.params["accept-language"]}}},C.prototype.handleResponse=function(e){return e.map(function(e){return{lon:e.lon,lat:e.lat,address:{name:e.address.neighbourhood||"",road:e.address.road||"",postcode:e.address.postcode,city:e.address.city||e.address.town,state:e.address.state,country:e.address.country},original:{formatted:e.display_name,details:e.address}}})};var S=function(){this.settings={url:"//search.mapzen.com/v1/search",params:{text:"",key:"",size:10}}};S.prototype.getParameters=function(e){return{url:this.settings.url,params:{text:e.query,key:e.key,size:e.limit||this.settings.params.size}}},S.prototype.handleResponse=function(e){return e.map(function(e){return{lon:e.geometry.coordinates[0],lat:e.geometry.coordinates[1],address:{name:e.properties.name,house_number:e.properties.housenumber,postcode:e.properties.postalcode,road:e.properties.street,city:e.properties.city,state:e.properties.region,country:e.properties.country},original:{formatted:e.properties.label,details:e.properties}}})};var E=function(){this.settings={url:"//maps.googleapis.com/maps/api/geocode/json",params:{address:"",key:"",language:"en-US"}}};E.prototype.getParameters=function(e){return{url:this.settings.url,params:{address:e.query,key:e.key,language:e.lang||this.settings.params.language}}},E.prototype.handleResponse=function(e){var t=["point_of_interest","establishment","natural_feature","airport"],r=["street_address","route","sublocality_level_5","intersection"],n=["postal_code"],s=["locality"],a=["administrative_area_level_1"],o=["country"],i=function(e){var i={name:"",road:"",postcode:"",city:"",state:"",country:""};return e.forEach(function(e){v.anyMatchInArray(e.types,t)?i.name=e.long_name:v.anyMatchInArray(e.types,r)?i.road=e.long_name:v.anyMatchInArray(e.types,n)?i.postcode=e.long_name:v.anyMatchInArray(e.types,s)?i.city=e.long_name:v.anyMatchInArray(e.types,a)?i.state=e.long_name:v.anyMatchInArray(e.types,o)&&(i.country=e.long_name)}),i},l=[];return e.forEach(function(e){var t=i(e.address_components);v.anyItemHasValue(t)&&l.push({lon:e.geometry.location.lng,lat:e.geometry.location.lat,address:{name:t.name,postcode:t.postcode,road:t.road,city:t.city,state:t.state,country:t.country},original:{formatted:e.formatted_address,details:e.address_components}})}),l};var b=function(e){return this.Base=e,this.layer_name=v.randomId("geocoder-layer-"),this.layer=new ol.layer.Vector({name:this.layer_name,source:new ol.source.Vector}),this.options=e.options,this.options.provider=this.options.provider.toLowerCase(),this.els=this.createControl(),this.container=this.els.container,this.registered_listeners={map_click:!1},this.setListeners(),this.Photon=new A,this.OpenStreet=new w,this.MapQuest=new C,this.Pelias=new S,this.Google=new E,this};b.prototype.createControl=function(){var s=v.createElement(["div",{classname:e+t}],b.html),o={container:s,control:s.querySelector("."+(e+r)),btn_search:s.querySelector("."+(e+n)),input_search:s.querySelector("."+(e+d)),result_container:s.querySelector("."+(e+a))};return o.input_search.placeholder=this.options.placeholder,o},b.prototype.setListeners=function(){var t=this,r=function(){v.hasClass(t.els.control,e+o)?t.collapse():t.expand()},n=function(e){if(13==e.keyCode){e.preventDefault();var r=v.htmlEscape(t.els.input_search.value);t.query(r)}};this.els.input_search.addEventListener("keydown",n,!1),this.els.btn_search.addEventListener("click",r,!1)},b.prototype.query=function(t){var r=this,n=this.options,a=this.els.input_search,o=this.getProvider({query:t,provider:n.provider,key:n.key,lang:n.lang,countrycodes:n.countrycodes,limit:n.limit});this.clearResults(),v.addClass(a,e+s),v.json(o.url,o.params).when({ready:function(t){n.debug&&console.info(t),v.removeClass(a,e+s);var o;switch(n.provider){case y.OSM:o=t.length>0?r.OpenStreet.handleResponse(t):void 0;break;case y.MAPQUEST:o=t.length>0?r.MapQuest.handleResponse(t):void 0;break;case y.PELIAS:o=t.features.length>0?r.Pelias.handleResponse(t.features):void 0;break;case y.PHOTON:o=t.features.length>0?r.Photon.handleResponse(t.features):void 0;break;case y.GOOGLE:o=t.results.length>0?r.Google.handleResponse(t.results):void 0}o&&(r.createList(o),r.listenMapClick())},error:function(){v.removeClass(a,e+s);var t=v.createElement("li","Error! No internet connection?
");r.els.result_container.appendChild(t)}})},b.prototype.createList=function(e){var t=this,r=this.els.result_container;e.forEach(function(e){var n=t.addressTemplate(e.address),s=''+n+"",a=v.createElement("li",s);a.addEventListener("click",function(r){r.preventDefault(),t.chosen(e,n,e.address,e.original)},!1),r.appendChild(a)})},b.prototype.chosen=function(e,t,r,n){var s=this.Base.getMap(),a=ol.proj.transform([parseFloat(e.lon),parseFloat(e.lat)],"EPSG:4326",s.getView().getProjection()),o={formatted:t,details:r,original:n};if(this.options.keepOpen===!1&&this.clearResults(!0),this.options.preventDefault===!0)this.Base.dispatchEvent({type:h.ADDRESSCHOSEN,address:o,coordinate:a});else{v.flyTo(s,a);var i=this.createFeature(a,o);this.Base.dispatchEvent({type:h.ADDRESSCHOSEN,address:o,feature:i,coordinate:a})}},b.prototype.createFeature=function(e){var t=new ol.Feature(new ol.geom.Point(e));this.addLayer(),t.setStyle(this.options.featureStyle),t.setId(v.randomId("geocoder-ft-")),this.getSource().addFeature(t)},b.prototype.addressTemplate=function(t){var r=[];return t.name&&r.push('{name}'),(t.road||t.building||t.house_number)&&r.push('{building} {road} {house_number}'),(t.city||t.town||t.village)&&r.push('{postcode} {city} {town} {village}'),(t.state||t.country)&&r.push('{state} {country}'),v.template(r.join("
"),t)},b.prototype.getProvider=function(e){var t;switch(e.provider){case y.OSM:t=this.OpenStreet.getParameters(e);break;case y.MAPQUEST:t=this.MapQuest.getParameters(e);break;case y.PHOTON:t=this.Photon.getParameters(e);break;case y.GOOGLE:t=this.Google.getParameters(e);break;case y.PELIAS:t=this.Pelias.getParameters(e)}return t},b.prototype.expand=function(){var t=this;v.removeClass(this.els.input_search,e+s),v.addClass(this.els.control,e+o),window.setTimeout(function(){t.els.input_search.focus()},100),this.listenMapClick()},b.prototype.collapse=function(){this.els.input_search.value="",this.els.input_search.blur(),v.removeClass(this.els.control,e+o),this.clearResults()},b.prototype.listenMapClick=function(){if(!this.registered_listeners.map_click){var e=this,t=this.Base.getMap().getTargetElement();this.registered_listeners.map_click=!0,t.addEventListener("click",{handleEvent:function(r){e.clearResults(!0),t.removeEventListener(r.type,this,!1),e.registered_listeners.map_click=!1}},!1)}},b.prototype.clearResults=function(e){e?this.collapse():v.removeAllChildren(this.els.result_container)},b.prototype.getSource=function(){return this.layer.getSource()},b.prototype.addLayer=function(){var e=this,t=!1,r=this.Base.getMap();r.getLayers().forEach(function(r){r===e.layer&&(t=!0)}),t||r.addLayer(this.layer)},b.html=['',"",'","
",''].join("");var L=function(e){function t(r,n){void 0===r&&(r="nominatim"),void 0===n&&(n={}),v.assert("string"==typeof r,"@param `control_type` should be string type!"),v.assert("object"==typeof n,"@param `opt_options` should be object type!"),this.options=v.mergeOptions(g,n),t.Nominatim=new b(this),e.call(this,{element:t.Nominatim.container})}return t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.getLayer=function(){return t.Nominatim.layer},t.prototype.getSource=function(){return this.getLayer().getSource()},t}(ol.control.Control);return L});
+!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?module.exports=t():"function"==typeof define&&define.amd?define(t):e.Geocoder=t()}(this,function(){"use strict";var e="ol3-geocoder",t="-container",r="-search",s="-btn-search",n="-loading",a="-result",o="-search-expanded",i="-country",l="-city",c="-road",u="ol-control",d="form-geocoder",p="-input-search",m="gcd-input",h={ADDRESSCHOSEN:"addresschosen"},f=[new ol.style.Style({image:new ol.style.Icon({anchor:[.5,1],src:["data:image/png;base64,","iVBORw0KGgoAAAANSUhEUgAAAC0AAAAtCAYAAAA6GuKaAAAABmJLR0QA/wD/AP+gvaeT","AAAACXBIWXMAAAsTAAALEwEAmpwYAAAAB3RJTUUH4AQWCiErd9Z21AAABAJJREFUWMPVm","U1oXFUUx3/3zatJx04SDOgiVUMSgrXJwpqIKy26SrKoLjQgCkIFW7otuCvdllbo1q6Epg","vNQvtx710lEFdihwpSjdikJLGJWEhrM9MyX7nPxbypwzBv5n3cqXpgmOHOuff/mzPn3Pf","ueWDBpqZnrPq1M5EUVitZ+9wPvA0cAgaALqAIbAI3gAWt5HbjvCcGXROdmp4RwDDwBfBW","iKmLwKfAqlbSiwvvJAAeAeaBWyGB8f1uAfNT0zMj/jqdjXQd8Ds+sJsguyrAe1rJb6NGX","MQAPgJ8k7QefPOAd7WSl6OAi4jAk8D3cdKqhRngda3k9bDgUSL9NLAO9GPftoEXtZIPrR","WiXyzHwwAbA8WyoFAUFMsCY0JB9wPHwxalGyH3T4RxHByo8MZEgf4+w/ZfDt9lu9n4I5T","MCeBzP8+tQL8KDAZuA7swOljh4yM5JsaKGAPGA0fABzN5sje7+PJyht/WXNxU8O/1dbK2","9ulPWn05tL/CqWP3GR8tUSgKSmVBpVJ9LxQF46MlTh27z9D+SiKdqNCBFw/jwexUnr4eg","xfwx3oe9PUYZqfyGC+eThzo4SCYTNpweLLQtuCMgcOTBTLp4B8XpBMXuqnfroGxkTIi5M","YpRNV/1yTjCQv9oHmkBXu7vRD1/s/1b2+3h+eJSDpxoa83G0w5HisbLqRCrpKClQ2XlON","F0okL/XXTyQ6sbe1h/Y7bNkWEgPU7Lmtbe3CcaDpxoS8CuaYbfcpj7mqmVXE9Ltq5qxnc","VKBjztexBl0Azgd9uZTt4spimlJZkHKqUa29Ug6UyoIri2mWsl2tNM77OlZvmIaBn4B00","6tiRfDSUIk3JwocerlIzz7DTt7hxi9dLGW7+fX2U7huYJQfAeNayduduDX9Cni/3X5sPI","HnVSPtCK9VDj/OZa3krPVbUx++J+y2FNF6tZI71s+IfhR2gNOWgU9rJXeinBUjnxGBF4A","fgWcsAN8DXgE2OnJGbIC/CHxoAXpOK/lRx1sIvn1mKTVirRO377EFnE0IfFYrudXxvkdD","bvcCvwOZGEvkgOeBB0+kwwTU9tIccClmlC8Bubj9vKQNyAPAzxHX8YCDWsnluLpOAmB84","fmIU+e1kstJ2r42OkVH/S5R2G7S0aSCsaFrHU+tZB44F3LaOa1k/l/pTzfZSQ4APwD7Wr","jmgdeA5STAttKjltsLbdwWkhSf1UjXRfxZ4M8WLs9pJe/a0HIsAeMDnQlwOaOVvPufeFD","UJLcH/H27t6EtcBDYTJrLViNdl9ubwLWG4Wv+uDUTWDb/LLlSNzSilVy1qeFYBsYHvOAP","XdBKrtrK5Y5A19lJqo8kTnZi8U6kRy0YY8BNwNgqwP+1/Q09w5giQWRk7AAAAABJRU5Er","kJggg=="].join("")})})],g={OSM:"osm",MAPQUEST:"mapquest",GOOGLE:"google",PHOTON:"photon",BING:"bing",PELIAS:"pelias"},y={provider:g.OSM,placeholder:"Search for an address",featureStyle:f,lang:"en-US",limit:5,keepOpen:!1,preventDefault:!1,debug:!1},v={toQueryString:function(e){var t=this;return Object.keys(e).reduce(function(r,s){return r.push("object"==typeof e[s]?t.toQueryString(e[s]):encodeURIComponent(s)+"="+encodeURIComponent(e[s])),r},[]).join("&")},encodeUrlXhr:function(e,t){if(t&&"object"==typeof t){var r=this.toQueryString(t);e+=(/\?/.test(e)?"&":"?")+r}return e},json:function(e,t){var r=new XMLHttpRequest,s="",n="",a={},o=function(){200===r.status&&a.ready.call(void 0,JSON.parse(r.response))},i=function(){console.info("Cannot XHR "+JSON.stringify(e))};return"object"==typeof e?(s=e.url,t=e.data,n=e.data_type||"json"):s=e,s=this.encodeUrlXhr(s,t),"jsonp"===n?this.jsonp(s,e.callbackName,function(e){a.ready.call(void 0,e)}):(r.open("GET",s,!0),r.setRequestHeader("Accept","application/json"),r.onload=o,r.onerror=i,r.send(null)),{when:function(e){a.ready=e.ready}}},jsonp:function(e,t,r){var s=document.head,n=document.createElement("script"),a="f"+Math.round(Math.random()*Date.now());n.setAttribute("src",e+(e.indexOf("?")>0?"&":"?")+t+"="+a),window[a]=function(e){window[a]=void 0,setTimeout(function(){s.removeChild(n)},0),r(e)},s.appendChild(n)},now:function(){if("performance"in window==0&&(window.performance={}),Date.now=Date.now||function(){return(new Date).getTime()},"now"in window.performance==0){var e=Date.now();performance.timing&&performance.timing.navigationStart&&(e=performance.timing.navigationStart),window.performance.now=function(){return Date.now()-e}}return window.performance.now()},flyTo:function(e,t,r,s){s=s||2.388657133911758,r=r||500;var n=e.getView(),a=ol.animation.pan({duration:r,source:n.getCenter()}),o=ol.animation.zoom({duration:r,resolution:n.getResolution()});e.beforeRender(a,o),n.setCenter(t),n.setResolution(s)},randomId:function(e){var t=this.now().toString(36);return e?e+t:t},isNumeric:function(e){return/^\d+$/.test(e)},classRegex:function(e){return new RegExp("(^|\\s+) "+e+" (\\s+|$)")},addClass:function(e,t,r){var s=this;if(Array.isArray(e))return void e.forEach(function(e){s.addClass(e,t)});for(var n=Array.isArray(t)?t:t.split(/\s+/),a=n.length;a--;)s.hasClass(e,n[a])||s._addClass(e,n[a],r)},_addClass:function(e,t,r){var s=this;e.classList?e.classList.add(t):e.className=(e.className+" "+t).trim(),r&&this.isNumeric(r)&&window.setTimeout(function(){s._removeClass(e,t)},r)},removeClass:function(e,t,r){var s=this;if(Array.isArray(e))return void e.forEach(function(e){s.removeClass(e,t,r)});for(var n=Array.isArray(t)?t:t.split(/\s+/),a=n.length;a--;)s.hasClass(e,n[a])&&s._removeClass(e,n[a],r)},_removeClass:function(e,t,r){var s=this;e.classList?e.classList.remove(t):e.className=e.className.replace(this.classRegex(t)," ").trim(),r&&this.isNumeric(r)&&window.setTimeout(function(){s._addClass(e,t)},r)},hasClass:function(e,t){return e.classList?e.classList.contains(t):this.classRegex(t).test(e.className)},toggleClass:function(e,t){var r=this;return Array.isArray(e)?void e.forEach(function(e){r.toggleClass(e,t)}):void(e.classList?e.classList.toggle(t):this.hasClass(e,t)?this._removeClass(e,t):this._addClass(e,t))},$:function(e){return e="#"===e[0]?e.substr(1,e.length):e,document.getElementById(e)},isElement:function(e){return"HTMLElement"in window?!!e&&e instanceof HTMLElement:!!e&&"object"==typeof e&&1===e.nodeType&&!!e.nodeName},getAllChildren:function(e,t){return[].slice.call(e.getElementsByTagName(t))},isEmpty:function(e){return!e||0===e.length},emptyArray:function(e){for(;e.length;)e.pop()},anyMatchInArray:function(e,t){return e.some(function(e){return t.indexOf(e)>=0})},everyMatchInArray:function(e,t){return t.every(function(t){return e.indexOf(t)>=0})},anyItemHasValue:function(e,t){var r=this;void 0===t&&(t=!1);for(var s in e)r.isEmpty(e[s])||(t=!0);return t},removeAllChildren:function(e){for(;e.firstChild;)e.removeChild(e.firstChild)},removeAll:function(e){for(var t;t=e[0];)t.parentNode.removeChild(t)},getChildren:function(e,t){return[].filter.call(e.childNodes,function(e){return t?1==e.nodeType&&e.tagName.toLowerCase()==t:1==e.nodeType})},template:function(e,t){var r=this;return e.replace(/\{ *([\w_-]+) *\}/g,function(e,s){var n=void 0===t[s]?"":t[s];return r.htmlEscape(n)})},htmlEscape:function(e){return String(e).replace(/&/g,"&").replace(//g,">").replace(/"/g,""").replace(/'/g,"'")},mergeOptions:function(e,t){var r={};for(var s in e)r[s]=e[s];for(var n in t)r[n]=t[n];return r},createElement:function(e,t){var r;if(Array.isArray(e)){if(r=document.createElement(e[0]),e[1].id&&(r.id=e[1].id),e[1].classname&&(r.className=e[1].classname),e[1].attr){var s=e[1].attr;if(Array.isArray(s))for(var n=-1;++n-1?e.lang:this.settings.params.lang}}},A.prototype.handleResponse=function(e){return e.map(function(e){return{lon:e.geometry.coordinates[0],lat:e.geometry.coordinates[1],address:{name:e.properties.name,postcode:e.properties.postcode,city:e.properties.city,state:e.properties.state,country:e.properties.country},original:{formatted:e.properties.name,details:e.properties}}})};var w=function(){this.settings={url:"//nominatim.openstreetmap.org/search/",params:{q:"",format:"json",addressdetails:1,limit:10,countrycodes:"","accept-language":"en-US"}}};w.prototype.getParameters=function(e){return{url:this.settings.url,params:{q:e.query,format:"json",addressdetails:1,limit:e.limit||this.settings.params.limit,countrycodes:e.countrycodes||this.settings.params.countrycodes,"accept-language":e.lang||this.settings.params["accept-language"]}}},w.prototype.handleResponse=function(e){return e.map(function(e){return{lon:e.lon,lat:e.lat,address:{name:e.address.neighbourhood||"",road:e.address.road||"",postcode:e.address.postcode,city:e.address.city||e.address.town,state:e.address.state,country:e.address.country},original:{formatted:e.display_name,details:e.address}}})};var C=function(){this.settings={url:"//open.mapquestapi.com/nominatim/v1/search.php",params:{q:"",key:"",format:"json",addressdetails:1,limit:10,countrycodes:"","accept-language":"en-US"}}};C.prototype.getParameters=function(e){return{url:this.settings.url,params:{q:e.query,key:e.key,format:"json",addressdetails:1,limit:e.limit||this.settings.params.limit,countrycodes:e.countrycodes||this.settings.params.countrycodes,"accept-language":e.lang||this.settings.params["accept-language"]}}},C.prototype.handleResponse=function(e){return e.map(function(e){return{lon:e.lon,lat:e.lat,address:{name:e.address.neighbourhood||"",road:e.address.road||"",postcode:e.address.postcode,city:e.address.city||e.address.town,state:e.address.state,country:e.address.country},original:{formatted:e.display_name,details:e.address}}})};var b=function(){this.settings={url:"//search.mapzen.com/v1/search",params:{text:"",key:"",size:10}}};b.prototype.getParameters=function(e){return{url:this.settings.url,params:{text:e.query,key:e.key,size:e.limit||this.settings.params.size}}},b.prototype.handleResponse=function(e){return e.map(function(e){return{lon:e.geometry.coordinates[0],lat:e.geometry.coordinates[1],address:{name:e.properties.name,house_number:e.properties.housenumber,postcode:e.properties.postalcode,road:e.properties.street,city:e.properties.city,state:e.properties.region,country:e.properties.country},original:{formatted:e.properties.label,details:e.properties}}})};var S=function(){this.settings={url:"//maps.googleapis.com/maps/api/geocode/json",params:{address:"",key:"",language:"en-US"}}};S.prototype.getParameters=function(e){return{url:this.settings.url,params:{address:e.query,key:e.key,language:e.lang||this.settings.params.language}}},S.prototype.handleResponse=function(e){var t=["point_of_interest","establishment","natural_feature","airport"],r=["street_address","route","sublocality_level_5","intersection"],s=["postal_code"],n=["locality"],a=["administrative_area_level_1"],o=["country"],i=function(e){var i={name:"",road:"",postcode:"",city:"",state:"",country:""};return e.forEach(function(e){v.anyMatchInArray(e.types,t)?i.name=e.long_name:v.anyMatchInArray(e.types,r)?i.road=e.long_name:v.anyMatchInArray(e.types,s)?i.postcode=e.long_name:v.anyMatchInArray(e.types,n)?i.city=e.long_name:v.anyMatchInArray(e.types,a)?i.state=e.long_name:v.anyMatchInArray(e.types,o)&&(i.country=e.long_name)}),i},l=[];return e.forEach(function(e){var t=i(e.address_components);v.anyItemHasValue(t)&&l.push({lon:e.geometry.location.lng,lat:e.geometry.location.lat,address:{name:t.name,postcode:t.postcode,road:t.road,city:t.city,state:t.state,country:t.country},original:{formatted:e.formatted_address,details:e.address_components}})}),l};var E=function(){this.settings={url:"//dev.virtualearth.net/REST/v1/Locations",callbackName:"jsonp",params:{query:"",key:"",includeNeighborhood:0,maxResults:10}}};E.prototype.getParameters=function(e){return{url:this.settings.url,callbackName:this.settings.callbackName,params:{query:e.query,key:e.key,includeNeighborhood:e.includeNeighborhood||this.settings.params.includeNeighborhood,maxResults:e.maxResults||this.settings.params.maxResults}}},E.prototype.handleResponse=function(e){return e.map(function(e){return{lon:e.point.coordinates[1],lat:e.point.coordinates[0],address:{name:e.name},original:{formatted:e.address.formattedAddress,details:e.address}}})};var k=function(e){return this.Base=e,this.layer_name=v.randomId("geocoder-layer-"),this.layer=new ol.layer.Vector({name:this.layer_name,source:new ol.source.Vector}),this.options=e.options,this.options.provider=this.options.provider.toLowerCase(),this.els=this.createControl(),this.container=this.els.container,this.registered_listeners={map_click:!1},this.setListeners(),this.Photon=new A,this.OpenStreet=new w,this.MapQuest=new C,this.Pelias=new b,this.Google=new S,this.Bing=new E,this};k.prototype.createControl=function(){var n=v.createElement(["div",{classname:e+t}],k.html),o={container:n,control:n.querySelector("."+(e+r)),btn_search:n.querySelector("."+(e+s)),input_search:n.querySelector("."+(e+p)),result_container:n.querySelector("."+(e+a))};return o.input_search.placeholder=this.options.placeholder,o},k.prototype.setListeners=function(){var t=this,r=function(){v.hasClass(t.els.control,e+o)?t.collapse():t.expand()},s=function(e){if(13==e.keyCode){e.preventDefault();var r=v.htmlEscape(t.els.input_search.value);t.query(r)}};this.els.input_search.addEventListener("keydown",s,!1),this.els.btn_search.addEventListener("click",r,!1)},k.prototype.query=function(t){var r=this,s={},a=this.options,o=this.els.input_search,i=this.getProvider({query:t,provider:a.provider,key:a.key,lang:a.lang,countrycodes:a.countrycodes,limit:a.limit});this.clearResults(),v.addClass(o,e+n),s.url=i.url,s.data=i.params,a.provider===g.BING&&(s.data_type="jsonp",s.callbackName=i.callbackName),v.json(s).when({ready:function(t){a.debug&&console.info(t),v.removeClass(o,e+n);var s;switch(a.provider){case g.OSM:s=t.length>0?r.OpenStreet.handleResponse(t):void 0;break;case g.MAPQUEST:s=t.length>0?r.MapQuest.handleResponse(t):void 0;break;case g.PELIAS:s=t.features.length>0?r.Pelias.handleResponse(t.features):void 0;break;case g.PHOTON:s=t.features.length>0?r.Photon.handleResponse(t.features):void 0;break;case g.GOOGLE:s=t.results.length>0?r.Google.handleResponse(t.results):void 0;break;case g.BING:s=t.resourceSets[0].resources.length>0?r.Bing.handleResponse(t.resourceSets[0].resources):void 0}s&&(r.createList(s),r.listenMapClick())},error:function(){v.removeClass(o,e+n);var t=v.createElement("li","Error! No internet connection?
");r.els.result_container.appendChild(t)}})},k.prototype.createList=function(e){var t=this,r=this.els.result_container;e.forEach(function(e){var s=t.addressTemplate(e.address),n=''+s+"",a=v.createElement("li",n);a.addEventListener("click",function(r){r.preventDefault(),t.chosen(e,s,e.address,e.original)},!1),r.appendChild(a)})},k.prototype.chosen=function(e,t,r,s){var n=this.Base.getMap(),a=ol.proj.transform([parseFloat(e.lon),parseFloat(e.lat)],"EPSG:4326",n.getView().getProjection()),o={formatted:t,details:r,original:s};if(this.options.keepOpen===!1&&this.clearResults(!0),this.options.preventDefault===!0)this.Base.dispatchEvent({type:h.ADDRESSCHOSEN,address:o,coordinate:a});else{v.flyTo(n,a);var i=this.createFeature(a,o);this.Base.dispatchEvent({type:h.ADDRESSCHOSEN,address:o,feature:i,coordinate:a})}},k.prototype.createFeature=function(e){var t=new ol.Feature(new ol.geom.Point(e));this.addLayer(),t.setStyle(this.options.featureStyle),t.setId(v.randomId("geocoder-ft-")),this.getSource().addFeature(t)},k.prototype.addressTemplate=function(t){var r=[];return t.name&&r.push('{name}'),(t.road||t.building||t.house_number)&&r.push('{building} {road} {house_number}'),(t.city||t.town||t.village)&&r.push('{postcode} {city} {town} {village}'),(t.state||t.country)&&r.push('{state} {country}'),v.template(r.join("
"),t)},k.prototype.getProvider=function(e){var t;switch(e.provider){case g.OSM:t=this.OpenStreet.getParameters(e);break;case g.MAPQUEST:t=this.MapQuest.getParameters(e);break;case g.PHOTON:t=this.Photon.getParameters(e);break;case g.GOOGLE:t=this.Google.getParameters(e);break;case g.PELIAS:t=this.Pelias.getParameters(e);break;case g.BING:t=this.Bing.getParameters(e)}return t},k.prototype.expand=function(){var t=this;v.removeClass(this.els.input_search,e+n),v.addClass(this.els.control,e+o),window.setTimeout(function(){t.els.input_search.focus()},100),this.listenMapClick()},k.prototype.collapse=function(){this.els.input_search.value="",this.els.input_search.blur(),v.removeClass(this.els.control,e+o),this.clearResults()},k.prototype.listenMapClick=function(){if(!this.registered_listeners.map_click){var e=this,t=this.Base.getMap().getTargetElement();this.registered_listeners.map_click=!0,t.addEventListener("click",{handleEvent:function(r){e.clearResults(!0),t.removeEventListener(r.type,this,!1),e.registered_listeners.map_click=!1}},!1)}},k.prototype.clearResults=function(e){e?this.collapse():v.removeAllChildren(this.els.result_container)},k.prototype.getSource=function(){return this.layer.getSource()},k.prototype.addLayer=function(){var e=this,t=!1,r=this.Base.getMap();r.getLayers().forEach(function(r){r===e.layer&&(t=!0)}),t||r.addLayer(this.layer)},k.html=['',"",'","
",''].join("");var _=function(e){function t(r,s){void 0===r&&(r="nominatim"),void 0===s&&(s={}),v.assert("string"==typeof r,"@param `control_type` should be string type!"),v.assert("object"==typeof s,"@param `opt_options` should be object type!"),this.options=v.mergeOptions(y,s),t.Nominatim=new k(this),e.call(this,{element:t.Nominatim.container})}return e&&(t.__proto__=e),t.prototype=Object.create(e&&e.prototype),t.prototype.constructor=t,t.prototype.getLayer=function(){return t.Nominatim.layer},t.prototype.getSource=function(){return this.getLayer().getSource()},t}(ol.control.Control);return _});
diff --git a/build/ol3-geocoder.min.css b/build/ol3-geocoder.min.css
index 67a5874..8eae188 100644
--- a/build/ol3-geocoder.min.css
+++ b/build/ol3-geocoder.min.css
@@ -1,8 +1,8 @@
/**
* A geocoder extension for OpenLayers 3.
* https://github.com/jonataswalker/ol3-geocoder
- * Version: v2.1.0
- * Built: 2016-06-16T11:50:12-0300
+ * Version: v2.2.0
+ * Built: 2016-07-29T12:53:37-03:00
*/
-.ol3-geocoder-container{position:absolute;top:calc(.5em + 65px);left:.5em;box-sizing:border-box}.ol3-geocoder-container *,.ol3-geocoder-container ::after,.ol3-geocoder-container ::before{box-sizing:inherit}.ol3-geocoder-search{width:31px;height:31px;overflow:hidden;-webkit-transition:width .2s,height .2s;transition:width .2s,height .2s}.ol3-geocoder-search-expanded{width:220px;height:35px}.ol3-geocoder-input-search{position:absolute;top:2px;left:32px;width:180px;padding:5px;border:1px solid #ccc;font-family:inherit;font-size:.875rem}.ol3-geocoder-input-search:focus{border-color:#35b5f4}ul.ol3-geocoder-result{position:absolute;top:37px;left:32px;width:260px;max-height:300px;white-space:normal;list-style:none;padding:0;margin:0;background-color:#fff;border-radius:0 0 4px 4px;border-top:none;overflow-x:hidden;overflow-y:auto;box-shadow:0 1px 7px rgba(0,0,0,.8);-webkit-transition:max-height .3s ease-in;transition:max-height .3s ease-in}ul.ol3-geocoder-result>li{width:100%;overflow:hidden;border-bottom:1px solid #eee;padding:0;line-height:.875rem}ul.ol3-geocoder-result>li>a{display:block;text-decoration:none;padding:3px 5px}ul.ol3-geocoder-result>li>a:hover{background-color:#d4d4d4}ul.ol3-geocoder-result>li:nth-child(odd){background-color:#e0ffe0}.ol3-geocoder-road{font-size:.875rem;font-weight:700;color:#000}.ol3-geocoder-city{font-size:.75rem;font-weight:400;color:#000}.ol3-geocoder-country{font-size:.75rem;font-weight:lighter;color:#444}.ol3-geocoder-btn-search{position:absolute;width:25px;height:25px;top:2px;left:2px;background-image:url();background-repeat:no-repeat;background-position:center center}.ol3-geocoder-loading{background-image:url();background-repeat:no-repeat;background-position:right center}
\ No newline at end of file
+.ol3-geocoder-container{position:absolute;top:calc(.5em + 65px);left:.5em;box-sizing:border-box}.ol3-geocoder-container *,.ol3-geocoder-container ::after,.ol3-geocoder-container ::before{box-sizing:inherit}.ol3-geocoder-search{width:31px;height:31px;overflow:hidden;-webkit-transition:width .2s,height .2s;transition:width .2s,height .2s}.ol3-geocoder-search-expanded{width:220px;height:35px}.ol3-geocoder-input-search{position:absolute;top:2px;left:32px;width:180px;padding:5px;border:1px solid #ccc;font-family:inherit;font-size:.875rem}.ol3-geocoder-input-search:focus{border-color:#35b5f4}ul.ol3-geocoder-result{position:absolute;top:37px;left:32px;width:260px;max-height:300px;white-space:normal;list-style:none;padding:0;margin:0;background-color:#fff;border-radius:0 0 4px 4px;border-top:none;overflow-x:hidden;overflow-y:auto;box-shadow:0 1px 7px rgba(0,0,0,.8);-webkit-transition:max-height .3s ease-in;transition:max-height .3s ease-in}ul.ol3-geocoder-result>li{width:100%;overflow:hidden;border-bottom:1px solid #eee;padding:0;line-height:.875rem}ul.ol3-geocoder-result>li>a{display:block;text-decoration:none;padding:3px 5px}ul.ol3-geocoder-result>li>a:hover{background-color:#d4d4d4}ul.ol3-geocoder-result>li:nth-child(odd){background-color:#e0ffe0}.ol3-geocoder-road{font-size:.875rem;font-weight:500;color:#000}.ol3-geocoder-city{font-size:.75rem;font-weight:400;color:#000}.ol3-geocoder-country{font-size:.75rem;font-weight:lighter;color:#444}.ol3-geocoder-btn-search{position:absolute;width:25px;height:25px;top:2px;left:2px;background-image:url();background-repeat:no-repeat;background-position:center center}.ol3-geocoder-loading{background-image:url();background-repeat:no-repeat;background-position:right center}
\ No newline at end of file
diff --git a/package.json b/package.json
index f99ed5e..750460e 100644
--- a/package.json
+++ b/package.json
@@ -1,6 +1,6 @@
{
"name": "ol3-geocoder",
- "version": "2.1.0",
+ "version": "2.2.0",
"description": "A geocoder extension for OpenLayers 3.",
"author": "Jonatas Walker",
"homepage": "https://github.com/jonataswalker/ol3-geocoder",
@@ -19,22 +19,22 @@
"url": "https://github.com/jonataswalker/ol3-geocoder/issues"
},
"dependencies": {
- "openlayers": "^3.14.0"
+ "openlayers": "^3.17.1"
},
"devDependencies": {
- "autoprefixer": "^6.3.6",
- "casperjs": "^1.1.1",
- "clean-css": "^3.4.12",
- "eslint": "^2.9.0",
- "node-sass": "^3.4.2",
- "node-sass-json-importer": "^1.0.6",
- "nodemon": "^1.9.1",
+ "autoprefixer": "^6.3.7",
+ "casperjs": "^1.1.3",
+ "clean-css": "^3.4.19",
+ "eslint": "^3.1.1",
+ "node-sass": "^3.8.0",
+ "node-sass-json-importer": "^2.1.1",
+ "nodemon": "^1.10.0",
"parallelshell": "^2.0.0",
- "postcss-cli": "^2.5.1",
- "rollup": "^0.26.1",
- "rollup-plugin-buble": "^0.6.0",
- "rollup-plugin-json": "^2.0.0",
- "uglify-js": "^2.6.2"
+ "postcss-cli": "^2.5.2",
+ "rollup": "^0.34.1",
+ "rollup-plugin-buble": "^0.12.1",
+ "rollup-plugin-json": "^2.0.1",
+ "uglify-js": "^2.7.0"
},
"eslintConfig": {
"env": {
@@ -52,7 +52,7 @@
"no-alert": 2,
"no-caller": 2,
"no-eval": 2,
- "no-proto": 2,
+ "no-proto": "warn",
"no-redeclare": 2,
"valid-typeof": 2,
"no-unreachable": 2,
@@ -64,16 +64,10 @@
"no-undef": 2,
"no-use-before-define": 2,
"no-unused-vars": 1,
- "strict": [
- 1,
- "global"
- ],
+ "strict": [1, "global"],
"key-spacing": 0,
"new-cap": 1,
- "quotes": [
- 1,
- "single"
- ]
+ "quotes": [1, "single"]
}
}
}