diff options
author | Bernhard Liebl <Bernhard.Liebl@gmx.org> | 2017-11-04 20:21:41 +0100 |
---|---|---|
committer | Bernhard Liebl <Bernhard.Liebl@gmx.org> | 2017-11-04 20:21:41 +0100 |
commit | 8f204d78fd20d0ad1008fa1643b863c863c0a0be (patch) | |
tree | 43b7c26100b018d1a7f252e63bd5b6bc1766277e /editor | |
parent | 3cbcf5c2ddadf1cd630137d6bd438634b8517b00 (diff) |
In Create New Node, always select and show best (shortest) match
Diffstat (limited to 'editor')
-rw-r--r-- | editor/create_dialog.cpp | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/editor/create_dialog.cpp b/editor/create_dialog.cpp index 520bf480fd..38484c8f52 100644 --- a/editor/create_dialog.cpp +++ b/editor/create_dialog.cpp @@ -171,6 +171,9 @@ void CreateDialog::add_type(const String &p_type, HashMap<String, TreeItem *> &p bool is_search_subsequence = search_box->get_text().is_subsequence_ofi(p_type); String to_select_type = *to_select ? (*to_select)->get_text(0) : ""; bool current_item_is_preffered = ClassDB::is_parent_class(p_type, preferred_search_result_type) && !ClassDB::is_parent_class(to_select_type, preferred_search_result_type); + if (*to_select && p_type.length() < (*to_select)->get_text(0).length()) { + current_item_is_preffered = true; + } if (((!*to_select || current_item_is_preffered) && is_search_subsequence) || search_box->get_text() == p_type) { *to_select = item; @@ -293,6 +296,7 @@ void CreateDialog::_update_search() { if (to_select) { to_select->select(0); + search_options->scroll_to_item(to_select); favorite->set_disabled(false); favorite->set_pressed(favorite_list.find(to_select->get_text(0)) != -1); } |