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

Unified Diff: chrome/browser/ui/webui/settings/people_handler.cc

Issue 2971353002: [sync] Prevent flash of error icon while loading syncSetup page (Closed)
Patch Set: rename MaybeAcquireSyncBlocker Created 3 years, 5 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/settings/people_handler.cc
diff --git a/chrome/browser/ui/webui/settings/people_handler.cc b/chrome/browser/ui/webui/settings/people_handler.cc
index b0a1c045b204ff1a7a11dd4e6dcfe7c810b26146..e6a1b37ef3d5d764e9942bba45e99c7f05ebeb4c 100644
--- a/chrome/browser/ui/webui/settings/people_handler.cc
+++ b/chrome/browser/ui/webui/settings/people_handler.cc
@@ -29,12 +29,14 @@
#include "chrome/browser/sync/sync_ui_util.h"
#include "chrome/browser/ui/browser_finder.h"
#include "chrome/browser/ui/browser_window.h"
+#include "chrome/browser/ui/chrome_pages.h"
#include "chrome/browser/ui/singleton_tabs.h"
#include "chrome/browser/ui/user_manager.h"
#include "chrome/browser/ui/webui/profile_helper.h"
#include "chrome/browser/ui/webui/signin/login_ui_service.h"
#include "chrome/browser/ui/webui/signin/login_ui_service_factory.h"
#include "chrome/common/chrome_switches.h"
+#include "chrome/common/url_constants.h"
#include "chrome/grit/generated_resources.h"
#include "components/autofill/core/common/autofill_constants.h"
#include "components/autofill/core/common/autofill_pref_names.h"
@@ -196,6 +198,7 @@ PeopleHandler::~PeopleHandler() {
}
void PeopleHandler::RegisterMessages() {
+ InitializeSyncBlocker();
web_ui()->RegisterMessageCallback(
"SyncSetupDidClosePage",
base::Bind(&PeopleHandler::OnDidClosePage, base::Unretained(this)));
@@ -625,7 +628,7 @@ void PeopleHandler::OpenSyncSetup() {
GetLoginUIService()->SetLoginUI(this);
ProfileSyncService* service = GetSyncService();
- if (service)
+ if (service && !sync_blocker_)
sync_blocker_ = service->GetSetupInProgressHandle();
// There are several different UI flows that can bring the user here:
@@ -686,6 +689,20 @@ void PeopleHandler::OpenSyncSetup() {
PushSyncPrefs();
}
+void PeopleHandler::InitializeSyncBlocker() {
+ if (!web_ui())
+ return;
+ WebContents* web_contents = web_ui()->GetWebContents();
+ if (web_contents) {
+ ProfileSyncService* service = GetSyncService();
+ const GURL current_url = web_contents->GetVisibleURL();
+ if (service &&
+ current_url == chrome::GetSettingsUrl(chrome::kSyncSetupSubPage)) {
+ sync_blocker_ = service->GetSetupInProgressHandle();
+ }
+ }
+}
+
void PeopleHandler::FocusUI() {
WebContents* web_contents = web_ui()->GetWebContents();
web_contents->GetDelegate()->ActivateContents(web_contents);
« no previous file with comments | « chrome/browser/ui/webui/settings/people_handler.h ('k') | chrome/browser/ui/webui/settings/people_handler_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698