mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-13 05:42:59 +00:00
Fix context menus not cycling over its edge when selecting items (#20592)
This commit is contained in:
parent
7e82ca8082
commit
84e47fb80b
1 changed files with 21 additions and 12 deletions
|
@ -262,29 +262,38 @@ impl ContextMenu {
|
||||||
|
|
||||||
fn select_next(&mut self, _: &SelectNext, cx: &mut ViewContext<Self>) {
|
fn select_next(&mut self, _: &SelectNext, cx: &mut ViewContext<Self>) {
|
||||||
if let Some(ix) = self.selected_index {
|
if let Some(ix) = self.selected_index {
|
||||||
for (ix, item) in self.items.iter().enumerate().skip(ix + 1) {
|
let next_index = ix + 1;
|
||||||
if item.is_selectable() {
|
if self.items.len() <= next_index {
|
||||||
self.selected_index = Some(ix);
|
self.select_first(&SelectFirst, cx);
|
||||||
cx.notify();
|
} else {
|
||||||
break;
|
for (ix, item) in self.items.iter().enumerate().skip(next_index) {
|
||||||
|
if item.is_selectable() {
|
||||||
|
self.selected_index = Some(ix);
|
||||||
|
cx.notify();
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
self.select_first(&Default::default(), cx);
|
self.select_first(&SelectFirst, cx);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn select_prev(&mut self, _: &SelectPrev, cx: &mut ViewContext<Self>) {
|
pub fn select_prev(&mut self, _: &SelectPrev, cx: &mut ViewContext<Self>) {
|
||||||
if let Some(ix) = self.selected_index {
|
if let Some(ix) = self.selected_index {
|
||||||
for (ix, item) in self.items.iter().enumerate().take(ix).rev() {
|
if ix == 0 {
|
||||||
if item.is_selectable() {
|
self.handle_select_last(&SelectLast, cx);
|
||||||
self.selected_index = Some(ix);
|
} else {
|
||||||
cx.notify();
|
for (ix, item) in self.items.iter().enumerate().take(ix).rev() {
|
||||||
break;
|
if item.is_selectable() {
|
||||||
|
self.selected_index = Some(ix);
|
||||||
|
cx.notify();
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
self.handle_select_last(&Default::default(), cx);
|
self.handle_select_last(&SelectLast, cx);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue