OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 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 | 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 #import <Cocoa/Cocoa.h> | 5 #import <Cocoa/Cocoa.h> |
6 #import <Carbon/Carbon.h> // kVK_Return. | 6 #import <Carbon/Carbon.h> // kVK_Return. |
7 | 7 |
8 #import "chrome/browser/ui/cocoa/profiles/profile_chooser_controller.h" | 8 #import "chrome/browser/ui/cocoa/profiles/profile_chooser_controller.h" |
9 | 9 |
10 #include "base/mac/bundle_locations.h" | 10 #include "base/mac/bundle_locations.h" |
11 #include "base/prefs/pref_service.h" | 11 #include "base/prefs/pref_service.h" |
12 #include "base/strings/string_util.h" | 12 #include "base/strings/string_util.h" |
13 #include "base/strings/sys_string_conversions.h" | 13 #include "base/strings/sys_string_conversions.h" |
14 #include "base/strings/utf_string_conversions.h" | 14 #include "base/strings/utf_string_conversions.h" |
15 #include "chrome/app/chrome_command_ids.h" | 15 #include "chrome/app/chrome_command_ids.h" |
16 #include "chrome/browser/browser_process.h" | 16 #include "chrome/browser/browser_process.h" |
17 #include "chrome/browser/chrome_notification_types.h" | 17 #include "chrome/browser/chrome_notification_types.h" |
18 #include "chrome/browser/lifetime/application_lifetime.h" | 18 #include "chrome/browser/lifetime/application_lifetime.h" |
19 #include "chrome/browser/prefs/incognito_mode_prefs.h" | 19 #include "chrome/browser/prefs/incognito_mode_prefs.h" |
20 #include "chrome/browser/profiles/avatar_menu.h" | 20 #include "chrome/browser/profiles/avatar_menu.h" |
21 #include "chrome/browser/profiles/avatar_menu_observer.h" | 21 #include "chrome/browser/profiles/avatar_menu_observer.h" |
22 #include "chrome/browser/profiles/profile_avatar_icon_util.h" | 22 #include "chrome/browser/profiles/profile_avatar_icon_util.h" |
23 #include "chrome/browser/profiles/profile_info_cache.h" | 23 #include "chrome/browser/profiles/profile_info_cache.h" |
24 #include "chrome/browser/profiles/profile_manager.h" | 24 #include "chrome/browser/profiles/profile_manager.h" |
25 #include "chrome/browser/profiles/profile_metrics.h" | 25 #include "chrome/browser/profiles/profile_metrics.h" |
26 #include "chrome/browser/profiles/profile_window.h" | 26 #include "chrome/browser/profiles/profile_window.h" |
27 #include "chrome/browser/profiles/profiles_state.h" | 27 #include "chrome/browser/profiles/profiles_state.h" |
28 #include "chrome/browser/signin/profile_oauth2_token_service_factory.h" | 28 #include "chrome/browser/signin/profile_oauth2_token_service_factory.h" |
| 29 #include "chrome/browser/signin/signin_error_controller_factory.h" |
29 #include "chrome/browser/signin/signin_header_helper.h" | 30 #include "chrome/browser/signin/signin_header_helper.h" |
30 #include "chrome/browser/signin/signin_manager_factory.h" | 31 #include "chrome/browser/signin/signin_manager_factory.h" |
31 #include "chrome/browser/signin/signin_promo.h" | 32 #include "chrome/browser/signin/signin_promo.h" |
32 #include "chrome/browser/signin/signin_ui_util.h" | 33 #include "chrome/browser/signin/signin_ui_util.h" |
33 #include "chrome/browser/ui/browser.h" | 34 #include "chrome/browser/ui/browser.h" |
34 #include "chrome/browser/ui/browser_commands.h" | 35 #include "chrome/browser/ui/browser_commands.h" |
35 #include "chrome/browser/ui/browser_window.h" | 36 #include "chrome/browser/ui/browser_window.h" |
36 #include "chrome/browser/ui/chrome_pages.h" | 37 #include "chrome/browser/ui/chrome_pages.h" |
37 #include "chrome/browser/ui/chrome_style.h" | 38 #include "chrome/browser/ui/chrome_style.h" |
38 #import "chrome/browser/ui/cocoa/browser_window_utils.h" | 39 #import "chrome/browser/ui/cocoa/browser_window_utils.h" |
(...skipping 201 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
240 [container addSubview:title_label]; | 241 [container addSubview:title_label]; |
241 CGFloat height = std::max(NSMaxY([title_label frame]), | 242 CGFloat height = std::max(NSMaxY([title_label frame]), |
242 NSMaxY([button frame])) + kVerticalSpacing; | 243 NSMaxY([button frame])) + kVerticalSpacing; |
243 [container setFrameSize:NSMakeSize(NSWidth([container frame]), height)]; | 244 [container setFrameSize:NSMakeSize(NSWidth([container frame]), height)]; |
244 | 245 |
245 return container.autorelease(); | 246 return container.autorelease(); |
246 } | 247 } |
247 | 248 |
248 bool HasAuthError(Profile* profile) { | 249 bool HasAuthError(Profile* profile) { |
249 const SigninErrorController* error_controller = | 250 const SigninErrorController* error_controller = |
250 profiles::GetSigninErrorController(profile); | 251 SigninErrorControllerFactory::GetForProfile(profile); |
251 return error_controller && error_controller->HasError(); | 252 return error_controller && error_controller->HasError(); |
252 } | 253 } |
253 | 254 |
| 255 std::string GetAuthErrorAccountId(Profile* profile) { |
| 256 const SigninErrorController* error_controller = |
| 257 SigninErrorControllerFactory::GetForProfile(profile); |
| 258 if (!error_controller) |
| 259 return std::string(); |
| 260 |
| 261 return error_controller->error_account_id(); |
| 262 } |
| 263 |
254 } // namespace | 264 } // namespace |
255 | 265 |
256 // Custom WebContentsDelegate that allows handling of hotkeys and suppresses | 266 // Custom WebContentsDelegate that allows handling of hotkeys and suppresses |
257 // the context menu. | 267 // the context menu. |
258 class GaiaWebContentsDelegate : public content::WebContentsDelegate { | 268 class GaiaWebContentsDelegate : public content::WebContentsDelegate { |
259 public: | 269 public: |
260 GaiaWebContentsDelegate() {} | 270 GaiaWebContentsDelegate() {} |
261 ~GaiaWebContentsDelegate() override {} | 271 ~GaiaWebContentsDelegate() override {} |
262 | 272 |
263 private: | 273 private: |
(...skipping 1671 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1935 | 1945 |
1936 Profile* profile = browser_->profile(); | 1946 Profile* profile = browser_->profile(); |
1937 std::string primaryAccount = | 1947 std::string primaryAccount = |
1938 SigninManagerFactory::GetForProfile(profile)->GetAuthenticatedAccountId(); | 1948 SigninManagerFactory::GetForProfile(profile)->GetAuthenticatedAccountId(); |
1939 DCHECK(!primaryAccount.empty()); | 1949 DCHECK(!primaryAccount.empty()); |
1940 std::vector<std::string>accounts = | 1950 std::vector<std::string>accounts = |
1941 profiles::GetSecondaryAccountsForProfile(profile, primaryAccount); | 1951 profiles::GetSecondaryAccountsForProfile(profile, primaryAccount); |
1942 | 1952 |
1943 // If there is an account with an authentication error, it needs to be | 1953 // If there is an account with an authentication error, it needs to be |
1944 // badged with a warning icon. | 1954 // badged with a warning icon. |
1945 const SigninErrorController* errorController = | 1955 std::string errorAccountId = GetAuthErrorAccountId(profile); |
1946 profiles::GetSigninErrorController(profile); | |
1947 std::string errorAccountId = | |
1948 errorController ? errorController->error_account_id() : std::string(); | |
1949 | 1956 |
1950 rect.origin.y = 0; | 1957 rect.origin.y = 0; |
1951 for (size_t i = 0; i < accounts.size(); ++i) { | 1958 for (size_t i = 0; i < accounts.size(); ++i) { |
1952 // Save the original email address, as the button text could be elided. | 1959 // Save the original email address, as the button text could be elided. |
1953 currentProfileAccounts_[i] = accounts[i]; | 1960 currentProfileAccounts_[i] = accounts[i]; |
1954 NSButton* accountButton = | 1961 NSButton* accountButton = |
1955 [self accountButtonWithRect:rect | 1962 [self accountButtonWithRect:rect |
1956 accountId:accounts[i] | 1963 accountId:accounts[i] |
1957 tag:i | 1964 tag:i |
1958 reauthRequired:errorAccountId == accounts[i]]; | 1965 reauthRequired:errorAccountId == accounts[i]]; |
(...skipping 13 matching lines...) Expand all Loading... |
1972 return container.autorelease(); | 1979 return container.autorelease(); |
1973 } | 1980 } |
1974 | 1981 |
1975 - (NSView*)buildGaiaEmbeddedView { | 1982 - (NSView*)buildGaiaEmbeddedView { |
1976 base::scoped_nsobject<NSView> container( | 1983 base::scoped_nsobject<NSView> container( |
1977 [[NSView alloc] initWithFrame:NSZeroRect]); | 1984 [[NSView alloc] initWithFrame:NSZeroRect]); |
1978 CGFloat yOffset = 0; | 1985 CGFloat yOffset = 0; |
1979 | 1986 |
1980 GURL url; | 1987 GURL url; |
1981 int messageId = -1; | 1988 int messageId = -1; |
1982 SigninErrorController* errorController = NULL; | |
1983 switch (viewMode_) { | 1989 switch (viewMode_) { |
1984 case profiles::BUBBLE_VIEW_MODE_GAIA_SIGNIN: | 1990 case profiles::BUBBLE_VIEW_MODE_GAIA_SIGNIN: |
1985 url = signin::GetPromoURL(signin_metrics::SOURCE_AVATAR_BUBBLE_SIGN_IN, | 1991 url = signin::GetPromoURL(signin_metrics::SOURCE_AVATAR_BUBBLE_SIGN_IN, |
1986 false /* auto_close */, | 1992 false /* auto_close */, |
1987 true /* is_constrained */); | 1993 true /* is_constrained */); |
1988 messageId = IDS_PROFILES_GAIA_SIGNIN_TITLE; | 1994 messageId = IDS_PROFILES_GAIA_SIGNIN_TITLE; |
1989 break; | 1995 break; |
1990 case profiles::BUBBLE_VIEW_MODE_GAIA_ADD_ACCOUNT: | 1996 case profiles::BUBBLE_VIEW_MODE_GAIA_ADD_ACCOUNT: |
1991 url = signin::GetPromoURL( | 1997 url = signin::GetPromoURL( |
1992 signin_metrics::SOURCE_AVATAR_BUBBLE_ADD_ACCOUNT, | 1998 signin_metrics::SOURCE_AVATAR_BUBBLE_ADD_ACCOUNT, |
1993 false /* auto_close */, | 1999 false /* auto_close */, |
1994 true /* is_constrained */); | 2000 true /* is_constrained */); |
1995 messageId = IDS_PROFILES_GAIA_ADD_ACCOUNT_TITLE; | 2001 messageId = IDS_PROFILES_GAIA_ADD_ACCOUNT_TITLE; |
1996 break; | 2002 break; |
1997 case profiles::BUBBLE_VIEW_MODE_GAIA_REAUTH: | 2003 case profiles::BUBBLE_VIEW_MODE_GAIA_REAUTH: |
1998 DCHECK(HasAuthError(browser_->profile())); | 2004 DCHECK(HasAuthError(browser_->profile())); |
1999 errorController = profiles::GetSigninErrorController(browser_->profile()); | |
2000 url = signin::GetReauthURL( | 2005 url = signin::GetReauthURL( |
2001 browser_->profile(), | 2006 browser_->profile(), GetAuthErrorAccountId(browser_->profile())); |
2002 errorController ? errorController->error_username() : std::string()); | |
2003 messageId = IDS_PROFILES_GAIA_REAUTH_TITLE; | 2007 messageId = IDS_PROFILES_GAIA_REAUTH_TITLE; |
2004 break; | 2008 break; |
2005 default: | 2009 default: |
2006 NOTREACHED() << "Called with invalid mode=" << viewMode_; | 2010 NOTREACHED() << "Called with invalid mode=" << viewMode_; |
2007 break; | 2011 break; |
2008 } | 2012 } |
2009 | 2013 |
2010 webContents_.reset(content::WebContents::Create( | 2014 webContents_.reset(content::WebContents::Create( |
2011 content::WebContents::CreateParams(browser_->profile()))); | 2015 content::WebContents::CreateParams(browser_->profile()))); |
2012 | 2016 |
(...skipping 298 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2311 } | 2315 } |
2312 | 2316 |
2313 - (bool)shouldShowGoIncognito { | 2317 - (bool)shouldShowGoIncognito { |
2314 bool incognitoAvailable = | 2318 bool incognitoAvailable = |
2315 IncognitoModePrefs::GetAvailability(browser_->profile()->GetPrefs()) != | 2319 IncognitoModePrefs::GetAvailability(browser_->profile()->GetPrefs()) != |
2316 IncognitoModePrefs::DISABLED; | 2320 IncognitoModePrefs::DISABLED; |
2317 return incognitoAvailable && !browser_->profile()->IsGuestSession(); | 2321 return incognitoAvailable && !browser_->profile()->IsGuestSession(); |
2318 } | 2322 } |
2319 | 2323 |
2320 @end | 2324 @end |
OLD | NEW |