1 // Copyright (c) 2012 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.
5 #ifndef CHROME_BROWSER_UI_GTK_AVATAR_MENU_ITEM_GTK_H_
6 #define CHROME_BROWSER_UI_GTK_AVATAR_MENU_ITEM_GTK_H_
10 #include "chrome/browser/profiles/avatar_menu.h"
11 #include "content/public/browser/notification_observer.h"
12 #include "content/public/browser/notification_registrar.h"
13 #include "ui/base/gtk/gtk_signal.h"
14 #include "ui/base/gtk/owned_widget_gtk.h"
16 class GtkThemeService;
18 // This widget contains the profile icon, user name, and synchronization status
19 // to be displayed in the AvatarMenuBubble. Clicking the profile will open a new
20 // browser window, and when the user hovers over an active profile item, a link
21 // is displayed that will allow editing the profile.
22 class AvatarMenuItemGtk : public content::NotificationObserver {
24 // Delegates opening or editing a profile.
27 // Open a new browser window using the profile at |profile_index|.
28 virtual void OpenProfile(size_t profile_index) = 0;
30 // Edit the profile given by |profile_index|.
31 virtual void EditProfile(size_t profile_index) = 0;
34 AvatarMenuItemGtk(Delegate* delegate,
35 const AvatarMenu::Item& item,
37 GtkThemeService* theme_service);
38 virtual ~AvatarMenuItemGtk();
40 // Returns the root widget for this menu item.
41 GtkWidget* widget() { return widget_.get(); }
43 // content::NotificationObserver implementation.
44 virtual void Observe(int type,
45 const content::NotificationSource& source,
46 const content::NotificationDetails& details) OVERRIDE;
50 void ShowStatusLabel();
53 CHROMEGTK_CALLBACK_1(AvatarMenuItemGtk, gboolean, OnProfileClick,
55 CHROMEGTK_CALLBACK_1(AvatarMenuItemGtk, gboolean, OnProfileEnter,
57 CHROMEGTK_CALLBACK_1(AvatarMenuItemGtk, gboolean, OnProfileLeave,
59 CHROMEGTK_CALLBACK_1(AvatarMenuItemGtk, gboolean, OnProfileFocusIn,
61 CHROMEGTK_CALLBACK_1(AvatarMenuItemGtk, gboolean, OnProfileFocusOut,
63 CHROMEGTK_CALLBACK_1(AvatarMenuItemGtk, gboolean, OnProfileKeyPress,
65 CHROMEGTK_CALLBACK_1(AvatarMenuItemGtk, gboolean, OnEventBoxExpose,
67 CHROMEGTK_CALLBACK_0(AvatarMenuItemGtk, void, OnEditProfileLinkClicked);
69 // Create all widgets in this menu item, using |theme_service|.
70 void Init(GtkThemeService* theme_service);
72 // A weak pointer to the item's delegate.
75 // Profile information to display for this item, e.g. user name, sync status.
76 AvatarMenu::Item item_;
78 // The index of this profile. The delegate uses this value to distinguish
79 // which profile should be switched to.
82 // The root widget for this menu item.
83 ui::OwnedWidgetGtk widget_;
86 GtkThemeService* theme_service_;
88 // A weak pointer to a label that displays the sync status. It is not shown
89 // when the user is hovering over the item if the profile is the active
91 GtkWidget* status_label_;
93 // A weak pointer to a link button to edit the given profile. It is shown only
94 // when the user is hovering over the active profile.
95 GtkWidget* link_alignment_;
97 // A weak pointer to a GtkChromeLinkButton so we can keep the use_gtk_theme
98 // property up to date.
99 GtkWidget* edit_profile_link_;
101 // The highlighted color. Depending on the theme, this is either |widget|'s
102 // bg[GTK_STATE_SELECTED] or a static highlight.
103 GdkColor highlighted_color_;
105 // The unhighlighted color. Depending on the theme, this is either NULL or a
106 // pointer to static data.
107 const GdkColor* unhighlighted_color_;
109 content::NotificationRegistrar registrar_;
111 DISALLOW_COPY_AND_ASSIGN(AvatarMenuItemGtk);
114 #endif // CHROME_BROWSER_UI_GTK_AVATAR_MENU_ITEM_GTK_H_