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

Unified Diff: chrome/browser/ui/webui/options2/options_sync_setup_handler.cc

Issue 8895023: Options2: Pull the trigger. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: DIAF. Created 9 years 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/options2/options_sync_setup_handler.cc
diff --git a/chrome/browser/ui/webui/options2/options_sync_setup_handler.cc b/chrome/browser/ui/webui/options2/options_sync_setup_handler.cc
new file mode 100644
index 0000000000000000000000000000000000000000..81e114e31c8c5b49d699f29571dda469fedc2a91
--- /dev/null
+++ b/chrome/browser/ui/webui/options2/options_sync_setup_handler.cc
@@ -0,0 +1,55 @@
+// Copyright (c) 2011 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/ui/webui/options2/options_sync_setup_handler.h"
+
+#include "chrome/browser/profiles/profile.h"
+#include "chrome/browser/sync/profile_sync_service.h"
+
+OptionsSyncSetupHandler::OptionsSyncSetupHandler(
+ ProfileManager* profile_manager) : SyncSetupHandler2(profile_manager) {
+}
+
+OptionsSyncSetupHandler::~OptionsSyncSetupHandler() {
+}
+
+void OptionsSyncSetupHandler::StepWizardForShowSetupUI() {
+ ProfileSyncService* service =
+ Profile::FromWebUI(web_ui_)->GetProfileSyncService();
+ DCHECK(service);
+
+ // We should bring up either a login or a configure flow based on the state of
+ // sync.
+ if (service->HasSyncSetupCompleted()) {
+ if (service->IsPassphraseRequiredForDecryption()) {
+ service->get_wizard().Step(SyncSetupWizard::ENTER_PASSPHRASE);
+ } else {
+ service->get_wizard().Step(SyncSetupWizard::CONFIGURE);
+ }
+ } else {
+ service->get_wizard().Step(SyncSetupWizard::GetLoginState());
+ }
+}
+
+void OptionsSyncSetupHandler::ShowSetupUI() {
+ ProfileSyncService* service =
+ Profile::FromWebUI(web_ui_)->GetProfileSyncService();
+ DCHECK(service);
+
+ // The user is trying to manually load a syncSetup URL. We should bring up
+ // either a login or a configure flow based on the state of sync.
+ if (service->HasSyncSetupCompleted()) {
+ if (service->IsPassphraseRequiredForDecryption()) {
+ service->get_wizard().Step(SyncSetupWizard::ENTER_PASSPHRASE);
+ } else {
+ service->get_wizard().Step(SyncSetupWizard::CONFIGURE);
+ }
+ } else {
+ service->get_wizard().Step(SyncSetupWizard::GetLoginState());
+ }
+
+ // Show the Sync Setup page.
+ scoped_ptr<Value> page(Value::CreateStringValue("syncSetup"));
+ web_ui_->CallJavascriptFunction("OptionsPage.navigateToPage", *page);
+}
« no previous file with comments | « chrome/browser/ui/webui/options2/options_sync_setup_handler.h ('k') | chrome/browser/ui/webui/options2/options_ui2.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698