From 6e4f20950317aef150bcc3ac8d2e914cecba06f1 Mon Sep 17 00:00:00 2001 From: Yuri Roubinsky Date: Tue, 17 Dec 2019 16:51:49 +0300 Subject: [PATCH] Fix toggle scripts panel to allow using shortcut in other areas --- editor/code_editor.cpp | 10 +++++++--- editor/code_editor.h | 1 + editor/plugins/script_editor_plugin.cpp | 19 +++++++++++++++++-- editor/plugins/script_editor_plugin.h | 2 +- 4 files changed, 26 insertions(+), 6 deletions(-) diff --git a/editor/code_editor.cpp b/editor/code_editor.cpp index 5d8aff67d173..30fc3789dc50 100644 --- a/editor/code_editor.cpp +++ b/editor/code_editor.cpp @@ -1509,7 +1509,7 @@ void CodeTextEditor::_set_show_warnings_panel(bool p_show) { } void CodeTextEditor::_toggle_scripts_pressed() { - toggle_scripts_button->set_icon(ScriptEditor::get_singleton()->toggle_scripts_panel() ? get_icon("Back", "EditorIcons") : get_icon("Forward", "EditorIcons")); + toggle_scripts_button->set_icon(ScriptEditor::get_singleton()->toggle_scripts_panel(this) ? get_icon("Back", "EditorIcons") : get_icon("Forward", "EditorIcons")); } void CodeTextEditor::_error_pressed(const Ref &p_event) { @@ -1528,7 +1528,7 @@ void CodeTextEditor::_notification(int p_what) { } break; case NOTIFICATION_THEME_CHANGED: { if (toggle_scripts_button->is_visible()) { - toggle_scripts_button->set_icon(ScriptEditor::get_singleton()->is_scripts_panel_toggled() ? get_icon("Back", "EditorIcons") : get_icon("Forward", "EditorIcons")); + update_toggle_scripts_button(); } _update_font(); } break; @@ -1652,6 +1652,10 @@ void CodeTextEditor::show_toggle_scripts_button() { toggle_scripts_button->show(); } +void CodeTextEditor::update_toggle_scripts_button() { + toggle_scripts_button->set_icon(ScriptEditor::get_singleton()->is_scripts_panel_toggled() ? get_icon("Back", "EditorIcons") : get_icon("Forward", "EditorIcons")); +} + CodeTextEditor::CodeTextEditor() { code_complete_func = NULL; @@ -1696,7 +1700,7 @@ CodeTextEditor::CodeTextEditor() { toggle_scripts_button = memnew(ToolButton); toggle_scripts_button->connect("pressed", this, "_toggle_scripts_pressed"); status_bar->add_child(toggle_scripts_button); - toggle_scripts_button->set_shortcut(ED_SHORTCUT("script_editor/toggle_scripts_panel", TTR("Toggle Scripts Panel"), KEY_MASK_CMD | KEY_BACKSLASH)); + toggle_scripts_button->set_tooltip(TTR("Toggle Scripts Panel") + " (" + ED_GET_SHORTCUT("script_editor/toggle_scripts_panel")->get_as_text() + ")"); toggle_scripts_button->hide(); // Error diff --git a/editor/code_editor.h b/editor/code_editor.h index 6d85f353f95c..118d95a10ec8 100644 --- a/editor/code_editor.h +++ b/editor/code_editor.h @@ -256,6 +256,7 @@ class CodeTextEditor : public VBoxContainer { void validate_script(); void show_toggle_scripts_button(); + void update_toggle_scripts_button(); CodeTextEditor(); }; diff --git a/editor/plugins/script_editor_plugin.cpp b/editor/plugins/script_editor_plugin.cpp index be6f45e75a17..54b9cf063017 100644 --- a/editor/plugins/script_editor_plugin.cpp +++ b/editor/plugins/script_editor_plugin.cpp @@ -987,8 +987,11 @@ Array ScriptEditor::_get_open_scripts() const { return ret; } -bool ScriptEditor::toggle_scripts_panel() { +bool ScriptEditor::toggle_scripts_panel(CodeTextEditor *p_editor) { list_split->set_visible(!list_split->is_visible()); + if (p_editor) { + p_editor->update_toggle_scripts_button(); + } return list_split->is_visible(); } @@ -1137,7 +1140,16 @@ void ScriptEditor::_menu_option(int p_option) { debug_menu->get_popup()->set_item_checked(debug_menu->get_popup()->get_item_index(DEBUG_WITH_EXTERNAL_EDITOR), debug_with_external_editor); } break; case TOGGLE_SCRIPTS_PANEL: { - toggle_scripts_panel(); + if (current) { + CodeTextEditor *code_editor = NULL; + ScriptTextEditor *editor = dynamic_cast(current); + if (editor) { + code_editor = editor->code_editor; + } + toggle_scripts_panel(code_editor); + } else { + toggle_scripts_panel(NULL); + } } } @@ -3315,6 +3327,9 @@ ScriptEditor::ScriptEditor(EditorNode *p_editor) { file_menu->get_popup()->add_separator(); file_menu->get_popup()->add_shortcut(ED_SHORTCUT("script_editor/run_file", TTR("Run"), KEY_MASK_CMD | KEY_MASK_SHIFT | KEY_X), FILE_RUN); + + file_menu->get_popup()->add_separator(); + file_menu->get_popup()->add_shortcut(ED_SHORTCUT("script_editor/toggle_scripts_panel", TTR("Toggle Scripts Panel"), KEY_MASK_CMD | KEY_BACKSLASH), TOGGLE_SCRIPTS_PANEL); file_menu->get_popup()->connect("id_pressed", this, "_menu_option"); script_search_menu = memnew(MenuButton); diff --git a/editor/plugins/script_editor_plugin.h b/editor/plugins/script_editor_plugin.h index e2fd67676bf2..e40d596be77e 100644 --- a/editor/plugins/script_editor_plugin.h +++ b/editor/plugins/script_editor_plugin.h @@ -419,7 +419,7 @@ class ScriptEditor : public PanelContainer { public: static ScriptEditor *get_singleton() { return script_editor; } - bool toggle_scripts_panel(); + bool toggle_scripts_panel(CodeTextEditor *p_editor); bool is_scripts_panel_toggled(); void ensure_focus_current(); void apply_scripts() const;