Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(36)

Side by Side Diff: chrome/browser/ui/views/frame/avatar_button_manager.cc

Issue 2851543002: Update avatar button to MD (part 1) (Closed)
Patch Set: Merged ThemedAvatarButton and Win10NativeAvatarButton into the base AvatarButton class Created 3 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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/ui/view_ids.h" 9 #include "chrome/browser/ui/view_ids.h"
10 #include "chrome/browser/ui/views/frame/browser_frame.h" 10 #include "chrome/browser/ui/views/frame/browser_frame.h"
11 #include "chrome/browser/ui/views/frame/browser_view.h" 11 #include "chrome/browser/ui/views/frame/browser_view.h"
12 #include "chrome/browser/ui/views/profiles/new_avatar_button.h" 12 #include "chrome/browser/ui/views/profiles/avatar_button.h"
13 13
14 AvatarButtonManager::AvatarButtonManager(BrowserNonClientFrameView* frame_view) 14 AvatarButtonManager::AvatarButtonManager(BrowserNonClientFrameView* frame_view)
15 : frame_view_(frame_view), view_(nullptr) {} 15 : frame_view_(frame_view), view_(nullptr) {}
16 16
17 void AvatarButtonManager::Update(AvatarButtonStyle style) { 17 void AvatarButtonManager::Update(AvatarButtonStyle style) {
18 BrowserView* browser_view = frame_view_->browser_view(); 18 BrowserView* browser_view = frame_view_->browser_view();
19 BrowserFrame* frame = frame_view_->frame(); 19 BrowserFrame* frame = frame_view_->frame();
20 Profile* profile = browser_view->browser()->profile(); 20 Profile* profile = browser_view->browser()->profile();
21 21
22 // This should never be called in incognito mode. 22 // This should never be called in incognito mode.
23 DCHECK(browser_view->IsRegularOrGuestSession()); 23 DCHECK(browser_view->IsRegularOrGuestSession());
24 ProfileAttributesEntry* unused; 24 ProfileAttributesEntry* unused;
25 if ((browser_view->IsBrowserTypeNormal() && 25 if ((browser_view->IsBrowserTypeNormal() &&
26 // Tests may not have a profile manager. 26 // Tests may not have a profile manager.
27 g_browser_process->profile_manager() && 27 g_browser_process->profile_manager() &&
28 g_browser_process->profile_manager() 28 g_browser_process->profile_manager()
29 ->GetProfileAttributesStorage() 29 ->GetProfileAttributesStorage()
30 .GetProfileAttributesWithPath(profile->GetPath(), &unused)) || 30 .GetProfileAttributesWithPath(profile->GetPath(), &unused)) ||
31 // Desktop guest shows the avatar button. 31 // Desktop guest shows the avatar button.
32 browser_view->IsIncognito()) { 32 browser_view->IsIncognito()) {
33 if (!view_) { 33 if (!view_) {
34 view_ = new NewAvatarButton(this, style, profile); 34 view_ = new AvatarButton(this, style, profile);
35 view_->set_id(VIEW_ID_AVATAR_BUTTON); 35 view_->set_id(VIEW_ID_AVATAR_BUTTON);
36 frame_view_->AddChildView(view_); 36 frame_view_->AddChildView(view_);
37 frame->GetRootView()->Layout(); 37 frame->GetRootView()->Layout();
38 } 38 }
39 } else if (view_) { 39 } else if (view_) {
40 delete view_; 40 delete view_;
41 view_ = nullptr; 41 view_ = nullptr;
42 frame->GetRootView()->Layout(); 42 frame->GetRootView()->Layout();
43 } 43 }
44 } 44 }
45 45
46 void AvatarButtonManager::ButtonPreferredSizeChanged() {
47 // Perform a re-layout if the avatar button has changed, since that can affect
48 // the size of the tabs.
49 if (!view_ || !frame_view_->browser_view()->initialized())
50 return; // Ignore the update during view creation.
51
52 frame_view_->InvalidateLayout();
53 frame_view_->frame()->GetRootView()->Layout();
54 }
55
56 void AvatarButtonManager::ButtonPressed(views::Button* sender, 46 void AvatarButtonManager::ButtonPressed(views::Button* sender,
57 const ui::Event& event) { 47 const ui::Event& event) {
58 DCHECK_EQ(view_, sender); 48 DCHECK_EQ(view_, sender);
59 BrowserWindow::AvatarBubbleMode mode = 49 BrowserWindow::AvatarBubbleMode mode =
60 BrowserWindow::AVATAR_BUBBLE_MODE_DEFAULT; 50 BrowserWindow::AVATAR_BUBBLE_MODE_DEFAULT;
61 if ((event.IsMouseEvent() && 51 if ((event.IsMouseEvent() &&
62 static_cast<const ui::MouseEvent&>(event).IsRightMouseButton()) || 52 static_cast<const ui::MouseEvent&>(event).IsRightMouseButton()) ||
63 (event.type() == ui::ET_GESTURE_LONG_PRESS)) { 53 (event.type() == ui::ET_GESTURE_LONG_PRESS)) {
64 return; 54 return;
65 } 55 }
66 frame_view_->browser_view()->ShowAvatarBubbleFromAvatarButton( 56 frame_view_->browser_view()->ShowAvatarBubbleFromAvatarButton(
67 mode, signin::ManageAccountsParams(), 57 mode, signin::ManageAccountsParams(),
68 signin_metrics::AccessPoint::ACCESS_POINT_AVATAR_BUBBLE_SIGN_IN, false); 58 signin_metrics::AccessPoint::ACCESS_POINT_AVATAR_BUBBLE_SIGN_IN, false);
69 } 59 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698