From b8493dca823232f13eb21ecd976276c3187d2c25 Mon Sep 17 00:00:00 2001 From: kobewi Date: Sun, 22 Jan 2023 19:24:11 +0100 Subject: [PATCH] Reselect signal after tree update --- editor/connections_dialog.cpp | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/editor/connections_dialog.cpp b/editor/connections_dialog.cpp index 9ff480f130e..7905dde913c 100644 --- a/editor/connections_dialog.cpp +++ b/editor/connections_dialog.cpp @@ -985,6 +985,10 @@ void ConnectionsDock::set_node(Node *p_node) { } void ConnectionsDock::update_tree() { + String prev_selected; + if (tree->is_anything_selected()) { + prev_selected = tree->get_selected()->get_text(0); + } tree->clear(); if (!selected_node) { @@ -1076,7 +1080,14 @@ void ConnectionsDock::update_tree() { // Create the children of the subsection - the actual list of signals. TreeItem *signal_item = tree->create_item(section_item); - signal_item->set_text(0, String(signal_name) + signaldesc); + String signame = String(signal_name) + signaldesc; + signal_item->set_text(0, signame); + + if (signame == prev_selected) { + signal_item->select(0); + prev_selected = ""; + } + Dictionary sinfo; sinfo["name"] = signal_name; sinfo["args"] = argnames;