Home | History | Annotate | Download | only in gtk
      1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
      2 // Use of this source code is governed by a BSD-style license that can be
      3 // found in the LICENSE file.
      4 //
      5 // This class replicates some menubar behaviors that are tricky to get right.
      6 // It is used to create a more native feel for the bookmark bar.
      7 
      8 #ifndef CHROME_BROWSER_UI_GTK_MENU_BAR_HELPER_H_
      9 #define CHROME_BROWSER_UI_GTK_MENU_BAR_HELPER_H_
     10 
     11 #include <gtk/gtk.h>
     12 
     13 #include <vector>
     14 
     15 #include "base/memory/scoped_ptr.h"
     16 #include "ui/base/gtk/gtk_signal.h"
     17 
     18 namespace ui {
     19 class GtkSignalRegistrar;
     20 }
     21 
     22 class MenuBarHelper {
     23  public:
     24   class Delegate {
     25    public:
     26     virtual ~Delegate() {}
     27 
     28     // Called when a the menu for a button ought to be triggered.
     29     virtual void PopupForButton(GtkWidget* button) = 0;
     30     virtual void PopupForButtonNextTo(GtkWidget* button,
     31                                       GtkMenuDirectionType dir) = 0;
     32   };
     33 
     34   // |delegate| cannot be null.
     35   explicit MenuBarHelper(Delegate* delegate);
     36   ~MenuBarHelper();
     37 
     38   // Must be called whenever a button's menu starts showing. It triggers the
     39   // MenuBarHelper to start listening for certain events.
     40   void MenuStartedShowing(GtkWidget* button, GtkWidget* menu);
     41 
     42   // Add |button| to the set of buttons we care about.
     43   void Add(GtkWidget* button);
     44 
     45   // Remove |button| from the set of buttons we care about.
     46   void Remove(GtkWidget* button);
     47 
     48   // Clear all buttons from the set.
     49   void Clear();
     50 
     51  private:
     52   CHROMEGTK_CALLBACK_0(MenuBarHelper, void, OnMenuHiddenOrDestroyed);
     53   CHROMEGTK_CALLBACK_1(MenuBarHelper, gboolean, OnMenuMotionNotify,
     54                        GdkEventMotion*);
     55   CHROMEGTK_CALLBACK_1(MenuBarHelper, void, OnMenuMoveCurrent,
     56                        GtkMenuDirectionType);
     57 
     58   // The buttons for which we pop up menus. We do not own these, or even add
     59   // refs to them.
     60   std::vector<GtkWidget*> buttons_;
     61 
     62   // The button that is currently showing a menu, or NULL.
     63   GtkWidget* button_showing_menu_;
     64 
     65   // The highest level menu that is currently showing, or NULL.
     66   GtkWidget* showing_menu_;
     67 
     68   // All the submenus of |showing_menu_|. We connect to motion events on all
     69   // of them.
     70   std::vector<GtkWidget*> submenus_;
     71 
     72   // Signal handlers that are attached only between the "show" and "hide" events
     73   // for the menu.
     74   scoped_ptr<ui::GtkSignalRegistrar> signal_handlers_;
     75 
     76   Delegate* delegate_;
     77 };
     78 
     79 #endif  // CHROME_BROWSER_UI_GTK_MENU_BAR_HELPER_H_
     80