]> 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 317266b1fb5fb4a4afe4f82f64d329053d81f8c9..60eff9a445d6ace0a15af81cec00414575fd48d6 100644 (file)
@@ -1,15 +1,19 @@
 <div id="mapkey">
-  <table class="mapkey-table">
-    <% YAML.load_file(Rails.root.join("config/key.yml")).each do |name,data| %>
-      <% data.each do |entry| %>
-        <tr class="mapkey-table-entry" data-layer="<%= name %>" data-zoom-min="<%= entry["min_zoom"] %>" data-zoom-max="<%= entry["max_zoom"] %>">
-          <td class="mapkey-table-key">
-            <%= image_tag "key/#{name}/#{entry['image']}" %>
+  <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">
-            <%= [*t(".table.entry.#{entry['name']}")].to_sentence %>
+            <%= Array(t(".table.entry.#{entry['name']}")).to_sentence %>
           </td>
-        </tr>
+        <% end %>
       <% end %>
     <% end %>
   </table>