1
0

Display readout list in tree format

This commit is contained in:
cryptogopher 2021-05-12 21:34:00 +02:00
parent bb43370329
commit 96d1c40cb8
9 changed files with 51 additions and 60 deletions

View File

@ -27,5 +27,13 @@ class ReadoutsController < ApplicationController
@measurements, @filter_q = @routine.measurements.includes(:routine, :source) @measurements, @filter_q = @routine.measurements.includes(:routine, :source)
.filter(session[:m_filters], @quantities) .filter(session[:m_filters], @quantities)
# Keep only non-nil readouts and their ancestors
@measurements.each do |measurement, readouts|
ancestors = {}
readouts.keep_if do |q, readout|
(readout || ancestors[q]) && (ancestors[q.parent] = true)
end
end
end end
end end

View File

@ -1,15 +1,17 @@
module BodyTrackersHelper module BodyTrackersHelper
def format_value(value, precision=2, mfu_unit=nil) def format_amount(amount, precision=2, mfu_unit=nil)
amount, unit = value value = amount.respond_to?(:value) ? amount.value : amount&.first
unit = amount.respond_to?(:unit) ? amount.unit : amount&.last
case case
when amount.nil? when value.nil?
'-' ''
when amount.nan? when value.nan?
'?' '?'
else else
a = amount.round(precision) value = value.round(precision)
a_desc = a.nonzero? ? "%.#{precision}f" % a : '-' a_desc = value.nonzero? ? "%.#{precision}f" % value : '-'
u_desc = unit && " [#{unit.shortname}]" || ' [-]' if unit != mfu_unit && a.nonzero? u_desc = unit ? " [#{unit.shortname}]" : ' [-]' if unit != mfu_unit && value.nonzero?
"#{a_desc}#{u_desc}" "#{a_desc}#{u_desc}"
end end
end end

View File

@ -1,4 +1,10 @@
module MeasurementsHelper module MeasurementsHelper
def readout_markup(quantity, readout)
content = "#{'&emsp;'*quantity.depth}#{quantity.name} #{format_amount(readout)}"
classes = 'bolded' if @routine.quantities.include?(quantity)
content_tag(:span, content, {class: classes}, false)
end
def action_links(m) def action_links(m)
link_to(l(:button_retake), retake_measurement_path(m, @view_params), link_to(l(:button_retake), retake_measurement_path(m, @view_params),
{remote: true, class: "icon icon-reload"}) + {remote: true, class: "icon icon-reload"}) +

View File

@ -42,7 +42,7 @@
</td> </td>
<% @quantities.each do |q| %> <% @quantities.each do |q| %>
<td class="primary right ellipsible"> <td class="primary right ellipsible">
<%= format_value(nutrients[q], @food_summary[:precision][q], <%= format_amount(nutrients[q], @food_summary[:precision][q],
@food_summary[:mfu_unit][q]) %> @food_summary[:mfu_unit][q]) %>
</td> </td>
<% end %> <% end %>
@ -62,7 +62,7 @@
<% @quantities.each do |q| %> <% @quantities.each do |q| %>
<td class="primary topleft ellipsible"> <td class="primary topleft ellipsible">
<%= q.name %> <%= q.name %>
<p class="right"><%= format_value(nutrients[q]) %></p> <p class="right"><%= format_amount(nutrients[q]) %></p>
</td> </td>
<% end %> <% end %>
<td rowspan="<%= rows %>" class="right shrunk unwrappable"> <td rowspan="<%= rows %>" class="right shrunk unwrappable">
@ -76,7 +76,7 @@
<% eqs.each do |q| %> <% eqs.each do |q| %>
<td class="extra topleft ellipsible"> <td class="extra topleft ellipsible">
<%= q.name if nutrients[q] %> <%= q.name if nutrients[q] %>
<p class="right"><%= format_value(nutrients[q]) %></p> <p class="right"><%= format_amount(nutrients[q]) %></p>
</td> </td>
<% end %> <% end %>
<% if @quantities.length > eqs.length %> <% if @quantities.length > eqs.length %>

View File

@ -37,7 +37,7 @@
<td class="right ellipsible" style="border-left: none;"></td> <td class="right ellipsible" style="border-left: none;"></td>
<% @quantities.each do |q| %> <% @quantities.each do |q| %>
<td class="right ellipsible"> <td class="right ellipsible">
<%= format_value(@ingredient_summary[m][q], @ingredient_summary[:precision][q]) %> <%= format_amount(@ingredient_summary[m][q], @ingredient_summary[:precision][q]) %>
</td> </td>
<% end %> <% end %>

View File

@ -7,7 +7,7 @@
<td class="right ellipsible" style="border-left: none;"></td> <td class="right ellipsible" style="border-left: none;"></td>
<% @quantities.each do |q| %> <% @quantities.each do |q| %>
<td class="right ellipsible"> <td class="right ellipsible">
<%= format_value(@ingredient_summary[date][q], @ingredient_summary[:precision][q]) %> <%= format_amount(@ingredient_summary[date][q], @ingredient_summary[:precision][q]) %>
</td> </td>
<% end %> <% end %>
<td></td> <td></td>

