diff options
author | Clement Tsang <34804052+ClementTsang@users.noreply.github.com> | 2020-05-16 22:38:19 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-05-16 22:38:19 -0400 |
commit | 12e4777d97b98987991ce4670df477108356b42f (patch) | |
tree | c7ed481a09cfab68308af640a292e0690599f9c4 /src/canvas | |
parent | a074808a00b90c33d09a2b77579ec15c646c9e63 (diff) |
change: remove slash, change scroll behaviour on cpu
- Removal of the old slash-space-to-hide behaviour of CPU widget
- Scrolling onto a specific entry will only show that entry
- Showing average is now default
Diffstat (limited to 'src/canvas')
-rw-r--r-- | src/canvas/canvas_colours.rs | 7 | ||||
-rw-r--r-- | src/canvas/canvas_colours/colour_utils.rs | 1 | ||||
-rw-r--r-- | src/canvas/widgets/cpu_graph.rs | 185 |
3 files changed, 84 insertions, 109 deletions
diff --git a/src/canvas/canvas_colours.rs b/src/canvas/canvas_colours.rs index 6be85866..714a1145 100644 --- a/src/canvas/canvas_colours.rs +++ b/src/canvas/canvas_colours.rs @@ -17,6 +17,7 @@ pub struct CanvasColours { pub tx_style: Style, pub total_rx_style: Style, pub total_tx_style: Style, + pub all_colour_style: Style, pub avg_colour_style: Style, pub cpu_colour_styles: Vec<Style>, pub border_style: Style, @@ -46,6 +47,7 @@ impl Default for CanvasColours { tx_style: Style::default().fg(STANDARD_SECOND_COLOUR), total_rx_style: Style::default().fg(STANDARD_THIRD_COLOUR), total_tx_style: Style::default().fg(STANDARD_FOURTH_COLOUR), + all_colour_style: Style::default().fg(ALL_COLOUR), avg_colour_style: Style::default().fg(AVG_COLOUR), cpu_colour_styles: Vec::new(), border_style: Style::default().fg(text_colour), @@ -122,6 +124,11 @@ impl CanvasColours { Ok(()) } + pub fn set_all_cpu_colour(&mut self, colour: &str) -> error::Result<()> { + self.all_colour_style = get_style_from_config(colour)?; + Ok(()) + } + pub fn set_cpu_colours(&mut self, colours: &[String]) -> error::Result<()> { let max_amount = std::cmp::min(colours.len(), NUM_COLOURS as usize); for (itx, colour) in colours.iter().enumerate() { diff --git a/src/canvas/canvas_colours/colour_utils.rs b/src/canvas/canvas_colours/colour_utils.rs index 595989cc..119b6be3 100644 --- a/src/canvas/canvas_colours/colour_utils.rs +++ b/src/canvas/canvas_colours/colour_utils.rs @@ -13,6 +13,7 @@ pub const STANDARD_THIRD_COLOUR: Color = Color::LightCyan; pub const STANDARD_FOURTH_COLOUR: Color = Color::LightGreen; pub const STANDARD_HIGHLIGHT_COLOUR: Color = Color::LightBlue; pub const AVG_COLOUR: Color = Color::Red; +pub const ALL_COLOUR: Color = Color::Green; lazy_static! { static ref COLOR_NAME_LOOKUP_TABLE: HashMap<&'static str, Color> = [ diff --git a/src/canvas/widgets/cpu_graph.rs b/src/canvas/widgets/cpu_graph.rs index 043f7025..fb1e6e00 100644 --- a/src/canvas/widgets/cpu_graph.rs +++ b/src/canvas/widgets/cpu_graph.rs @@ -22,6 +22,9 @@ use tui::{ const CPU_SELECT_LEGEND_HEADER: [&str; 2] = ["CPU", "Show"]; const CPU_LEGEND_HEADER: [&str; 2] = ["CPU", "Use%"]; +const AVG_POSITION: usize = 1; +const ALL_POSITION: usize = 0; + lazy_static! { static ref CPU_LEGEND_HEADER_LENS: Vec<usize> = CPU_LEGEND_HEADER .iter() @@ -97,6 +100,8 @@ impl CpuGraphWidget for Painter { fn draw_cpu_graph<B: Backend>( &self, f: &mut Frame<'_, B>, app_state: &mut App, draw_loc: Rect, widget_id: u64, ) { + use std::convert::TryFrom; + if let Some(cpu_widget_state) = app_state.cpu_state.widget_states.get_mut(&widget_id) { let cpu_data: &mut [ConvertedCpuData] = &mut app_state.canvas_data.cpu_data; @@ -142,47 +147,58 @@ impl CpuGraphWidget for Painter { let use_dot = app_state.app_config_fields.use_dot; let show_avg_cpu = app_state.app_config_fields.show_average_cpu; - let dataset_vector: Vec<Dataset<'_>> = cpu_data - .iter() - .zip(&cpu_widget_state.core_show_vec) - .enumerate() - .rev() - .filter_map(|(itx, (cpu, cpu_show_vec))| { - if *cpu_show_vec { - Some( + let dataset_vector: Vec<Dataset<'_>> = if let Ok(current_scroll_position) = + usize::try_from(cpu_widget_state.scroll_state.current_scroll_position) + { + if current_scroll_position == ALL_POSITION { + cpu_data + .iter() + .enumerate() + .rev() + .map(|(itx, cpu)| { Dataset::default() .marker(if use_dot { Marker::Dot } else { Marker::Braille }) - .style(if show_avg_cpu && itx == 0 { + .style(if show_avg_cpu && itx == AVG_POSITION { self.colours.avg_colour_style } else { self.colours.cpu_colour_styles [itx % self.colours.cpu_colour_styles.len()] }) .data(&cpu.cpu_data[..]) - .graph_type(tui::widgets::GraphType::Line), - ) - } else { - None - } - }) - .collect(); - - let title = if app_state.is_expanded && !cpu_widget_state.is_showing_tray { - const TITLE_BASE: &str = " CPU ── Esc to go back "; - format!( - " CPU ─{}─ Esc to go back ", - "─".repeat( - usize::from(draw_loc.width).saturating_sub(TITLE_BASE.chars().count() + 2) - ) - ) + .graph_type(tui::widgets::GraphType::Line) + }) + .collect() + } else if let Some(cpu) = cpu_data.get(current_scroll_position) { + vec![Dataset::default() + .marker(if use_dot { + Marker::Dot + } else { + Marker::Braille + }) + .style(if show_avg_cpu && current_scroll_position == AVG_POSITION { + self.colours.avg_colour_style + } else { + self.colours.cpu_colour_styles[cpu_widget_state + .scroll_state + .current_scroll_position + as usize + % self.colours.cpu_colour_styles.len()] + }) + .data(&cpu.cpu_data[..]) + .graph_type(tui::widgets::GraphType::Line)] + } else { + vec![] + } } else { - " CPU ".to_string() + vec![] }; + let title = " CPU ".to_string(); + let border_style = if app_state.current_widget.widget_id == widget_id { self.colours.highlighted_border_style } else { @@ -231,35 +247,13 @@ impl CpuGraphWidget for Painter { let mut offset_scroll_index = (cpu_widget_state.scroll_state.current_scroll_position - start_position) as usize; - let show_disabled_data = app_state.app_config_fields.show_disabled_data; let show_avg_cpu = app_state.app_config_fields.show_average_cpu; let cpu_rows = sliced_cpu_data.iter().enumerate().filter_map(|(itx, cpu)| { - let cpu_string_row: Vec<Cow<'_, str>> = if let Some(cpu_core_show_vec) = - cpu_widget_state - .core_show_vec - .get(itx + start_position as usize) - { - if cpu_widget_state.is_showing_tray { - vec![ - Cow::Borrowed(&cpu.cpu_name), - if *cpu_core_show_vec { - "[*]".into() - } else { - "[ ]".into() - }, - ] - } else if show_disabled_data || *cpu_core_show_vec { - vec![ - Cow::Borrowed(&cpu.cpu_name), - Cow::Borrowed(&cpu.legend_value), - ] - } else { - Vec::new() - } - } else { - Vec::new() - }; + let cpu_string_row: Vec<Cow<'_, str>> = vec![ + Cow::Borrowed(&cpu.cpu_name), + Cow::Borrowed(&cpu.legend_value), + ]; if cpu_string_row.is_empty() { offset_scroll_index += 1; @@ -267,21 +261,22 @@ impl CpuGraphWidget for Painter { } else { Some(Row::StyledData( cpu_string_row.into_iter(), - if is_on_widget { - if itx == offset_scroll_index { - self.colours.currently_selected_text_style - } else if show_avg_cpu && itx == 0 { + if is_on_widget && itx == offset_scroll_index { + self.colours.currently_selected_text_style + } else if itx == ALL_POSITION { + self.colours.all_colour_style + } else if show_avg_cpu { + if itx == AVG_POSITION { self.colours.avg_colour_style } else { - self.colours.cpu_colour_styles[itx - + start_position as usize - % self.colours.cpu_colour_styles.len()] + self.colours.cpu_colour_styles[itx + start_position as usize + - AVG_POSITION + - 1 % self.colours.cpu_colour_styles.len()] } - } else if show_avg_cpu && itx == 0 { - self.colours.avg_colour_style } else { - self.colours.cpu_colour_styles[itx - + start_position as usize % self.colours.cpu_colour_styles.len()] + self.colours.cpu_colour_styles[itx + start_position as usize + - ALL_POSITION + - 1 % self.colours.cpu_colour_styles.len()] }, )) } @@ -291,29 +286,10 @@ impl CpuGraphWidget for Painter { let width = f64::from(draw_loc.width); let width_ratios = vec![0.5, 0.5]; - let variable_intrinsic_results = get_variable_intrinsic_widths( - width as u16, - &width_ratios, - if cpu_widget_state.is_showing_tray { - &CPU_SELECT_LEGEND_HEADER_LENS - } else { - &CPU_LEGEND_HEADER_LENS - }, - ); + let variable_intrinsic_results = + get_variable_intrinsic_widths(width as u16, &width_ratios, &CPU_LEGEND_HEADER_LENS); let intrinsic_widths = &(variable_intrinsic_results.0)[0..variable_intrinsic_results.1]; - let title = if cpu_widget_state.is_showing_tray { - const TITLE_BASE: &str = " Esc to close "; - format!( - "{} Esc to close ", - "─".repeat( - usize::from(draw_loc.width).saturating_sub(TITLE_BASE.chars().count() + 2) - ) - ) - } else { - "".to_string() - }; - let (border_and_title_style, highlight_style) = if is_on_widget { ( self.colours.highlighted_border_style, @@ -325,31 +301,22 @@ impl CpuGraphWidget for Painter { // Draw f.render_widget( - Table::new( - if cpu_widget_state.is_showing_tray { - CPU_SELECT_LEGEND_HEADER - } else { - CPU_LEGEND_HEADER - } - .iter(), - cpu_rows, - ) - .block( - Block::default() - .title(&title) - .title_style(border_and_title_style) - .borders(Borders::ALL) - .border_style(border_and_title_style), - ) - .header_style(self.colours.table_header_style) - .highlight_style(highlight_style) - .widths( - &(intrinsic_widths - .iter() - .map(|calculated_width| Constraint::Length(*calculated_width as u16)) - .collect::<Vec<_>>()), - ) - .header_gap(app_state.app_config_fields.table_gap), + Table::new(CPU_LEGEND_HEADER.iter(), cpu_rows) + .block( + Block::default() + .title_style(border_and_title_style) + .borders(Borders::ALL) + .border_style(border_and_title_style), + ) + .header_style(self.colours.table_header_style) + .highlight_style(highlight_style) + .widths( + &(intrinsic_widths + .iter() + .map(|calculated_width| Constraint::Length(*calculated_width as u16)) + .collect::<Vec<_>>()), + ) + .header_gap(app_state.app_config_fields.table_gap), draw_loc, ); } |