[gnome-shell/wip/aggregate-menu: 32/75] popupMenu: Emit open-state-changed at the start of animating a submenu



commit ed72997df74c3d2a7f8bd48300ff764a4a356191
Author: Jasper St. Pierre <jstpierre mecheye net>
Date:   Tue Jun 11 18:29:36 2013 -0400

    popupMenu: Emit open-state-changed at the start of animating a submenu
    
    Doing it at the end has confusing semantics, especially as there is
    this point where isOpen is true, but the corresponding open-state-changed
    has not been emitted.
    
    https://bugzilla.gnome.org/show_bug.cgi?id=702539

 js/ui/popupMenu.js |    9 ++-------
 1 files changed, 2 insertions(+), 7 deletions(-)
---
diff --git a/js/ui/popupMenu.js b/js/ui/popupMenu.js
index eda3032..d239c8b 100644
--- a/js/ui/popupMenu.js
+++ b/js/ui/popupMenu.js
@@ -1183,6 +1183,7 @@ const PopupSubMenu = new Lang.Class({
             return;
 
         this.isOpen = true;
+        this.emit('open-state-changed', true);
 
         this.actor.show();
 
@@ -1221,12 +1222,10 @@ const PopupSubMenu = new Lang.Class({
                                onCompleteScope: this,
                                onComplete: function() {
                                    this.actor.set_height(-1);
-                                   this.emit('open-state-changed', true);
                                }
                              });
         } else {
             this._arrow.rotation_angle_z = 90;
-            this.emit('open-state-changed', true);
         }
     },
 
@@ -1235,6 +1234,7 @@ const PopupSubMenu = new Lang.Class({
             return;
 
         this.isOpen = false;
+        this.emit('open-state-changed', false);
 
         if (this._activeMenuItem)
             this._activeMenuItem.setActive(false);
@@ -1252,8 +1252,6 @@ const PopupSubMenu = new Lang.Class({
                                onComplete: function() {
                                    this.actor.hide();
                                    this.actor.set_height(-1);
-
-                                   this.emit('open-state-changed', false);
                                },
                                onUpdateScope: this,
                                onUpdate: function() {
@@ -1263,9 +1261,6 @@ const PopupSubMenu = new Lang.Class({
             } else {
                 this._arrow.rotation_angle_z = 0;
                 this.actor.hide();
-
-                this.isOpen = false;
-                this.emit('open-state-changed', false);
             }
     },
 


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]