Browse Source

Merge pull request #94053 from Hilderin/fix-toggle-last-opened-bottom-panel-after-restoring-to-side

Fix Toggle Last Opened Bottom Panel not working after restoring FileSystem Dock to the side
Rémi Verschelde 1 year ago
parent
commit
efae318304
1 changed files with 12 additions and 1 deletions
  1. 12 1
      editor/gui/editor_bottom_panel.cpp

+ 12 - 1
editor/gui/editor_bottom_panel.cpp

@@ -188,10 +188,11 @@ Button *EditorBottomPanel::add_item(String p_text, Control *p_item, const Ref<Sh
 }
 }
 
 
 void EditorBottomPanel::remove_item(Control *p_item) {
 void EditorBottomPanel::remove_item(Control *p_item) {
+	bool was_visible = false;
 	for (int i = 0; i < items.size(); i++) {
 	for (int i = 0; i < items.size(); i++) {
 		if (items[i].control == p_item) {
 		if (items[i].control == p_item) {
 			if (p_item->is_visible_in_tree()) {
 			if (p_item->is_visible_in_tree()) {
-				_switch_to_item(false, i);
+				was_visible = true;
 			}
 			}
 			item_vbox->remove_child(items[i].control);
 			item_vbox->remove_child(items[i].control);
 			button_hbox->remove_child(items[i].button);
 			button_hbox->remove_child(items[i].button);
@@ -200,6 +201,16 @@ void EditorBottomPanel::remove_item(Control *p_item) {
 			break;
 			break;
 		}
 		}
 	}
 	}
+
+	if (was_visible) {
+		// Open the first panel to ensure that if the removed dock was visible, the bottom
+		// panel will not collapse.
+		_switch_to_item(true, 0);
+	} else if (last_opened_control == p_item) {
+		// When a dock is removed by plugins, it might not have been visible, and it
+		// might have been the last_opened_control. We need to make sure to reset the last opened control.
+		last_opened_control = items[0].control;
+	}
 }
 }
 
 
 void EditorBottomPanel::make_item_visible(Control *p_item, bool p_visible) {
 void EditorBottomPanel::make_item_visible(Control *p_item, bool p_visible) {