summaryrefslogtreecommitdiff
path: root/editor
diff options
context:
space:
mode:
authorErik <35656626+SeleckyErik@users.noreply.github.com>2019-02-08 18:42:05 +0100
committerErik <35656626+SeleckyErik@users.noreply.github.com>2019-02-08 18:42:05 +0100
commita83877a8e84b949061b7c48a92e4636fbfd3d19d (patch)
tree713fbece28ebd5449dfc75a3c41cea3a2d43448d /editor
parent16d402147b9057c9f7d43ef9b46eb8654e5483cc (diff)
Moves cursor to and selects "new_script" in Create Script dialog
When Create Script dialog pops up, the cursor in the Path LineEdit is moved to the "new_script" name placeholder and it is selected.
Diffstat (limited to 'editor')
-rw-r--r--editor/script_create_dialog.cpp18
-rw-r--r--editor/script_create_dialog.h1
2 files changed, 19 insertions, 0 deletions
diff --git a/editor/script_create_dialog.cpp b/editor/script_create_dialog.cpp
index 6a3ed1c5e0..1fc682920d 100644
--- a/editor/script_create_dialog.cpp
+++ b/editor/script_create_dialog.cpp
@@ -50,6 +50,22 @@ void ScriptCreateDialog::_notification(int p_what) {
}
}
+void ScriptCreateDialog::_path_hbox_sorted() {
+ if (is_visible()) {
+ int filename_start_pos = initial_bp.find_last("/") + 1;
+ int filename_end_pos = initial_bp.length();
+
+ file_path->select(filename_start_pos, filename_end_pos);
+
+ // First set cursor to the end of line to scroll LineEdit view
+ // to the right and then set the actual cursor position.
+ file_path->set_cursor_position(file_path->get_text().length());
+ file_path->set_cursor_position(filename_start_pos);
+
+ file_path->grab_focus();
+ }
+}
+
bool ScriptCreateDialog::_can_be_built_in() {
return (supports_built_in && built_in_enabled);
}
@@ -586,6 +602,7 @@ void ScriptCreateDialog::_update_dialog() {
void ScriptCreateDialog::_bind_methods() {
+ ClassDB::bind_method("_path_hbox_sorted", &ScriptCreateDialog::_path_hbox_sorted);
ClassDB::bind_method("_class_name_changed", &ScriptCreateDialog::_class_name_changed);
ClassDB::bind_method("_parent_name_changed", &ScriptCreateDialog::_parent_name_changed);
ClassDB::bind_method("_lang_changed", &ScriptCreateDialog::_lang_changed);
@@ -760,6 +777,7 @@ ScriptCreateDialog::ScriptCreateDialog() {
/* Path */
hb = memnew(HBoxContainer);
+ hb->connect("sort_children", this, "_path_hbox_sorted");
file_path = memnew(LineEdit);
file_path->connect("text_changed", this, "_path_changed");
file_path->connect("text_entered", this, "_path_entered");
diff --git a/editor/script_create_dialog.h b/editor/script_create_dialog.h
index 15e838d69f..038c5c0bce 100644
--- a/editor/script_create_dialog.h
+++ b/editor/script_create_dialog.h
@@ -75,6 +75,7 @@ class ScriptCreateDialog : public ConfirmationDialog {
String script_template;
Vector<String> template_list;
+ void _path_hbox_sorted();
bool _can_be_built_in();
void _path_changed(const String &p_path = String());
void _path_entered(const String &p_path = String());