Allow folder checking in export preset file list

This commit is contained in:
Tomasz Chabora 2020-11-14 16:02:14 +01:00
parent dd5485142f
commit 08a292fec3
2 changed files with 52 additions and 3 deletions

View file

@ -721,14 +721,19 @@ void ProjectExportDialog::_fill_resource_tree() {
} }
bool ProjectExportDialog::_fill_tree(EditorFileSystemDirectory *p_dir, TreeItem *p_item, Ref<EditorExportPreset> &current, bool p_only_scenes) { bool ProjectExportDialog::_fill_tree(EditorFileSystemDirectory *p_dir, TreeItem *p_item, Ref<EditorExportPreset> &current, bool p_only_scenes) {
p_item->set_cell_mode(0, TreeItem::CELL_MODE_CHECK);
p_item->set_icon(0, presets->get_theme_icon("folder", "FileDialog")); p_item->set_icon(0, presets->get_theme_icon("folder", "FileDialog"));
p_item->set_text(0, p_dir->get_name() + "/"); p_item->set_text(0, p_dir->get_name() + "/");
p_item->set_editable(0, true);
p_item->set_metadata(0, p_dir->get_path());
bool used = false; bool used = false;
bool checked = true;
for (int i = 0; i < p_dir->get_subdir_count(); i++) { for (int i = 0; i < p_dir->get_subdir_count(); i++) {
TreeItem *subdir = include_files->create_item(p_item); TreeItem *subdir = include_files->create_item(p_item);
if (_fill_tree(p_dir->get_subdir(i), subdir, current, p_only_scenes)) { if (_fill_tree(p_dir->get_subdir(i), subdir, current, p_only_scenes)) {
used = true; used = true;
checked = checked && subdir->is_checked(0);
} else { } else {
memdelete(subdir); memdelete(subdir);
} }
@ -750,10 +755,12 @@ bool ProjectExportDialog::_fill_tree(EditorFileSystemDirectory *p_dir, TreeItem
file->set_editable(0, true); file->set_editable(0, true);
file->set_checked(0, current->has_export_file(path)); file->set_checked(0, current->has_export_file(path));
file->set_metadata(0, path); file->set_metadata(0, path);
checked = checked && file->is_checked(0);
used = true; used = true;
} }
p_item->set_checked(0, checked);
return used; return used;
} }
@ -775,11 +782,51 @@ void ProjectExportDialog::_tree_changed() {
String path = item->get_metadata(0); String path = item->get_metadata(0);
bool added = item->is_checked(0); bool added = item->is_checked(0);
if (added) { if (path.ends_with("/")) {
current->add_export_file(path); _check_dir_recursive(item, added);
} else { } else {
current->remove_export_file(path); if (added) {
current->add_export_file(path);
} else {
current->remove_export_file(path);
}
} }
_refresh_parent_checks(item); // Makes parent folder checked if all files/folders are checked.
}
void ProjectExportDialog::_check_dir_recursive(TreeItem *p_dir, bool p_checked) {
for (TreeItem *child = p_dir->get_children(); child; child = child->get_next()) {
String path = child->get_metadata(0);
child->set_checked(0, p_checked);
if (path.ends_with("/")) {
_check_dir_recursive(child, p_checked);
} else {
if (p_checked) {
get_current_preset()->add_export_file(path);
} else {
get_current_preset()->remove_export_file(path);
}
}
}
}
void ProjectExportDialog::_refresh_parent_checks(TreeItem *p_item) {
TreeItem *parent = p_item->get_parent();
if (!parent) {
return;
}
bool checked = true;
for (TreeItem *child = parent->get_children(); child; child = child->get_next()) {
checked = checked && child->is_checked(0);
if (!checked) {
break;
}
}
parent->set_checked(0, checked);
_refresh_parent_checks(parent);
} }
void ProjectExportDialog::_export_pck_zip() { void ProjectExportDialog::_export_pck_zip() {

View file

@ -123,6 +123,8 @@ private:
void _fill_resource_tree(); void _fill_resource_tree();
bool _fill_tree(EditorFileSystemDirectory *p_dir, TreeItem *p_item, Ref<EditorExportPreset> &current, bool p_only_scenes); bool _fill_tree(EditorFileSystemDirectory *p_dir, TreeItem *p_item, Ref<EditorExportPreset> &current, bool p_only_scenes);
void _tree_changed(); void _tree_changed();
void _check_dir_recursive(TreeItem *p_dir, bool p_checked);
void _refresh_parent_checks(TreeItem *p_item);
Variant get_drag_data_fw(const Point2 &p_point, Control *p_from); Variant get_drag_data_fw(const Point2 &p_point, Control *p_from);
bool can_drop_data_fw(const Point2 &p_point, const Variant &p_data, Control *p_from) const; bool can_drop_data_fw(const Point2 &p_point, const Variant &p_data, Control *p_from) const;