Power menu as popup
authorEnrico Zini <enrico@enricozini.org>
Sun, 16 Aug 2009 14:39:42 +0000 (15:39 +0100)
committerEnrico Zini <enrico@enricozini.org>
Sun, 16 Aug 2009 14:39:42 +0000 (15:39 +0100)
src/app_power.vala
src/zavai.vala

index 1edd502bc88baf79f4d40027b8e22eb8e163d52e..98d351ab4937471e4935d856ad74d346c198dcf2 100644 (file)
@@ -22,7 +22,7 @@ using GLib;
 
 namespace zavai {
 namespace ui {
-namespace powerbutton {
+namespace power {
 
 public class Power : zavai.Resource, Object
 {
@@ -286,11 +286,16 @@ public class PowerMenu : zavai.Resource, Gtk.Window
 
        public PowerMenu()
        {
-               type = Gtk.WindowType.POPUP;
+               type = Gtk.WindowType.TOPLEVEL;
                title = "Power Menu";
                shown = false;
+               destroy_with_parent = true;
+               set_transient_for(zavai.app);
+               set_modal(true);
+               set_position(Gtk.WindowPosition.CENTER_ON_PARENT);
+               set_size_request(300, 500);
 
-               vbox = new Gtk.VBox(true, 0);
+               vbox = new Gtk.VBox(false, 0);
                add(vbox);
 
                //destroy += Gtk.main_quit;
@@ -315,7 +320,7 @@ public class PowerMenu : zavai.Resource, Gtk.Window
                act_backlight_on = new ServiceRequestLink("backlight", "Keep backlight on", "Let backlight fade");
                vbox.pack_start(act_backlight_on, false, false, 0);
 
-               vbox.show_all();
+               //vbox.show_all();
        }
 
        public void toggle()
@@ -323,6 +328,9 @@ public class PowerMenu : zavai.Resource, Gtk.Window
                if (!shown)
                {
                        show_all();
+                       show();
+                       visible = true;
+                       present();
                        shown = true;
                } else {
                        // TODO: do more in case it is visible but has no visibility (is covered by others)
@@ -340,11 +348,29 @@ public class PowerMenu : zavai.Resource, Gtk.Window
        public void shutdown() {}
 }
 
+/*
+public class TogglePowerMenu : Gtk.Button
+{
+       public TogglePowerMenu()
+       {
+               label = "Toggle power menu";
+               clicked += on_clicked;
+               set_size_request(0, zavai.config.min_button_height);
+       }
+
+       public void on_clicked()
+       {
+               zavai.log.info("Toggling power menu");
+               power_menu.toggle();
+       }
+}
+*/
 
 Power power;
 PowerMenu power_menu;
 BatteryIcon battery_icon;
 Backlight backlight;
+//TogglePowerMenu tpm;
 
 public void init()
 {
@@ -359,6 +385,8 @@ public void init()
        zavai.registry.register_resource("powermenu", power_menu);
        
     //zavai.registry.getmenu("menu.main").add_applet("menu.power");
+       //tpm = new TogglePowerMenu();
+    //zavai.registry.getmenu("menu.main").add_widget(tpm);
 
     /*
        raise_icon = new RaiseIcon();
index 657665f674fa70619daabb9bce63520427461c14..977734e08bf7e76e3379496550bd530f9ce4cb2f 100644 (file)
@@ -67,12 +67,14 @@ static int main (string[] args) {
        zavai.ui.gps.init();
        zavai.ui.kbd.init();
        zavai.ui.wm.init();
-       zavai.ui.powerbutton.init();
+       zavai.ui.power.init();
        zavai.ui.polygen.init();
        zavai.ui.debug.init();
 
        zavai.app.show_applet("menu.main");
 
+       //zavai.ui.power.power_menu.toggle();
+
        // # Register main factories
        // registry.register(conf, "conf")
        // registry.register_factory(zavai.GPX, "gpx")