summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorYuri Sizov <11782833+YuriSizov@users.noreply.github.com>2023-07-10 16:30:14 +0200
committerGitHub <noreply@github.com>2023-07-10 16:30:14 +0200
commitef155c1aeb216fa5a732913b6f2dc321e4b512dc (patch)
tree4f4d12837e4cd4a81f174b21911e54715a171349
parent349e44091da989c63b19b214e125b2368a76c06c (diff)
parent59ae7e2445a43a126c9ce01de156a1c1a279faa8 (diff)
downloadredot-engine-ef155c1aeb216fa5a732913b6f2dc321e4b512dc.tar.gz
Merge pull request #79078 from KoBeWi/if_you_gaze_into_the_empty_bottom_panel,_the_empty_bottom_panel_gazes_also_into_you
Collapse bottom panel if there is no active tab
-rw-r--r--editor/editor_node.cpp18
1 files changed, 13 insertions, 5 deletions
diff --git a/editor/editor_node.cpp b/editor/editor_node.cpp
index 0c74468816..f3c35e80fc 100644
--- a/editor/editor_node.cpp
+++ b/editor/editor_node.cpp
@@ -5275,21 +5275,29 @@ void EditorNode::_save_central_editor_layout_to_config(Ref<ConfigFile> p_config_
void EditorNode::_load_central_editor_layout_from_config(Ref<ConfigFile> p_config_file) {
// Bottom panel.
- if (p_config_file->has_section_key(EDITOR_NODE_CONFIG_SECTION, "center_split_offset")) {
- int center_split_offset = p_config_file->get_value(EDITOR_NODE_CONFIG_SECTION, "center_split_offset");
- center_split->set_split_offset(center_split_offset);
- }
-
+ bool has_active_tab = false;
if (p_config_file->has_section_key(EDITOR_NODE_CONFIG_SECTION, "selected_bottom_panel_item")) {
int selected_bottom_panel_item_idx = p_config_file->get_value(EDITOR_NODE_CONFIG_SECTION, "selected_bottom_panel_item");
if (selected_bottom_panel_item_idx >= 0 && selected_bottom_panel_item_idx < bottom_panel_items.size()) {
// Make sure we don't try to open contextual editors which are not enabled in the current context.
if (bottom_panel_items[selected_bottom_panel_item_idx].button->is_visible()) {
_bottom_panel_switch(true, selected_bottom_panel_item_idx);
+ has_active_tab = true;
}
}
}
+ if (p_config_file->has_section_key(EDITOR_NODE_CONFIG_SECTION, "center_split_offset")) {
+ int center_split_offset = p_config_file->get_value(EDITOR_NODE_CONFIG_SECTION, "center_split_offset");
+ center_split->set_split_offset(center_split_offset);
+
+ // If there is no active tab we need to collapse the panel.
+ if (!has_active_tab) {
+ bottom_panel_items[0].control->show(); // _bottom_panel_switch() can collapse only visible tabs.
+ _bottom_panel_switch(false, 0);
+ }
+ }
+
// Debugger tab.
if (p_config_file->has_section_key(EDITOR_NODE_CONFIG_SECTION, "selected_default_debugger_tab_idx")) {