]> git.openstreetmap.org Git - rails.git/blob - app/views/site/_search.html.erb
Move more styling into CSS and make it support RTL layout
[rails.git] / app / views / site / _search.html.erb
1 <script type="text/javascript">
2 <!--
3   function describeLocation() {
4     var args = getArgs($("viewanchor").href);
5
6     <%= remote_function(:loading => "startSearch()",
7                         :url => { :controller => :geocoder, :action => :description },
8                         :with => "'lat=' + args['lat'] + '&lon=' + args['lon'] + '&zoom=' + args['zoom']") %>
9   }
10
11   function setSearchViewbox() {
12     <% if params[:action] == 'index' %>
13     var extent = getMapExtent();
14
15     var minlon = document.createElement("input");
16     minlon.type = "hidden";
17     minlon.id = "minlon";
18     minlon.name = "minlon";
19     minlon.value = extent.left;
20     $("search_form").appendChild(minlon);
21
22     var minlat = document.createElement("input");
23     minlat.type = "hidden";
24     minlat.id = "minlat";
25     minlat.name = "minlat";
26     minlat.value = extent.bottom;
27     $("search_form").appendChild(minlat);
28
29     var maxlon = document.createElement("input");
30     maxlon.type = "hidden";
31     maxlon.id = "maxlon";
32     maxlon.name = "maxlon";
33     maxlon.value = extent.left;
34     $("search_form").appendChild(maxlon);
35
36     var maxlat = document.createElement("input");
37     maxlat.type = "hidden";
38     maxlat.id = "maxlat";
39     maxlat.name = "maxlat";
40     maxlat.value = extent.bottom;
41     $("search_form").appendChild(maxlat);
42     <% end %>
43   }
44
45   function startSearch() {
46     updateSidebar("<%= t 'site.sidebar.search_results' %>", "");
47   }
48
49   function endSearch() {
50     <% if params[:action] == 'index' %>
51     $("minlon").remove();
52     $("minlat").remove();
53     $("maxlon").remove();
54     $("maxlat").remove();
55     <% end %>
56   }
57
58   <% if params[:query] %>
59   <%= remote_function(:loading => "startSearch()",
60                       :url => { :controller => :geocoder, :action => :search, :query => h(params[:query]) }) %>
61   <% end %>
62 // -->
63 </script>
64
65 <% content_for "optionals" do %>
66   <div class="optionalbox">
67     <span class="whereami"><a href="javascript:describeLocation()" title="<%= t 'site.search.where_am_i_title' %>"><%= t 'site.search.where_am_i' %></a></span>
68     <h1><%= t 'site.search.search' %></h1>
69     <div class="search_container">
70     <div id="search_field">
71     <% form_remote_tag(:before => "setSearchViewbox()",
72                        :loading => "startSearch()",
73                        :complete => "endSearch()",
74                        :url => { :controller => :geocoder, :action => :search },
75                        :html => { :id => "search_form", :method => "get", :action => url_for(:action => "index") }) do %>
76       <%= text_field_tag :query, h(params[:query]), :tabindex => "1" %>
77       <%= submit_tag t('site.search.submit_text') %>
78     <% end %>
79     </div>
80     </div>
81     <p class="search_help">
82       <%= t 'site.search.search_help' %>
83     </p>
84   </div>
85 <% end %>