summaryrefslogtreecommitdiffstats
path: root/perl-install/standalone/draksambashare
diff options
context:
space:
mode:
authorAntoine Ginies <aginies@mandriva.com>2005-08-27 13:46:18 +0000
committerAntoine Ginies <aginies@mandriva.com>2005-08-27 13:46:18 +0000
commitcf0b3b919bbf4a40cc0e4dc2ae81b95ea705b0c2 (patch)
tree2d9208160a821ad35a56fb93f00e6767883824a0 /perl-install/standalone/draksambashare
parent56fa65110e3cf20a4a73584bba89df64bdfa5c45 (diff)
downloaddrakx-cf0b3b919bbf4a40cc0e4dc2ae81b95ea705b0c2.tar
drakx-cf0b3b919bbf4a40cc0e4dc2ae81b95ea705b0c2.tar.gz
drakx-cf0b3b919bbf4a40cc0e4dc2ae81b95ea705b0c2.tar.bz2
drakx-cf0b3b919bbf4a40cc0e4dc2ae81b95ea705b0c2.tar.xz
drakx-cf0b3b919bbf4a40cc0e4dc2ae81b95ea705b0c2.zip
add popup menu to easily modify/remove share
Diffstat (limited to 'perl-install/standalone/draksambashare')
-rwxr-xr-xperl-install/standalone/draksambashare36
1 files changed, 34 insertions, 2 deletions
diff --git a/perl-install/standalone/draksambashare b/perl-install/standalone/draksambashare
index 235532e3a..38c16ac5e 100755
--- a/perl-install/standalone/draksambashare
+++ b/perl-install/standalone/draksambashare
@@ -78,7 +78,7 @@ sub create_share_list() {
N("Default case") => 'text',
);
$share_list->set_headers_clickable(1);
- foreach ($share_list->get_columns()) {
+ foreach ($share_list->get_columns) {
$_->set_resizable(1);
}
foreach (1, 2, 3) {
@@ -1064,6 +1064,38 @@ $user_list->signal_connect(button_press_event => sub {
$user_list->{data}[$selected][1] and modify_user_info($user_list->{data}[$selected][1], "", "change") if $event->type eq '2button-press';
});
+# dont know why "$event->type eq '2button-press'" when starting draksambashare so i can't use mapn :/
+#mapn {
+# $_[0]->signal_connect(button_press_event => sub {
+# my (undef, $event) = @_;
+# my ($selected) = $_[0]->get_selected_indices;
+# return unless $event->type eq '2button-press';
+# $_[0]->{data}[$selected][1] and $_[1]($selected); # if $event->type eq '2button-press';
+# });
+#} [ $share_list, $printer_list, $user_list ], [ modify_entry, modify_printers_entry, modify_user_info ];
+
+# create popup menu
+my $menupopup = Gtk2::Menu->new;
+my $menuitem1 = Gtk2::MenuItem->new(N("Modify"));
+my $menuitem2 = Gtk2::MenuItem->new(N("Remove"));
+$menuitem1->signal_connect(activate => sub {
+ my ($selected) = $share_list->get_selected_indices;
+ modify_entry($selected, $share_list);
+ });
+$menuitem2->signal_connect(activate => sub {
+ my ($selected) = $share_list->get_selected_indices;
+ ask_okcancel("Remove entry ?", "Remove $share_list->{data}[$selected][1]") or return;
+ remove_entry($selected, $share_list);
+ });
+$_->show foreach $menuitem1, $menuitem2;
+$menupopup->append($_) foreach $menuitem1, $menuitem2;
+$share_list->signal_connect('button-press-event' => sub {
+ my ($widget, $event) = @_;
+ return unless $event->button == 3;
+ $menupopup->popup(undef, undef, undef, undef, $event->button, $event->time);
+ }
+ );
+
# create menu
my @items = get_items();
my $factory = Gtk2::ItemFactory->new('Gtk2::MenuBar', '<main>', undef);
@@ -1149,7 +1181,7 @@ gtkappend_page($nb, gtkpack_(gtkset_border_width(Gtk2::HBox->new, 0),
),
gtkshow(gtkpack_(Gtk2::HBox->new(0,0),
0, Gtk2::Image->new_from_file($printershare_icon),
- 0, Gtk2::Label->new(N("Printers"))
+ 0, Gtk2::Label->new(N("Printers")),
),
),
);