summaryrefslogtreecommitdiffstats
path: root/editor/fbx_importer_manager.cpp
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2023-03-03 13:10:06 +0100
committerRémi Verschelde <rverschelde@gmail.com>2023-03-03 13:53:03 +0100
commitd81e6ee024a8c64b80ac25c96b33c749ba1db79d (patch)
tree699cea5d99e3448e87ac89091b1dce8521009afb /editor/fbx_importer_manager.cpp
parent61d2c855114c824f5ca27ded0a1fa71cc7b21134 (diff)
downloadredot-engine-d81e6ee024a8c64b80ac25c96b33c749ba1db79d.tar.gz
FBX: Disable importer when canceling FBX2glTF setup
Pretty hacky solution but it's better than an infinite loop. All this import setup needs to be redone, it's very difficult to properly bail out from an invalid import without triggering reimport loops. Also fix underline not visible at default editor scale in LinkButton. Fixes #73319.
Diffstat (limited to 'editor/fbx_importer_manager.cpp')
-rw-r--r--editor/fbx_importer_manager.cpp26
1 files changed, 25 insertions, 1 deletions
diff --git a/editor/fbx_importer_manager.cpp b/editor/fbx_importer_manager.cpp
index 2a005034a5..87f2d596e8 100644
--- a/editor/fbx_importer_manager.cpp
+++ b/editor/fbx_importer_manager.cpp
@@ -30,6 +30,8 @@
#include "fbx_importer_manager.h"
+#include "core/config/project_settings.h"
+#include "editor/editor_node.h"
#include "editor/editor_scale.h"
#include "editor/editor_settings.h"
#include "scene/gui/link_button.h"
@@ -47,9 +49,19 @@ void FBXImporterManager::show_dialog(bool p_exclusive) {
fbx_path->set_text(fbx2gltf_path);
_validate_path(fbx2gltf_path);
- set_flag(Window::FLAG_BORDERLESS, p_exclusive); // Avoid closing accidentally .
+ // If exclusive, we're importing a FBX file, there's no exit.
+ is_importing = p_exclusive;
+ set_flag(Window::FLAG_BORDERLESS, p_exclusive); // Avoid closing accidentally.
set_close_on_escape(!p_exclusive);
+ if (is_importing) {
+ get_cancel_button()->set_text(TTR("Disable FBX & Restart"));
+ get_cancel_button()->set_tooltip_text(TTR("Canceling this dialog will disable the FBX importer.\nYou can re-enable it in the Project Settings under Filesystem > Import > FBX > Enabled.\n\nThe editor will restart as importers are registered when the editor starts."));
+ } else {
+ get_cancel_button()->set_text(TTR("Cancel"));
+ get_cancel_button()->set_tooltip_text("");
+ }
+
popup_centered();
}
@@ -96,6 +108,17 @@ void FBXImporterManager::_path_confirmed() {
EditorSettings::get_singleton()->save();
}
+void FBXImporterManager::_cancel_setup() {
+ if (!is_importing) {
+ return; // No worry.
+ }
+ // No escape.
+ ProjectSettings::get_singleton()->set("filesystem/import/fbx/enabled", false);
+ ProjectSettings::get_singleton()->save();
+ EditorNode::get_singleton()->save_all_scenes();
+ EditorNode::get_singleton()->restart_editor();
+}
+
void FBXImporterManager::_browse_install() {
if (fbx_path->get_text() != String()) {
browse_dialog->set_current_file(fbx_path->get_text());
@@ -140,6 +163,7 @@ FBXImporterManager::FBXImporterManager() {
fbx_path->connect("text_changed", callable_mp(this, &FBXImporterManager::_validate_path));
get_ok_button()->set_text(TTR("Confirm Path"));
+ get_cancel_button()->connect("pressed", callable_mp(this, &FBXImporterManager::_cancel_setup));
browse_dialog = memnew(EditorFileDialog);
browse_dialog->set_access(EditorFileDialog::ACCESS_FILESYSTEM);