status after hackweekend London
@@ -158,6 +158,8 @@ you edit `settings/local.php` with
|
|||||||
|
|
||||||
pgsql://postgres@localhost:9999/nominatim_it
|
pgsql://postgres@localhost:9999/nominatim_it
|
||||||
|
|
||||||
|
To access postgres directly remember to specify the hostname, e.g. `psql --host localhost --port 9999 nominatim_it`
|
||||||
|
|
||||||
|
|
||||||
##### My computer is slow and the import takes too long. Can I start the virtual machine "in the cloud"?
|
##### My computer is slow and the import takes too long. Can I start the virtual machine "in the cloud"?
|
||||||
|
|
||||||
|
|||||||
BIN
data/monaco.osm.pbf
Normal file
35
data/specialphrases_countries.sql
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
select getorcreate_country(make_standard_name('uk'), 'gb');
|
||||||
|
select getorcreate_country(make_standard_name('united states'), 'us');
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(country_code), country_code) from country_name where country_code is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:af'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:af']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:ar'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:ar']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:br'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:br']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:ca'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:ca']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:cs'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:cs']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:de'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:de']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:en'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:en']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:es'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:es']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:et'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:et']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:eu'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:eu']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:fa'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:fa']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:fi'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:fi']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:fr'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:fr']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:gl'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:gl']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:hr'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:hr']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:hu'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:hu']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:ia'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:ia']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:is'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:is']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:it'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:it']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:ja'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:ja']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:mk'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:mk']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:nl'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:nl']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:no'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:no']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:pl'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:pl']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:ps'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:ps']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:pt'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:pt']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:ru'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:ru']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:sk'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:sk']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:sv'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:sv']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:uk'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:uk']) is not null) as x;
|
||||||
|
select count(*) from (select getorcreate_country(make_standard_name(get_name_by_language(country_name.name,ARRAY['name:vi'])), country_code) from country_name where get_name_by_language(country_name.name, ARRAY['name:vi']) is not null) as x;
|
||||||
6
lib/template/includes/html-footer.php
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
<script src="js/jquery.min.js"></script>
|
||||||
|
<script src="js/bootstrap.min.js"></script>
|
||||||
|
<script src="js/leaflet.min.js"></script>
|
||||||
|
<script src="js/leaflet-omnivore.min.js"></script>
|
||||||
|
<script src="js/nominatim-ui.js"></script>
|
||||||
|
|
||||||
13
lib/template/includes/html-header.php
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="en">
|
||||||
|
<head>
|
||||||
|
<title>OpenStreetMap Nominatim: Search</title>
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
|
|
||||||
|
<base href="<?php echo CONST_Website_BaseURL;?>" />
|
||||||
|
<link href="nominatim.xml" rel="search" title="Nominatim Search" type="application/opensearchdescription+xml" />
|
||||||
|
<link href="css/leaflet.css" rel="stylesheet" />
|
||||||
|
<link href="css/bootstrap-theme.min.css" rel="stylesheet" />
|
||||||
|
<link href="css/bootstrap.min.css" rel="stylesheet" />
|
||||||
|
<link href="css/search.css" rel="stylesheet" type="text/css" />
|
||||||
|
</head>
|
||||||
2
lib/template/includes/introduction.php
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
<h2>This is Nominatim</h2>
|
||||||
|
abc def
|
||||||
24
lib/template/includes/report-errors.php
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
<p>
|
||||||
|
Before reporting problems please read the <a target="_blank" href="http://wiki.openstreetmap.org/wiki/Nominatim">user documentation</a>
|
||||||
|
and
|
||||||
|
<a target="_blank" href="http://wiki.openstreetmap.org/wiki/Nominatim/FAQ">FAQ</a>.
|
||||||
|
|
||||||
|
If your problem relates to the address of a particular search result please use the 'details' link
|
||||||
|
to check how the address was generated before reporting a problem.
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
Use <a target="_blank" href="https://github.com/twain47/nominatim/issues">Nominatim issues on github</a>
|
||||||
|
to report problems.
|
||||||
|
<!-- You can search for existing bug reports
|
||||||
|
<a href="http://trac.openstreetmap.org/query?status=new&status=assigned&status=reopened&component=nominatim&order=priority">here</a>.</p>
|
||||||
|
-->
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
Please ensure that you include a full description of the problem, including the search
|
||||||
|
query that you used, the problem with the result and, if the problem relates to missing data,
|
||||||
|
the osm type (node, way, relation) and id of the item that is missing.
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
Problems that contain enough detail are likely to get looked at before ones that require
|
||||||
|
significant research.
|
||||||
|
</p>
|
||||||
@@ -1,222 +1,92 @@
|
|||||||
<?php
|
<?php
|
||||||
header("content-type: text/html; charset=UTF-8");
|
header("content-type: text/html; charset=UTF-8");
|
||||||
?>
|
?>
|
||||||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
|
<body id="search-page">
|
||||||
<html xmlns="http://www.w3.org/1999/xhtml">
|
|
||||||
<head>
|
|
||||||
<title>OpenStreetMap Nominatim: Search</title>
|
|
||||||
|
|
||||||
<base href="<?php echo CONST_Website_BaseURL;?>" />
|
<?php include(CONST_BasePath.'/lib/template/includes/html-header.php'); ?>
|
||||||
<link href="nominatim.xml" rel="search" title="Nominatim Search" type="application/opensearchdescription+xml" />
|
|
||||||
<link href="css/search.css" rel="stylesheet" type="text/css" />
|
|
||||||
|
|
||||||
<script src="js/OpenLayers.js" type="text/javascript"></script>
|
<header class="container-fluid">
|
||||||
<script src="js/tiles.js" type="text/javascript"></script>
|
<div class="row">
|
||||||
<script src="js/prototype-1.6.0.3.js" type="text/javascript"></script>
|
<div class="col-xs-4">
|
||||||
|
<div class="brand">
|
||||||
|
<a href="<?php echo CONST_Website_BaseURL;?>">
|
||||||
|
<img alt="logo" src="images/osm_logo.120px.png" width="40" height="40"/>
|
||||||
|
<h1>Nominatim</h1>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div id="last-updated" class="col-xs-4 text-center">
|
||||||
|
Data last updated:
|
||||||
|
<br>
|
||||||
|
<?php echo $sDataDate; ?>
|
||||||
|
</div>
|
||||||
|
<div class="col-xs-4 text-right">
|
||||||
|
<div class="btn-group">
|
||||||
|
<button class="dropdown-toggle btn btn-link" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false">
|
||||||
|
About & Help <span class="caret"></span>
|
||||||
|
</button>
|
||||||
|
<ul class="dropdown-menu dropdown-menu-right">
|
||||||
|
<li><a href="http://wiki.openstreetmap.org/wiki/Nominatim" target="_blank">Documentation</a></li>
|
||||||
|
<li><a href="http://wiki.openstreetmap.org/wiki/Nominatim/FAQ" target="_blank">FAQ</a></li>
|
||||||
|
<li role="separator" class="divider"></li>
|
||||||
|
<li><a href="#" class="" data-toggle="modal" data-target="#report-modal">Report problem with results</a></li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</header>
|
||||||
|
|
||||||
<script type="text/javascript">
|
<form class="form-inline" role="search" accept-charset="UTF-8" action="<?php echo CONST_Website_BaseURL; ?>search.php">
|
||||||
|
<div class="form-group">
|
||||||
|
<input id="q" name="q" type="text" class="form-control input-sm" placeholder="Search" value="<?php echo htmlspecialchars($sQuery); ?>" >
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<button type="submit" class="btn btn-primary btn-sm">Search</button>
|
||||||
|
<?php if (CONST_Search_AreaPolygons) { ?>
|
||||||
|
<!-- <input type="checkbox" value="1" name="polygon" <?php if ($bAsText) echo "checked='checked'"; ?>/> Highlight -->
|
||||||
|
<input type="hidden" value="1" name="polygon" />
|
||||||
|
<?php } ?>
|
||||||
|
<input type="hidden" name="viewbox" value="<?php echo $sViewBox; ?>" />
|
||||||
|
<div class="checkbox-inline">
|
||||||
|
<label>
|
||||||
|
<input type="checkbox" id="use_viewbox" <?php if ($sViewBox) echo "checked='checked'"; ?>>
|
||||||
|
apply viewbox
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
|
||||||
var map;
|
|
||||||
|
|
||||||
function handleResize()
|
|
||||||
{
|
|
||||||
if ($('searchresults'))
|
|
||||||
{
|
|
||||||
var viewwidth = ((document.documentElement.clientWidth > 0?document.documentElement.clientWidth:document.documentElement.offsetWidth) - 200) + 'px';
|
|
||||||
$('map').style.width = viewwidth;
|
|
||||||
$('report').style.width = viewwidth;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$('map').style.width = ((document.documentElement.clientWidth > 0?document.documentElement.clientWidth:document.documentElement.offsetWidth) - 0) + 'px';
|
|
||||||
$('map').style.left = '0px';
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($('map')) $('map').style.height = ((document.documentElement.clientHeight > 0?document.documentElement.clientHeight:document.documentElement.offsetHeight) - 38) + 'px';
|
|
||||||
if ($('searchresults')) $('searchresults').style.height = ((document.documentElement.clientHeight > 0?document.documentElement.clientHeight:document.documentElement.offsetHeight) - 38) + 'px';
|
|
||||||
if ($('report')) $('report').style.height = ((document.documentElement.clientHeight > 0?document.documentElement.clientHeight:document.documentElement.offsetHeight) - 38) + 'px';
|
|
||||||
}
|
|
||||||
window.onresize = handleResize;
|
|
||||||
|
|
||||||
function panToLatLon(lat,lon) {
|
|
||||||
var lonLat = new OpenLayers.LonLat(lon, lat).transform(new OpenLayers.Projection("EPSG:4326"), map.getProjectionObject());
|
|
||||||
map.panTo(lonLat, <?php echo $iZoom ?>);
|
|
||||||
}
|
|
||||||
|
|
||||||
function panToLatLonZoom(lat, lon, zoom) {
|
|
||||||
var lonLat = new OpenLayers.LonLat(lon, lat).transform(new OpenLayers.Projection("EPSG:4326"), map.getProjectionObject());
|
|
||||||
if (zoom != map.getZoom())
|
|
||||||
map.setCenter(lonLat, zoom);
|
|
||||||
else
|
|
||||||
map.panTo(lonLat, 10);
|
|
||||||
}
|
|
||||||
|
|
||||||
function panToLatLonBoundingBox(lat,lon,minlat,maxlat,minlon,maxlon,wkt) {
|
|
||||||
vectorLayer.destroyFeatures();
|
|
||||||
var proj_EPSG4326 = new OpenLayers.Projection("EPSG:4326");
|
|
||||||
var proj_map = map.getProjectionObject();
|
|
||||||
map.zoomToExtent(new OpenLayers.Bounds(minlon,minlat,maxlon,maxlat).transform(proj_EPSG4326, proj_map));
|
|
||||||
var lonLat = new OpenLayers.LonLat(lon, lat).transform(proj_EPSG4326, proj_map);
|
|
||||||
map.panTo(lonLat, <?php echo $iZoom ?>);
|
|
||||||
|
|
||||||
if (wkt)
|
|
||||||
{
|
|
||||||
var freader = new OpenLayers.Format.WKT({
|
|
||||||
'internalProjection': proj_map,
|
|
||||||
'externalProjection': proj_EPSG4326
|
|
||||||
});
|
|
||||||
|
|
||||||
var feature = freader.read(wkt);
|
|
||||||
if (feature)
|
|
||||||
{
|
|
||||||
feature.style = {
|
|
||||||
strokeColor: "#75ADFF",
|
|
||||||
fillColor: "#F0F7FF",
|
|
||||||
strokeWidth: 2,
|
|
||||||
strokeOpacity: 0.75,
|
|
||||||
fillOpacity: 0.75,
|
|
||||||
pointRadius: 100
|
|
||||||
};
|
|
||||||
vectorLayer.addFeatures([feature]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function round(v,n)
|
|
||||||
{
|
|
||||||
n = Math.pow(10,n);
|
|
||||||
return Math.round(v*n)/n;
|
|
||||||
}
|
|
||||||
function floor(v,n)
|
|
||||||
{
|
|
||||||
n = Math.pow(10,n);
|
|
||||||
return Math.floor(v*n)/n;
|
|
||||||
}
|
|
||||||
function ceil(v,n)
|
|
||||||
{
|
|
||||||
n = Math.pow(10,n);
|
|
||||||
return Math.ceil(v*n)/n;
|
|
||||||
}
|
|
||||||
|
|
||||||
function mapEventMove() {
|
|
||||||
var proj = new OpenLayers.Projection("EPSG:4326");
|
|
||||||
var bounds = map.getExtent();
|
|
||||||
bounds = bounds.transform(map.getProjectionObject(), proj);
|
|
||||||
$('viewbox').value = floor(bounds.left,2)+','+ceil(bounds.top,2)+','+ceil(bounds.right,2)+','+floor(bounds.bottom,2);
|
|
||||||
}
|
|
||||||
|
|
||||||
function init() {
|
|
||||||
handleResize();
|
|
||||||
map = new OpenLayers.Map ("map", {
|
|
||||||
controls:[
|
|
||||||
new OpenLayers.Control.Navigation(),
|
|
||||||
new OpenLayers.Control.PanZoomBar(),
|
|
||||||
new OpenLayers.Control.MousePosition(),
|
|
||||||
new OpenLayers.Control.Attribution()],
|
|
||||||
maxExtent: new OpenLayers.Bounds(-20037508.34,-20037508.34,20037508.34,20037508.34),
|
|
||||||
maxResolution: 156543.0399,
|
|
||||||
numZoomLevels: 19,
|
|
||||||
units: 'm',
|
|
||||||
projection: new OpenLayers.Projection("EPSG:900913"),
|
|
||||||
displayProjection: new OpenLayers.Projection("EPSG:4326"),
|
|
||||||
eventListeners: {
|
|
||||||
"moveend": mapEventMove
|
|
||||||
}
|
|
||||||
} );
|
|
||||||
map.addLayer(new OpenLayers.Layer.OSM.<?php echo CONST_Tile_Default;?>("Default"));
|
|
||||||
|
|
||||||
var layer_style = OpenLayers.Util.extend({}, OpenLayers.Feature.Vector.style['default']);
|
|
||||||
layer_style.fillOpacity = 0.2;
|
|
||||||
layer_style.graphicOpacity = 1;
|
|
||||||
vectorLayer = new OpenLayers.Layer.Vector("Points", {style: layer_style});
|
|
||||||
map.addLayer(vectorLayer);
|
|
||||||
|
|
||||||
// var lonLat = new OpenLayers.LonLat(<?php echo $fLon ?>, <?php echo $fLat ?>).transform(new OpenLayers.Projection("EPSG:4326"), map.getProjectionObject());
|
|
||||||
// map.setCenter (lonLat, <?php echo $iZoom ?>);
|
|
||||||
}
|
|
||||||
|
|
||||||
function setfocus(field_id) {
|
|
||||||
$(field_id).focus()
|
|
||||||
}
|
|
||||||
|
|
||||||
</script>
|
|
||||||
</head>
|
|
||||||
|
|
||||||
<body onload="setfocus('q');">
|
|
||||||
|
|
||||||
<div id="seachheaderfade1"></div><div id="seachheaderfade2"></div><div id="seachheaderfade3"></div><div id="seachheaderfade4"></div>
|
|
||||||
|
|
||||||
<div id="seachheader">
|
|
||||||
<form accept-charset="UTF-8" action="<?php echo CONST_Website_BaseURL; ?>search.php" method="get">
|
|
||||||
<table border="0" width="100%" summary="header">
|
|
||||||
<tr>
|
|
||||||
<td valign="middle" style="width:30px;"><img alt="logo" src="images/logo.gif" /></td>
|
|
||||||
<td valign="middle" style="width:400px;"><input id="q" name="q" value="<?php echo htmlspecialchars($sQuery);
|
|
||||||
?>" style="width:270px;" /><input type="text" id="viewbox" style="width:120px;" name="viewbox" /></td>
|
|
||||||
<td style="width:80px;"><input type="submit" value="Search"/></td>
|
|
||||||
<?php if (CONST_Search_AreaPolygons) { ?> <td style="width:100px;"><input type="checkbox" value="1" name="polygon" <?php if ($bAsText) echo "checked='checked'"; ?>/> Highlight</td>
|
|
||||||
<td style="text-align:right;">Data: <?php echo $sDataDate; ?></td>
|
|
||||||
<td style="text-align:right;">
|
|
||||||
<a href="http://wiki.openstreetmap.org/wiki/Nominatim" target="_blank">Documentation</a> | <a href="http://wiki.openstreetmap.org/wiki/Nominatim/FAQ"
|
|
||||||
target="_blank">FAQ</a></td>
|
|
||||||
|
|
||||||
<?php } ?> <td style="text-align:right;"><?php if ($sQuery) { ?><input type="button" value="Report Problem With Results" onclick="$('report').style.visibility=($('report').style.visibility=='hidden'?'visible':'hidden')"/><?php } ?></td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
<div id="content">
|
||||||
<?php
|
<?php
|
||||||
if ($sQuery)
|
if ($sQuery)
|
||||||
{
|
{
|
||||||
?>
|
?>
|
||||||
<div id="searchresultsfade1"></div><div id="searchresultsfade2"></div><div id="searchresultsfade3"></div><div id="searchresultsfade4"></div>
|
<div id="searchresults" class="sidebar">
|
||||||
<div id="searchresults">
|
|
||||||
<?php
|
<?php
|
||||||
if ($sSuggestionURL)
|
$i = 0;
|
||||||
{
|
|
||||||
echo '<div class="more"><b>Suggest: </b><a href="'.$sSuggestionURL.'"><b>'.$sSuggestion.'</b></a></div>';
|
|
||||||
}
|
|
||||||
foreach($aSearchResults as $iResNum => $aResult)
|
foreach($aSearchResults as $iResNum => $aResult)
|
||||||
{
|
{
|
||||||
if ($aResult['aBoundingBox'])
|
|
||||||
{
|
echo '<div class="result" data-position=' . $i . '>';
|
||||||
echo '<div class="result" onClick=\'panToLatLonBoundingBox('.$aResult['lat'].', '.$aResult['lon'];
|
|
||||||
echo ', '.$aResult['aBoundingBox'][0];
|
|
||||||
echo ', '.$aResult['aBoundingBox'][1];
|
|
||||||
echo ', '.$aResult['aBoundingBox'][2];
|
|
||||||
echo ', '.$aResult['aBoundingBox'][3];
|
|
||||||
if (isset($aResult['astext'])) echo ', "'.$aResult['astext'].'"';
|
|
||||||
echo ");'>\n";
|
|
||||||
}
|
|
||||||
elseif (isset($aResult['zoom']))
|
|
||||||
{
|
|
||||||
echo '<div class="result" onClick="panToLatLonZoom('.$aResult['lat'].', '.$aResult['lon'].', '.$aResult['zoom'].');">';
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
echo '<div class="result" onClick="panToLatLon('.$aResult['lat'].', '.$aResult['lon'].');">';
|
|
||||||
}
|
|
||||||
|
|
||||||
echo (isset($aResult['icon'])?'<img alt="icon" src="'.$aResult['icon'].'"/>':'');
|
echo (isset($aResult['icon'])?'<img alt="icon" src="'.$aResult['icon'].'"/>':'');
|
||||||
echo ' <span class="name">'.htmlspecialchars($aResult['name']).'</span>';
|
echo ' <span class="name">'.htmlspecialchars($aResult['name']).'</span>';
|
||||||
echo ' <span class="latlon">'.round($aResult['lat'],3).','.round($aResult['lon'],3).'</span>';
|
// echo ' <span class="latlon">'.round($aResult['lat'],3).','.round($aResult['lon'],3).'</span>';
|
||||||
echo ' <span class="place_id">'.$aResult['place_id'].'</span>';
|
// echo ' <span class="place_id">'.$aResult['place_id'].'</span>';
|
||||||
if (isset($aResult['label']))
|
if (isset($aResult['label']))
|
||||||
echo ' <span class="type">('.$aResult['label'].')</span>';
|
echo ' <span class="type">('.$aResult['label'].')</span>';
|
||||||
else if ($aResult['type'] == 'yes')
|
else if ($aResult['type'] == 'yes')
|
||||||
echo ' <span class="type">('.ucwords(str_replace('_',' ',$aResult['class'])).')</span>';
|
echo ' <span class="type">('.ucwords(str_replace('_',' ',$aResult['class'])).')</span>';
|
||||||
else
|
else
|
||||||
echo ' <span class="type">('.ucwords(str_replace('_',' ',$aResult['type'])).')</span>';
|
echo ' <span class="type">('.ucwords(str_replace('_',' ',$aResult['type'])).')</span>';
|
||||||
echo ' <span class="details">(<a href="details.php?place_id='.$aResult['place_id'].'">details</a>)</span>';
|
echo ' <a class="btn btn-default btn-xs details" href="details.php?place_id='.$aResult['place_id'].'">details</a>';
|
||||||
echo '</div>';
|
echo '</div>';
|
||||||
|
$i = $i+1;
|
||||||
}
|
}
|
||||||
if (sizeof($aSearchResults))
|
if (sizeof($aSearchResults) && $sMoreURL)
|
||||||
{
|
{
|
||||||
if ($sMoreURL)
|
echo '<div class="more"><a class="btn btn-primary" href="'.htmlentities($sMoreURL).'">Search for more results</a></div>';
|
||||||
{
|
|
||||||
echo '<div class="more"><a href="'.htmlentities($sMoreURL).'">Search for more results</a></div>';
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -224,77 +94,71 @@ target="_blank">FAQ</a></td>
|
|||||||
}
|
}
|
||||||
|
|
||||||
?>
|
?>
|
||||||
<div class="disclaimer">Addresses and postcodes are approximate
|
|
||||||
<input type="button" value="Report Problem" onclick="$('report').style.visibility=($('report').style.visibility=='hidden'?'visible':'hidden')"/>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<?php
|
<?php
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
?>
|
?>
|
||||||
|
<div id="intro" class="sidebar">
|
||||||
|
</div>
|
||||||
|
|
||||||
<div id="map"></div>
|
<?php
|
||||||
<div id="report" style="visibility:hidden;"><div style="width:600px;margin:auto;margin-top:60px;">
|
|
||||||
<h2>Report a problem</h2>
|
}
|
||||||
<p>Before reporting problems please read the <a href="http://wiki.openstreetmap.org/wiki/Nominatim">user documentation</a> and <a
|
?>
|
||||||
href="http://wiki.openstreetmap.org/wiki/Nominatim/FAQ">FAQ</a>. If your problem relates to the address of a particular search result please use the 'details' link
|
<div id="map-wrapper">
|
||||||
to check how the address was generated before reporting a problem.</p>
|
<div id="map-position"></div>
|
||||||
<p>Please use <a href="http://trac.openstreetmap.org/newticket?component=nominatim">trac.openstreetmap.org</a> to report problems
|
<div id="map"></div>
|
||||||
making sure to set
|
</div>
|
||||||
the component to 'nominatim'. You can search for existing bug reports <a href="http://trac.openstreetmap.org/query?status=new&status=assigned&status=reopened&component=nominatim&order=priority">here</a>.</p>
|
|
||||||
<p>Please ensure that you include a full description of the problem, including the search query that you used, the problem with the result and, if
|
|
||||||
the problem relates to missing data, the osm id of the item that is missing. Problems that contain enough detail are likely to get looked at before ones that
|
|
||||||
require significant research!</p>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<!--
|
|
||||||
<p>Please use this form to report problems with the search results. Of particular interest are items missing, but please also use this form to
|
|
||||||
report any other problems.</p>
|
|
||||||
<p>If your problem relates to the address of a particular search result please use the 'details' link to check how the address was generated before
|
|
||||||
reporting a problem.</p>
|
|
||||||
<p>If you are reporting a missing result please (if possible) include the OSM ID of the item you where expecting (i.e. node 422162)</p>
|
|
||||||
<form method="post">
|
|
||||||
<table>
|
|
||||||
<tr><th>Your Query:</th><td><input type="hidden" name="report:query" value="<?php echo htmlspecialchars($sQuery); ?>" style="width:500px;"><?php echo htmlspecialchars($sQuery); ?></td></tr>
|
|
||||||
<tr><th>Your Email Address(opt):</th><td><input type="text" name="report:email" value="" style="width:500px;"></td></tr>
|
|
||||||
<tr><th>Description of Problem:</th><td><textarea name="report:description" style="width:500px;height:200px;"></textarea></td></tr>
|
|
||||||
<tr><td colspan="2" class="button"><input type="button" value="Cancel" onclick="$('report').style.visibility='hidden'"><input type="submit" value="Report"></td></tr>
|
|
||||||
</table>
|
|
||||||
</form>
|
|
||||||
<h2>Known Problems</h2>
|
|
||||||
<ul>
|
|
||||||
<li>Countries where missed out of the index</li>
|
|
||||||
<li>Area Polygons relate to the search area - not the address area which would make more sense</li>
|
|
||||||
</ul>
|
|
||||||
-->
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<footer>
|
||||||
|
<p class="disclaimer">
|
||||||
|
Addresses and postcodes are approximate
|
||||||
|
</p>
|
||||||
|
<p class="copyright">
|
||||||
|
© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors
|
||||||
|
</p>
|
||||||
|
</footer>
|
||||||
|
|
||||||
|
<div class="modal fade" id="report-modal">
|
||||||
|
<div class="modal-dialog">
|
||||||
|
<div class="modal-content">
|
||||||
|
<div class="modal-header">
|
||||||
|
<button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">×</span></button>
|
||||||
|
<h4 class="modal-title">Report a problem</h4>
|
||||||
|
</div>
|
||||||
|
<div class="modal-body">
|
||||||
|
<?php include(CONST_BasePath.'/lib/template/includes/report-errors.php'); ?>
|
||||||
|
</div>
|
||||||
|
<div class="modal-footer">
|
||||||
|
<button type="button" class="btn btn-default" data-dismiss="modal">OK</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
init();
|
<?php
|
||||||
<?php
|
|
||||||
foreach($aSearchResults as $iResNum => $aResult)
|
|
||||||
{
|
|
||||||
if ($aResult['aBoundingBox'])
|
|
||||||
{
|
|
||||||
echo 'panToLatLonBoundingBox('.$aResult['lat'].', '.$aResult['lon'];
|
|
||||||
echo ', '.$aResult['aBoundingBox'][0];
|
|
||||||
echo ', '.$aResult['aBoundingBox'][1];
|
|
||||||
echo ', '.$aResult['aBoundingBox'][2];
|
|
||||||
echo ', '.$aResult['aBoundingBox'][3];
|
|
||||||
if (isset($aResult['astext'])) echo ", '".$aResult['astext']."'";
|
|
||||||
echo ');'."\n";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
echo 'panToLatLonZoom('.$fLat.', '.$fLon.', '.$iZoom.');'."\n";
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if (!sizeof($aSearchResults))
|
|
||||||
{
|
|
||||||
echo 'panToLatLonZoom('.$fLat.', '.$fLon.', '.$iZoom.');'."\n";
|
|
||||||
}
|
|
||||||
?>
|
|
||||||
</script>
|
|
||||||
</body>
|
|
||||||
|
|
||||||
|
$aNominatimMapInit = [
|
||||||
|
'zoom' => $iZoom,
|
||||||
|
'lat' => $fLat,
|
||||||
|
'lon' => $fLon
|
||||||
|
];
|
||||||
|
echo 'var nominatim_map_init = ' . json_encode($aNominatimMapInit, JSON_PRETTY_PRINT) . ';';
|
||||||
|
|
||||||
|
$aNominatimResults = [];
|
||||||
|
echo 'var nominatim_results = ' . json_encode($aSearchResults, JSON_PRETTY_PRINT) . ';';
|
||||||
|
?>
|
||||||
|
</script>
|
||||||
|
<?php include(CONST_BasePath.'/lib/template/includes/html-footer.php'); ?>
|
||||||
|
|
||||||
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|||||||
10
settings/local-vagrant.php
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
<?php
|
||||||
|
// General settings
|
||||||
|
// @define('CONST_Database_DSN', 'pgsql://@/nominatim');
|
||||||
|
@define('CONST_Database_DSN', 'pgsql://postgres@localhost:9999/nominatim');
|
||||||
|
// Paths
|
||||||
|
@define('CONST_Postgresql_Version', '9.3');
|
||||||
|
@define('CONST_Postgis_Version', '2.1');
|
||||||
|
// Website settings
|
||||||
|
@define('CONST_Website_BaseURL', 'http://localhost:8089/nominatim/');
|
||||||
|
|
||||||
14
website/css/bootstrap-theme.min.css
vendored
Executable file
14
website/css/bootstrap.min.css
vendored
Executable file
480
website/css/leaflet.css
Normal file
@@ -0,0 +1,480 @@
|
|||||||
|
/* http://cdnjs.cloudflare.com/ajax/libs/leaflet/0.7.3/leaflet.css */
|
||||||
|
|
||||||
|
/* required styles */
|
||||||
|
|
||||||
|
.leaflet-map-pane,
|
||||||
|
.leaflet-tile,
|
||||||
|
.leaflet-marker-icon,
|
||||||
|
.leaflet-marker-shadow,
|
||||||
|
.leaflet-tile-pane,
|
||||||
|
.leaflet-tile-container,
|
||||||
|
.leaflet-overlay-pane,
|
||||||
|
.leaflet-shadow-pane,
|
||||||
|
.leaflet-marker-pane,
|
||||||
|
.leaflet-popup-pane,
|
||||||
|
.leaflet-overlay-pane svg,
|
||||||
|
.leaflet-zoom-box,
|
||||||
|
.leaflet-image-layer,
|
||||||
|
.leaflet-layer {
|
||||||
|
position: absolute;
|
||||||
|
left: 0;
|
||||||
|
top: 0;
|
||||||
|
}
|
||||||
|
.leaflet-container {
|
||||||
|
overflow: hidden;
|
||||||
|
-ms-touch-action: none;
|
||||||
|
}
|
||||||
|
.leaflet-tile,
|
||||||
|
.leaflet-marker-icon,
|
||||||
|
.leaflet-marker-shadow {
|
||||||
|
-webkit-user-select: none;
|
||||||
|
-moz-user-select: none;
|
||||||
|
user-select: none;
|
||||||
|
-webkit-user-drag: none;
|
||||||
|
}
|
||||||
|
.leaflet-marker-icon,
|
||||||
|
.leaflet-marker-shadow {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
/* map is broken in FF if you have max-width: 100% on tiles */
|
||||||
|
.leaflet-container img {
|
||||||
|
max-width: none !important;
|
||||||
|
}
|
||||||
|
/* stupid Android 2 doesn't understand "max-width: none" properly */
|
||||||
|
.leaflet-container img.leaflet-image-layer {
|
||||||
|
max-width: 15000px !important;
|
||||||
|
}
|
||||||
|
.leaflet-tile {
|
||||||
|
filter: inherit;
|
||||||
|
visibility: hidden;
|
||||||
|
}
|
||||||
|
.leaflet-tile-loaded {
|
||||||
|
visibility: inherit;
|
||||||
|
}
|
||||||
|
.leaflet-zoom-box {
|
||||||
|
width: 0;
|
||||||
|
height: 0;
|
||||||
|
}
|
||||||
|
/* workaround for https://bugzilla.mozilla.org/show_bug.cgi?id=888319 */
|
||||||
|
.leaflet-overlay-pane svg {
|
||||||
|
-moz-user-select: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-tile-pane { z-index: 2; }
|
||||||
|
.leaflet-objects-pane { z-index: 3; }
|
||||||
|
.leaflet-overlay-pane { z-index: 4; }
|
||||||
|
.leaflet-shadow-pane { z-index: 5; }
|
||||||
|
.leaflet-marker-pane { z-index: 6; }
|
||||||
|
.leaflet-popup-pane { z-index: 7; }
|
||||||
|
|
||||||
|
.leaflet-vml-shape {
|
||||||
|
width: 1px;
|
||||||
|
height: 1px;
|
||||||
|
}
|
||||||
|
.lvml {
|
||||||
|
behavior: url(#default#VML);
|
||||||
|
display: inline-block;
|
||||||
|
position: absolute;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* control positioning */
|
||||||
|
|
||||||
|
.leaflet-control {
|
||||||
|
position: relative;
|
||||||
|
z-index: 7;
|
||||||
|
pointer-events: auto;
|
||||||
|
}
|
||||||
|
.leaflet-top,
|
||||||
|
.leaflet-bottom {
|
||||||
|
position: absolute;
|
||||||
|
z-index: 1000;
|
||||||
|
pointer-events: none;
|
||||||
|
}
|
||||||
|
.leaflet-top {
|
||||||
|
top: 0;
|
||||||
|
}
|
||||||
|
.leaflet-right {
|
||||||
|
right: 0;
|
||||||
|
}
|
||||||
|
.leaflet-bottom {
|
||||||
|
bottom: 0;
|
||||||
|
}
|
||||||
|
.leaflet-left {
|
||||||
|
left: 0;
|
||||||
|
}
|
||||||
|
.leaflet-control {
|
||||||
|
float: left;
|
||||||
|
clear: both;
|
||||||
|
}
|
||||||
|
.leaflet-right .leaflet-control {
|
||||||
|
float: right;
|
||||||
|
}
|
||||||
|
.leaflet-top .leaflet-control {
|
||||||
|
margin-top: 10px;
|
||||||
|
}
|
||||||
|
.leaflet-bottom .leaflet-control {
|
||||||
|
margin-bottom: 10px;
|
||||||
|
}
|
||||||
|
.leaflet-left .leaflet-control {
|
||||||
|
margin-left: 10px;
|
||||||
|
}
|
||||||
|
.leaflet-right .leaflet-control {
|
||||||
|
margin-right: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* zoom and fade animations */
|
||||||
|
|
||||||
|
.leaflet-fade-anim .leaflet-tile,
|
||||||
|
.leaflet-fade-anim .leaflet-popup {
|
||||||
|
opacity: 0;
|
||||||
|
-webkit-transition: opacity 0.2s linear;
|
||||||
|
-moz-transition: opacity 0.2s linear;
|
||||||
|
-o-transition: opacity 0.2s linear;
|
||||||
|
transition: opacity 0.2s linear;
|
||||||
|
}
|
||||||
|
.leaflet-fade-anim .leaflet-tile-loaded,
|
||||||
|
.leaflet-fade-anim .leaflet-map-pane .leaflet-popup {
|
||||||
|
opacity: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-zoom-anim .leaflet-zoom-animated {
|
||||||
|
-webkit-transition: -webkit-transform 0.25s cubic-bezier(0,0,0.25,1);
|
||||||
|
-moz-transition: -moz-transform 0.25s cubic-bezier(0,0,0.25,1);
|
||||||
|
-o-transition: -o-transform 0.25s cubic-bezier(0,0,0.25,1);
|
||||||
|
transition: transform 0.25s cubic-bezier(0,0,0.25,1);
|
||||||
|
}
|
||||||
|
.leaflet-zoom-anim .leaflet-tile,
|
||||||
|
.leaflet-pan-anim .leaflet-tile,
|
||||||
|
.leaflet-touching .leaflet-zoom-animated {
|
||||||
|
-webkit-transition: none;
|
||||||
|
-moz-transition: none;
|
||||||
|
-o-transition: none;
|
||||||
|
transition: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-zoom-anim .leaflet-zoom-hide {
|
||||||
|
visibility: hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* cursors */
|
||||||
|
|
||||||
|
.leaflet-clickable {
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
.leaflet-container {
|
||||||
|
cursor: -webkit-grab;
|
||||||
|
cursor: -moz-grab;
|
||||||
|
}
|
||||||
|
.leaflet-popup-pane,
|
||||||
|
.leaflet-control {
|
||||||
|
cursor: auto;
|
||||||
|
}
|
||||||
|
.leaflet-dragging .leaflet-container,
|
||||||
|
.leaflet-dragging .leaflet-clickable {
|
||||||
|
cursor: move;
|
||||||
|
cursor: -webkit-grabbing;
|
||||||
|
cursor: -moz-grabbing;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* visual tweaks */
|
||||||
|
|
||||||
|
.leaflet-container {
|
||||||
|
background: #ddd;
|
||||||
|
outline: 0;
|
||||||
|
}
|
||||||
|
.leaflet-container a {
|
||||||
|
color: #0078A8;
|
||||||
|
}
|
||||||
|
.leaflet-container a.leaflet-active {
|
||||||
|
outline: 2px solid orange;
|
||||||
|
}
|
||||||
|
.leaflet-zoom-box {
|
||||||
|
border: 2px dotted #38f;
|
||||||
|
background: rgba(255,255,255,0.5);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* general typography */
|
||||||
|
.leaflet-container {
|
||||||
|
font: 12px/1.5 "Helvetica Neue", Arial, Helvetica, sans-serif;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* general toolbar styles */
|
||||||
|
|
||||||
|
.leaflet-bar {
|
||||||
|
box-shadow: 0 1px 5px rgba(0,0,0,0.65);
|
||||||
|
border-radius: 4px;
|
||||||
|
}
|
||||||
|
.leaflet-bar a,
|
||||||
|
.leaflet-bar a:hover {
|
||||||
|
background-color: #fff;
|
||||||
|
border-bottom: 1px solid #ccc;
|
||||||
|
width: 26px;
|
||||||
|
height: 26px;
|
||||||
|
line-height: 26px;
|
||||||
|
display: block;
|
||||||
|
text-align: center;
|
||||||
|
text-decoration: none;
|
||||||
|
color: black;
|
||||||
|
}
|
||||||
|
.leaflet-bar a,
|
||||||
|
.leaflet-control-layers-toggle {
|
||||||
|
background-position: 50% 50%;
|
||||||
|
background-repeat: no-repeat;
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
.leaflet-bar a:hover {
|
||||||
|
background-color: #f4f4f4;
|
||||||
|
}
|
||||||
|
.leaflet-bar a:first-child {
|
||||||
|
border-top-left-radius: 4px;
|
||||||
|
border-top-right-radius: 4px;
|
||||||
|
}
|
||||||
|
.leaflet-bar a:last-child {
|
||||||
|
border-bottom-left-radius: 4px;
|
||||||
|
border-bottom-right-radius: 4px;
|
||||||
|
border-bottom: none;
|
||||||
|
}
|
||||||
|
.leaflet-bar a.leaflet-disabled {
|
||||||
|
cursor: default;
|
||||||
|
background-color: #f4f4f4;
|
||||||
|
color: #bbb;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-touch .leaflet-bar a {
|
||||||
|
width: 30px;
|
||||||
|
height: 30px;
|
||||||
|
line-height: 30px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* zoom control */
|
||||||
|
|
||||||
|
.leaflet-control-zoom-in,
|
||||||
|
.leaflet-control-zoom-out {
|
||||||
|
font: bold 18px 'Lucida Console', Monaco, monospace;
|
||||||
|
text-indent: 1px;
|
||||||
|
}
|
||||||
|
.leaflet-control-zoom-out {
|
||||||
|
font-size: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-touch .leaflet-control-zoom-in {
|
||||||
|
font-size: 22px;
|
||||||
|
}
|
||||||
|
.leaflet-touch .leaflet-control-zoom-out {
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* layers control */
|
||||||
|
|
||||||
|
.leaflet-control-layers {
|
||||||
|
box-shadow: 0 1px 5px rgba(0,0,0,0.4);
|
||||||
|
background: #fff;
|
||||||
|
border-radius: 5px;
|
||||||
|
}
|
||||||
|
.leaflet-control-layers-toggle {
|
||||||
|
background-image: url(images/layers.png);
|
||||||
|
width: 36px;
|
||||||
|
height: 36px;
|
||||||
|
}
|
||||||
|
.leaflet-retina .leaflet-control-layers-toggle {
|
||||||
|
background-image: url(images/layers-2x.png);
|
||||||
|
background-size: 26px 26px;
|
||||||
|
}
|
||||||
|
.leaflet-touch .leaflet-control-layers-toggle {
|
||||||
|
width: 44px;
|
||||||
|
height: 44px;
|
||||||
|
}
|
||||||
|
.leaflet-control-layers .leaflet-control-layers-list,
|
||||||
|
.leaflet-control-layers-expanded .leaflet-control-layers-toggle {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.leaflet-control-layers-expanded .leaflet-control-layers-list {
|
||||||
|
display: block;
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
.leaflet-control-layers-expanded {
|
||||||
|
padding: 6px 10px 6px 6px;
|
||||||
|
color: #333;
|
||||||
|
background: #fff;
|
||||||
|
}
|
||||||
|
.leaflet-control-layers-selector {
|
||||||
|
margin-top: 2px;
|
||||||
|
position: relative;
|
||||||
|
top: 1px;
|
||||||
|
}
|
||||||
|
.leaflet-control-layers label {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
.leaflet-control-layers-separator {
|
||||||
|
height: 0;
|
||||||
|
border-top: 1px solid #ddd;
|
||||||
|
margin: 5px -10px 5px -6px;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* attribution and scale controls */
|
||||||
|
|
||||||
|
.leaflet-container .leaflet-control-attribution {
|
||||||
|
background: #fff;
|
||||||
|
background: rgba(255, 255, 255, 0.7);
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
.leaflet-control-attribution,
|
||||||
|
.leaflet-control-scale-line {
|
||||||
|
padding: 0 5px;
|
||||||
|
color: #333;
|
||||||
|
}
|
||||||
|
.leaflet-control-attribution a {
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
.leaflet-control-attribution a:hover {
|
||||||
|
text-decoration: underline;
|
||||||
|
}
|
||||||
|
.leaflet-container .leaflet-control-attribution,
|
||||||
|
.leaflet-container .leaflet-control-scale {
|
||||||
|
font-size: 11px;
|
||||||
|
}
|
||||||
|
.leaflet-left .leaflet-control-scale {
|
||||||
|
margin-left: 5px;
|
||||||
|
}
|
||||||
|
.leaflet-bottom .leaflet-control-scale {
|
||||||
|
margin-bottom: 5px;
|
||||||
|
}
|
||||||
|
.leaflet-control-scale-line {
|
||||||
|
border: 2px solid #777;
|
||||||
|
border-top: none;
|
||||||
|
line-height: 1.1;
|
||||||
|
padding: 2px 5px 1px;
|
||||||
|
font-size: 11px;
|
||||||
|
white-space: nowrap;
|
||||||
|
overflow: hidden;
|
||||||
|
-moz-box-sizing: content-box;
|
||||||
|
box-sizing: content-box;
|
||||||
|
|
||||||
|
background: #fff;
|
||||||
|
background: rgba(255, 255, 255, 0.5);
|
||||||
|
}
|
||||||
|
.leaflet-control-scale-line:not(:first-child) {
|
||||||
|
border-top: 2px solid #777;
|
||||||
|
border-bottom: none;
|
||||||
|
margin-top: -2px;
|
||||||
|
}
|
||||||
|
.leaflet-control-scale-line:not(:first-child):not(:last-child) {
|
||||||
|
border-bottom: 2px solid #777;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-touch .leaflet-control-attribution,
|
||||||
|
.leaflet-touch .leaflet-control-layers,
|
||||||
|
.leaflet-touch .leaflet-bar {
|
||||||
|
box-shadow: none;
|
||||||
|
}
|
||||||
|
.leaflet-touch .leaflet-control-layers,
|
||||||
|
.leaflet-touch .leaflet-bar {
|
||||||
|
border: 2px solid rgba(0,0,0,0.2);
|
||||||
|
background-clip: padding-box;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* popup */
|
||||||
|
|
||||||
|
.leaflet-popup {
|
||||||
|
position: absolute;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
.leaflet-popup-content-wrapper {
|
||||||
|
padding: 1px;
|
||||||
|
text-align: left;
|
||||||
|
border-radius: 12px;
|
||||||
|
}
|
||||||
|
.leaflet-popup-content {
|
||||||
|
margin: 13px 19px;
|
||||||
|
line-height: 1.4;
|
||||||
|
}
|
||||||
|
.leaflet-popup-content p {
|
||||||
|
margin: 18px 0;
|
||||||
|
}
|
||||||
|
.leaflet-popup-tip-container {
|
||||||
|
margin: 0 auto;
|
||||||
|
width: 40px;
|
||||||
|
height: 20px;
|
||||||
|
position: relative;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
.leaflet-popup-tip {
|
||||||
|
width: 17px;
|
||||||
|
height: 17px;
|
||||||
|
padding: 1px;
|
||||||
|
|
||||||
|
margin: -10px auto 0;
|
||||||
|
|
||||||
|
-webkit-transform: rotate(45deg);
|
||||||
|
-moz-transform: rotate(45deg);
|
||||||
|
-ms-transform: rotate(45deg);
|
||||||
|
-o-transform: rotate(45deg);
|
||||||
|
transform: rotate(45deg);
|
||||||
|
}
|
||||||
|
.leaflet-popup-content-wrapper,
|
||||||
|
.leaflet-popup-tip {
|
||||||
|
background: white;
|
||||||
|
|
||||||
|
box-shadow: 0 3px 14px rgba(0,0,0,0.4);
|
||||||
|
}
|
||||||
|
.leaflet-container a.leaflet-popup-close-button {
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
right: 0;
|
||||||
|
padding: 4px 4px 0 0;
|
||||||
|
text-align: center;
|
||||||
|
width: 18px;
|
||||||
|
height: 14px;
|
||||||
|
font: 16px/14px Tahoma, Verdana, sans-serif;
|
||||||
|
color: #c3c3c3;
|
||||||
|
text-decoration: none;
|
||||||
|
font-weight: bold;
|
||||||
|
background: transparent;
|
||||||
|
}
|
||||||
|
.leaflet-container a.leaflet-popup-close-button:hover {
|
||||||
|
color: #999;
|
||||||
|
}
|
||||||
|
.leaflet-popup-scrolled {
|
||||||
|
overflow: auto;
|
||||||
|
border-bottom: 1px solid #ddd;
|
||||||
|
border-top: 1px solid #ddd;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-oldie .leaflet-popup-content-wrapper {
|
||||||
|
zoom: 1;
|
||||||
|
}
|
||||||
|
.leaflet-oldie .leaflet-popup-tip {
|
||||||
|
width: 24px;
|
||||||
|
margin: 0 auto;
|
||||||
|
|
||||||
|
-ms-filter: "progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";
|
||||||
|
filter: progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678);
|
||||||
|
}
|
||||||
|
.leaflet-oldie .leaflet-popup-tip-container {
|
||||||
|
margin-top: -1px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.leaflet-oldie .leaflet-control-zoom,
|
||||||
|
.leaflet-oldie .leaflet-control-layers,
|
||||||
|
.leaflet-oldie .leaflet-popup-content-wrapper,
|
||||||
|
.leaflet-oldie .leaflet-popup-tip {
|
||||||
|
border: 1px solid #999;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* div icon */
|
||||||
|
|
||||||
|
.leaflet-div-icon {
|
||||||
|
background: #fff;
|
||||||
|
border: 1px solid #666;
|
||||||
|
}
|
||||||
@@ -1,166 +1,154 @@
|
|||||||
* {-moz-box-sizing: border-box;}
|
header {
|
||||||
body {
|
/*position: fixed;*/
|
||||||
margin:0px;
|
width: 100%;
|
||||||
padding:0px;
|
padding: 15px;
|
||||||
overflow: hidden;
|
z-index: 5;
|
||||||
background:#ffffff;
|
|
||||||
height: 100%;
|
|
||||||
font: normal 12px/15px arial,sans-serif;
|
|
||||||
}
|
|
||||||
#seachheader {
|
|
||||||
position:absolute;
|
|
||||||
z-index:5;
|
|
||||||
top:0px;
|
|
||||||
left:0px;
|
|
||||||
width:100%;
|
|
||||||
height:38px;
|
|
||||||
background:#F0F7FF;
|
|
||||||
border-bottom: 2px solid #75ADFF;
|
|
||||||
}
|
|
||||||
#q {
|
|
||||||
width:300px;
|
|
||||||
}
|
|
||||||
#seachheaderfade1, #seachheaderfade2, #seachheaderfade3, #seachheaderfade4{
|
|
||||||
position:absolute;
|
|
||||||
z-index:4;
|
|
||||||
top:0px;
|
|
||||||
left:0px;
|
|
||||||
width:100%;
|
|
||||||
opacity: 0.15;
|
|
||||||
filter: alpha(opacity = 15);
|
|
||||||
background:#000000;
|
|
||||||
border: 1px solid #000000;
|
|
||||||
}
|
|
||||||
#seachheaderfade1{
|
|
||||||
height:39px;
|
|
||||||
}
|
|
||||||
#seachheaderfade2{
|
|
||||||
height:40px;
|
|
||||||
}
|
|
||||||
#seachheaderfade3{
|
|
||||||
height:41px;
|
|
||||||
}
|
|
||||||
#seachheaderfade4{
|
|
||||||
height:42px;
|
|
||||||
}
|
|
||||||
#searchresultsfade1, #searchresultsfade2, #searchresultsfade3, #searchresultsfade4 {
|
|
||||||
position:absolute;
|
|
||||||
z-index:2;
|
|
||||||
top:0px;
|
|
||||||
left:200px;
|
|
||||||
height: 100%;
|
|
||||||
opacity: 0.2;
|
|
||||||
filter: alpha(opacity = 20);
|
|
||||||
background:#ffffff;
|
|
||||||
border: 1px solid #ffffff;
|
|
||||||
}
|
|
||||||
#searchresultsfade1{
|
|
||||||
width:1px;
|
|
||||||
}
|
|
||||||
#searchresultsfade2{
|
|
||||||
width:2px;
|
|
||||||
}
|
|
||||||
#searchresultsfade3{
|
|
||||||
width:3px;
|
|
||||||
}
|
|
||||||
#searchresultsfade4{
|
|
||||||
width:4px;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#searchresults{
|
header .brand {
|
||||||
position:absolute;
|
white-space: nowrap;
|
||||||
z-index:3;
|
}
|
||||||
top:41px;
|
|
||||||
width:200px;
|
header .brand a:hover{
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
header .brand h1 {
|
||||||
|
display: inline;
|
||||||
|
font-size: 1.5em;
|
||||||
|
color: #333;
|
||||||
|
}
|
||||||
|
|
||||||
|
header .brand > img {
|
||||||
|
display: inline-block;
|
||||||
|
margin-right: 5px;
|
||||||
|
margin-top: -5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
header #last-updated {
|
||||||
|
font-size: 0.7em;
|
||||||
|
white-space: nowrap;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
form {
|
||||||
|
width: 100%;
|
||||||
|
padding: 1em 15px;
|
||||||
|
}
|
||||||
|
form #q {
|
||||||
|
min-width: 500px;
|
||||||
|
}
|
||||||
|
form .checkbox-inline {
|
||||||
|
margin-left: 10px;
|
||||||
|
}
|
||||||
|
form label {
|
||||||
|
font-weight: normal;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sidebar {
|
||||||
|
width: 25%;
|
||||||
|
padding: 10px;
|
||||||
|
padding-top: 0;
|
||||||
|
display: inline-block;
|
||||||
|
float: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#map-wrapper {
|
||||||
|
position: relative;
|
||||||
|
min-height: 700px;
|
||||||
|
width: 75%;
|
||||||
|
padding-right: 20px;
|
||||||
|
display: inline-block;
|
||||||
|
float: left;
|
||||||
|
}
|
||||||
|
|
||||||
|
#map {
|
||||||
height: 100%;
|
height: 100%;
|
||||||
background:#ffffff;
|
|
||||||
border: 1px solid #ffffff;
|
|
||||||
overflow: auto;
|
|
||||||
}
|
|
||||||
#map{
|
|
||||||
position:absolute;
|
|
||||||
z-index:1;
|
|
||||||
top:38px;
|
|
||||||
left:200px;
|
|
||||||
width:100%;
|
|
||||||
height:100%;
|
|
||||||
background:#eee;
|
background:#eee;
|
||||||
}
|
}
|
||||||
#report{
|
|
||||||
position:absolute;
|
#map-position {
|
||||||
z-index:2;
|
position: absolute;
|
||||||
top:38px;
|
top: 0;
|
||||||
left:200px;
|
right: 20px;
|
||||||
width:100%;
|
padding: 0 5px;
|
||||||
height:100%;
|
color: #333;
|
||||||
background:#eee;
|
font-size: 11px;
|
||||||
font: normal 12px/15px arial,sans-serif;
|
background-color: rgba(255, 255, 255, 0.7);
|
||||||
padding:20px;
|
z-index: 100;
|
||||||
}
|
|
||||||
#report table {
|
|
||||||
margin-left:20px;
|
|
||||||
}
|
|
||||||
#report th {
|
|
||||||
vertical-align:top;
|
|
||||||
text-align:left;
|
|
||||||
}
|
|
||||||
#report td.button {
|
|
||||||
text-align:right;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.result {
|
.result {
|
||||||
margin:5px;
|
font-size: 0.8em;
|
||||||
margin-bottom:0px;
|
margin: 5px;
|
||||||
padding:2px;
|
margin-top:0px;
|
||||||
padding-left:4px;
|
padding: 4px 8px;
|
||||||
padding-right:4px;
|
border-radius: 2px;
|
||||||
border-radius: 5px;
|
|
||||||
-moz-border-radius: 5px;
|
|
||||||
-webkit-border-radius: 5px;
|
|
||||||
background:#F0F7FF;
|
background:#F0F7FF;
|
||||||
border: 2px solid #D7E7FF;
|
border: 2px solid #D7E7FF;
|
||||||
font: normal 12px/15px arial,sans-serif;
|
|
||||||
cursor:pointer;
|
cursor:pointer;
|
||||||
}
|
min-height: 5em;
|
||||||
.result img{
|
|
||||||
float:right;
|
|
||||||
}
|
|
||||||
.result .latlon{
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
.result .place_id{
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
.result .type{
|
|
||||||
color: #999;
|
|
||||||
text-align:center;
|
|
||||||
font: normal 9px/10px arial,sans-serif;
|
|
||||||
padding-top:4px;
|
|
||||||
}
|
|
||||||
.result .details, .result .details a{
|
|
||||||
color: #999;
|
|
||||||
text-align:center;
|
|
||||||
font: normal 9px/10px arial,sans-serif;
|
|
||||||
padding-top:4px;
|
|
||||||
}
|
|
||||||
.noresults{
|
|
||||||
color: #000;
|
|
||||||
text-align:center;
|
|
||||||
font: normal 12px arial,sans-serif;
|
|
||||||
padding-top:4px;
|
|
||||||
}
|
|
||||||
.more{
|
|
||||||
color: #ccc;
|
|
||||||
text-align:center;
|
|
||||||
padding-top:4px;
|
|
||||||
}
|
|
||||||
.disclaimer{
|
|
||||||
color: #ccc;
|
|
||||||
text-align:center;
|
|
||||||
font: normal 9px/10px arial,sans-serif;
|
|
||||||
padding-top:4px;
|
|
||||||
}
|
|
||||||
form{
|
|
||||||
margin:0px;
|
|
||||||
padding:0px;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.result.highlight {
|
||||||
|
background-color: #D9E7F7;
|
||||||
|
border-color: #9DB9E4;
|
||||||
|
}
|
||||||
|
.result.highlight .details {
|
||||||
|
margin: 10px auto;
|
||||||
|
display: block;
|
||||||
|
max-width: 10em;
|
||||||
|
}
|
||||||
|
.result img{
|
||||||
|
float: right;
|
||||||
|
}
|
||||||
|
.result .type{
|
||||||
|
color: gray;
|
||||||
|
font-size: 0.8em;
|
||||||
|
}
|
||||||
|
.result .details {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.noresults{
|
||||||
|
text-align: center;
|
||||||
|
padding: 1em;
|
||||||
|
}
|
||||||
|
|
||||||
|
.more{
|
||||||
|
text-align:center;
|
||||||
|
margin-top: 1em;
|
||||||
|
}
|
||||||
|
|
||||||
|
footer {
|
||||||
|
text-align: center;
|
||||||
|
padding: 2em 0;
|
||||||
|
font-size: 0.8em;
|
||||||
|
clear: both;
|
||||||
|
color: #333;
|
||||||
|
}
|
||||||
|
|
||||||
|
footer p {
|
||||||
|
margin: 1em;
|
||||||
|
}
|
||||||
|
|
||||||
|
@media (max-width: 768px) {
|
||||||
|
#content {
|
||||||
|
top: 0;
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
#map-wrapper {
|
||||||
|
width: 100%;
|
||||||
|
max-height: 300px;
|
||||||
|
padding: 20px;
|
||||||
|
}
|
||||||
|
#map-position {
|
||||||
|
top: 20px;
|
||||||
|
right: 20px;
|
||||||
|
}
|
||||||
|
.sidebar {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
BIN
website/images/crosshair.png
Normal file
|
After Width: | Height: | Size: 140 B |
BIN
website/images/layers-2x.png
Normal file
|
After Width: | Height: | Size: 2.8 KiB |
BIN
website/images/layers.png
Normal file
|
After Width: | Height: | Size: 1.5 KiB |
BIN
website/images/osm_logo.120px.png
Normal file
|
After Width: | Height: | Size: 27 KiB |
11
website/js/bootstrap.min.js
vendored
Executable file
BIN
website/js/images/marker-icon-2x.png
Normal file
|
After Width: | Height: | Size: 3.9 KiB |
BIN
website/js/images/marker-icon.png
Normal file
|
After Width: | Height: | Size: 1.7 KiB |
BIN
website/js/images/marker-shadow.png
Normal file
|
After Width: | Height: | Size: 797 B |
5
website/js/jquery.min.js
vendored
Normal file
1
website/js/leaflet-omnivore.min.js
vendored
Normal file
9
website/js/leaflet.min.js
vendored
Normal file
151
website/js/nominatim-ui.js
Normal file
@@ -0,0 +1,151 @@
|
|||||||
|
var map;
|
||||||
|
var last_click_latlng;
|
||||||
|
|
||||||
|
jQuery(document).on('ready', function(){
|
||||||
|
$('#q').focus();
|
||||||
|
|
||||||
|
map = new L.map('map', {
|
||||||
|
center: [nominatim_map_init.lat, nominatim_map_init.lon],
|
||||||
|
zoom: nominatim_map_init.zoom,
|
||||||
|
attributionControl: false,
|
||||||
|
scrollWheelZoom: false,
|
||||||
|
touchZoom: false,
|
||||||
|
});
|
||||||
|
|
||||||
|
L.tileLayer('http://{s}.tile.osm.org/{z}/{x}/{y}.png', {
|
||||||
|
// attribution: '© <a href="http://osm.org/copyright">OpenStreetMap</a> contributors'
|
||||||
|
}).addTo(map);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
function display_map_position(mouse_lat_lng){
|
||||||
|
|
||||||
|
html_mouse = "mouse position " + (mouse_lat_lng ? [mouse_lat_lng.lat.toFixed(5), mouse_lat_lng.lng.toFixed(5)].join(',') : '-');
|
||||||
|
html_click = "last click: " + (last_click_latlng ? [last_click_latlng.lat.toFixed(5),last_click_latlng.lng.toFixed(5)].join(',') : '-');
|
||||||
|
|
||||||
|
html_center =
|
||||||
|
"map center: " +
|
||||||
|
map.getCenter().lat.toFixed(5) + ',' + map.getCenter().lng.toFixed(5) +
|
||||||
|
" <a target='_blank' href='" + map_link_to_osm() + "'>view on osm.org</a>";
|
||||||
|
|
||||||
|
html_viewbox = "viewbox: " + map_viewbox_as_string();
|
||||||
|
|
||||||
|
$('#map-position').html([html_center,html_viewbox,html_click,html_mouse].join('<br/>'));
|
||||||
|
$('input#use_viewbox').trigger('change');
|
||||||
|
}
|
||||||
|
|
||||||
|
map.on('move', function(e) {
|
||||||
|
display_map_position();
|
||||||
|
});
|
||||||
|
|
||||||
|
map.on('mousemove', function(e) {
|
||||||
|
display_map_position(e.latlng);
|
||||||
|
});
|
||||||
|
|
||||||
|
map.on('click', function(e) {
|
||||||
|
last_click_latlng = e.latlng;
|
||||||
|
display_map_position();
|
||||||
|
});
|
||||||
|
|
||||||
|
map.on('load', function(e){
|
||||||
|
display_map_position();
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
$('input#use_viewbox').on('change', function(){
|
||||||
|
$('input[name=viewbox]').val( $(this).prop('checked') ? map_viewbox_as_string() : '');
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
function map_viewbox_as_string() {
|
||||||
|
// since .toBBoxString() doesn't round numbers
|
||||||
|
return [
|
||||||
|
map.getBounds().getSouthWest().lat.toFixed(5),
|
||||||
|
map.getBounds().getSouthWest().lng.toFixed(5),
|
||||||
|
map.getBounds().getNorthEast().lat.toFixed(5),
|
||||||
|
map.getBounds().getNorthEast().lng.toFixed(5) ].join(',');
|
||||||
|
}
|
||||||
|
function map_link_to_osm(){
|
||||||
|
return "http://openstreetmap.org/#map=" + map.getZoom() + "/" + map.getCenter().lat + "/" + map.getCenter().lng;
|
||||||
|
}
|
||||||
|
|
||||||
|
function get_result_element(position){
|
||||||
|
return $('.result').eq(position);
|
||||||
|
}
|
||||||
|
function marker_for_result(result){
|
||||||
|
return L.marker([result.lat,result.lon], {riseOnHover:true,title:result.name });
|
||||||
|
}
|
||||||
|
function circle_for_result(result){
|
||||||
|
return L.circleMarker([result.lat,result.lon], { radius: 50, weight: 1, fillColor: '#F0F7FF', color: 'red', opacity: 0.75});
|
||||||
|
}
|
||||||
|
|
||||||
|
var layerGroup = new L.layerGroup().addTo(map);
|
||||||
|
function highlight_result(position, bool_focus){
|
||||||
|
var result = nominatim_results[position];
|
||||||
|
if (!result){ return }
|
||||||
|
var result_el = get_result_element(position);
|
||||||
|
|
||||||
|
$('.result').removeClass('highlight');
|
||||||
|
result_el.addClass('highlight');
|
||||||
|
|
||||||
|
layerGroup.clearLayers();
|
||||||
|
|
||||||
|
if (result.aBoundingBox){
|
||||||
|
|
||||||
|
console.log('bounding box, maybe polygon', result);
|
||||||
|
var bounds = [[result.aBoundingBox[0]*1,result.aBoundingBox[2]*1], [result.aBoundingBox[1]*1,result.aBoundingBox[3]*1]];
|
||||||
|
map.fitBounds(bounds);
|
||||||
|
if (result.astext && result.astext.match(/POLY/) ){
|
||||||
|
var layer = omnivore.wkt.parse(result.astext);
|
||||||
|
layerGroup.addLayer(layer);
|
||||||
|
// layer.addTo(map);
|
||||||
|
// addedLayers.push(layer);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
var layer = L.rectangle(bounds, {color: "#ff7800", weight: 1} );
|
||||||
|
layerGroup.addLayer(layer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// console.log('lat,lon,zoom');
|
||||||
|
map.panTo([result.lat,result.lon], result.zoom || nominatim_map_init.zoom);
|
||||||
|
var circle = circle_for_result(result);
|
||||||
|
circle.on('click', function(){
|
||||||
|
highlight_result(i);
|
||||||
|
});
|
||||||
|
layerGroup.addLayer(layer);
|
||||||
|
|
||||||
|
// circle.addTo(map);
|
||||||
|
}
|
||||||
|
|
||||||
|
var crosshairIcon = L.icon({
|
||||||
|
iconUrl: 'images/crosshair.png',
|
||||||
|
iconSize: [12, 12],
|
||||||
|
iconAnchor: [6, 6],
|
||||||
|
});
|
||||||
|
var crossMarker = new L.Marker([result.lat,result.lon], { icon: crosshairIcon, clickable: false});
|
||||||
|
layerGroup.addLayer(crossMarker);
|
||||||
|
|
||||||
|
// crossMarker.addTo(map);
|
||||||
|
// addedLayers.push(crossMarker);
|
||||||
|
|
||||||
|
|
||||||
|
if (bool_focus){
|
||||||
|
$('#map').focus();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$.each(nominatim_results, function(i, result){
|
||||||
|
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
$('.result').on('click', function(e){
|
||||||
|
highlight_result($(this).data('position'), true);
|
||||||
|
});
|
||||||
|
|
||||||
|
highlight_result(0, false);
|
||||||
|
|
||||||
|
|
||||||
|
});
|
||||||
@@ -13,7 +13,6 @@
|
|||||||
$fLat = CONST_Default_Lat;
|
$fLat = CONST_Default_Lat;
|
||||||
$fLon = CONST_Default_Lon;
|
$fLon = CONST_Default_Lon;
|
||||||
$iZoom = CONST_Default_Zoom;
|
$iZoom = CONST_Default_Zoom;
|
||||||
$sSuggestionURL = false;
|
|
||||||
|
|
||||||
$oGeocode =& new Geocode($oDB);
|
$oGeocode =& new Geocode($oDB);
|
||||||
|
|
||||||
|
|||||||