]> git.openstreetmap.org Git - rails.git/blob - app/views/diary_entry/edit.rhtml
be a bit smarter about enlarging the bbox (note to self: must remember to put this...
[rails.git] / app / views / diary_entry / edit.rhtml
1 <h1><%= @title %></h1>
2
3 <%= error_messages_for 'diary_entry' %>
4
5 <% form_for :diary_entry do |f| %>
6   <table>
7     <tr valign="top">
8       <th>Subject</th>
9       <td><%= f.text_field :title, :size => 60 %></td>
10     </tr>
11     <tr valign="top">
12       <th>Body</th>
13       <td><%= f.text_area :body, :cols => 80 %></td>
14     </tr>
15     <tr valign="top">
16       <th>Location</th>
17       <td>
18         <div id="map" style="border: 1px solid black; position: relative; width : 90%; height : 400px; display: none;"></div>
19         <span class="location">Latitude: <%= f.text_field :latitude, :size => 20, :id => "latitude" %> Longitude: <%= f.text_field :longitude, :size => 20, :id => "longitude" %></span>
20         <a href="javascript:openMap()" id="usemap">use map</a>
21       </td>
22     </tr>
23     <tr>
24       <th></th>
25       <td><%= submit_tag 'Save' %></td>
26     </tr>
27   </table>
28 <% end %>
29
30 <% if @user.home_lat.nil? or @user.home_lon.nil? %>
31   <% lon = h(params['lon'] || '-0.1') %>
32   <% lat = h(params['lat'] || '51.5') %>
33   <% zoom = h(params['zoom'] || '4') %> 
34 <% else %>
35   <% lon = @user.home_lon %>
36   <% lat = @user.home_lat %>
37   <% zoom = '12' %>
38 <% end %>
39
40 <%= javascript_include_tag '/openlayers/OpenLayers.js' %>
41 <%= javascript_include_tag '/openlayers/OpenStreetMap.js' %>
42 <%= javascript_include_tag 'map.js' %>
43
44 <script type="text/javascript">
45   <!--
46   var marker;
47
48   function init() {
49     var centre = new OpenLayers.LonLat(<%= lon %>, <%= lat %>);
50     var zoom = <%= zoom %>;
51
52     var map = createMap("map");
53
54     setMapCenter(centre, zoom);
55
56     map.events.register("click", map, setLocation);
57   }        
58
59   function setLocation( e ) { 
60     closeMapPopup();
61
62     var lonlat = getEventPosition(e);
63
64     document.getElementById('latitude').value = lonlat.lat;
65     document.getElementById('longitude').value = lonlat.lon;
66
67     if (marker) {
68       removeMarkerFromMap(marker);
69     }
70
71     marker = addMarkerToMap(lonlat, null, "Diary entry location");
72   }
73
74   function openMap() {
75     $("map").style.display = "block";
76     $("usemap").style.display = "none";
77   }
78
79   window.onload = init;
80 // -->
81 </script>