Fix context menus not cycling over its edge when selecting items (#20592)

This commit is contained in:
Kirill Bulatov 2024-11-13 15:14:23 +01:00 committed by GitHub
parent 7e82ca8082
commit 84e47fb80b
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -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);
} }
} }