// Copyright (c) 2011 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef CHROME_BROWSER_UI_GTK_GLOBAL_MENU_BAR_H_ #define CHROME_BROWSER_UI_GTK_GLOBAL_MENU_BAR_H_ #include #include "chrome/browser/command_updater.h" #include "content/common/notification_observer.h" #include "content/common/notification_registrar.h" #include "ui/base/gtk/gtk_signal.h" class Browser; class BrowserWindowGtk; struct GlobalMenuBarCommand; typedef struct _GtkAccelGroup GtkAccelGroup; typedef struct _GtkWidget GtkWidget; // Controls the Mac style menu bar on Linux. // // Unity and some configurations of GNOME have a Apple-like menu bar at the top // of the screen that changes depending on the active window. These mainly work // by inspecting the application's widget hierarchy, and intercepting any // GtkMenuBar found. Thankfully, these systems don't check to see if the menu // bar itself is visible, so we insert a GtkMenuBar into the window hierarchy // and set it to be invisible. class GlobalMenuBar : public CommandUpdater::CommandObserver, public NotificationObserver { public: GlobalMenuBar(Browser* browser, BrowserWindowGtk* window); virtual ~GlobalMenuBar(); GtkWidget* widget() { return menu_bar_; } private: typedef std::map IDMenuItemMap; // Helper function that builds the data. void BuildGtkMenuFrom(int menu_str_id, std::map* id_to_menu_item, GlobalMenuBarCommand* commands); // CommandUpdater::CommandObserver: virtual void EnabledStateChangedForCommand(int id, bool enabled); // NotificationObserver: virtual void Observe(NotificationType type, const NotificationSource& source, const NotificationDetails& details); CHROMEGTK_CALLBACK_0(GlobalMenuBar, void, OnItemActivated); Browser* browser_; BrowserWindowGtk* browser_window_; NotificationRegistrar registrar_; // Our menu bar widget. GtkWidget* menu_bar_; // For some menu items, we want to show the accelerator, but not actually // explicitly handle it. To this end we connect those menu items' accelerators // to this group, but don't attach this group to any top level window. GtkAccelGroup* dummy_accel_group_; // A mapping from command ids to GtkMenuItem objects. We use this to update // the enable state since we are a . IDMenuItemMap id_to_menu_item_; // gtk_check_menu_item_set_active() will call the "activate" signal. We need // to block this activation while we change the checked state. bool block_activation_; }; #endif // CHROME_BROWSER_UI_GTK_GLOBAL_MENU_BAR_H_