lib/timetrap/formatters/text.rb in timetrap-1.8.12 vs lib/timetrap/formatters/text.rb in timetrap-1.8.13
- old
+ new
@@ -10,36 +10,44 @@
h[e.sheet] ||= []
h[e.sheet] << e
h
end
longest_note = entries.inject('Notes'.length) {|l, e| [e.note.to_s.rstrip.length, l].max}
+ max_id_length = if Timetrap::CLI.args['-v']
+ entries.inject(3) {|l, e| [e.id.to_s.length, l].max}
+ else
+ 3
+ end
(sheet_names = sheets.keys.sort).each do |sheet|
+
self.output << "Timesheet: #{sheet}\n"
- id_heading = Timetrap::CLI.args['-v'] ? 'Id' : ' '
+ id_heading = Timetrap::CLI.args['-v'] ? "Id#{' ' * (max_id_length - 3)}" : " "
self.output << "#{id_heading} Day Start End Duration Notes\n"
last_start = nil
from_current_day = []
+
+
sheets[sheet].each_with_index do |e, i|
from_current_day << e
- self.output << "%-4s%16s%11s -%9s%10s %s\n" % [
+ self.output << "%-#{max_id_length + 1}s%16s%11s -%9s%10s %s\n" % [
(Timetrap::CLI.args['-v'] ? e.id : ''),
format_date_if_new(e.start, last_start),
format_time(e.start),
format_time(e.end),
format_duration(e.duration),
e.note
]
nxt = sheets[sheet].to_a[i+1]
if nxt == nil or !same_day?(e.start, nxt.start)
- self.output << "%52s\n" % format_total(from_current_day)
+ self.output << "%#{49 + max_id_length}s\n" % format_total(from_current_day)
from_current_day = []
else
end
last_start = e.start
end
- self.output << " %s\n" % ('-'*(52+longest_note))
- self.output << " Total%43s\n" % format_total(sheets[sheet])
+ self.output << "#{' ' * (max_id_length + 1)}%s\n" % ('-'*(52+longest_note))
+ self.output << "#{' ' * (max_id_length + 1)}Total%43s\n" % format_total(sheets[sheet])
self.output << "\n" unless sheet == sheet_names.last
end
if sheets.size > 1
self.output << "%s\n" % ('-'*(4+52+longest_note))
self.output << "Grand Total%41s\n" % format_total(sheets.values.flatten)