From 27bed37935370a2b4f5ad7e2d0dc99bb7e5ad687 Mon Sep 17 00:00:00 2001 From: Angelo Naselli Date: Thu, 27 Nov 2014 17:57:09 +0100 Subject: first attempt to add and remove a group from tree tree --- modules/rpmdragora/rpmdragora | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) (limited to 'modules') diff --git a/modules/rpmdragora/rpmdragora b/modules/rpmdragora/rpmdragora index 6bb949f..47d8393 100755 --- a/modules/rpmdragora/rpmdragora +++ b/modules/rpmdragora/rpmdragora @@ -246,7 +246,12 @@ sub _do_search($$$$$$) { $entry =~ s/^\s*$//; } my $entry_rx = eval { qr/$entry/i } or return; + reset_search(); + # TODO FIXME speed up, we cannot remove an item but rebuilding all is slow + # We could just rebuild the tree items + $options->{rebuild_tree}->(); + $options->{state}{flat} and $options->{delete_all}->(); # TODO: write a collapse_all method #$tree->collapse_all; @@ -381,11 +386,13 @@ sub _do_search($$$$$$) { $searchw->destroy; } - my $iter; +# my $iter; if (@search_results) { @search_results = sort_packages(@search_results); $elems{$results_ok} = [ map { [ $_, $results_ok ] } @search_results ]; - $iter = $options->{add_parent}->($tree, $results_ok); +# $iter = $options->{add_parent}->($tree, $results_ok); + + AdminPanel::Rpmdragora::gui::add_tree_item($tree, $results_ok, 1); $options->{add_nodes}->(map { [ $_, $results_ok . ($options->{tree_mode} eq 'by_presence' ? '|' . ($pkgs->{$_}{pkg}->flag_installed ? $loc->N("Upgradable") : $loc->N("Addable")) : ($options->{tree_mode} eq 'by_selection' @@ -393,7 +400,8 @@ sub _do_search($$$$$$) { : '')) ] } @search_results); } else { - $iter = $options->{add_parent}->($tree, $results_none); + AdminPanel::Rpmdragora::gui::add_tree_item($tree, $results_none, 1); +# $iter = $options->{add_parent}->($tree, $results_none); # clear package list: $options->{add_nodes}->(); my $string = $default_list_mode eq 'all' && $filter->[0] eq 'all' ? $loc->N("No search results.") : @@ -1181,7 +1189,9 @@ sub run_treeview_dialog { reset_search(); } elsif ($widget == $find_button) { + yui::YUI::app()->busyCursor(); _do_search($find_entry, $tree, $options, $current_search_type, $urpm, $pkgs); + yui::YUI::app()->normalCursor(); } elsif ($widget == $select_all_button) { toggle_all($options, 1); -- cgit v1.2.1