summaryrefslogtreecommitdiffstats
path: root/perl-install/interactive_gtk.pm
diff options
context:
space:
mode:
authorPascal Rigaux <pixel@mandriva.com>2000-02-23 10:45:42 +0000
committerPascal Rigaux <pixel@mandriva.com>2000-02-23 10:45:42 +0000
commitd070fb9cf74a1aaca5782cf40154f5f62999edfa (patch)
tree715e21337163a219ac0f0197e35a9bcf18299d85 /perl-install/interactive_gtk.pm
parent9f7bd6130d2974168c8d2fbb2153d1703408afaf (diff)
downloaddrakx-d070fb9cf74a1aaca5782cf40154f5f62999edfa.tar
drakx-d070fb9cf74a1aaca5782cf40154f5f62999edfa.tar.gz
drakx-d070fb9cf74a1aaca5782cf40154f5f62999edfa.tar.bz2
drakx-d070fb9cf74a1aaca5782cf40154f5f62999edfa.tar.xz
drakx-d070fb9cf74a1aaca5782cf40154f5f62999edfa.zip
no_comment
Diffstat (limited to 'perl-install/interactive_gtk.pm')
-rw-r--r--perl-install/interactive_gtk.pm23
1 files changed, 14 insertions, 9 deletions
diff --git a/perl-install/interactive_gtk.pm b/perl-install/interactive_gtk.pm
index 8d45913fe..6b9d89fb9 100644
--- a/perl-install/interactive_gtk.pm
+++ b/perl-install/interactive_gtk.pm
@@ -78,8 +78,12 @@ sub ask_from_treelistW {
if ($def eq $_) {
$wdef = $node;
my $s; $tree->expand($wtree{$s .= "$_$separator"}) foreach split $sep, $root;
- foreach (1 .. @$l) {
- $tree->node_nth($_) == $node and $ndef = $_, last;
+ foreach my $nb (1 .. @$l) {
+ if ($tree->node_nth($nb) == $node) {
+ $tree->focus_row($nb);
+ Gtk->idle_add(sub { $tree->moveto($nb, 0, 0.5, 0); 0 });
+ last;
+ }
}
}
}
@@ -98,9 +102,11 @@ sub ask_from_treelistW {
$w->{ok_clicked} = $leave;
$w->{cancel_clicked} = sub { $o->destroy; die "ask_from_list cancel" }; #- make sure windows doesn't live any more.
gtkadd($w->{window},
- gtkpack_(new Gtk::VBox(0,0),
- 1, gtkset_usize(createScrolledWindow($tree), 400, 350),
- 0, $w->create_okcancel));
+ gtkpack($w->create_box_with_title(@$messages),
+ gtkpack_(new Gtk::VBox(0,7),
+ 1, gtkset_usize(createScrolledWindow($tree), 300, 350),
+ 0, $w->create_okcancel)));
+ $tree->set_column_auto_resize(0, 1);
$tree->set_selection_mode('browse');
$tree->signal_connect(tree_select_row => sub { $curr = $_[1]; });
$tree->signal_connect(button_press_event => sub { &$leave if $_[1]{type} =~ /^2/ });
@@ -114,10 +120,9 @@ sub ask_from_treelistW {
1;
});
- $tree->focus_row($ndef) if $ndef;
- $tree->select($wdef) if $wdef;
- $tree->node_moveto($wdef, 0, 0.5, 0) if $wdef;
-
+ if ($wdef) {
+ $tree->select($wdef);
+ }
$tree->grab_focus;
$w->main or die "ask_from_list cancel";