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

Unified Diff: chrome/browser/ui/views/profiles/new_avatar_button.cc

Issue 1701563002: Refactor ProfileInfoCache in c/b/ui/views (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Respond to comments Created 4 years, 10 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/ui/views/profiles/new_avatar_button.cc
diff --git a/chrome/browser/ui/views/profiles/new_avatar_button.cc b/chrome/browser/ui/views/profiles/new_avatar_button.cc
index 5595166ecc4eaa3daeb22986f90b57078e493ce8..8101291f7f92675a757efff527a208c909d52893 100644
--- a/chrome/browser/ui/views/profiles/new_avatar_button.cc
+++ b/chrome/browser/ui/views/profiles/new_avatar_button.cc
@@ -9,6 +9,7 @@
#include "base/win/windows_version.h"
#include "build/build_config.h"
#include "chrome/browser/browser_process.h"
+#include "chrome/browser/profiles/profile_attributes_entry.h"
#include "chrome/browser/profiles/profile_manager.h"
#include "chrome/browser/profiles/profiles_state.h"
#include "chrome/browser/ui/browser.h"
@@ -100,7 +101,8 @@ NewAvatarButton::NewAvatarButton(views::ButtonListener* listener,
*rb->GetImageNamed(IDR_AVATAR_NATIVE_BUTTON_AVATAR).ToImageSkia();
}
- g_browser_process->profile_manager()->GetProfileInfoCache().AddObserver(this);
+ g_browser_process->profile_manager()->
+ GetProfileAttributesStorage().AddObserver(this);
// Subscribe to authentication error changes so that the avatar button can
// update itself. Note that guest mode profiles won't have a token service.
@@ -117,7 +119,7 @@ NewAvatarButton::NewAvatarButton(views::ButtonListener* listener,
NewAvatarButton::~NewAvatarButton() {
g_browser_process->profile_manager()->
- GetProfileInfoCache().RemoveObserver(this);
+ GetProfileAttributesStorage().RemoveObserver(this);
SigninErrorController* error =
profiles::GetSigninErrorController(browser_->profile());
if (error)
@@ -184,18 +186,20 @@ void NewAvatarButton::OnErrorChanged() {
}
void NewAvatarButton::Update() {
- const ProfileInfoCache& cache =
- g_browser_process->profile_manager()->GetProfileInfoCache();
+ ProfileAttributesStorage& storage =
+ g_browser_process->profile_manager()->GetProfileAttributesStorage();
// If we have a single local profile, then use the generic avatar
// button instead of the profile name. Never use the generic button if
// the active profile is Guest.
- bool use_generic_button = (!browser_->profile()->IsGuestSession() &&
- cache.GetNumberOfProfiles() == 1 &&
- !cache.ProfileIsAuthenticatedAtIndex(0));
-
- SetText(use_generic_button ? base::string16() :
- profiles::GetAvatarButtonTextForProfile(browser_->profile()));
+ bool use_generic_button =
achuithb 2016/02/19 11:55:22 const
lwchkg 2016/02/20 05:20:04 Done.
+ !browser_->profile()->IsGuestSession() &&
+ storage.GetNumberOfProfiles() == 1 &&
+ storage.GetAllProfilesAttributes().front()->IsAuthenticated();
+
+ SetText(use_generic_button
+ ? base::string16()
+ : profiles::GetAvatarButtonTextForProfile(browser_->profile()));
// If the button has no text, clear the text shadows to make sure the
// image is centered correctly.

Powered by Google App Engine
This is Rietveld 408576698