From 35887a2afef8de54551d36f5ad86944978ead36d Mon Sep 17 00:00:00 2001 From: Hugo Locurcio Date: Wed, 31 Mar 2021 15:56:01 +0200 Subject: [PATCH] Allow selecting multiple files in the editor translation/remap dialogs This makes it faster to add several translations. The undo/redo messages were also tweaked to give better context. --- editor/project_settings_editor.cpp | 56 ++++++++++++++++++------------ editor/project_settings_editor.h | 6 ++-- 2 files changed, 37 insertions(+), 25 deletions(-) diff --git a/editor/project_settings_editor.cpp b/editor/project_settings_editor.cpp index 211ffb03a6b..b002c9e8256 100644 --- a/editor/project_settings_editor.cpp +++ b/editor/project_settings_editor.cpp @@ -1156,20 +1156,29 @@ void ProjectSettingsEditor::_copy_to_platform(int p_which) { } void ProjectSettingsEditor::add_translation(const String &p_translation) { - _translation_add(p_translation); + PoolStringArray translations; + translations.push_back(p_translation); + _translation_add(translations); } -void ProjectSettingsEditor::_translation_add(const String &p_path) { +void ProjectSettingsEditor::_translation_add(const PoolStringArray &p_paths) { PoolStringArray translations = ProjectSettings::get_singleton()->get("locale/translations"); + for (int i = 0; i < p_paths.size(); i++) { + bool duplicate = false; + for (int j = 0; j < translations.size(); j++) { + if (translations[j] == p_paths[i]) { + duplicate = true; + break; + } + } - for (int i = 0; i < translations.size(); i++) { - if (translations[i] == p_path) { - return; //exists + // Don't add duplicate translation paths. + if (!duplicate) { + translations.push_back(p_paths[i]); } } - translations.push_back(p_path); - undo_redo->create_action(TTR("Add Translation")); + undo_redo->create_action(vformat(TTR("Add %d Translations"), p_paths.size())); undo_redo->add_do_property(ProjectSettings::get_singleton(), "locale/translations", translations); undo_redo->add_undo_property(ProjectSettings::get_singleton(), "locale/translations", ProjectSettings::get_singleton()->get("locale/translations")); undo_redo->add_do_method(this, "_update_translations"); @@ -1209,7 +1218,7 @@ void ProjectSettingsEditor::_translation_res_file_open() { translation_res_file_open->popup_centered_ratio(); } -void ProjectSettingsEditor::_translation_res_add(const String &p_path) { +void ProjectSettingsEditor::_translation_res_add(const PoolStringArray &p_paths) { Variant prev; Dictionary remaps; @@ -1218,13 +1227,14 @@ void ProjectSettingsEditor::_translation_res_add(const String &p_path) { prev = remaps; } - if (remaps.has(p_path)) { - return; //pointless already has it + for (int i = 0; i < p_paths.size(); i++) { + if (!remaps.has(p_paths[i])) { + // Don't overwrite with an empty remap array if an array already exists for the given path. + remaps[p_paths[i]] = PoolStringArray(); + } } - remaps[p_path] = PoolStringArray(); - - undo_redo->create_action(TTR("Add Remapped Path")); + undo_redo->create_action(vformat(TTR("Translation Resource Remap: Add %d Path(s)"), p_paths.size())); undo_redo->add_do_property(ProjectSettings::get_singleton(), "locale/translation_remaps", remaps); undo_redo->add_undo_property(ProjectSettings::get_singleton(), "locale/translation_remaps", prev); undo_redo->add_do_method(this, "_update_translations"); @@ -1237,7 +1247,7 @@ void ProjectSettingsEditor::_translation_res_add(const String &p_path) { void ProjectSettingsEditor::_translation_res_option_file_open() { translation_res_option_file_open->popup_centered_ratio(); } -void ProjectSettingsEditor::_translation_res_option_add(const String &p_path) { +void ProjectSettingsEditor::_translation_res_option_add(const PoolStringArray &p_paths) { ERR_FAIL_COND(!ProjectSettings::get_singleton()->has_setting("locale/translation_remaps")); Dictionary remaps = ProjectSettings::get_singleton()->get("locale/translation_remaps"); @@ -1249,10 +1259,12 @@ void ProjectSettingsEditor::_translation_res_option_add(const String &p_path) { ERR_FAIL_COND(!remaps.has(key)); PoolStringArray r = remaps[key]; - r.push_back(p_path + ":" + "en"); + for (int i = 0; i < p_paths.size(); i++) { + r.push_back(p_paths[i] + ":" + "en"); + } remaps[key] = r; - undo_redo->create_action(TTR("Resource Remap Add Remap")); + undo_redo->create_action(vformat(TTR("Translation Resource Remap: Add %d Remap(s)"), p_paths.size())); undo_redo->add_do_property(ProjectSettings::get_singleton(), "locale/translation_remaps", remaps); undo_redo->add_undo_property(ProjectSettings::get_singleton(), "locale/translation_remaps", ProjectSettings::get_singleton()->get("locale/translation_remaps")); undo_redo->add_do_method(this, "_update_translations"); @@ -1996,8 +2008,8 @@ ProjectSettingsEditor::ProjectSettingsEditor(EditorData *p_data) { translation_file_open = memnew(EditorFileDialog); add_child(translation_file_open); - translation_file_open->set_mode(EditorFileDialog::MODE_OPEN_FILE); - translation_file_open->connect("file_selected", this, "_translation_add"); + translation_file_open->set_mode(EditorFileDialog::MODE_OPEN_FILES); + translation_file_open->connect("files_selected", this, "_translation_add"); } { @@ -2022,8 +2034,8 @@ ProjectSettingsEditor::ProjectSettingsEditor(EditorData *p_data) { translation_res_file_open = memnew(EditorFileDialog); add_child(translation_res_file_open); - translation_res_file_open->set_mode(EditorFileDialog::MODE_OPEN_FILE); - translation_res_file_open->connect("file_selected", this, "_translation_res_add"); + translation_res_file_open->set_mode(EditorFileDialog::MODE_OPEN_FILES); + translation_res_file_open->connect("files_selected", this, "_translation_res_add"); thb = memnew(HBoxContainer); tvb->add_child(thb); @@ -2052,8 +2064,8 @@ ProjectSettingsEditor::ProjectSettingsEditor(EditorData *p_data) { translation_res_option_file_open = memnew(EditorFileDialog); add_child(translation_res_option_file_open); - translation_res_option_file_open->set_mode(EditorFileDialog::MODE_OPEN_FILE); - translation_res_option_file_open->connect("file_selected", this, "_translation_res_option_add"); + translation_res_option_file_open->set_mode(EditorFileDialog::MODE_OPEN_FILES); + translation_res_option_file_open->connect("files_selected", this, "_translation_res_option_add"); } { diff --git a/editor/project_settings_editor.h b/editor/project_settings_editor.h index 006151a5e5e..57b148157c2 100644 --- a/editor/project_settings_editor.h +++ b/editor/project_settings_editor.h @@ -139,16 +139,16 @@ class ProjectSettingsEditor : public AcceptDialog { void _copy_to_platform(int p_which); void _translation_file_open(); - void _translation_add(const String &p_path); + void _translation_add(const PoolStringArray &p_paths); void _translation_delete(Object *p_item, int p_column, int p_button); void _update_translations(); void _translation_res_file_open(); - void _translation_res_add(const String &p_path); + void _translation_res_add(const PoolStringArray &p_paths); void _translation_res_delete(Object *p_item, int p_column, int p_button); void _translation_res_select(); void _translation_res_option_file_open(); - void _translation_res_option_add(const String &p_path); + void _translation_res_option_add(const PoolStringArray &p_paths); void _translation_res_option_changed(); void _translation_res_option_delete(Object *p_item, int p_column, int p_button);