mirror of
https://github.com/FoggedLens/iD.git
synced 2026-02-18 03:32:55 +00:00
75 lines
2.5 KiB
JavaScript
75 lines
2.5 KiB
JavaScript
iD.ui.geocoder = function() {
|
|
|
|
var map, context;
|
|
|
|
function geocoder(selection) {
|
|
function keydown() {
|
|
if (d3.event.keyCode !== 13) return;
|
|
d3.event.preventDefault();
|
|
var searchVal = this.value;
|
|
d3.json('http://nominatim.openstreetmap.org/search/' +
|
|
encodeURIComponent(searchVal) + '?limit=10&format=json', function(err, resp) {
|
|
if (err) return hide();
|
|
hide();
|
|
if (!resp.length) {
|
|
return iD.ui.flash(context.container())
|
|
.select('.content')
|
|
.append('h3')
|
|
.text('No location found for "' + searchVal + '"');
|
|
}
|
|
var bounds = resp[0].boundingbox;
|
|
map.extent(iD.geo.Extent([parseFloat(bounds[3]), parseFloat(bounds[0])], [parseFloat(bounds[2]), parseFloat(bounds[1])]));
|
|
if (map.zoom() > 19) map.zoom(19);
|
|
});
|
|
}
|
|
|
|
function clickoutside(selection) {
|
|
selection
|
|
.on('click.geocoder-inside', function() {
|
|
return d3.event.stopPropagation();
|
|
});
|
|
context.container().on('click.geocoder-outside', hide);
|
|
}
|
|
|
|
function show() { setVisible(true); }
|
|
function hide() { setVisible(false); }
|
|
function toggle() { setVisible(gcForm.classed('hide')); }
|
|
|
|
function setVisible(show) {
|
|
button.classed('active', show);
|
|
gcForm.classed('hide', !show);
|
|
if (show) inputNode.node().focus();
|
|
else inputNode.node().blur();
|
|
}
|
|
|
|
var button = selection.append('button')
|
|
.attr('tabindex', -1)
|
|
.attr('title', t('geocoder.find_location'))
|
|
.html('<span class=\'geocode icon\'></span>')
|
|
.on('click', toggle);
|
|
|
|
var gcForm = selection.append('form');
|
|
|
|
var inputNode = gcForm.attr('class','content fillD map-overlay hide')
|
|
.append('input')
|
|
.attr({ type: 'text', placeholder: t('geocoder.find_a_place') })
|
|
.on('keydown', keydown);
|
|
|
|
selection.call(clickoutside);
|
|
}
|
|
|
|
geocoder.map = function(_) {
|
|
if (!arguments.length) return map;
|
|
map = _;
|
|
return geocoder;
|
|
};
|
|
|
|
geocoder.context = function(_) {
|
|
if (!arguments.length) return context;
|
|
context = _;
|
|
return geocoder;
|
|
};
|
|
|
|
return geocoder;
|
|
};
|