mirror of
https://github.com/extrawurst/gitui.git
synced 2025-01-07 18:21:31 +03:00
parent
6c974ee1d3
commit
457f644f30
@ -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 {
|
||||||
|
@ -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 {
|
||||||
|
@ -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)
|
||||||
|
@ -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 {
|
||||||
|
@ -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(())
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user