diff options
Diffstat (limited to 'editor')
-rw-r--r-- | editor/action_map_editor.cpp | 4 | ||||
-rw-r--r-- | editor/action_map_editor.h | 1 | ||||
-rw-r--r-- | editor/editor_autoload_settings.cpp | 4 | ||||
-rw-r--r-- | editor/editor_autoload_settings.h | 2 | ||||
-rw-r--r-- | editor/filesystem_dock.cpp | 7 | ||||
-rw-r--r-- | editor/filesystem_dock.h | 1 | ||||
-rw-r--r-- | editor/group_settings_editor.cpp | 4 | ||||
-rw-r--r-- | editor/group_settings_editor.h | 1 | ||||
-rw-r--r-- | editor/gui/editor_file_dialog.cpp | 6 | ||||
-rw-r--r-- | editor/project_settings_editor.cpp | 28 | ||||
-rw-r--r-- | editor/project_settings_editor.h | 1 | ||||
-rw-r--r-- | editor/shader_globals_editor.cpp | 4 | ||||
-rw-r--r-- | editor/shader_globals_editor.h | 2 |
13 files changed, 63 insertions, 2 deletions
diff --git a/editor/action_map_editor.cpp b/editor/action_map_editor.cpp index 5154d2e0e0..7856d454d0 100644 --- a/editor/action_map_editor.cpp +++ b/editor/action_map_editor.cpp @@ -380,6 +380,10 @@ LineEdit *ActionMapEditor::get_search_box() const { return action_list_search; } +LineEdit *ActionMapEditor::get_path_box() const { + return add_edit; +} + InputEventConfigurationDialog *ActionMapEditor::get_configuration_dialog() { return event_config_dialog; } diff --git a/editor/action_map_editor.h b/editor/action_map_editor.h index 2848d23e83..2b329f2fca 100644 --- a/editor/action_map_editor.h +++ b/editor/action_map_editor.h @@ -118,6 +118,7 @@ protected: public: LineEdit *get_search_box() const; + LineEdit *get_path_box() const; InputEventConfigurationDialog *get_configuration_dialog(); // Dictionary represents an Action with "events" (Array) and "deadzone" (float) items. Pass with no param to update list from cached action map. diff --git a/editor/editor_autoload_settings.cpp b/editor/editor_autoload_settings.cpp index a615acf9f8..a7b15e50d7 100644 --- a/editor/editor_autoload_settings.cpp +++ b/editor/editor_autoload_settings.cpp @@ -587,6 +587,10 @@ void EditorAutoloadSettings::_script_created(Ref<Script> p_script) { _autoload_add(); } +LineEdit *EditorAutoloadSettings::get_path_box() const { + return autoload_add_path; +} + Variant EditorAutoloadSettings::get_drag_data_fw(const Point2 &p_point, Control *p_control) { if (autoload_cache.size() <= 1) { return false; diff --git a/editor/editor_autoload_settings.h b/editor/editor_autoload_settings.h index 11d7cdbe4d..e4ac62e700 100644 --- a/editor/editor_autoload_settings.h +++ b/editor/editor_autoload_settings.h @@ -108,6 +108,8 @@ public: bool autoload_add(const String &p_name, const String &p_path); void autoload_remove(const String &p_name); + LineEdit *get_path_box() const; + EditorAutoloadSettings(); ~EditorAutoloadSettings(); }; diff --git a/editor/filesystem_dock.cpp b/editor/filesystem_dock.cpp index a7e40ce5b9..88fed16db1 100644 --- a/editor/filesystem_dock.cpp +++ b/editor/filesystem_dock.cpp @@ -2575,6 +2575,11 @@ void FileSystemDock::fix_dependencies(const String &p_for_file) { deps_editor->edit(p_for_file); } +void FileSystemDock::focus_on_path() { + current_path_line_edit->grab_focus(); + current_path_line_edit->select_all(); +} + void FileSystemDock::focus_on_filter() { LineEdit *current_search_box = nullptr; if (display_mode == DISPLAY_MODE_TREE_ONLY) { @@ -3398,6 +3403,8 @@ void FileSystemDock::_tree_gui_input(Ref<InputEvent> p_event) { _tree_rmb_option(FILE_OPEN_EXTERNAL); } else if (ED_IS_SHORTCUT("filesystem_dock/open_in_terminal", p_event)) { _tree_rmb_option(FILE_OPEN_IN_TERMINAL); + } else if (ED_IS_SHORTCUT("file_dialog/focus_path", p_event)) { + focus_on_path(); } else if (ED_IS_SHORTCUT("editor/open_search", p_event)) { focus_on_filter(); } else { diff --git a/editor/filesystem_dock.h b/editor/filesystem_dock.h index 06bf3eda52..acb7ca017b 100644 --- a/editor/filesystem_dock.h +++ b/editor/filesystem_dock.h @@ -386,6 +386,7 @@ public: String get_current_directory() const; void navigate_to_path(const String &p_path); + void focus_on_path(); void focus_on_filter(); ScriptCreateDialog *get_script_create_dialog() const; diff --git a/editor/group_settings_editor.cpp b/editor/group_settings_editor.cpp index 634192ab50..da169b36b2 100644 --- a/editor/group_settings_editor.cpp +++ b/editor/group_settings_editor.cpp @@ -483,6 +483,10 @@ void GroupSettingsEditor::_show_rename_dialog() { rename_group->grab_focus(); } +LineEdit *GroupSettingsEditor::get_name_box() const { + return group_name; +} + GroupSettingsEditor::GroupSettingsEditor() { ProjectSettings::get_singleton()->add_hidden_prefix("global_group/"); diff --git a/editor/group_settings_editor.h b/editor/group_settings_editor.h index 660c15865e..5be0013e96 100644 --- a/editor/group_settings_editor.h +++ b/editor/group_settings_editor.h @@ -90,6 +90,7 @@ protected: static void _bind_methods(); public: + LineEdit *get_name_box() const; void show_message(const String &p_message); void remove_references(const StringName &p_name); diff --git a/editor/gui/editor_file_dialog.cpp b/editor/gui/editor_file_dialog.cpp index d0b78a35cf..fe86ac442b 100644 --- a/editor/gui/editor_file_dialog.cpp +++ b/editor/gui/editor_file_dialog.cpp @@ -224,6 +224,7 @@ void EditorFileDialog::shortcut_input(const Ref<InputEvent> &p_event) { } if (ED_IS_SHORTCUT("file_dialog/focus_path", p_event)) { dir->grab_focus(); + dir->select_all(); handled = true; } if (ED_IS_SHORTCUT("file_dialog/move_favorite_up", p_event)) { @@ -1783,7 +1784,10 @@ EditorFileDialog::EditorFileDialog() { ED_SHORTCUT("file_dialog/toggle_mode", TTR("Toggle Mode"), KeyModifierMask::ALT | Key::V); ED_SHORTCUT("file_dialog/create_folder", TTR("Create Folder"), KeyModifierMask::CMD_OR_CTRL | Key::N); ED_SHORTCUT("file_dialog/delete", TTR("Delete"), Key::KEY_DELETE); - ED_SHORTCUT("file_dialog/focus_path", TTR("Focus Path"), KeyModifierMask::CMD_OR_CTRL | Key::D); + ED_SHORTCUT("file_dialog/focus_path", TTR("Focus Path"), KeyModifierMask::CMD_OR_CTRL | Key::L); + // Allow both Cmd + L and Cmd + Shift + G to match Safari's and Finder's shortcuts respectively. + ED_SHORTCUT_OVERRIDE_ARRAY("file_dialog/focus_path", "macos", + { int32_t(KeyModifierMask::META | Key::L), int32_t(KeyModifierMask::META | KeyModifierMask::SHIFT | Key::G) }); ED_SHORTCUT("file_dialog/move_favorite_up", TTR("Move Favorite Up"), KeyModifierMask::CMD_OR_CTRL | Key::UP); ED_SHORTCUT("file_dialog/move_favorite_down", TTR("Move Favorite Down"), KeyModifierMask::CMD_OR_CTRL | Key::DOWN); diff --git a/editor/project_settings_editor.cpp b/editor/project_settings_editor.cpp index b7f28068b7..57fbbecb60 100644 --- a/editor/project_settings_editor.cpp +++ b/editor/project_settings_editor.cpp @@ -256,11 +256,16 @@ void ProjectSettingsEditor::shortcut_input(const Ref<InputEvent> &p_event) { handled = true; } - if (k->is_match(InputEventKey::create_reference(KeyModifierMask::CMD_OR_CTRL | Key::F))) { + if (ED_IS_SHORTCUT("editor/open_search", p_event)) { _focus_current_search_box(); handled = true; } + if (ED_IS_SHORTCUT("file_dialog/focus_path", p_event)) { + _focus_current_path_box(); + handled = true; + } + if (handled) { set_input_as_handled(); } @@ -347,6 +352,27 @@ void ProjectSettingsEditor::_focus_current_search_box() { } } +void ProjectSettingsEditor::_focus_current_path_box() { + Control *tab = tab_container->get_current_tab_control(); + LineEdit *current_path_box = nullptr; + if (tab == general_editor) { + current_path_box = property_box; + } else if (tab == action_map_editor) { + current_path_box = action_map_editor->get_path_box(); + } else if (tab == autoload_settings) { + current_path_box = autoload_settings->get_path_box(); + } else if (tab == shaders_global_shader_uniforms_editor) { + current_path_box = shaders_global_shader_uniforms_editor->get_name_box(); + } else if (tab == group_settings) { + current_path_box = group_settings->get_name_box(); + } + + if (current_path_box) { + current_path_box->grab_focus(); + current_path_box->select_all(); + } +} + void ProjectSettingsEditor::_editor_restart() { ProjectSettings::get_singleton()->save(); EditorNode::get_singleton()->save_all_scenes(); diff --git a/editor/project_settings_editor.h b/editor/project_settings_editor.h index 7771bdda61..3107c18406 100644 --- a/editor/project_settings_editor.h +++ b/editor/project_settings_editor.h @@ -97,6 +97,7 @@ class ProjectSettingsEditor : public AcceptDialog { void _tabs_tab_changed(int p_tab); void _focus_current_search_box(); + void _focus_current_path_box(); void _editor_restart_request(); void _editor_restart(); diff --git a/editor/shader_globals_editor.cpp b/editor/shader_globals_editor.cpp index 46f520df45..97f6ce2215 100644 --- a/editor/shader_globals_editor.cpp +++ b/editor/shader_globals_editor.cpp @@ -356,6 +356,10 @@ String ShaderGlobalsEditor::_check_new_variable_name(const String &p_variable_na return ""; } +LineEdit *ShaderGlobalsEditor::get_name_box() const { + return variable_name; +} + void ShaderGlobalsEditor::_variable_name_text_changed(const String &p_variable_name) { const String &warning = _check_new_variable_name(p_variable_name.strip_edges()); variable_add->set_tooltip_text(warning); diff --git a/editor/shader_globals_editor.h b/editor/shader_globals_editor.h index fc50564aae..de871f76bf 100644 --- a/editor/shader_globals_editor.h +++ b/editor/shader_globals_editor.h @@ -61,6 +61,8 @@ protected: void _notification(int p_what); public: + LineEdit *get_name_box() const; + ShaderGlobalsEditor(); ~ShaderGlobalsEditor(); }; |