Merge pull request #11706 from toger5/create_node_preferred_logic

added smart searching with preferrence to root node
This commit is contained in:
Andreas Haas 2017-10-02 22:49:28 +02:00 committed by GitHub
commit 359704bccf
3 changed files with 34 additions and 7 deletions

View file

@ -168,8 +168,11 @@ void CreateDialog::add_type(const String &p_type, HashMap<String, TreeItem *> &p
item->set_custom_color(0, get_color("disabled_font_color", "Editor")); item->set_custom_color(0, get_color("disabled_font_color", "Editor"));
item->set_selectable(0, false); item->set_selectable(0, false);
} else { } else {
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 && (search_box->get_text().is_subsequence_ofi(p_type))) || search_box->get_text() == p_type) { if (((!*to_select || current_item_is_preffered) && is_search_subsequence) || search_box->get_text() == p_type) {
*to_select = item; *to_select = item;
} }
} }
@ -361,6 +364,19 @@ void CreateDialog::set_base_type(const String &p_base) {
_update_search(); _update_search();
} }
String CreateDialog::get_base_type() const {
return base_type;
}
void CreateDialog::set_preferred_search_result_type(const String &p_preferred_type) {
preferred_search_result_type = p_preferred_type;
}
String CreateDialog::get_preferred_search_result_type() {
return preferred_search_result_type;
}
String CreateDialog::get_selected_type() { String CreateDialog::get_selected_type() {
TreeItem *selected = search_options->get_selected(); TreeItem *selected = search_options->get_selected();
@ -411,11 +427,6 @@ Object *CreateDialog::instance_selected() {
return NULL; return NULL;
} }
String CreateDialog::get_base_type() const {
return base_type;
}
void CreateDialog::_item_selected() { void CreateDialog::_item_selected() {
TreeItem *item = search_options->get_selected(); TreeItem *item = search_options->get_selected();
@ -654,6 +665,7 @@ CreateDialog::CreateDialog() {
search_options->connect("cell_selected", this, "_item_selected"); search_options->connect("cell_selected", this, "_item_selected");
//search_options->set_hide_root(true); //search_options->set_hide_root(true);
base_type = "Object"; base_type = "Object";
preferred_search_result_type = "";
help_bit = memnew(EditorHelpBit); help_bit = memnew(EditorHelpBit);
vbc->add_margin_child(TTR("Description:"), help_bit); vbc->add_margin_child(TTR("Description:"), help_bit);

View file

@ -53,7 +53,7 @@ class CreateDialog : public ConfirmationDialog {
LineEdit *search_box; LineEdit *search_box;
Tree *search_options; Tree *search_options;
String base_type; String base_type;
String preferred_search_result_type;
EditorHelpBit *help_bit; EditorHelpBit *help_bit;
void _item_selected(); void _item_selected();
@ -93,6 +93,9 @@ public:
void set_base_type(const String &p_base); void set_base_type(const String &p_base);
String get_base_type() const; String get_base_type() const;
void set_preferred_search_result_type(const String &p_preferred_type);
String get_preferred_search_result_type();
void popup_create(bool p_dontclear); void popup_create(bool p_dontclear);
CreateDialog(); CreateDialog();

View file

@ -270,6 +270,18 @@ void SceneTreeDock::_tool_selected(int p_tool, bool p_confirm_override) {
switch (p_tool) { switch (p_tool) {
case TOOL_NEW: { case TOOL_NEW: {
String preferred = "";
Node *current_edited_scene_root = EditorNode::get_singleton()->get_edited_scene();
if (current_edited_scene_root) {
if (ClassDB::is_parent_class(current_edited_scene_root->get_class_name(), "Node2D"))
preferred = "Node2D";
else if (ClassDB::is_parent_class(current_edited_scene_root->get_class_name(), "Spatial"))
preferred = "Spatial";
}
create_dialog->set_preferred_search_result_type(preferred);
create_dialog->popup_create(true); create_dialog->popup_create(true);
} break; } break;
case TOOL_INSTANCE: { case TOOL_INSTANCE: {