Refactor to remove some code duplication.
[rails.git] / app / views / browse / _map.rhtml
1 <%= javascript_include_tag '/openlayers/OpenLayers.js' %>
2 <%= javascript_include_tag '/openlayers/OpenStreetMap.js' %>
3 <%= javascript_include_tag 'map.js' %>
4 <td align="right">
5   <% if map.visible %>
6     <div id="small_map" style="width:250px; height: 300px; border: solid 1px black">
7     </div>
8     <span id="loading">Loading...</span>
9     <a id="larger_map" href=""></a>
10   <% else %>
11     Deleted
12   <% end %>
13 </td>
14 <script type="text/javascript">
15   function init() {
16     var obj_type = "<%= map.class.name.downcase %>";
17     var obj_id = <%= map.id %>;
18     var url = "/api/<%= "#{API_VERSION}" %>/<%= map.class.name.downcase %>/<%= map.id %>";
19
20     if (obj_type != "node") {
21       url += "/full";
22     }
23
24     var map = createMap("small_map", {
25       controls: [ new OpenLayers.Control.Navigation() ]
26     });
27
28     var osm_layer = new OpenLayers.Layer.GML("OSM", url, {
29       format: OpenLayers.Format.OSM,
30       projection: new OpenLayers.Projection("EPSG:4326")
31     });
32
33     osm_layer.events.register("loadend", osm_layer, function() {
34       $("loading").innerHTML = "";
35
36       if (this.features.length) { 
37         var extent =  this.features[0].geometry.getBounds();
38
39         for (var i = 1; i < this.features.length; i++) {
40           extent.extend(this.features[i].geometry.getBounds());
41         }
42
43         if (extent) {
44           this.map.zoomToExtent(extent);
45         } else {
46           this.map.zoomToMaxExtent();
47         }
48
49         var center = getMapCenter();
50         $("larger_map").href = '/?lat='+center.lat+'&lon='+center.lon+'&zoom='+this.map.getZoom();
51         $("larger_map").innerHTML = "View Larger Map";
52       } else {
53         $("small_map").style.display = "none";
54       }
55     });
56
57     map.addLayer(osm_layer);
58
59     osm_layer.loadGML();
60     osm_layer.loaded = true;
61   }
62
63   window.onload = init;
64 </script>