// JavaScript Document
    //<![CDATA[
    var map;
    var geocoder;

    function loadmap() {
      if (GBrowserIsCompatible()) {
        geocoder = new GClientGeocoder();
        map = new GMap2(document.getElementById('googlemap'));
        map.addControl(new GSmallMapControl());
        map.addControl(new GMapTypeControl());
        map.setCenter(new GLatLng(40, -100), 4);
		/* Want to add a double-click event? 
		GEvent.addListener(map, "dblclick", function(overlay,latlng) {
          if (latlng) {
			   searchLocationsNear(latlng);
          }
        }); 
        */
      }
    }

   function searchLocations() {
     var address = document.getElementById('addressInput').value;
	 if (address) {
		 geocoder.getLatLng(address, function(latlng) {
		   if (!latlng) {
			 alert(address + ' not found.');
		   } else {
			 searchLocationsNear(latlng);
		   }
		 });
	 }
   }

   function searchLocationsNear(center) {
     var radius = document.getElementById('radiusSelect').value;
     var searchUrl = 'phpsqlsearch_genxml.php?lat=' + center.lat() + '&lng=' + center.lng() + '&radius=' + radius;
     GDownloadUrl(searchUrl, function(data) {
       var xml = GXml.parse(data);
       var markers = xml.documentElement.getElementsByTagName('marker');
       map.clearOverlays();

       var sidebar = document.getElementById('sidebar');
       sidebar.innerHTML = '';
       if (markers.length == 0) {
         sidebar.innerHTML = 'No results found.';
         map.setCenter(new GLatLng(40, -100), 4);
         return;
       }
	   
       var bounds = new GLatLngBounds();
       for (var i = 0; i < markers.length; i++) {
         var name = markers[i].getAttribute('name');
         var phone = markers[i].getAttribute('phone');
         var address = markers[i].getAttribute('address');
         var distance = parseFloat(markers[i].getAttribute('distance'));
         var point = new GLatLng(parseFloat(markers[i].getAttribute('lat')),
                                 parseFloat(markers[i].getAttribute('lng')));
         
         var marker = createMarker(point, name, phone, address);
         map.addOverlay(marker);
         var sidebarEntry = createSidebarEntry(marker, name, phone, address, distance);
         sidebar.appendChild(sidebarEntry);
         bounds.extend(point);
       }
       map.setCenter(bounds.getCenter(), map.getBoundsZoomLevel(bounds));
     });
   }
    function ptdescription(name, phone, address) {
	  var html = '';
	  if (name) {
		html='<b>' + name + '</b>';
	  }
	  if (phone) {
		if (html) { html  = html+'<br />'; }
		html=html+phone;
	  }
	  if (address) {
		if (html) { html  = html+'<br />'; }
		html=html+address;
	  }
	  return html;
	}
    function createMarker(point, name, phone, address) {
      var marker = new GMarker(point);
      var html = ptdescription(name,phone,address);
      GEvent.addListener(marker, 'click', function() {
        marker.openInfoWindowHtml(html);
      });
      return marker;
    }

    function createSidebarEntry(marker, name, phone, address, distance) {
      var div = document.createElement('div');
      //var html = '<b>' + name + '</b> (' + distance.toFixed(1) + ')<br/>' + address;
	  var html=ptdescription(name,phone,address)+'<hr>';
      div.innerHTML = html;
      div.style.cursor = 'pointer';
      div.style.marginBottom = '0px'; 
      GEvent.addDomListener(div, 'click', function() {
        GEvent.trigger(marker, 'click');
      });
      GEvent.addDomListener(div, 'mouseover', function() {
        div.style.backgroundColor = '#eee';
      });
      GEvent.addDomListener(div, 'mouseout', function() {
        div.style.backgroundColor = '#BDB1D5'; // '#92D69D';
      });
      return div;
    }
    //]]>


