Support mouse scrolling (#306)

Linked to #226
This commit is contained in:
Richard Menzies 2021-02-23 10:03:50 +00:00 committed by GitHub
parent 6c974ee1d3
commit 457f644f30
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 95 additions and 8 deletions

View File

@ -12,7 +12,10 @@ use asyncgit::{
sync::{self, CommitDetails, CommitId, CommitMessage}, sync::{self, CommitDetails, CommitId, CommitMessage},
CWD, CWD,
}; };
use crossterm::event::Event; use crossterm::event::{
Event,
MouseEventKind::{ScrollDown, ScrollUp},
};
use itertools::Itertools; use itertools::Itertools;
use std::clone::Clone; use std::clone::Clone;
use std::{borrow::Cow, cell::Cell}; use std::{borrow::Cow, cell::Cell};
@ -394,7 +397,15 @@ impl Component for DetailsComponent {
fn event(&mut self, event: Event) -> Result<bool> { fn event(&mut self, event: Event) -> Result<bool> {
if self.focused { if self.focused {
if let Event::Key(e) = event { if let Event::Mouse(mouse_ev) = event {
return Ok(match mouse_ev.kind {
ScrollUp => self.move_scroll_top(ScrollType::Up),
ScrollDown => {
self.move_scroll_top(ScrollType::Down)
}
_ => false,
});
} else if let Event::Key(e) = event {
return Ok(if e == self.key_config.move_up { return Ok(if e == self.key_config.move_up {
self.move_scroll_top(ScrollType::Up) self.move_scroll_top(ScrollType::Up)
} else if e == self.key_config.move_down { } else if e == self.key_config.move_down {

View File

@ -11,7 +11,10 @@ use crate::{
}; };
use anyhow::Result; use anyhow::Result;
use asyncgit::sync::Tags; use asyncgit::sync::Tags;
use crossterm::event::Event; use crossterm::event::{
Event,
MouseEventKind::{ScrollDown, ScrollUp},
};
use std::{ use std::{
borrow::Cow, cell::Cell, cmp, convert::TryFrom, time::Instant, borrow::Cow, cell::Cell, cmp, convert::TryFrom, time::Instant,
}; };
@ -346,7 +349,16 @@ impl DrawableComponent for CommitList {
impl Component for CommitList { impl Component for CommitList {
fn event(&mut self, ev: Event) -> Result<bool> { fn event(&mut self, ev: Event) -> Result<bool> {
if let Event::Key(k) = ev { if let Event::Mouse(mouse_ev) = ev {
let selection_changed = match mouse_ev.kind {
ScrollUp => self.move_selection(ScrollType::Up)?,
ScrollDown => {
self.move_selection(ScrollType::Down)?
}
_ => false,
};
return Ok(selection_changed);
} else if let Event::Key(k) = ev {
let selection_changed = if k == self.key_config.move_up { let selection_changed = if k == self.key_config.move_up {
self.move_selection(ScrollType::Up)? self.move_selection(ScrollType::Up)?
} else if k == self.key_config.move_down { } else if k == self.key_config.move_down {

View File

@ -11,7 +11,10 @@ use crate::{
use anyhow::Result; use anyhow::Result;
use asyncgit::{hash, sync, DiffLine, DiffLineType, FileDiff, CWD}; use asyncgit::{hash, sync, DiffLine, DiffLineType, FileDiff, CWD};
use bytesize::ByteSize; use bytesize::ByteSize;
use crossterm::event::Event; use crossterm::event::{
Event, KeyModifiers,
MouseEventKind::{ScrollDown, ScrollUp},
};
use std::{borrow::Cow, cell::Cell, cmp, path::Path}; use std::{borrow::Cow, cell::Cell, cmp, path::Path};
use tui::{ use tui::{
backend::Backend, backend::Backend,
@ -629,9 +632,54 @@ impl Component for DiffComponent {
CommandBlocking::PassingOn CommandBlocking::PassingOn
} }
#[allow(clippy::too_many_lines)]
fn event(&mut self, ev: Event) -> Result<bool> { fn event(&mut self, ev: Event) -> Result<bool> {
if self.focused { if self.focused {
if let Event::Key(e) = ev { if let Event::Mouse(mouse_ev) = ev {
return match mouse_ev.kind {
ScrollUp => {
match mouse_ev.modifiers {
KeyModifiers::SHIFT => {
self.modify_selection(Direction::Up);
}
KeyModifiers::CONTROL => {
self.modify_selection(Direction::Up);
self.modify_selection(Direction::Up);
self.modify_selection(Direction::Up);
}
KeyModifiers::NONE => {
self.move_selection(ScrollType::Up);
}
_ => {}
};
Ok(true)
}
ScrollDown => {
match mouse_ev.modifiers {
KeyModifiers::SHIFT => {
self.modify_selection(Direction::Down)
}
KeyModifiers::CONTROL => {
self.modify_selection(
Direction::Down,
);
self.modify_selection(
Direction::Down,
);
self.modify_selection(
Direction::Down,
);
}
KeyModifiers::NONE => {
self.move_selection(ScrollType::Down);
}
_ => {}
};
Ok(true)
}
_ => Ok(false),
};
} else if let Event::Key(e) = ev {
return if e == self.key_config.move_down { return if e == self.key_config.move_down {
self.move_selection(ScrollType::Down); self.move_selection(ScrollType::Down);
Ok(true) Ok(true)

View File

@ -15,7 +15,10 @@ use crate::{
}; };
use anyhow::Result; use anyhow::Result;
use asyncgit::{hash, StatusItem, StatusItemType}; use asyncgit::{hash, StatusItem, StatusItemType};
use crossterm::event::Event; use crossterm::event::{
Event,
MouseEventKind::{ScrollDown, ScrollUp},
};
use std::{borrow::Cow, cell::Cell, convert::From, path::Path}; use std::{borrow::Cow, cell::Cell, convert::From, path::Path};
use tui::{backend::Backend, layout::Rect, text::Span, Frame}; use tui::{backend::Backend, layout::Rect, text::Span, Frame};
@ -395,7 +398,17 @@ impl Component for FileTreeComponent {
fn event(&mut self, ev: Event) -> Result<bool> { fn event(&mut self, ev: Event) -> Result<bool> {
if self.focused { if self.focused {
if let Event::Key(e) = ev { if let Event::Mouse(mouse_ev) = ev {
return match mouse_ev.kind {
ScrollUp => {
Ok(self.move_selection(MoveSelection::Up))
}
ScrollDown => {
Ok(self.move_selection(MoveSelection::Down))
}
_ => Ok(false),
};
} else if let Event::Key(e) = ev {
return if e == self.key_config.move_down { return if e == self.key_config.move_down {
Ok(self.move_selection(MoveSelection::Down)) Ok(self.move_selection(MoveSelection::Down))
} else if e == self.key_config.move_up { } else if e == self.key_config.move_up {

View File

@ -35,6 +35,7 @@ use clap::{
}; };
use crossbeam_channel::{tick, unbounded, Receiver, Select}; use crossbeam_channel::{tick, unbounded, Receiver, Select};
use crossterm::{ use crossterm::{
event::{DisableMouseCapture, EnableMouseCapture},
terminal::{ terminal::{
disable_raw_mode, enable_raw_mode, EnterAlternateScreen, disable_raw_mode, enable_raw_mode, EnterAlternateScreen,
LeaveAlternateScreen, LeaveAlternateScreen,
@ -167,11 +168,13 @@ fn main() -> Result<()> {
fn setup_terminal() -> Result<()> { fn setup_terminal() -> Result<()> {
enable_raw_mode()?; enable_raw_mode()?;
io::stdout().execute(EnterAlternateScreen)?; io::stdout().execute(EnterAlternateScreen)?;
io::stdout().execute(EnableMouseCapture)?;
Ok(()) Ok(())
} }
fn shutdown_terminal() -> Result<()> { fn shutdown_terminal() -> Result<()> {
io::stdout().execute(LeaveAlternateScreen)?; io::stdout().execute(LeaveAlternateScreen)?;
io::stdout().execute(DisableMouseCapture)?;
disable_raw_mode()?; disable_raw_mode()?;
Ok(()) Ok(())
} }