Don't dismiss context menu when right-clicking project panel again

Antonio Scandurra created

Change summary

crates/context_menu/src/context_menu.rs | 8 ++++++--
1 file changed, 6 insertions(+), 2 deletions(-)

Detailed changes

crates/context_menu/src/context_menu.rs 🔗

@@ -50,6 +50,7 @@ impl ContextMenuItem {
 }
 
 pub struct ContextMenu {
+    show_count: usize,
     position: Vector2F,
     items: Vec<ContextMenuItem>,
     selected_index: Option<usize>,
@@ -106,6 +107,7 @@ impl View for ContextMenu {
 impl ContextMenu {
     pub fn new(cx: &mut ViewContext<Self>) -> Self {
         Self {
+            show_count: 0,
             position: Default::default(),
             items: Default::default(),
             selected_index: Default::default(),
@@ -143,8 +145,9 @@ impl ContextMenu {
 
     fn cancel(&mut self, _: &Cancel, cx: &mut ViewContext<Self>) {
         self.reset(cx);
-        cx.defer(|this, cx| {
-            if cx.handle().is_focused(cx) {
+        let show_count = self.show_count;
+        cx.defer(move |this, cx| {
+            if cx.handle().is_focused(cx) && this.show_count == show_count {
                 let window_id = cx.window_id();
                 (**cx).focus(window_id, this.previously_focused_view_id.take());
             }
@@ -212,6 +215,7 @@ impl ContextMenu {
             self.items = items.collect();
             self.position = position;
             self.visible = true;
+            self.show_count += 1;
             if !cx.is_self_focused() {
                 self.previously_focused_view_id = cx.focused_view_id(cx.window_id());
             }