View File

@ -6,7 +6,7 @@
</td> </td>
<% @quantities.each do |q| %> <% @quantities.each do |q| %>
<td class="right ellipsible"> <td class="right ellipsible">
<%= format_value(@ingredients[i][q], @ingredient_summary[:precision][q], <%= format_amount(@ingredients[i][q], @ingredient_summary[:precision][q],
@ingredient_summary[:mfu_unit][q]) %> @ingredient_summary[:mfu_unit][q]) %>
</td> </td>
<% end %> <% end %>

View File

@ -16,58 +16,33 @@
<tbody> <tbody>
<% extra_quantities = @measurements.values.first.keys - @quantities %> <% extra_quantities = @measurements.values.first.keys - @quantities %>
<% @measurements.each do |measurement, readouts| %> <% @measurements.each do |measurement, readouts| %>
<% row_class = "measurement #{cycle('odd', 'even')}" %> <tr id="measurement-<%= measurement.id %>"
<tr id="measurement-<%= measurement.id %>" class="primary <%= row_class %>"> class="measurement <%= cycle('odd', 'even') %>">
<td class="topleft unwrappable" style="cursor: pointer;" <td class="topleft unwrappable">
onclick="$(this).closest('tr').toggle(); $(this).closest('tr').nextUntil('tr.primary', '.measurement').toggle(); return false;"> <%= link_to format_datetime(measurement.taken_at), '',
<span class="icon icon-bullet-closed"> {class: 'icon icon-arrow-right',
<%= format_datetime(measurement.taken_at) %> onclick: "$(this).closest('tr').nextUntil('tr.measurement', '.details')
</span> .show(); return false;"} %>
</td> </td>
<% @quantities.each do |q| %> <% @quantities.each do |q| %>
<td class="primary right ellipsible"><%= format_value(readouts[q]) %></td> <td class="right ellipsible"><%= format_amount(readouts[q]) %></td>
<% end %> <% end %>
<td class="right shrunk unwrappable"><%= action_links(measurement) %></td> <td class="right shrunk unwrappable"><%= action_links(measurement) %></td>
</tr> </tr>
<tr class="<%= row_class %>" style="display:none"> <tr class="details <%= current_cycle %>" style="display:none">
<% if @quantities.length > 0 <td class="topleft">
rows = (readouts.length - 1) / @quantities.length + 1 <%= link_to l(:button_close), "#", {class: 'icon icon-close',
else onclick: '$(this).closest("tr")
rows = 1 .nextUntil("tr.measurement", ":not(.details)")
end %> .show().addBack().first().hide(); return false;'} %>
<td rowspan="<%= rows %>" class="topleft unwrappable" style="cursor: pointer;"
onclick="$(this).closest('tr').prev('tr.primary').toggle(); $(this).closest('tr').prev('tr.primary').nextUntil('tr.primary', '.measurement').toggle(); return false;">
<span class="icon icon-bullet-open">
<%= format_datetime(measurement.taken_at) %>
</span>
</td>
<% @quantities.each do |q| %>
<td class="primary topleft ellipsible">
<%= q.name %>
<p class="right"><%= format_value(readouts[q]) %></p>
</td> </td>
<% content = readouts.keys.inject('') do |output, q| %>
<% raw "#{output}#{readout_markup(q, readouts[q])}\n" %>
<% end %> <% end %>
<td rowspan="<%= rows %>" class="right shrunk unwrappable"> <td class="topleft" colspan="<%= @quantities.length + 1 %>"
<%= action_links(measurement) %> style="white-space:pre-line;"><%= content %></td>
</td>
</tr> </tr>
<% next if @quantities.empty? %>
<% extra_quantities.each_slice(@quantities.length) do |eqs| %>
<tr class="extra <%= row_class %>" style="display:none">
<% eqs.each do |q| %>
<td class="extra topleft ellipsible">
<%= q.name if readouts[q] %>
<p class="right"><%= format_value(readouts[q]) %></p>
</td>
<% end %>
<% if @quantities.length > eqs.length %>
<td class="space" colspan="<%= @quantities.length - eqs.length %>"></td>
<% end %>
</tr>
<% end %>
<% end %> <% end %>
</tbody> </tbody>
</table> </table>

View File

@ -109,7 +109,7 @@ module BodyTracking
filter_values = completed_q.delete(filter_q) filter_values = completed_q.delete(filter_q)
items.to_a.keep_if { |i| filter_values[i][0] } if filter_values items.to_a.keep_if { |i| filter_values[i][0] } if filter_values
subitems.merge!(completed_q) subitems.merge!(completed_q)
subitem_keys = subitems.keys.select { |k| k.class == Quantity }.sort_by { |q| q.lft } subitem_keys = subitems.keys.select { |k| k.instance_of?(Quantity) }.sort_by(&:lft)
items.map { |i| [i, subitem_keys.map { |q| [q, subitems[q][i]] }.to_h] }.to_h items.map { |i| [i, subitem_keys.map { |q| [q, subitems[q][i]] }.to_h] }.to_h
end end
end end