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

Unified Diff: chrome/browser/ui/webui/signin/inline_login_handler.cc

Issue 256623002: Implemented inline login dialog for Chrome OS. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Comments addressed. Created 6 years, 8 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/webui/signin/inline_login_handler.cc
diff --git a/chrome/browser/ui/webui/signin/inline_login_handler.cc b/chrome/browser/ui/webui/signin/inline_login_handler.cc
index 6c6e9110734ab67b83de49c47ce2690d505587c6..d104d14195d86b725cd0f42b67935b57331db581 100644
--- a/chrome/browser/ui/webui/signin/inline_login_handler.cc
+++ b/chrome/browser/ui/webui/signin/inline_login_handler.cc
@@ -5,10 +5,15 @@
#include "chrome/browser/ui/webui/signin/inline_login_handler.h"
#include "base/bind.h"
+#include "base/strings/utf_string_conversions.h"
#include "base/values.h"
#include "chrome/browser/browser_process.h"
+#include "chrome/browser/profiles/profile.h"
+#include "chrome/browser/ui/browser_navigator.h"
+#include "content/public/browser/web_contents.h"
#include "content/public/browser/web_ui.h"
#include "google_apis/gaia/gaia_urls.h"
+#include "net/base/url_util.h"
InlineLoginHandler::InlineLoginHandler() {}
@@ -21,6 +26,10 @@ void InlineLoginHandler::RegisterMessages() {
web_ui()->RegisterMessageCallback("completeLogin",
base::Bind(&InlineLoginHandler::HandleCompleteLoginMessage,
base::Unretained(this)));
+ web_ui()->RegisterMessageCallback(
+ "switchToFullTab",
+ base::Bind(&InlineLoginHandler::HandleSwitchToFullTabMessage,
+ base::Unretained(this)));
}
void InlineLoginHandler::HandleInitializeMessage(const base::ListValue* args) {
@@ -41,3 +50,21 @@ void InlineLoginHandler::HandleCompleteLoginMessage(
const base::ListValue* args) {
CompleteLogin(args);
}
+
+void InlineLoginHandler::HandleSwitchToFullTabMessage(
+ const base::ListValue* args) {
+ base::string16 url_str;
+ CHECK(args->GetString(0, &url_str));
+
+ content::WebContents* web_contents = web_ui()->GetWebContents();
+ GURL main_frame_url(web_contents->GetURL());
+ main_frame_url = net::AppendOrReplaceQueryParameter(
+ main_frame_url, "frameUrl", base::UTF16ToASCII(url_str));
+ chrome::NavigateParams params(
+ Profile::FromWebUI(web_ui()),
+ net::AppendOrReplaceQueryParameter(main_frame_url, "constrained", "0"),
+ content::PAGE_TRANSITION_AUTO_TOPLEVEL);
+ chrome::Navigate(&params);
+
+ web_ui()->CallJavascriptFunction("inline.login.closeDialog");
+}

Powered by Google App Engine
This is Rietveld 408576698