]> git.openstreetmap.org Git - rails.git/blobdiff - app/views/browse/_way.html.erb
Extend containing relation fix to nested relations
[rails.git] / app / views / browse / _way.html.erb
index 9156d23998b8558e3036a8bc458b273e22c0526e..19c5ff59087f86e4a9f5f4b52ecdbfdcc51a4202 100644 (file)
@@ -1,33 +1,43 @@
-<div class='browse-section'>
-  <% if way.redacted? %>
-    <%= t 'browse.redacted.message_html',
-          :type => t('browse.redacted.type.way'),
+<% if way.redacted? && !params[:show_redactions] %>
+  <div class="browse-section browse-redacted">
+    <%= t "browse.redacted.message_html",
+          :type => t("browse.redacted.type.way"),
           :version => way.version,
           :version => way.version,
-          :redaction_link => link_to(t('browse.redacted.redaction',
+          :redaction_link => link_to(t("browse.redacted.redaction",
                                        :id => way.redaction.id), way.redaction) %>
                                        :id => way.redaction.id), way.redaction) %>
-  <% else %>
-    <%= render :partial => "common_details", :object => way %>
+  </div>
+<% else %>
+  <%= tag.div :class => ["browse-section", "browse-way", { "text-muted" => way.redacted? }] do %>
+    <%= render :partial => "browse/common_details", :object => way %>
 
 
-    <% unless way.way_nodes.empty? %>
-      <h4><%= t'browse.way.nodes' %></h4>
-      <ul>
-        <% way.way_nodes.each do |wn| %>
-          <li>
-            <%= link_to h(printable_name(wn.node)), { :action => "node", :id => wn.node_id.to_s }, :class => link_class('node', wn.node), :title => link_title(wn.node) %>
-            <% related_ways = wn.node.ways.reject { |w| w.id == wn.way_id } %>
-            <% if related_ways.size > 0 then %>
-              (<%= raw t 'browse.way.also_part_of', :count => related_ways.size, :related_ways => related_ways.map { |w| link_to(h(printable_name(w)), { :action => "way", :id => w.id.to_s }, :class => link_class('way', w), :title => link_title(w) ) }.to_sentence %>)
-            <% end %>
-          </li>
-        <% end %>
-      </ul>
+    <% unless way.containing_relation_members.empty? %>
+      <h4><%= t "browse.part_of" %></h4>
+      <details <%= "open" if way.containing_relation_members.count < 10 %>>
+        <summary><%= t "browse.part_of_relations", :count => way.containing_relation_members.uniq.count %></summary>
+        <ul class="list-unstyled">
+          <%= render :partial => "browse/containing_relation", :collection => way.containing_relation_members.uniq %>
+        </ul>
+      </details>
     <% end %>
 
     <% end %>
 
-    <% unless way.containing_relation_members.empty? %>
-      <h4><%= t'browse.part_of' %></h4>
-      <ul>
-        <%= render :partial => "containing_relation", :collection => way.containing_relation_members %>
-      </ul>
+    <% unless way.way_nodes.empty? %>
+      <h4><%= t ".nodes" %></h4>
+      <details <%= "open" if way.way_nodes.count < 10 %>>
+        <summary><%= t ".nodes_count", :count => way.way_nodes.count %></summary>
+        <ul class="list-unstyled">
+          <% way.way_nodes.each do |wn| %>
+            <li>
+              <%= element_single_current_link "node", wn.node, node_path(wn.node) %>
+              <% related_ways = wn.node.ways.reject { |w| w.id == wn.way_id } %>
+              <% if related_ways.size > 0 then %>
+                (<%= t ".also_part_of_html",
+                       :count => related_ways.size,
+                       :related_ways => to_sentence(related_ways.map { |w| element_single_current_link "way", w, way_path(w) }) %>)
+              <% end %>
+            </li>
+          <% end %>
+        </ul>
+      </details>
     <% end %>
   <% end %>
     <% end %>
   <% end %>
-</div>
+<% end %>