]> git.zerfleddert.de Git - snom-frontend/blobdiff - snom.pl
some more key-shortcuts
[snom-frontend] / snom.pl
diff --git a/snom.pl b/snom.pl
index 283b3988f06e35cec60ae5cea8489f763abadd12..45dfe5cfe88e4ff49b70d980df498dfd98e24bcb 100755 (executable)
--- a/snom.pl
+++ b/snom.pl
@@ -1,5 +1,5 @@
 #!/bin/sh
-#$Id: snom.pl,v 1.1 2006-05-21 11:53:53 simigern Exp $
+#$Id: snom.pl,v 1.10 2006-05-21 13:26:27 simigern Exp $
 
 PATH=/opt/csw/bin:/opt/local/bin:/usr/bin:/bin exec perl -w -x "$0" "$@"
 
@@ -12,8 +12,9 @@ use strict;
 
 use LWP::UserAgent;
 my $ua = LWP::UserAgent->new;
+#$ua->credentials("${ARGV[0]}:80","snom","root","geheim");
 
-#set_locale Gtk2;
+set_locale Gtk2;
 
 sub snom_key(@) {
        (my $key) = @_;
@@ -59,7 +60,7 @@ my $fkeys = Gtk2::Table->new(6, 2, 1);
 $fkeys->set_row_spacings(2);
 $fkeys->set_col_spacings(2);
 $n = 0;
-foreach my $i qw(Redial Settings Directory Help Menu snom _ _ Conference Transfer Hold DND) {
+foreach my $i qw(Redial Settings Directory Help Menu snom _ _ _Conference _Transfer H_old _DND) {
        if ($i ne '_') {
                $key{$i} = Gtk2::Button->new("${i}");
                $key{$i}->signal_connect(clicked => \&KeyPressed, $i);
@@ -112,7 +113,7 @@ my $output = Gtk2::Table->new(2, 3);
 $output->set_row_spacings(2);
 $output->set_col_spacings(2);
 $n = 0;
-foreach my $i qw(- + _ Mute Speaker Headset) {
+foreach my $i qw(- + _ _Mute _Speaker _Headset) {
        if ( $i ne '_' ) {
                $key{$i} = Gtk2::Button->new("${i}");
                $key{$i}->signal_connect(clicked => \&KeyPressed, $i);
@@ -138,9 +139,7 @@ $special->show();
 my $display = Gtk2::Entry->new();
 $display->signal_connect(activate => \&DialNumber);
 my $kph_blocked = FALSE;
-#$display->signal_connect(focus_in_event => \&DisplayMouseOver, TRUE);
 $display->signal_connect(enter_notify_event => \&DisplayMouseOver, TRUE);
-#$display->signal_connect(focus_out_event => \&DisplayMouseOver, FALSE);
 $display->signal_connect(leave_notify_event => \&DisplayMouseOver, FALSE);
 $display->show();
 
@@ -187,6 +186,8 @@ $mainbox->show();
 $window->add($mainbox);
 $window->show();
 
+$key{OK}->grab_focus();
+
 # Gtk2 event loop
 Gtk2->main;
 
@@ -197,13 +198,14 @@ exit( 0 );
 sub KeyPressed
 {
        my ($button, $text) = @_;
+       $text=~ s/_//g;
        foreach my $i (1, 2, 3, 4, 5, 6, 7, 8, 9, '*', 0, '#',
                'F1', 'F2', 'F3', 'F4',
                'P1', 'P2', 'P3', 'P4', 'P5', 'P6',
                'P7', 'P8', 'P9', 'P10', 'P11', 'P12') {
                if ($i eq $text) {
                        snom_key($i);
-                       return;
+                       return TRUE;
                }
        }
 
@@ -234,12 +236,15 @@ sub KeyPressed
 
        snom_key("VOLUME_UP") if ( $text eq "+" );
        snom_key("VOLUME_DOWN") if ( $text eq "-" );
+       return TRUE;
 }
 
 sub DialNumber
 {
        my ($entry) = @_;
+
        snom_number($entry->get_text());
+       return TRUE;
 }
 
 sub DisplayMouseOver
@@ -268,33 +273,80 @@ sub KBDInput
        my ($widget, $event) = @_;
 
        my $keyval = $event->keyval;
-       foreach my $i (1, 2, 3, 4, 5, 6, 7, 8, 9, 0, 'F1', 'F2', 'F3', 'F4') {
-               if ($keyval == $Gtk2::Gdk::Keysyms{$i}) {
+
+       for (my $i=0; $i<10; $i++) {
+               if ($keyval == $Gtk2::Gdk::Keysyms{$i} || $keyval == $Gtk2::Gdk::Keysyms{"KP_${i}"}) {
                        snom_key($i);
                        return TRUE;
                }
        }
 
-       if ($keyval == $Gtk2::Gdk::Keysyms{Return}) {snom_key("ENTER"); return TRUE;}
-       if ($keyval == $Gtk2::Gdk::Keysyms{KP_Enter}) {snom_key("ENTER"); return TRUE;}
-       if ($keyval == $Gtk2::Gdk::Keysyms{Escape}) {snom_key("CANCEL"); return TRUE;}
-       if ($keyval == $Gtk2::Gdk::Keysyms{Left}) {snom_key("LEFT"); return TRUE;}
-       if ($keyval == $Gtk2::Gdk::Keysyms{KP_Left}) {snom_key("LEFT"); return TRUE;}
-       if ($keyval == $Gtk2::Gdk::Keysyms{Right}) {snom_key("RIGHT"); return TRUE;}
-       if ($keyval == $Gtk2::Gdk::Keysyms{KP_Right}) {snom_key("RIGHT"); return TRUE;}
-       if ($keyval == $Gtk2::Gdk::Keysyms{Up}) {snom_key("UP"); return TRUE;}
-       if ($keyval == $Gtk2::Gdk::Keysyms{KP_Up}) {snom_key("UP"); return TRUE;}
-       if ($keyval == $Gtk2::Gdk::Keysyms{Down}) {snom_key("DOWN"); return TRUE;}
-       if ($keyval == $Gtk2::Gdk::Keysyms{KP_Down}) {snom_key("DOWN"); return TRUE;}
-       return TRUE;
+       if (!$event->state || $event->state eq 'shift-mask') {
+               if ($keyval == $Gtk2::Gdk::Keysyms{asterisk}) {snom_key('*'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{KP_Multiply}) {snom_key('*'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{numbersign}) {snom_key('#'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{KP_Add}) {snom_key('VOLUME_UP'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{plus}) {snom_key('VOLUME_UP'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{KP_Subtract}) {snom_key('VOLUME_DOWN'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{minus}) {snom_key('VOLUME_DOWN'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{Return}) {snom_key("ENTER"); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{KP_Enter}) {snom_key("ENTER"); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{Escape}) {snom_key("CANCEL"); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{Left}) {snom_key("LEFT"); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{KP_Left}) {snom_key("LEFT"); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{Right}) {snom_key("RIGHT"); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{KP_Right}) {snom_key("RIGHT"); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{Up}) {snom_key("UP"); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{KP_Up}) {snom_key("UP"); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{Down}) {snom_key("DOWN"); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{KP_Down}) {snom_key("DOWN"); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{M}) {snom_key('MUTE'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{m}) {snom_key('MUTE'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{S}) {snom_key('SPEAKER'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{s}) {snom_key('SPEAKER'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{H}) {snom_key('HEADSET'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{h}) {snom_key('HEADSET'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{C}) {snom_key('CONFERENCE'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{c}) {snom_key('CONFERENCE'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{T}) {snom_key('TRANSFER'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{t}) {snom_key('TRANSFER'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{O}) {snom_key('F_R'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{o}) {snom_key('F_R'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{D}) {snom_key('DND'); return TRUE;}
+               if ($keyval == $Gtk2::Gdk::Keysyms{d}) {snom_key('DND'); return TRUE;}
+       }
+
+       if (!$event->state) {
+               for (my $i=1; $i<5; $i++) {
+                       if ($keyval == $Gtk2::Gdk::Keysyms{"F${i}"}) {
+                               snom_key("F${i}");
+                               return TRUE;
+                       }
+               }
+       } else {
+               if ($event->state eq 'mod1-mask') {
+                       for (my $i=1; $i<13; $i++) {
+                               if ($keyval == $Gtk2::Gdk::Keysyms{"F${i}"}) {
+                                       snom_key("P${i}");
+                                       return TRUE;
+                               }
+                       }
+               }
+       }
+
+       print "Unhandled: Modifier: ".$event->state.", Key: ";
+       foreach my $key (keys(%Gtk2::Gdk::Keysyms)) {
+               if ($keyval == $Gtk2::Gdk::Keysyms{$key}) {
+                       print "${key}\n";
+                       return TRUE;
+               }
+       }
+       print "ERR\n";
+       return FALSE;
 }
 
-### Callback function to close the window
 sub CloseAppWindow
 {
        $window->destroy;
        return TRUE;
 }
-
-
-# END EXAMPLE PROGRAM
Impressum, Datenschutz