]> git.openstreetmap.org Git - rails.git/blobdiff - app/views/site/key.html.erb
Load map key data in controller
[rails.git] / app / views / site / key.html.erb
index d0fd361483c2a1c812abf53c783b940446c549a7..60eff9a445d6ace0a15af81cec00414575fd48d6 100644 (file)
@@ -1,18 +1,18 @@
 <div id="mapkey">
-  <table class="mapkey-table">
-    <% YAML.load_file("#{RAILS_ROOT}/config/key.yml").each do |name,data| %>
-      <% if params[:layer] == name %>
-        <% data.each do |entry| %>
-          <% if params[:zoom].to_i >= entry['min_zoom'] && params[:zoom].to_i <= entry['max_zoom'] %>
-            <tr>
-              <td class="mapkey-table-key" align="center">
-                <%= image_tag "key/#{name}/#{entry['image']}" %>
-              </td>
-              <td class="mapkey-table-value">
-                <%= [*t("site.key.table.entry.#{entry['name']}")].to_sentence %>
-              </td>
-            </tr>
-          <% end %>
+  <table class="table table-sm table-borderless mapkey-table mb-0">
+    <% @key.each do |layer_name, layer_data| %>
+      <% layer_data.each do |entry| %>
+        <%= tag.tr :class => "mapkey-table-entry", :data => { :layer => layer_name, :zoom_min => entry["min_zoom"], :zoom_max => entry["max_zoom"] } do %>
+          <td class="mapkey-table-key align-middle">
+            <% if entry["width"] && entry["height"] && entry["fill"] %>
+              <%= image_tag "data:image/svg+xml,#{u("<svg xmlns='http://www.w3.org/2000/svg' width='#{entry['width']}' height='#{entry['height']}'><rect width='100%' height='100%' fill='#{entry['fill']}' /></svg>")}" %>
+            <% else %>
+              <%= image_tag "key/#{layer_name}/#{entry['image']}" %>
+            <% end %>
+          </td>
+          <td class="mapkey-table-value">
+            <%= Array(t(".table.entry.#{entry['name']}")).to_sentence %>
+          </td>
         <% end %>
       <% end %>
     <% end %>