• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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 #ifndef CHROME_BROWSER_UI_GTK_GLOBAL_MENU_BAR_H_
6 #define CHROME_BROWSER_UI_GTK_GLOBAL_MENU_BAR_H_
7 
8 #include <map>
9 
10 #include "chrome/browser/command_updater.h"
11 #include "content/common/notification_observer.h"
12 #include "content/common/notification_registrar.h"
13 #include "ui/base/gtk/gtk_signal.h"
14 
15 class Browser;
16 class BrowserWindowGtk;
17 struct GlobalMenuBarCommand;
18 
19 typedef struct _GtkAccelGroup GtkAccelGroup;
20 typedef struct _GtkWidget GtkWidget;
21 
22 // Controls the Mac style menu bar on Linux.
23 //
24 // Unity and some configurations of GNOME have a Apple-like menu bar at the top
25 // of the screen that changes depending on the active window. These mainly work
26 // by inspecting the application's widget hierarchy, and intercepting any
27 // GtkMenuBar found. Thankfully, these systems don't check to see if the menu
28 // bar itself is visible, so we insert a GtkMenuBar into the window hierarchy
29 // and set it to be invisible.
30 class GlobalMenuBar : public CommandUpdater::CommandObserver,
31                       public NotificationObserver {
32  public:
33   GlobalMenuBar(Browser* browser, BrowserWindowGtk* window);
34   virtual ~GlobalMenuBar();
35 
widget()36   GtkWidget* widget() { return menu_bar_; }
37 
38  private:
39   typedef std::map<int, GtkWidget*> IDMenuItemMap;
40 
41   // Helper function that builds the data.
42   void BuildGtkMenuFrom(int menu_str_id,
43                         std::map<int, GtkWidget*>* id_to_menu_item,
44                         GlobalMenuBarCommand* commands);
45 
46   // CommandUpdater::CommandObserver:
47   virtual void EnabledStateChangedForCommand(int id, bool enabled);
48 
49   // NotificationObserver:
50   virtual void Observe(NotificationType type,
51                        const NotificationSource& source,
52                        const NotificationDetails& details);
53 
54   CHROMEGTK_CALLBACK_0(GlobalMenuBar, void, OnItemActivated);
55 
56   Browser* browser_;
57   BrowserWindowGtk* browser_window_;
58 
59   NotificationRegistrar registrar_;
60 
61   // Our menu bar widget.
62   GtkWidget* menu_bar_;
63 
64   // For some menu items, we want to show the accelerator, but not actually
65   // explicitly handle it. To this end we connect those menu items' accelerators
66   // to this group, but don't attach this group to any top level window.
67   GtkAccelGroup* dummy_accel_group_;
68 
69   // A mapping from command ids to GtkMenuItem objects. We use this to update
70   // the enable state since we are a .
71   IDMenuItemMap id_to_menu_item_;
72 
73   // gtk_check_menu_item_set_active() will call the "activate" signal. We need
74   // to block this activation while we change the checked state.
75   bool block_activation_;
76 };
77 
78 #endif  // CHROME_BROWSER_UI_GTK_GLOBAL_MENU_BAR_H_
79