OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/ui/views/frame/avatar_button_manager.h" | 5 #include "chrome/browser/ui/views/frame/avatar_button_manager.h" |
6 | 6 |
7 #include "chrome/browser/browser_process.h" | 7 #include "chrome/browser/browser_process.h" |
8 #include "chrome/browser/profiles/profile_manager.h" | 8 #include "chrome/browser/profiles/profile_manager.h" |
| 9 #include "chrome/browser/themes/theme_service.h" |
| 10 #include "chrome/browser/themes/theme_service_factory.h" |
9 #include "chrome/browser/ui/view_ids.h" | 11 #include "chrome/browser/ui/view_ids.h" |
10 #include "chrome/browser/ui/views/frame/browser_frame.h" | 12 #include "chrome/browser/ui/views/frame/browser_frame.h" |
11 #include "chrome/browser/ui/views/frame/browser_view.h" | 13 #include "chrome/browser/ui/views/frame/browser_view.h" |
12 #include "chrome/browser/ui/views/profiles/new_avatar_button.h" | 14 #include "chrome/browser/ui/views/profiles/new_avatar_button.h" |
| 15 #include "chrome/browser/ui/views/profiles/profile_chooser_view.h" |
| 16 |
| 17 #if defined(OS_WIN) |
| 18 #include "base/win/windows_version.h" |
| 19 #endif |
13 | 20 |
14 AvatarButtonManager::AvatarButtonManager(BrowserNonClientFrameView* frame_view) | 21 AvatarButtonManager::AvatarButtonManager(BrowserNonClientFrameView* frame_view) |
15 : frame_view_(frame_view), view_(nullptr) {} | 22 : frame_view_(frame_view), button_(nullptr) {} |
16 | 23 |
17 void AvatarButtonManager::Update(AvatarButtonStyle style) { | 24 void AvatarButtonManager::Update(AvatarButtonStyle style) { |
18 BrowserView* browser_view = frame_view_->browser_view(); | 25 BrowserView* browser_view = frame_view_->browser_view(); |
19 BrowserFrame* frame = frame_view_->frame(); | 26 BrowserFrame* frame = frame_view_->frame(); |
20 Profile* profile = browser_view->browser()->profile(); | 27 Profile* profile = browser_view->browser()->profile(); |
21 | 28 |
22 // This should never be called in incognito mode. | 29 // This should never be called in incognito mode. |
23 DCHECK(browser_view->IsRegularOrGuestSession()); | 30 DCHECK(browser_view->IsRegularOrGuestSession()); |
24 ProfileAttributesEntry* unused; | 31 ProfileAttributesEntry* unused; |
25 if ((browser_view->IsBrowserTypeNormal() && | 32 if ((browser_view->IsBrowserTypeNormal() && |
26 // Tests may not have a profile manager. | 33 // Tests may not have a profile manager. |
27 g_browser_process->profile_manager() && | 34 g_browser_process->profile_manager() && |
28 g_browser_process->profile_manager() | 35 g_browser_process->profile_manager() |
29 ->GetProfileAttributesStorage() | 36 ->GetProfileAttributesStorage() |
30 .GetProfileAttributesWithPath(profile->GetPath(), &unused)) || | 37 .GetProfileAttributesWithPath(profile->GetPath(), &unused)) || |
31 // Desktop guest shows the avatar button. | 38 // Desktop guest shows the avatar button. |
32 browser_view->IsIncognito()) { | 39 browser_view->IsIncognito()) { |
33 if (!view_) { | 40 if (!button_) { |
34 view_ = new NewAvatarButton(this, style, profile); | 41 #if defined(OS_WIN) |
35 view_->set_id(VIEW_ID_AVATAR_BUTTON); | 42 // TODO: use MD button in other cases, too [http://crbug.com/591586] |
36 frame_view_->AddChildView(view_); | 43 if ((base::win::GetVersion() >= base::win::VERSION_WIN10) && |
| 44 ThemeServiceFactory::GetForProfile(profile)->UsingSystemTheme()) { |
| 45 DCHECK_EQ(AvatarButtonStyle::NATIVE, style); |
| 46 button_ = new MaterialDesignAvatarButton(this, profile, browser_view); |
| 47 } else { |
| 48 button_ = new NewAvatarButton(this, style, profile); |
| 49 } |
| 50 #else |
| 51 button_ = new NewAvatarButton(this, style, profile); |
| 52 #endif // defined(OS_WIN) |
| 53 |
| 54 button_->set_id(VIEW_ID_AVATAR_BUTTON); |
| 55 frame_view_->AddChildView(button_); |
37 frame->GetRootView()->Layout(); | 56 frame->GetRootView()->Layout(); |
38 } | 57 } |
39 } else if (view_) { | 58 } else if (button_) { |
40 delete view_; | 59 delete button_; |
41 view_ = nullptr; | 60 button_ = nullptr; |
42 frame->GetRootView()->Layout(); | 61 frame->GetRootView()->Layout(); |
43 } | 62 } |
44 } | 63 } |
45 | 64 |
46 void AvatarButtonManager::ButtonPreferredSizeChanged() { | 65 void AvatarButtonManager::ButtonPreferredSizeChanged() { |
47 // Perform a re-layout if the avatar button has changed, since that can affect | 66 // Perform a re-layout if the avatar button has changed, since that can affect |
48 // the size of the tabs. | 67 // the size of the tabs. |
49 if (!view_ || !frame_view_->browser_view()->initialized()) | 68 if (!button_ || !frame_view_->browser_view()->initialized()) |
50 return; // Ignore the update during view creation. | 69 return; // Ignore the update during view creation. |
51 | 70 |
52 frame_view_->InvalidateLayout(); | 71 frame_view_->InvalidateLayout(); |
53 frame_view_->frame()->GetRootView()->Layout(); | 72 frame_view_->frame()->GetRootView()->Layout(); |
54 } | 73 } |
55 | 74 |
56 void AvatarButtonManager::ButtonPressed(views::Button* sender, | 75 void AvatarButtonManager::OnMenuButtonClicked(views::MenuButton* source, |
57 const ui::Event& event) { | 76 const gfx::Point& point, |
58 DCHECK_EQ(view_, sender); | 77 const ui::Event* event) { |
| 78 DCHECK_EQ(button_, source); |
59 BrowserWindow::AvatarBubbleMode mode = | 79 BrowserWindow::AvatarBubbleMode mode = |
60 BrowserWindow::AVATAR_BUBBLE_MODE_DEFAULT; | 80 BrowserWindow::AVATAR_BUBBLE_MODE_DEFAULT; |
61 if ((event.IsMouseEvent() && | 81 |
62 static_cast<const ui::MouseEvent&>(event).IsRightMouseButton()) || | 82 if (event && event->type() == ui::ET_GESTURE_LONG_PRESS) |
63 (event.type() == ui::ET_GESTURE_LONG_PRESS)) { | |
64 return; | 83 return; |
65 } | 84 |
66 frame_view_->browser_view()->ShowAvatarBubbleFromAvatarButton( | 85 frame_view_->browser_view()->ShowAvatarBubbleFromAvatarButton( |
67 mode, signin::ManageAccountsParams(), | 86 mode, signin::ManageAccountsParams(), |
68 signin_metrics::AccessPoint::ACCESS_POINT_AVATAR_BUBBLE_SIGN_IN, false); | 87 signin_metrics::AccessPoint::ACCESS_POINT_AVATAR_BUBBLE_SIGN_IN, false); |
69 } | 88 } |
OLD | NEW |