1 // Copyright 2014 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_VIEWS_PROFILES_NEW_AVATAR_BUTTON_H_
6 #define CHROME_BROWSER_UI_VIEWS_PROFILES_NEW_AVATAR_BUTTON_H_
8 #include "chrome/browser/profiles/profile_info_cache_observer.h"
9 #include "components/signin/core/browser/signin_error_controller.h"
10 #include "ui/views/controls/button/label_button.h"
14 // Avatar button that displays the active profile's name in the caption area.
15 class NewAvatarButton
: public views::LabelButton
,
16 public ProfileInfoCacheObserver
,
17 public SigninErrorController::Observer
{
19 // Different button styles that can be applied.
20 enum AvatarButtonStyle
{
21 THEMED_BUTTON
, // Used in a themed browser window.
22 NATIVE_BUTTON
, // Used in a native aero or metro window.
25 NewAvatarButton(views::ButtonListener
* listener
,
26 AvatarButtonStyle button_style
,
28 ~NewAvatarButton() override
;
31 bool OnMousePressed(const ui::MouseEvent
& event
) override
;
32 void OnMouseReleased(const ui::MouseEvent
& event
) override
;
35 friend class ProfileChooserViewExtensionsTest
;
37 // ProfileInfoCacheObserver:
38 void OnProfileAdded(const base::FilePath
& profile_path
) override
;
39 void OnProfileWasRemoved(const base::FilePath
& profile_path
,
40 const base::string16
& profile_name
) override
;
41 void OnProfileNameChanged(const base::FilePath
& profile_path
,
42 const base::string16
& old_profile_name
) override
;
43 void OnProfileSupervisedUserIdChanged(
44 const base::FilePath
& profile_path
) override
;
46 // SigninErrorController::Observer:
47 void OnErrorChanged() override
;
49 // Called when the profile info cache has changed, which means we might
50 // have to update the icon/text of the button.
55 // Whether the signed in profile has an authentication error. Used to display
56 // an error icon next to the button text.
59 // The icon displayed instead of the profile name in the local profile case.
60 // Different assets are used depending on the OS version.
61 gfx::ImageSkia generic_avatar_
;
63 // This is used to check if the bubble was showing during the mouse pressed
64 // event. If this is true then the mouse released event is ignored to prevent
65 // the bubble from reshowing.
66 bool suppress_mouse_released_action_
;
68 DISALLOW_COPY_AND_ASSIGN(NewAvatarButton
);
71 #endif // CHROME_BROWSER_UI_VIEWS_PROFILES_NEW_AVATAR_BUTTON_H_