Allow folder checking in export preset file list
This commit is contained in:
parent
dd5485142f
commit
08a292fec3
2 changed files with 52 additions and 3 deletions
|
@ -721,14 +721,19 @@ void ProjectExportDialog::_fill_resource_tree() {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ProjectExportDialog::_fill_tree(EditorFileSystemDirectory *p_dir, TreeItem *p_item, Ref<EditorExportPreset> ¤t, bool p_only_scenes) {
|
bool ProjectExportDialog::_fill_tree(EditorFileSystemDirectory *p_dir, TreeItem *p_item, Ref<EditorExportPreset> ¤t, 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() {
|
||||||
|
|
|
@ -123,6 +123,8 @@ private:
|
||||||
void _fill_resource_tree();
|
void _fill_resource_tree();
|
||||||
bool _fill_tree(EditorFileSystemDirectory *p_dir, TreeItem *p_item, Ref<EditorExportPreset> ¤t, bool p_only_scenes);
|
bool _fill_tree(EditorFileSystemDirectory *p_dir, TreeItem *p_item, Ref<EditorExportPreset> ¤t, 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;
|
||||||
|
|
Loading…
Reference in a new issue