]> git.openstreetmap.org Git - rails.git/blob - app/views/browse/_map.html.erb
ac6f32fc6dbea253fc2165995a7365b2fb11708d
[rails.git] / app / views / browse / _map.html.erb
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.instance_of? Changeset or map.visible %>
6     <div id="small_map" style="width:250px; height: 300px; border: solid 1px black">
7     </div>
8     <span id="loading"><%= t 'browse.map.loading' %></span>
9     <a id="area_larger_map" href=""></a>
10     <% unless map.instance_of? Changeset %>
11     <br />
12     <a id="object_larger_map" href=""></a>
13     <% end %>
14   <% else %>
15     <%= t 'browse.map.deleted' %>
16   <% end %>
17 </td>
18 <% if map.instance_of? Changeset or map.visible %>
19   <script type="text/javascript">
20     OpenLayers.Lang.setCode("<%= I18n.locale.to_s %>");
21
22     function init() {
23       var map = createMap("small_map", {
24         controls: [ new OpenLayers.Control.Navigation() ]
25       });
26
27       <% if map.instance_of? Changeset %>
28         var minlon = <%= map.min_lon / GeoRecord::SCALE.to_f %>;
29         var minlat = <%= map.min_lat / GeoRecord::SCALE.to_f %>;
30         var maxlon = <%= map.max_lon / GeoRecord::SCALE.to_f %>;
31         var maxlat = <%= map.max_lat / GeoRecord::SCALE.to_f %>;
32         var bbox = new OpenLayers.Bounds(minlon, minlat, maxlon, maxlat);
33
34         setMapExtent(bbox);
35         addBoxToMap(bbox);
36
37         $("loading").innerHTML = "";
38
39         $("area_larger_map").href = '/?minlon='+minlon+'&minlat='+minlat+'&maxlon='+maxlon+'&maxlat='+maxlat+'&box=yes';
40         $("area_larger_map").innerHTML = "<%= t 'browse.map.larger.area' %>";
41       <% else %>
42         var obj_type = "<%= map.class.name.downcase %>";
43         var obj_id = <%= map.id %>;
44         var url = "/api/<%= "#{API_VERSION}" %>/<%= map.class.name.downcase %>/<%= map.id %>";
45
46         if (obj_type != "node") {
47           url += "/full";
48         }
49
50         var osm_layer = new OpenLayers.Layer.GML("OSM", url, {
51           format: OpenLayers.Format.OSM,
52           projection: new OpenLayers.Projection("EPSG:4326")
53         });
54
55         osm_layer.events.register("loadend", osm_layer, function() {
56           $("loading").innerHTML = "";
57
58           if (this.features.length) {
59             var extent =  this.features[0].geometry.getBounds();
60
61             for (var i = 1; i < this.features.length; i++) {
62               extent.extend(this.features[i].geometry.getBounds());
63             }
64
65             if (extent) {
66               this.map.zoomToExtent(extent);
67             } else {
68               this.map.zoomToMaxExtent();
69             }
70
71             var center = getMapCenter();
72             $("area_larger_map").href = '/?lat='+center.lat+'&lon='+center.lon+'&zoom='+this.map.getZoom();
73             $("area_larger_map").innerHTML = "<%= t 'browse.map.larger.area' %>";
74             <% unless map.instance_of? Changeset %>
75             $("object_larger_map").href = '/?<%= map.class.to_s.downcase %>=<%= map.id %>';
76             $("object_larger_map").innerHTML = "<%= t('browse.map.larger.' + map.class.to_s.downcase) %>";
77             <% end %>
78           } else {
79             $("small_map").style.display = "none";
80           }
81         });
82
83         map.addLayer(osm_layer);
84
85         osm_layer.loadGML();
86         osm_layer.loaded = true;
87       <% end %>
88     }
89
90     window.onload = init;
91   </script>
92 <% end %>