Include a general location from GeoNames in the reverse geocode description.
authorTom Hughes <tom@compton.nu>
Fri, 24 Aug 2007 22:50:34 +0000 (22:50 +0000)
committerTom Hughes <tom@compton.nu>
Fri, 24 Aug 2007 22:50:34 +0000 (22:50 +0000)
app/controllers/geocoder_controller.rb
app/helpers/geocoder_helper.rb

index 6c4afeb90eee44a0378d9c62f53d3133ed642856..4ed94b6498be7aa70e9ffa47b1d6218b9f83dae1 100644 (file)
@@ -41,6 +41,7 @@ class GeocoderController < ApplicationController
     results.push description_osm_namefinder("cities", lat, lon, 2)
     results.push description_osm_namefinder("towns", lat, lon, 4)
     results.push description_osm_namefinder("places", lat, lon, 10)
+    results.push description_geonames(lat, lon)
 
     render :update do |page|
       page.replace_html :search_results_content, :partial => 'results', :object => results
@@ -196,6 +197,24 @@ private
     return { :type => types.capitalize, :source => "OpenStreetMap Namefinder", :url => "http://www.frankieandshadow.com/osm/", :error => "Error contacting www.frankieandshadow.com: #{ex.to_s}" }
   end
 
+  def description_geonames(lat, lon)
+    results = Array.new
+
+    # ask geonames.org
+    response = fetch_xml("http://ws.geonames.org/countrySubdivision?lat=#{lat}&lng=#{lon}")
+
+    # parse the response
+    response.elements.each("geonames/countrySubdivision") do |geoname|
+      name = geoname.get_text("adminName1").to_s
+      country = geoname.get_text("countryName").to_s
+      results.push({:prefix => "#{name}, #{country}"})
+    end
+
+    return { :type => "Location", :source => "GeoNames", :url => "http://www.geonames.org/", :results => results }
+  rescue Exception => ex
+    return { :type => types.capitalize, :source => "OpenStreetMap Namefinder", :url => "http://www.frankieandshadow.com/osm/", :error => "Error contacting www.frankieandshadow.com: #{ex.to_s}" }
+  end
+
   def fetch_text(url)
     return Net::HTTP.get(URI.parse(url))
   end
index 879b1dca1c3a989db6483615cea50396d23d6096..75e81665126375a65884743fd790e5138992d8e8 100644 (file)
@@ -4,7 +4,7 @@ module GeocoderHelper
     #html_options[:title] = strip_tags(result[:description]) if result[:description]
     html = ""
     html << result[:prefix] if result[:prefix]
-    html << link_to_function(result[:name], "setPosition(#{result[:lat]}, #{result[:lon]}, #{result[:zoom]})", html_options) 
+    html << link_to_function(result[:name], "setPosition(#{result[:lat]}, #{result[:lon]}, #{result[:zoom]})", html_options)  if result[:name]
     html << result[:suffix] if result[:suffix]
     return html
   end