Index: chrome/browser/ui/webui/signin/login_ui_service.cc |
diff --git a/chrome/browser/ui/webui/signin/login_ui_service.cc b/chrome/browser/ui/webui/signin/login_ui_service.cc |
index ed917088fc84fa2c4fe3e50491fb923041e8144b..159cb74c62d1b4710d9f4950ebb44720c6a7d697 100644 |
--- a/chrome/browser/ui/webui/signin/login_ui_service.cc |
+++ b/chrome/browser/ui/webui/signin/login_ui_service.cc |
@@ -8,12 +8,14 @@ |
#include "chrome/browser/signin/signin_promo.h" |
#include "chrome/browser/ui/browser.h" |
#include "chrome/browser/ui/browser_navigator.h" |
+#include "chrome/browser/ui/browser_window.h" |
#include "chrome/browser/ui/chrome_pages.h" |
#include "chrome/browser/ui/host_desktop.h" |
#include "chrome/browser/ui/scoped_tabbed_browser_displayer.h" |
#include "chrome/browser/ui/sync/inline_login_dialog.h" |
#include "chrome/browser/ui/webui/signin/login_ui_service_factory.h" |
#include "chrome/common/url_constants.h" |
+#include "components/signin/core/common/profile_management_switches.h" |
#if defined(OS_CHROMEOS) |
#include "chrome/browser/app_mode/app_mode_utils.h" |
@@ -64,3 +66,29 @@ void LoginUIService::ShowLoginPopup() { |
chrome::ShowBrowserSignin(displayer.browser(), signin::SOURCE_APP_LAUNCHER); |
#endif |
} |
+ |
+void LoginUIService::DisplayLoginResult(Browser* browser, |
+ const base::string16& message) { |
+ last_login_result_ = message; |
+ if (switches::IsNewAvatarMenu()) { |
+ browser->window()->ShowAvatarBubbleFromAvatarButton( |
+ message.empty() ? BrowserWindow::AVATAR_BUBBLE_MODE_CONFIRM_SIGNIN : |
+ BrowserWindow::AVATAR_BUBBLE_MODE_SHOW_ERROR, |
+ signin::ManageAccountsParams()); |
+ } else { |
+#if defined(ENABLE_ONE_CLICK_SIGNIN) |
+ browser->window()->ShowOneClickSigninBubble( |
+ BrowserWindow::ONE_CLICK_SIGNIN_BUBBLE_TYPE_BUBBLE, |
+ base::string16(), /* no SAML email */ |
+ message, |
+ // This callback is never invoked. |
+ // TODO(rogerta): Separate out the bubble API so we don't have to pass |
+ // ignored |email| and |callback| params. |
+ BrowserWindow::StartSyncCallback()); |
+#endif |
+ } |
+} |
+ |
+const base::string16& LoginUIService::GetLastLoginResult() { |
+ return last_login_result_; |
+} |