Export: Properly reload preset when opening dialog
Fixes #20119 where newly installed templates were not detected. Also fix a bug with preset deletion where it would attempt to edit an already removed preset. For this I made it so that ItemList::deselect_all() also resets `current` to -1, as a manual ItemList::deselect(idx) already does.
This commit is contained in:
parent
d603a74c53
commit
13239cd4cc
5 changed files with 5 additions and 12 deletions
|
@ -1856,10 +1856,6 @@ void EditorNode::_menu_option_confirm(int p_option, bool p_confirmed) {
|
|||
|
||||
} break;
|
||||
|
||||
case SETTINGS_EXPORT_PREFERENCES: {
|
||||
|
||||
//project_export_settings->popup_centered_ratio();
|
||||
} break;
|
||||
case FILE_IMPORT_SUBSCENE: {
|
||||
|
||||
if (!editor_data.get_edited_scene_root()) {
|
||||
|
|
|
@ -164,7 +164,6 @@ private:
|
|||
SETTINGS_UPDATE_ALWAYS,
|
||||
SETTINGS_UPDATE_CHANGES,
|
||||
SETTINGS_UPDATE_SPINNER_HIDE,
|
||||
SETTINGS_EXPORT_PREFERENCES,
|
||||
SETTINGS_PREFERENCES,
|
||||
SETTINGS_LAYOUT_SAVE,
|
||||
SETTINGS_LAYOUT_DELETE,
|
||||
|
|
|
@ -123,7 +123,6 @@ void ExportTemplateManager::_update_template_list() {
|
|||
|
||||
void ExportTemplateManager::_download_template(const String &p_version) {
|
||||
|
||||
print_line("download " + p_version);
|
||||
while (template_list->get_child_count()) {
|
||||
memdelete(template_list->get_child(0));
|
||||
}
|
||||
|
@ -352,7 +351,6 @@ void ExportTemplateManager::_http_download_mirror_completed(int p_status, int p_
|
|||
bool mirrors_found = false;
|
||||
|
||||
Dictionary d = r;
|
||||
print_line(r);
|
||||
if (d.has("mirrors")) {
|
||||
Array mirrors = d["mirrors"];
|
||||
for (int i = 0; i < mirrors.size(); i++) {
|
||||
|
@ -507,7 +505,6 @@ void ExportTemplateManager::_notification(int p_what) {
|
|||
|
||||
if (p_what == NOTIFICATION_VISIBILITY_CHANGED) {
|
||||
if (!is_visible_in_tree()) {
|
||||
print_line("closed");
|
||||
set_process(false);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -76,6 +76,9 @@ void ProjectExportDialog::popup_export() {
|
|||
}
|
||||
|
||||
_update_presets();
|
||||
if (presets->get_current() >= 0) {
|
||||
_edit_preset(presets->get_current()); // triggers rescan for templates if newly installed
|
||||
}
|
||||
|
||||
// Restore valid window bounds or pop up at default size.
|
||||
if (EditorSettings::get_singleton()->has_setting("interface/dialogs/export_bounds")) {
|
||||
|
@ -154,7 +157,6 @@ void ProjectExportDialog::_update_presets() {
|
|||
|
||||
if (current_idx != -1) {
|
||||
presets->select(current_idx);
|
||||
//_edit_preset(current_idx);
|
||||
}
|
||||
|
||||
updating = false;
|
||||
|
@ -167,6 +169,7 @@ void ProjectExportDialog::_edit_preset(int p_index) {
|
|||
name->set_editable(false);
|
||||
runnable->set_disabled(true);
|
||||
parameters->edit(NULL);
|
||||
presets->unselect_all();
|
||||
delete_preset->set_disabled(true);
|
||||
sections->hide();
|
||||
patches->clear();
|
||||
|
@ -438,11 +441,9 @@ void ProjectExportDialog::_delete_preset() {
|
|||
void ProjectExportDialog::_delete_preset_confirm() {
|
||||
|
||||
int idx = presets->get_current();
|
||||
parameters->edit(NULL); //to avoid crash
|
||||
_edit_preset(-1);
|
||||
EditorExport::get_singleton()->remove_export_preset(idx);
|
||||
_update_presets();
|
||||
_edit_preset(presets->get_current());
|
||||
}
|
||||
|
||||
Variant ProjectExportDialog::get_drag_data_fw(const Point2 &p_point, Control *p_from) {
|
||||
|
|
|
@ -285,7 +285,7 @@ void ItemList::unselect_all() {
|
|||
|
||||
items[i].selected = false;
|
||||
}
|
||||
|
||||
current = -1;
|
||||
update();
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue