Auto hide language bar when disable input method.
authorHuang Peng <shawn.p.huang@gmail.com>
Wed, 27 Aug 2008 10:45:50 +0000 (18:45 +0800)
committerHuang Peng <shawn.p.huang@gmail.com>
Wed, 27 Aug 2008 10:45:50 +0000 (18:45 +0800)
panel/languagebar.py
panel/panel.py

index 33266d9f3459c31ef4fc96846d0e4d65b8098a11..1dda039736102667cee1b18bb2491c21ff940c55 100644 (file)
@@ -47,6 +47,7 @@ class LanguageBar(gtk.Toolbar):
     def __init__ (self):
         super(LanguageBar, self).__init__()
         self.__auto_hide = False
+        self.__enabled = False
         self.__has_focus = False
         self.set_style(gtk.TOOLBAR_ICONS)
         self.set_show_arrow(False)
@@ -109,6 +110,17 @@ class LanguageBar(gtk.Toolbar):
     def reset(self):
         self.__remove_properties()
 
+    def set_enabled(self, enabled):
+        self.__enabled = enabled
+        if self.__enabled and self.__has_focus:
+            self.__toplevel.show_all()
+            self.__toplevel.window.raise_()
+        if not self.__enabled and self.__auto_hide:
+            self.__toplevel.hide_all()
+
+    def is_enabled(self):
+        return self.__enabled
+
     def set_auto_hide(self, auto_hide):
         self.__auto_hide = auto_hide
         if self.__has_focus:
@@ -163,8 +175,9 @@ class LanguageBar(gtk.Toolbar):
     def focus_in(self):
         self.__has_focus = True
         self.__im_menu.set_sensitive(True)
-        self.__toplevel.show_all()
-        self.__toplevel.window.raise_()
+        if self.__enabled:
+            self.__toplevel.show_all()
+            self.__toplevel.window.raise_()
 
     def focus_out(self):
         self.__has_focus = False
index 1ae332342628a801e22ae7a0248255c76da0f6e2..645e85e067e1f5b06b24c3d79d11a4fbba38dfb3 100644 (file)
@@ -156,6 +156,7 @@ class Panel(ibus.PanelBase):
         self.__focus_ic = ic
 
         factory, enabled = self.__bus.get_input_context_states(ic)
+        self.__language_bar.set_enabled(enabled)
 
         if factory == "" or not enabled:
             self.__set_im_icon("ibus")
@@ -175,6 +176,7 @@ class Panel(ibus.PanelBase):
         if not self.__focus_ic:
             return
         factory, enabled = self.__bus.get_input_context_states(self.__focus_ic)
+        self.__language_bar.set_enabled(enabled)
         if enabled == False or not factory:
             self.__set_im_icon("ibus")
         else: