1
0
mirror of https://github.com/godotengine/godot.git synced 2025-11-08 12:40:44 +00:00

Replace radion buttons with checkboxes in GDNativeLibrary editor

This commit is contained in:
NilsIrl
2019-07-27 16:45:37 +02:00
parent 94aabf56a0
commit ba63e0a5a2
2 changed files with 18 additions and 15 deletions

View File

@@ -66,10 +66,13 @@ void GDNativeLibraryEditor::_update_tree() {
tree->clear(); tree->clear();
TreeItem *root = tree->create_item(); TreeItem *root = tree->create_item();
for (Map<String, NativePlatformConfig>::Element *E = platforms.front(); E; E = E->next()) { PopupMenu *filter_list = filter->get_popup();
for (int i = 0; i < filter_list->get_item_count(); i++) {
if (showing_platform != E->key() && showing_platform != "All") if (!filter_list->is_item_checked(i)) {
continue; continue;
}
Map<String, NativePlatformConfig>::Element *E = platforms.find(filter_list->get_item_metadata(i));
TreeItem *platform = tree->create_item(root); TreeItem *platform = tree->create_item(root);
platform->set_text(0, E->get().name); platform->set_text(0, E->get().name);
@@ -162,9 +165,10 @@ void GDNativeLibraryEditor::_on_dependencies_selected(const PoolStringArray &fil
_set_target_value(file_dialog->get_meta("section"), file_dialog->get_meta("target"), files); _set_target_value(file_dialog->get_meta("section"), file_dialog->get_meta("target"), files);
} }
void GDNativeLibraryEditor::_on_filter_selected(int id) { void GDNativeLibraryEditor::_on_filter_selected(int index) {
showing_platform = filter->get_item_metadata(id); PopupMenu *filter_list = filter->get_popup();
filter_list->set_item_checked(index, !filter_list->is_item_checked(index));
_update_tree(); _update_tree();
} }
@@ -265,8 +269,6 @@ void GDNativeLibraryEditor::_translate_to_config_file() {
GDNativeLibraryEditor::GDNativeLibraryEditor() { GDNativeLibraryEditor::GDNativeLibraryEditor() {
showing_platform = "All";
{ // Define platforms { // Define platforms
NativePlatformConfig platform_windows; NativePlatformConfig platform_windows;
platform_windows.name = "Windows"; platform_windows.name = "Windows";
@@ -336,20 +338,21 @@ GDNativeLibraryEditor::GDNativeLibraryEditor() {
Label *label = memnew(Label); Label *label = memnew(Label);
label->set_text(TTR("Platform:")); label->set_text(TTR("Platform:"));
hbox->add_child(label); hbox->add_child(label);
filter = memnew(OptionButton); filter = memnew(MenuButton);
filter->set_text(TTR("Choose platform"));
hbox->add_child(filter); hbox->add_child(filter);
filter->set_h_size_flags(SIZE_EXPAND_FILL); PopupMenu *filter_list = filter->get_popup();
filter_list->set_hide_on_checkable_item_selection(false);
filter_list->set_h_size_flags(SIZE_EXPAND_FILL);
int idx = 0; int idx = 0;
filter->add_item(TTR("All"), idx);
filter->set_item_metadata(idx, "All");
idx += 1;
for (Map<String, NativePlatformConfig>::Element *E = platforms.front(); E; E = E->next()) { for (Map<String, NativePlatformConfig>::Element *E = platforms.front(); E; E = E->next()) {
filter->add_item(E->get().name, idx); filter_list->add_check_item(E->get().name, idx);
filter->set_item_metadata(idx, E->key()); filter_list->set_item_metadata(idx, E->key());
filter_list->set_item_checked(idx, true);
idx += 1; idx += 1;
} }
filter->connect("item_selected", this, "_on_filter_selected"); filter_list->connect("index_pressed", this, "_on_filter_selected");
tree = memnew(Tree); tree = memnew(Tree);
container->add_child(tree); container->add_child(tree);

View File

@@ -61,7 +61,7 @@ class GDNativeLibraryEditor : public Control {
}; };
Tree *tree; Tree *tree;
OptionButton *filter; MenuButton *filter;
EditorFileDialog *file_dialog; EditorFileDialog *file_dialog;
ConfirmationDialog *new_architecture_dialog; ConfirmationDialog *new_architecture_dialog;
LineEdit *new_architecture_input; LineEdit *new_architecture_input;