Fix #5615 - gitlive - force all roojs projects to autobranch
[gitlive] / StatusIcon.vala
index c176e27..f429e1a 100644 (file)
@@ -39,7 +39,8 @@ public class StatusIconA : StatusIcon {
 
     public bool paused = false;
     public static StatusIconA statusicon;
-     
+    
     public StatusIconA() {
         
         statusicon = this;
@@ -52,15 +53,40 @@ public class StatusIconA : StatusIcon {
         this.set_name("gitlive");
         this.set_visible(true);      
         
-        var menu = new MenuA();
+        var menu = new GitliveMenu();
         menu.ref();       
+               this.button_press_event.connect( ( ev ) =>{
+             print("button press event called\n");
+                       menu.updateMerges();
+            menu.show_all();
+            
+            if (this.paused) {
+                menu.resume.show();
+                menu.pause.hide();
+            } else {
+                menu.resume.hide();
+                menu.pause.show();
+            }
+              //               public void popup (Gtk.Widget? parent_menu_shell, Gtk.Widget? parent_menu_item,
+                    // [CCode (scope = "async")] Gtk.MenuPositionFunc? func, uint button, uint32 activate_time);
+            //Gtk.get_current_event_device ()
+            menu.popup(
 
+                        null, null,
+                       this.position_menu,
+                       
+                    ev.button,  ev.time //   time
+            );
+             
+             return true;
            
-        //this.popup_menu.connect( (  button,   time) =>{
-       this.button_press_event.connect( (  button) =>{
-               
+           });
+       this.popup_menu.connect( (  button,   time) =>{
+       //this.button_press_event.connect( (  ) =>{
             //print(Array.prototype.slice.call(arguments).join(','));
             print("menu activiate called\n");
+                       menu.updateMerges();
             //var menu = this.get('menu');
             
             menu.show_all();
@@ -72,19 +98,18 @@ public class StatusIconA : StatusIcon {
                 menu.resume.hide();
                 menu.pause.show();
             }
-              
+              //               public void popup (Gtk.Widget? parent_menu_shell, Gtk.Widget? parent_menu_item,
+                    // [CCode (scope = "async")] Gtk.MenuPositionFunc? func, uint button, uint32 activate_time);
             //Gtk.get_current_event_device ()
             menu.popup(
-                    
+
                         null, null,
-                        //this.position_menu,
-                       null,
-                        button,
-                      0 //   time
+                       this.position_menu,
+                       
+                    button,  time //   time
             );
                         
             
-            
             //var g = { };
             //var a = new Gdk.Rectangle();
             //  needs direction=inout setting in gir to work (in bugzilla @present)
@@ -93,36 +118,126 @@ public class StatusIconA : StatusIcon {
             // should check to see if @ top or bottom I guess..
             //menu.el.get_toplevel().move(a.x, a.y +a.height);
             //menu.el.get_toplevel().move(10,10);
+            //return false;
               
         }); 
         
     }
     
-    class MenuA : Gtk.Menu
+    public void pause()
+    {
+               this.set_from_stock( Gtk.Stock.MEDIA_PAUSE );
+               this.paused = true;
+    }
+    
+    public void resume()
+    {
+               this.set_from_stock( Gtk.Stock.MEDIA_PLAY );
+               this.paused = false;
+    }
+    
+    public void refreshing()
+    {
+               this.set_from_stock( Gtk.Stock.REFRESH );
+    }
+    
+    public void pauseError()
+    {
+                this.paused = true;
+                var flag = true;
+                Timeout.add_full(Priority.LOW, 500, () => {
+                
+                       if (!this.paused) {
+                               return false;
+                       }
+                       this.set_from_stock( flag == true ? Gtk.Stock.MEDIA_RECORD  
+                                       : Gtk.Stock.MEDIA_PAUSE);
+                       flag = !flag;
+                       return true;
+               });
+                
+    }
+    
+    class GitliveMenu : Gtk.Menu
     {
         public ImageMenuItem pause;
         public ImageMenuItem resume;
+        public Gtk.MenuItem before_seperator;
+        public Gtk.MenuItem after_seperator;        
+        
         
-        public MenuA()
+        public GitliveMenu()
         {
-            this.pause = new ImageMenuItemA();
+            this.pause = new MenuItemPause();
             this.append(this.pause);
-            this.resume = new ImageMenuItemB();
+            this.resume = new MenuItemStartCommits();
             this.append(this.resume);
-            this.append(new ImageMenuItemC());
-            this.append(new ImageMenuItemD());
-            this.append(new ImageMenuItemE());
-            this.append(new ImageMenuItemF());
-            this.append(new ImageMenuItemG());
-            
-            
-            
+            this.append(new MenuItemPullAll());
+            this.before_seperator = new Gtk.SeparatorMenuItem();
+            this.append(this.before_seperator);
+
+            this.after_seperator = new Gtk.SeparatorMenuItem();
+            this.append(this.after_seperator);
+            //this.append(new MenuItemUpdateTimesheet());            
+            this.append(new MenuItemManageClones());
+            this.append(new MenuItemNewTicket());            
+            this.append(new MenuItemAbout());
+            this.append(new MenuItemQuit());
+            this.merge_items = new  Gee.ArrayList<Gtk.MenuItem>();
         }
+        public Gee.ArrayList<Gtk.MenuItem> merge_items;
+        
+        
+        public void updateMerges()
+        {
+               // show a list of possible merges on the menu.
+               foreach (var m in this.merge_items) {
+                       this.remove(m);
+               }
+               foreach(var r in GitRepo.singleton().cache.values ) {
+                       GLib.debug("checking %s for branch = %s", r.name, r.currentBranch.name);
+                       if (r.is_master_branch()) {
+                               continue;
+                               }
+                       GLib.debug("checking  for activeTicket");                               
+                               var t = r.activeTicket;
+                               if (t == null) { 
+                                       continue;
+                               }
+                               var mi = new MergeMenuItem(r,t);
+                               this.insert (mi,4); //backwards.
+                               this.merge_items.add(mi);                       
+                                
+               }
+               
+        }
+        
+       
+        class MergeMenuItem : Gtk.MenuItem {        
+        
+               GitRepo repo;
+               RooTicket ticket;
+        
+               public MergeMenuItem(GitRepo r, RooTicket t)
+               {
+                       this.repo = r;
+                       this.ticket = t;
+                       
+                       this.label = ("Merge [%s] #%s %s".printf(r.name, t.id , t.summary));
+
+                               this.activate.connect(() => {
+                                       MergeBranch.singleton().show(this.ticket, null);
+                                       // show merge dialog..
+                               });
+               
+               }
+               
+       }
         
         
-        class ImageMenuItemA : ImageMenuItem {
+        class MenuItemPause : ImageMenuItem {
             
-            public ImageMenuItemA()
+            public MenuItemPause()
             {
                 //this.set_from_stock( Gtk.Stock.MEDIA_PAUSE );
                 
@@ -148,9 +263,9 @@ public class StatusIconA : StatusIcon {
             
             
         }
-        class ImageMenuItemB : ImageMenuItem {
+        class MenuItemStartCommits : ImageMenuItem {
             
-            public ImageMenuItemB()
+            public MenuItemStartCommits()
             {
                 
                 var  image = new Gtk.Image();
@@ -176,9 +291,9 @@ public class StatusIconA : StatusIcon {
         }
         
         
-        class ImageMenuItemC : ImageMenuItem {
+        class MenuItemPullAll : ImageMenuItem {
             
-            public ImageMenuItemC()
+            public MenuItemPullAll()
             {
                 
                 var  image = new Gtk.Image();
@@ -189,10 +304,17 @@ public class StatusIconA : StatusIcon {
                 this.accel_group = null;
                 
                 this.activate.connect( () => {
+                    
+                    this.pullAll();
+                    /*
                     GitMonitor.gitmonitor.stop();
                     var tr = GitRepo.list();
+                    
+                    
+                    
                     for (var i= 0; i< tr.length;i++) {
-                        statusicon.set_from_stock( i%2 == 0 ?  Gtk.Stock.FULLSCREEN : Gtk.Stock.LEAVE_FULLSCREEN );
+                        statusicon.set_from_stock( 
+                               i%2 == 0 ?  Gtk.Stock.FULLSCREEN : Gtk.Stock.LEAVE_FULLSCREEN );
                                 
                         var repo = tr.index(i);
                         //if (!repo.autocommit()) {
@@ -224,26 +346,95 @@ public class StatusIconA : StatusIcon {
                         }        
 
                     } 
-                    statusicon.set_tooltip_text("Gitlive");
-                             
-                            
-                    GitMonitor.gitmonitor.start();         
+                    */
+                           
                            
                 });
             }
-            
+            void pullAll()
+            {
+                       var tr = GitRepo.list();
+                
+                GitMonitor.gitmonitor.stop();
+                    
+                
+               this.total = tr.length;
+                this.has_error = 0;
+                this.pull_all_error_message = "";
+                for (var i= 0; i< tr.length;i++) {
+                    statusicon.set_from_stock( 
+                               i%2 == 0 ?  Gtk.Stock.FULLSCREEN : Gtk.Stock.LEAVE_FULLSCREEN );
+                            
+                    var repo = tr.index(i);
+                    //repo.ref();
+                    //this.ref();
+                    
+                    statusicon.set_tooltip_text("pull: " + repo.name);
+                                       
+                    repo.pull_async(this.pullAllCallback); 
+                                // do not care if it's already in sycn..
+                        
+                     
+
+                } 
+
+                  
+        
+        
+               }
+               uint total = 0; 
+                       uint has_error = 0;
+                       string pull_all_error_message = "";
+               
+               void pullAllCallback(GitRepo repo, int err, string res)
+               {
+                       this.total--;
+                       
+                       if (err > 0) {
+                               this.has_error = 1;
+                               this.pull_all_error_message += this.pull_all_error_message.length > 0 ? "\n" : "";
+                               this.pull_all_error_message += "Error Pulling " + repo.name +"\n" + res;
+                       }
+                       
+                       if (!Regex.match_simple ("Already up-to-date", res) ) {
+                       var notification = new Notify.Notification( 
+                         "Pull completed ",
+                          "Updated: " +repo.name + "\n" + res +"\n",
+                            "dialog-information"
+                    );
+                    notification.set_timeout(20);
+                               notification.show();
+                       
+                       }
+                       if (this.total < 1) {
+                               if (this.has_error > 0) {
+                                       GitMonitor.gitmonitor.pauseError(this.pull_all_error_message);
+                                       return;
+                               }
+                       
+                               statusicon.set_tooltip_text("Gitlive");
+                  
+                               GitMonitor.gitmonitor.start();
+                               //this.unref();
+                               //repo.unref();
+                       }
+                       
+               }
+        
             
         }
         
         
-        class ImageMenuItemD : ImageMenuItem {
+        class MenuItemUpdateTimesheet : ImageMenuItem {
             
-            public ImageMenuItemD()
+            public MenuItemUpdateTimesheet()
             {
                 
                 var  image = new Gtk.Image();
                 image.set_from_stock(Gtk.Stock.SAVE,Gtk.IconSize.MENU );
-               this.set_image (image);
+                               this.set_image (image);
                 this.label= "Update Timesheet";
                 this.always_show_image = true;
                 this.accel_group = null;
@@ -256,9 +447,9 @@ public class StatusIconA : StatusIcon {
             
         }
         
-        class ImageMenuItemE : ImageMenuItem {
+        class MenuItemManageClones : ImageMenuItem {
             
-            public ImageMenuItemE()
+            public MenuItemManageClones()
             {
                 
                 var  image = new Gtk.Image();
@@ -269,16 +460,42 @@ public class StatusIconA : StatusIcon {
                 this.accel_group = null;
                 
                 this.activate.connect( () => {
-                 //var ret = imports.Clones.Clones.show();
+                       GitRepo.updateAll("show_clones");
+                
+                     // Clones.singleton().show();
                 });
             }
             
             
         }
         
-        class ImageMenuItemF : ImageMenuItem {
+        class MenuItemNewTicket : ImageMenuItem {
             
-            public ImageMenuItemF()
+            public MenuItemNewTicket()
+            {
+                
+                var  image = new Gtk.Image();
+                image.set_from_stock(Gtk.Stock.FULLSCREEN,Gtk.IconSize.MENU );
+                this.set_image (image);
+                this.label= "New Ticket";
+                this.always_show_image = true;
+                this.accel_group = null;
+                
+                this.activate.connect( () => {
+                       Ticket.singleton().show(null);
+
+                
+                     // Clones.singleton().show();
+                });
+            }
+            
+            
+        }
+        
+        
+        class MenuItemAbout : ImageMenuItem {
+            
+            public MenuItemAbout()
             {
                 
                 var  image = new Gtk.Image();
@@ -306,9 +523,9 @@ public class StatusIconA : StatusIcon {
             
         }
         
-         class ImageMenuItemG : ImageMenuItem {
+         class MenuItemQuit : ImageMenuItem {
             
-            public ImageMenuItemG()
+            public MenuItemQuit()
             {
                 
                 var  image = new Gtk.Image();
@@ -332,4 +549,4 @@ public class StatusIconA : StatusIcon {
 }
       
                 
-                  
+                  
\ No newline at end of file