From 55f5da509630ff1a3f69e42877be054cb8a175be Mon Sep 17 00:00:00 2001 From: Phil Weir Date: Sat, 10 Aug 2024 09:59:27 +0100 Subject: [PATCH] feat(ultracompact): reduce complexity of interactive draw(...) --- .../src/command/client/search/interactive.rs | 44 ++++++++++++------- 1 file changed, 28 insertions(+), 16 deletions(-) diff --git a/crates/atuin/src/command/client/search/interactive.rs b/crates/atuin/src/command/client/search/interactive.rs index 2ef899e0b93..acf096026f8 100644 --- a/crates/atuin/src/command/client/search/interactive.rs +++ b/crates/atuin/src/command/client/search/interactive.rs @@ -659,7 +659,6 @@ impl State { } } - #[allow(clippy::cast_possible_truncation)] #[allow(clippy::bool_to_int_with_if)] #[allow(clippy::too_many_lines)] fn draw( @@ -844,9 +843,6 @@ impl State { } if !matches!(compactness, Compactness::Ultracompact) { - let input = self.build_input(style); - f.render_widget(input, input_chunk); - let preview_width = match compactness { Compactness::Full => preview_width - 2, _ => preview_width, @@ -858,20 +854,36 @@ impl State { preview_chunk.width.into(), theme, ); - f.render_widget(preview, preview_chunk); + self.draw_preview(f, style, input_chunk, compactness, preview_chunk, preview); + }; + } - let extra_width = UnicodeWidthStr::width(self.search.input.substring()); + #[allow(clippy::cast_possible_truncation)] + fn draw_preview( + &self, + f: &mut Frame, + style: StyleState, + input_chunk: Rect, + compactness: Compactness, + preview_chunk: Rect, + preview: Paragraph, + ) { + let input = self.build_input(style); + f.render_widget(input, input_chunk); - let cursor_offset = match compactness { - Compactness::Full => 1, - _ => 0, - }; - f.set_cursor( - // Put cursor past the end of the input text - input_chunk.x + extra_width as u16 + PREFIX_LENGTH + 1 + cursor_offset, - input_chunk.y + cursor_offset, - ); - } + f.render_widget(preview, preview_chunk); + + let extra_width = UnicodeWidthStr::width(self.search.input.substring()); + + let cursor_offset = match compactness { + Compactness::Full => 1, + _ => 0, + }; + f.set_cursor( + // Put cursor past the end of the input text + input_chunk.x + extra_width as u16 + PREFIX_LENGTH + 1 + cursor_offset, + input_chunk.y + cursor_offset, + ); } fn build_title(&self, theme: &Theme) -> Paragraph {