Module: RailsPulse::ChartFormatters
- Defined in:
- app/helpers/rails_pulse/chart_formatters.rb
Class Method Summary collapse
- .period_as_time_or_date(time_diff_hours) ⇒ Object
- .tooltip_as_time_or_date_with_marker(time_diff_hours) ⇒ Object
Class Method Details
.period_as_time_or_date(time_diff_hours) ⇒ Object
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |
# File 'app/helpers/rails_pulse/chart_formatters.rb', line 3 def self.period_as_time_or_date(time_diff_hours) if time_diff_hours <= 25 <<~JS function(value) { const date = new Date(value * 1000); return date.getHours().toString().padStart(2, '0') + ':00'; } JS else <<~JS function(value) { const date = new Date(value * 1000); return date.toLocaleDateString('en-US', { month: 'short', day: 'numeric' }); } JS end end |
.tooltip_as_time_or_date_with_marker(time_diff_hours) ⇒ Object
21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 |
# File 'app/helpers/rails_pulse/chart_formatters.rb', line 21 def self.tooltip_as_time_or_date_with_marker(time_diff_hours) if time_diff_hours <= 25 <<~JS function(params) { const data = params[0]; const date = new Date(data.axisValue * 1000); const dateString = date.getHours().toString().padStart(2, '0') + ':00'; return `${dateString} <br /> ${data.marker} ${parseInt(data.data)} ms`; } JS else <<~JS function(params) { const data = params[0]; const date = new Date(data.axisValue * 1000); const dateString = date.toLocaleDateString('en-US', { month: 'short', day: 'numeric' }); return `${dateString} <br /> ${data.marker} ${parseInt(data.data)} ms`; } JS end end |