2         header("content-type: text/html; charset=UTF-8");
 
   6         <title>OpenStreetMap Nominatim: Search</title>
 
   8         <base href="<?php echo CONST_Website_BaseURL;?>" />
 
   9         <link href="nominatim.xml" rel="search" title="Nominatim Search" type="application/opensearchdescription+xml" />
 
  11         <script src="js/OpenLayers.js"></script>
 
  12         <script src="js/tiles.js"></script>
 
  13         <script src="js/prototype-1.6.0.3.js"></script>
 
  16 * {-moz-box-sizing: border-box;}
 
  23   font: normal 12px/15px arial,sans-serif;
 
  33   border-bottom: 2px solid #75ADFF;
 
  38 #seachheaderfade1, #seachheaderfade2, #seachheaderfade3, #seachheaderfade4{
 
  45   filter: alpha(opacity = 15);
 
  47   border: 1px solid #000000;
 
  61 #searchresultsfade1, #searchresultsfade2, #searchresultsfade3, #searchresultsfade4 {
 
  68   filter: alpha(opacity = 20);
 
  70   border: 1px solid #ffffff;
 
  92   border: 1px solid #ffffff;
 
 112   font: normal 12px/15px arial,sans-serif;
 
 132   -moz-border-radius: 5px;
 
 133   -webkit-border-radius: 5px;
 
 135   border: 2px solid #D7E7FF;
 
 136   font: normal 12px/15px arial,sans-serif;
 
 151   font: normal 9px/10px arial,sans-serif;
 
 154 .result .details, .result .details a{
 
 157   font: normal 9px/10px arial,sans-serif;
 
 163   font: normal 12px arial,sans-serif;
 
 174   font: normal 9px/10px arial,sans-serif;
 
 183         <script type="text/javascript">
 
 187                 function handleResize()
 
 189                         if ($('searchresults'))
 
 191                                 $('map').style.width = (document.documentElement.clientWidth > 0?document.documentElement.clientWidth:document.documentElement.offsetWidth) - 200;
 
 192                                 $('report').style.width = (document.documentElement.clientWidth > 0?document.documentElement.clientWidth:document.documentElement.offsetWidth) - 200;
 
 196                                 $('map').style.width = (document.documentElement.clientWidth > 0?document.documentElement.clientWidth:document.documentElement.offsetWidth) - 0;
 
 197                                 $('map').style.left = 0;
 
 200                         if ($('map')) $('map').style.height = (document.documentElement.clientHeight > 0?document.documentElement.clientHeight:document.documentElement.offsetHeight) - 38;
 
 201                         if ($('searchresults')) $('searchresults').style.height = (document.documentElement.clientHeight > 0?document.documentElement.clientHeight:document.documentElement.offsetHeight) - 38;
 
 202                         if ($('report')) $('report').style.height = (document.documentElement.clientHeight > 0?document.documentElement.clientHeight:document.documentElement.offsetHeight) - 38;
 
 204                 window.onresize = handleResize;
 
 206                 function panToLatLon(lat,lon) {
 
 207                         var lonLat = new OpenLayers.LonLat(lon, lat).transform(new OpenLayers.Projection("EPSG:4326"), map.getProjectionObject());
 
 208                         map.panTo(lonLat, <?php echo $iZoom ?>);
 
 211                 function panToLatLonZoom(lat,lon, zoom) {
 
 212                         var lonLat = new OpenLayers.LonLat(lon, lat).transform(new OpenLayers.Projection("EPSG:4326"), map.getProjectionObject());
 
 213                         if (zoom != map.getZoom())
 
 214                                 map.setCenter(lonLat, zoom);
 
 216                                 map.panTo(lonLat, 10);
 
 219                 function panToLatLonBoundingBox(lat,lon,minlat,maxlat,minlon,maxlon,points) {
 
 220                         var proj_EPSG4326 = new OpenLayers.Projection("EPSG:4326");
 
 221                         var proj_map = map.getProjectionObject();
 
 222                         map.zoomToExtent(new OpenLayers.Bounds(minlon,minlat,maxlon,maxlat).transform(proj_EPSG4326, proj_map));
 
 226                                 strokeColor: "#75ADFF",
 
 227                                 fillColor: "#F0F7FF",
 
 232                         var proj_EPSG4326 = new OpenLayers.Projection("EPSG:4326");
 
 233                         var proj_map = map.getProjectionObject();
 
 236                                 points.each(function(p){
 
 237                                         pointList.push(new OpenLayers.Geometry.Point(p[0],p[1]));
 
 239                                 var linearRing = new OpenLayers.Geometry.LinearRing(pointList).transform(proj_EPSG4326, proj_map);;
 
 240                                 var polygonFeature = new OpenLayers.Feature.Vector(new OpenLayers.Geometry.Polygon([linearRing]),null,style);
 
 241                                 vectorLayer.destroyFeatures();
 
 242                                 vectorLayer.addFeatures([polygonFeature]);
 
 246                                 var lonLat = new OpenLayers.LonLat(lon, lat).transform(new OpenLayers.Projection("EPSG:4326"), map.getProjectionObject());
 
 247                                 var point = new OpenLayers.Geometry.Point(lonLat.lon, lonLat.lat);
 
 248                                 var pointFeature = new OpenLayers.Feature.Vector(point,null,style);
 
 249                                 vectorLayer.destroyFeatures();
 
 250                                 vectorLayer.addFeatures([pointFeature]);
 
 257                         return Math.round(v*n)/n;
 
 262                         return Math.floor(v*n)/n;
 
 267                         return Math.ceil(v*n)/n;
 
 270                 function mapEventMove() {
 
 271                         var proj = new OpenLayers.Projection("EPSG:4326");
 
 272                         var bounds = map.getExtent();
 
 273                         bounds = bounds.transform(map.getProjectionObject(), proj);
 
 274                         $('viewbox').value = floor(bounds.left,2)+','+ceil(bounds.top,2)+','+ceil(bounds.right,2)+','+floor(bounds.bottom,2);
 
 279                         map = new OpenLayers.Map ("map", {
 
 281                                                                                 new OpenLayers.Control.Navigation(),
 
 282                                                                                 new OpenLayers.Control.PanZoomBar(),
 
 283                                                                                 new OpenLayers.Control.MouseDefaults(),
 
 284                                                                                 new OpenLayers.Control.MousePosition(),
 
 285                                                                                 new OpenLayers.Control.Attribution()],
 
 286                 maxExtent: new OpenLayers.Bounds(-20037508.34,-20037508.34,20037508.34,20037508.34),
 
 287                 maxResolution: 156543.0399,
 
 290                 projection: new OpenLayers.Projection("EPSG:900913"),
 
 291                 displayProjection: new OpenLayers.Projection("EPSG:4326"),
 
 293                                                                         "moveend": mapEventMove
 
 296                         map.addLayer(new OpenLayers.Layer.OSM.<?php echo CONST_Tile_Default;?>("Default"));
 
 298                         var layer_style = OpenLayers.Util.extend({}, OpenLayers.Feature.Vector.style['default']);
 
 299                         layer_style.fillOpacity = 0.2;
 
 300                         layer_style.graphicOpacity = 1;
 
 301                         vectorLayer = new OpenLayers.Layer.Vector("Points", {style: layer_style});
 
 302                         map.addLayer(vectorLayer);
 
 304 //                      var lonLat = new OpenLayers.LonLat(<?php echo $fLon ?>, <?php echo $fLat ?>).transform(new OpenLayers.Projection("EPSG:4326"), map.getProjectionObject());
 
 305 //                      map.setCenter (lonLat, <?php echo $iZoom ?>);
 
 308                 function setfocus(field_id) { 
 
 315 <body onload="setfocus('q');">
 
 317         <div id="seachheaderfade1"></div><div id="seachheaderfade2"></div><div id="seachheaderfade3"></div><div id="seachheaderfade4"></div>
 
 319         <div id="seachheader">
 
 320                 <form accept-charset="UTF-8" action="<?php echo CONST_Website_BaseURL; ?>search.php" method="get">
 
 321                         <table border="0" width="100%">
 
 323                                         <td valign="center" style="width:30px;"><img src="images/logo.gif"></td>
 
 324                                         <td valign="center" style="width:400px;"><input id="q" name="q" value="<?php echo htmlspecialchars($sQuery); 
 
 325 ?>" style="width:270px;"><input type="text" id="viewbox" style="width:130px;" name="viewbox"></td>
 
 326                                         <td style="width:80px;"><input type="submit" value="Search"></td>
 
 327 <?php if (CONST_Search_AreaPolygons) { ?>                                       <td style="width:100px;"><input type="checkbox" value="1" name="polygon" <?php if ($bShowPolygons) echo "checked"; ?>> Highlight</td>
 
 328 <td style="text-align:right;">Data: <?php echo $sDataDate; ?></td>
 
 329 <td style="text-align:right;">
 
 330 <a href="http://wiki.openstreetmap.org/wiki/Nominatim" target="_blank">Documentation</a> | <a href="http://wiki.openstreetmap.org/wiki/Nominatim/FAQ" 
 
 331 target="_blank">FAQ</a></td>
 
 333 <?php } ?>                                      <td style="text-align:right;"><?php if ($sQuery) { if ($sReportDescription) {?><div style="text-align:center;"><b>Thank you for your problem report</b></div><?php } else { ?><input type="button" value="Report Problem With Results" onclick="$('report').style.visibility=($('report').style.visibility=='hidden'?'visible':'hidden')"><?php }} ?></td>
 
 340         if ($sQuery || sizeof($aSearchResults))
 
 343         <div id="searchresultsfade1"></div><div id="searchresultsfade2"></div><div id="searchresultsfade3"></div><div id="searchresultsfade4"></div>
 
 344         <div id="searchresults">
 
 348                 echo '<div class="more"><b>Suggest: </b><a href="'.$sSuggestionURL.'"><b>'.$sSuggestion.'</b></a></div>';
 
 350         foreach($aSearchResults as $iResNum => $aResult)
 
 352                 if ($aResult['aBoundingBox'])
 
 354                         echo '<div class="result" onClick=\'panToLatLonBoundingBox('.$aResult['lat'].', '.$aResult['lon'];
 
 355                         echo ', '.$aResult['aBoundingBox'][0];
 
 356                         echo ', '.$aResult['aBoundingBox'][1];
 
 357                         echo ', '.$aResult['aBoundingBox'][2];
 
 358                         echo ', '.$aResult['aBoundingBox'][3];
 
 359                         echo ', '.javascript_renderData($aResult['aPolyPoints']);
 
 362                 elseif (isset($aResult['zoom']))
 
 364                         echo '<div class="result" onClick="panToLatLonZoom('.$aResult['lat'].', '.$aResult['lon'].', '.$aResult['zoom'].');">';
 
 368                         echo '<div class="result" onClick="panToLatLon('.$aResult['lat'].', '.$aResult['lon'].');">';
 
 371                 echo ($aResult['icon']?'<img src="'.$aResult['icon'].'">':'');
 
 372                 echo ' <span class="name">'.$aResult['name'].'</span>';
 
 373                 echo ' <span class="latlon">'.round($aResult['lat'],3).','.round($aResult['lat'],3).'</span>';
 
 374                 echo ' <span class="place_id">'.$aResult['place_id'].'</span>';
 
 375                 if (isset($aResult['label']))
 
 376                         echo ' <span class="type">('.$aResult['label'].')</span>';
 
 378                         echo ' <span class="type">('.ucwords(str_replace('_',' ',$aResult['type'])).')</span>';
 
 379                 echo ' <span class="details">(<a href="details.php?place_id='.$aResult['place_id'].'">details</a>)</span>';
 
 382         if (sizeof($aSearchResults))
 
 386                         echo '<div class="more"><a href="'.$sMoreURL.'">Search for more results</a></div>';
 
 391                 echo '<div class="noresults">No search results found</div>';
 
 395                 <div class="disclaimer">Addresses and postcodes are approximate
 
 396                         <input type="button" value="Report Problem" onclick="$('report').style.visibility=($('report').style.visibility=='hidden'?'visible':'hidden')">
 
 404         <div id="report" style="visibility:hidden;"><div style="width:600px;margin:auto;margin-top:60px;">
 
 405                 <h2>Report a problem</h2>
 
 406                 <p>Before reporting problems please read the <a href="http://wiki.openstreetmap.org/wiki/Nominatim">user documentation</a> and <a 
 
 407 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 
 
 408 to check how the address was generated before reporting a problem.</p>
 
 409                 <p>Please use <a href="http://trac.openstreetmap.org/newticket?component=nominatim">trac.openstreetmap.org</a> to report problems 
 
 411 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>
 
 412                 <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 
 
 413 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 
 
 414 require significant research!</p>
 
 418                 <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 
 
 419 report any other problems.</p>
 
 420                 <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 
 
 421 reporting a problem.</p>
 
 422                 <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>
 
 425                 <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>
 
 426                 <tr><th>Your Email Address(opt):</th><td><input type="text" name="report:email" value="" style="width:500px;"></td></tr>
 
 427                 <tr><th>Description of Problem:</th><td><textarea name="report:description" style="width:500px;height:200px;"></textarea></td></tr>
 
 428                 <tr><td colspan="2" class="button"><input type="button" value="Cancel" onclick="$('report').style.visibility='hidden'"><input type="submit" value="Report"></td></tr>
 
 431                 <h2>Known Problems</h2>
 
 433                 <li>Countries where missed out of the index</li>
 
 434                 <li>Area Polygons relate to the search area - not the address area which would make more sense</li>
 
 439         <script type="text/javascript">
 
 442         foreach($aSearchResults as $iResNum => $aResult)
 
 444                 if ($aResult['aBoundingBox'])
 
 446                         echo 'panToLatLonBoundingBox('.$aResult['lat'].', '.$aResult['lon'];
 
 447                         echo ', '.$aResult['aBoundingBox'][0];
 
 448                         echo ', '.$aResult['aBoundingBox'][1];
 
 449                         echo ', '.$aResult['aBoundingBox'][2];
 
 450                         echo ', '.$aResult['aBoundingBox'][3];
 
 451                         echo ', '.javascript_renderData($aResult['aPolyPoints']);
 
 456                         echo 'panToLatLonZoom('.$fLat.', '.$fLon.', '.$iZoom.');'."\n";
 
 460         if (!sizeof($aSearchResults))
 
 462                 echo 'panToLatLonZoom('.$fLat.', '.$fLon.', '.$iZoom.');'."\n";