Add handlers for arrow keys
This commit is contained in:
parent
dc8433ce59
commit
6e14a0baea
3 changed files with 91 additions and 3 deletions
30
src/app.rs
30
src/app.rs
|
|
@ -47,6 +47,10 @@ pub enum Action {
|
||||||
EditLocation,
|
EditLocation,
|
||||||
HistoryNext,
|
HistoryNext,
|
||||||
HistoryPrevious,
|
HistoryPrevious,
|
||||||
|
ItemDown,
|
||||||
|
ItemLeft,
|
||||||
|
ItemRight,
|
||||||
|
ItemUp,
|
||||||
LocationUp,
|
LocationUp,
|
||||||
MoveToTrash,
|
MoveToTrash,
|
||||||
NewFile,
|
NewFile,
|
||||||
|
|
@ -79,6 +83,10 @@ impl Action {
|
||||||
Action::EditLocation => Message::EditLocation(entity_opt),
|
Action::EditLocation => Message::EditLocation(entity_opt),
|
||||||
Action::HistoryNext => Message::TabMessage(entity_opt, tab::Message::GoNext),
|
Action::HistoryNext => Message::TabMessage(entity_opt, tab::Message::GoNext),
|
||||||
Action::HistoryPrevious => Message::TabMessage(entity_opt, tab::Message::GoPrevious),
|
Action::HistoryPrevious => Message::TabMessage(entity_opt, tab::Message::GoPrevious),
|
||||||
|
Action::ItemDown => Message::TabMessage(entity_opt, tab::Message::ItemDown),
|
||||||
|
Action::ItemLeft => Message::TabMessage(entity_opt, tab::Message::ItemLeft),
|
||||||
|
Action::ItemRight => Message::TabMessage(entity_opt, tab::Message::ItemRight),
|
||||||
|
Action::ItemUp => Message::TabMessage(entity_opt, tab::Message::ItemUp),
|
||||||
Action::LocationUp => Message::TabMessage(entity_opt, tab::Message::LocationUp),
|
Action::LocationUp => Message::TabMessage(entity_opt, tab::Message::LocationUp),
|
||||||
Action::MoveToTrash => Message::MoveToTrash(entity_opt),
|
Action::MoveToTrash => Message::MoveToTrash(entity_opt),
|
||||||
Action::NewFile => Message::NewItem(entity_opt, false),
|
Action::NewFile => Message::NewItem(entity_opt, false),
|
||||||
|
|
@ -658,10 +666,26 @@ impl Application for App {
|
||||||
// Usually, the Escape key (for example) closes menus and panes one by one instead
|
// Usually, the Escape key (for example) closes menus and panes one by one instead
|
||||||
// of closing everything on one press
|
// of closing everything on one press
|
||||||
// TODO: Close MenuBar too
|
// TODO: Close MenuBar too
|
||||||
match self.tab_model.data_mut::<Tab>(entity) {
|
if let Some(tab) = self.tab_model.data_mut::<Tab>(entity) {
|
||||||
Some(tab) if tab.context_menu.is_some() => tab.context_menu = None,
|
if tab.context_menu.is_some() {
|
||||||
_ => self.core.window.show_context = false,
|
tab.context_menu = None;
|
||||||
|
return Command::none();
|
||||||
|
}
|
||||||
|
|
||||||
|
if let Some(ref mut items) = tab.items_opt {
|
||||||
|
let mut had_selection = false;
|
||||||
|
for item in items.iter_mut() {
|
||||||
|
if item.selected {
|
||||||
|
item.selected = false;
|
||||||
|
had_selection = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if had_selection {
|
||||||
|
return Command::none();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
self.core.window.show_context = false;
|
||||||
|
|
||||||
Command::none()
|
Command::none()
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -65,6 +65,16 @@ pub fn key_binds() -> HashMap<KeyBind, Action> {
|
||||||
bind!([Ctrl], Key::Character("l".into()), EditLocation);
|
bind!([Ctrl], Key::Character("l".into()), EditLocation);
|
||||||
bind!([Alt], Key::Named(Named::ArrowRight), HistoryNext);
|
bind!([Alt], Key::Named(Named::ArrowRight), HistoryNext);
|
||||||
bind!([Alt], Key::Named(Named::ArrowLeft), HistoryPrevious);
|
bind!([Alt], Key::Named(Named::ArrowLeft), HistoryPrevious);
|
||||||
|
// Catch arrow keys
|
||||||
|
bind!([], Key::Named(Named::ArrowDown), ItemDown);
|
||||||
|
bind!([], Key::Named(Named::ArrowLeft), ItemLeft);
|
||||||
|
bind!([], Key::Named(Named::ArrowRight), ItemRight);
|
||||||
|
bind!([], Key::Named(Named::ArrowUp), ItemUp);
|
||||||
|
// We also need to catch these when shift is held
|
||||||
|
bind!([Shift], Key::Named(Named::ArrowDown), ItemDown);
|
||||||
|
bind!([Shift], Key::Named(Named::ArrowLeft), ItemLeft);
|
||||||
|
bind!([Shift], Key::Named(Named::ArrowRight), ItemRight);
|
||||||
|
bind!([Shift], Key::Named(Named::ArrowUp), ItemUp);
|
||||||
bind!([Alt], Key::Named(Named::ArrowUp), LocationUp);
|
bind!([Alt], Key::Named(Named::ArrowUp), LocationUp);
|
||||||
bind!([], Key::Named(Named::Delete), MoveToTrash);
|
bind!([], Key::Named(Named::Delete), MoveToTrash);
|
||||||
bind!([Ctrl, Shift], Key::Character("N".into()), NewFolder);
|
bind!([Ctrl, Shift], Key::Character("N".into()), NewFolder);
|
||||||
|
|
|
||||||
54
src/tab.rs
54
src/tab.rs
|
|
@ -373,6 +373,10 @@ pub enum Message {
|
||||||
EditLocation(Option<Location>),
|
EditLocation(Option<Location>),
|
||||||
GoNext,
|
GoNext,
|
||||||
GoPrevious,
|
GoPrevious,
|
||||||
|
ItemDown,
|
||||||
|
ItemLeft,
|
||||||
|
ItemRight,
|
||||||
|
ItemUp,
|
||||||
Location(Location),
|
Location(Location),
|
||||||
LocationUp,
|
LocationUp,
|
||||||
Open,
|
Open,
|
||||||
|
|
@ -705,6 +709,56 @@ impl Tab {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Message::ItemDown | Message::ItemLeft => {
|
||||||
|
//TODO: handle grid correctly
|
||||||
|
//TODO: do not wrap
|
||||||
|
if let Some(ref mut items) = self.items_opt {
|
||||||
|
let mut last_selected_opt = None;
|
||||||
|
for (i, item) in items.iter_mut().enumerate() {
|
||||||
|
if item.selected {
|
||||||
|
if !modifiers.contains(Modifiers::SHIFT) {
|
||||||
|
item.selected = false;
|
||||||
|
}
|
||||||
|
last_selected_opt = Some(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (i, item) in items.iter_mut().enumerate() {
|
||||||
|
if !self.config.show_hidden && item.hidden {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if last_selected_opt.map_or(true, |last_selected| i > last_selected) {
|
||||||
|
item.selected = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Message::ItemUp | Message::ItemRight => {
|
||||||
|
//TODO: handle grid correctly
|
||||||
|
//TODO: do not wrap
|
||||||
|
if let Some(ref mut items) = self.items_opt {
|
||||||
|
let mut last_selected_opt = None;
|
||||||
|
for (i, item) in items.iter_mut().enumerate().rev() {
|
||||||
|
if item.selected {
|
||||||
|
if !modifiers.contains(Modifiers::SHIFT) {
|
||||||
|
item.selected = false;
|
||||||
|
}
|
||||||
|
last_selected_opt = Some(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (i, item) in items.iter_mut().enumerate().rev() {
|
||||||
|
if !self.config.show_hidden && item.hidden {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if last_selected_opt.map_or(true, |last_selected| i < last_selected) {
|
||||||
|
item.selected = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Message::Location(location) => {
|
Message::Location(location) => {
|
||||||
cd = Some(location);
|
cd = Some(location);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue