Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 #include "chrome/browser/dom_ui/options/personal_options_handler.h" | 5 #include "chrome/browser/dom_ui/options/personal_options_handler.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 | 8 |
| 9 #include "app/l10n_util.h" | 9 #include "app/l10n_util.h" |
| 10 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
| 11 #include "base/callback.h" | 11 #include "base/callback.h" |
| 12 #include "base/path_service.h" | 12 #include "base/path_service.h" |
| 13 #include "base/stl_util-inl.h" | 13 #include "base/stl_util-inl.h" |
| 14 #include "base/utf_string_conversions.h" | 14 #include "base/utf_string_conversions.h" |
| 15 #include "base/values.h" | 15 #include "base/values.h" |
| 16 #include "build/build_config.h" | 16 #include "build/build_config.h" |
| 17 #include "chrome/browser/browser_list.h" | 17 #include "chrome/browser/browser_list.h" |
| 18 #include "chrome/browser/dom_ui/options/dom_options_util.h" | 18 #include "chrome/browser/dom_ui/options/dom_options_util.h" |
| 19 #include "chrome/browser/dom_ui/options/options_managed_banner_handler.h" | 19 #include "chrome/browser/dom_ui/options/options_managed_banner_handler.h" |
| 20 #include "chrome/browser/profiles/profile.h" | 20 #include "chrome/browser/profiles/profile.h" |
| 21 #include "chrome/browser/profiles/profile_manager.h" | 21 #include "chrome/browser/profiles/profile_manager.h" |
| 22 #include "chrome/browser/sync/profile_sync_service.h" | 22 #include "chrome/browser/sync/profile_sync_service.h" |
| 23 #include "chrome/browser/sync/sync_setup_flow.h" | |
| 23 #include "chrome/browser/sync/sync_ui_util.h" | 24 #include "chrome/browser/sync/sync_ui_util.h" |
| 24 #include "chrome/browser/themes/browser_theme_provider.h" | 25 #include "chrome/browser/themes/browser_theme_provider.h" |
| 25 #include "chrome/browser/ui/options/options_page_base.h" | 26 #include "chrome/browser/ui/options/options_page_base.h" |
| 26 #include "chrome/browser/ui/options/options_window.h" | 27 #include "chrome/browser/ui/options/options_window.h" |
| 27 #include "chrome/common/net/gaia/google_service_auth_error.h" | 28 #include "chrome/common/net/gaia/google_service_auth_error.h" |
| 28 #include "chrome/common/notification_service.h" | 29 #include "chrome/common/notification_service.h" |
| 29 #include "chrome/common/chrome_paths.h" | 30 #include "chrome/common/chrome_paths.h" |
| 30 #include "grit/browser_resources.h" | 31 #include "grit/browser_resources.h" |
| 31 #include "grit/chromium_strings.h" | 32 #include "grit/chromium_strings.h" |
| 32 #include "grit/generated_resources.h" | 33 #include "grit/generated_resources.h" |
| (...skipping 84 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 117 Value::CreateStringValue( | 118 Value::CreateStringValue( |
| 118 l10n_util::GetStringUTF8(IDS_SYNC_OPTIONS_SELECT_DATATYPES))); | 119 l10n_util::GetStringUTF8(IDS_SYNC_OPTIONS_SELECT_DATATYPES))); |
| 119 sync_select_list->Append(datatypes); | 120 sync_select_list->Append(datatypes); |
| 120 ListValue* everything = new ListValue; | 121 ListValue* everything = new ListValue; |
| 121 everything->Append(Value::CreateBooleanValue(true)); | 122 everything->Append(Value::CreateBooleanValue(true)); |
| 122 everything->Append( | 123 everything->Append( |
| 123 Value::CreateStringValue( | 124 Value::CreateStringValue( |
| 124 l10n_util::GetStringUTF8(IDS_SYNC_OPTIONS_SELECT_EVERYTHING))); | 125 l10n_util::GetStringUTF8(IDS_SYNC_OPTIONS_SELECT_EVERYTHING))); |
| 125 sync_select_list->Append(everything); | 126 sync_select_list->Append(everything); |
| 126 localized_strings->Set("syncSelectList", sync_select_list); | 127 localized_strings->Set("syncSelectList", sync_select_list); |
| 128 | |
| 129 if (!ProfileSyncService::IsSyncEnabled()) | |
| 130 return; | |
|
James Hawkins
2011/01/17 23:46:18
The sync strings should be loaded regardless of wh
tfarina
2011/01/17 23:52:17
Removed.
| |
| 131 | |
| 132 // Sync page - ChromeOS | |
|
James Hawkins
2011/01/17 23:46:18
s/ - ChromeOS/./
tfarina
2011/01/17 23:52:17
Done.
| |
| 133 localized_strings->SetString("syncPage", | |
| 134 l10n_util::GetStringUTF16(IDS_SYNC_NTP_SYNC_SECTION_TITLE)); | |
| 135 localized_strings->SetString("sync_title", | |
| 136 l10n_util::GetStringUTF16(IDS_CUSTOMIZE_SYNC_DESCRIPTION)); | |
| 137 localized_strings->SetString("syncsettings", | |
| 138 l10n_util::GetStringUTF16(IDS_SYNC_DATATYPE_PREFERENCES)); | |
| 139 localized_strings->SetString("syncbookmarks", | |
| 140 l10n_util::GetStringUTF16(IDS_SYNC_DATATYPE_BOOKMARKS)); | |
| 141 localized_strings->SetString("synctypedurls", | |
| 142 l10n_util::GetStringUTF16(IDS_SYNC_DATATYPE_TYPED_URLS)); | |
| 143 localized_strings->SetString("syncpasswords", | |
| 144 l10n_util::GetStringUTF16(IDS_SYNC_DATATYPE_PASSWORDS)); | |
| 145 localized_strings->SetString("syncextensions", | |
| 146 l10n_util::GetStringUTF16(IDS_SYNC_DATATYPE_EXTENSIONS)); | |
| 147 localized_strings->SetString("syncautofill", | |
| 148 l10n_util::GetStringUTF16(IDS_SYNC_DATATYPE_AUTOFILL)); | |
| 149 localized_strings->SetString("syncthemes", | |
| 150 l10n_util::GetStringUTF16(IDS_SYNC_DATATYPE_THEMES)); | |
| 151 localized_strings->SetString("syncapps", | |
| 152 l10n_util::GetStringUTF16(IDS_SYNC_DATATYPE_APPS)); | |
| 153 localized_strings->SetString("syncsessions", | |
| 154 l10n_util::GetStringUTF16(IDS_SYNC_DATATYPE_SESSIONS)); | |
| 127 } | 155 } |
| 128 | 156 |
| 129 void PersonalOptionsHandler::RegisterMessages() { | 157 void PersonalOptionsHandler::RegisterMessages() { |
| 130 DCHECK(dom_ui_); | 158 DCHECK(dom_ui_); |
| 131 dom_ui_->RegisterMessageCallback( | 159 dom_ui_->RegisterMessageCallback( |
| 132 "showSyncLoginDialog", | 160 "showSyncLoginDialog", |
| 133 NewCallback(this, &PersonalOptionsHandler::ShowSyncLoginDialog)); | 161 NewCallback(this, &PersonalOptionsHandler::ShowSyncLoginDialog)); |
| 134 dom_ui_->RegisterMessageCallback( | 162 dom_ui_->RegisterMessageCallback( |
| 135 "themesReset", | 163 "themesReset", |
| 136 NewCallback(this, &PersonalOptionsHandler::ThemesReset)); | 164 NewCallback(this, &PersonalOptionsHandler::ThemesReset)); |
| 137 #if defined(TOOLKIT_GTK) | 165 #if defined(TOOLKIT_GTK) |
| 138 dom_ui_->RegisterMessageCallback( | 166 dom_ui_->RegisterMessageCallback( |
| 139 "themesSetGTK", | 167 "themesSetGTK", |
| 140 NewCallback(this, &PersonalOptionsHandler::ThemesSetGTK)); | 168 NewCallback(this, &PersonalOptionsHandler::ThemesSetGTK)); |
| 141 #endif | 169 #endif |
| 170 if (!ProfileSyncService::IsSyncEnabled()) | |
|
James Hawkins
2011/01/17 23:46:18
Same as above.
tfarina
2011/01/17 23:52:17
Removed.
| |
| 171 return; | |
| 172 dom_ui_->RegisterMessageCallback("updatePreferredDataTypes", | |
| 173 NewCallback(this, &PersonalOptionsHandler::OnPreferredDataTypesUpdated)); | |
| 142 } | 174 } |
| 143 | 175 |
| 144 void PersonalOptionsHandler::Observe(NotificationType type, | 176 void PersonalOptionsHandler::Observe(NotificationType type, |
| 145 const NotificationSource& source, | 177 const NotificationSource& source, |
| 146 const NotificationDetails& details) { | 178 const NotificationDetails& details) { |
| 147 if (type == NotificationType::BROWSER_THEME_CHANGED) | 179 if (type == NotificationType::BROWSER_THEME_CHANGED) |
| 148 ObserveThemeChanged(); | 180 ObserveThemeChanged(); |
| 149 else | 181 else |
| 150 OptionsPageUIHandler::Observe(type, source, details); | 182 OptionsPageUIHandler::Observe(type, source, details); |
| 151 } | 183 } |
| (...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 218 | 250 |
| 219 visible.reset(Value::CreateBooleanValue(status_has_error)); | 251 visible.reset(Value::CreateBooleanValue(status_has_error)); |
| 220 dom_ui_->CallJavascriptFunction( | 252 dom_ui_->CallJavascriptFunction( |
| 221 L"PersonalOptions.setSyncStatusErrorVisible", *visible); | 253 L"PersonalOptions.setSyncStatusErrorVisible", *visible); |
| 222 #if !defined(OS_CHROMEOS) | 254 #if !defined(OS_CHROMEOS) |
| 223 dom_ui_->CallJavascriptFunction( | 255 dom_ui_->CallJavascriptFunction( |
| 224 L"PersonalOptions.setSyncActionLinkErrorVisible", *visible); | 256 L"PersonalOptions.setSyncActionLinkErrorVisible", *visible); |
| 225 #endif | 257 #endif |
| 226 } | 258 } |
| 227 | 259 |
| 260 void PersonalOptionsHandler::OnLoginSuccess() { | |
| 261 OnStateChanged(); | |
| 262 } | |
| 263 | |
| 264 void PersonalOptionsHandler::OnLoginFailure( | |
| 265 const GoogleServiceAuthError& error) { | |
| 266 OnStateChanged(); | |
| 267 } | |
| 268 | |
| 228 void PersonalOptionsHandler::ObserveThemeChanged() { | 269 void PersonalOptionsHandler::ObserveThemeChanged() { |
| 229 Profile* profile = dom_ui_->GetProfile(); | 270 Profile* profile = dom_ui_->GetProfile(); |
| 230 #if defined(TOOLKIT_GTK) | 271 #if defined(TOOLKIT_GTK) |
| 231 GtkThemeProvider* provider = GtkThemeProvider::GetFrom(profile); | 272 GtkThemeProvider* provider = GtkThemeProvider::GetFrom(profile); |
| 232 bool is_gtk_theme = provider->UseGtkTheme(); | 273 bool is_gtk_theme = provider->UseGtkTheme(); |
| 233 FundamentalValue gtk_enabled(!is_gtk_theme); | 274 FundamentalValue gtk_enabled(!is_gtk_theme); |
| 234 dom_ui_->CallJavascriptFunction( | 275 dom_ui_->CallJavascriptFunction( |
| 235 L"options.PersonalOptions.setGtkThemeButtonEnabled", gtk_enabled); | 276 L"options.PersonalOptions.setGtkThemeButtonEnabled", gtk_enabled); |
| 236 #else | 277 #else |
| 237 BrowserThemeProvider* provider = | 278 BrowserThemeProvider* provider = |
| (...skipping 19 matching lines...) Expand all Loading... | |
| 257 ObserveThemeChanged(); | 298 ObserveThemeChanged(); |
| 258 | 299 |
| 259 ProfileSyncService* sync_service = | 300 ProfileSyncService* sync_service = |
| 260 dom_ui_->GetProfile()->GetProfileSyncService(); | 301 dom_ui_->GetProfile()->GetProfileSyncService(); |
| 261 if (sync_service) { | 302 if (sync_service) { |
| 262 sync_service->AddObserver(this); | 303 sync_service->AddObserver(this); |
| 263 OnStateChanged(); | 304 OnStateChanged(); |
| 264 } else { | 305 } else { |
| 265 dom_ui_->CallJavascriptFunction(L"options.PersonalOptions.hideSyncSection"); | 306 dom_ui_->CallJavascriptFunction(L"options.PersonalOptions.hideSyncSection"); |
| 266 } | 307 } |
| 308 | |
| 309 if (!sync_service) | |
|
James Hawkins
2011/01/17 23:46:18
if (sync_service) is 7 lines above. Please refacto
tfarina
2011/01/17 23:52:17
Done.
| |
| 310 return; // Can happen in ChromeOS if called before login. | |
| 311 | |
| 312 if (!ProfileSyncService::IsSyncEnabled()) | |
|
James Hawkins
2011/01/17 23:46:18
As above, whether sync is enabled or not has nothi
tfarina
2011/01/17 23:52:17
Removed.
| |
| 313 return; | |
| 314 | |
| 315 DictionaryValue args; | |
| 316 SyncSetupFlow::GetArgsForConfigure(sync_service, &args); | |
| 317 | |
| 318 dom_ui_->CallJavascriptFunction( | |
| 319 L"PersonalOptions.setRegisteredDataTypes", args); | |
| 267 } | 320 } |
| 268 | 321 |
| 269 void PersonalOptionsHandler::ShowSyncLoginDialog(const ListValue* args) { | 322 void PersonalOptionsHandler::ShowSyncLoginDialog(const ListValue* args) { |
| 270 #if defined(OS_CHROMEOS) | 323 #if defined(OS_CHROMEOS) |
| 271 std::string email = chromeos::UserManager::Get()->logged_in_user().email(); | 324 std::string email = chromeos::UserManager::Get()->logged_in_user().email(); |
| 272 string16 message = l10n_util::GetStringFUTF16( | 325 string16 message = l10n_util::GetStringFUTF16( |
| 273 IDS_SYNC_LOGIN_INTRODUCTION, | 326 IDS_SYNC_LOGIN_INTRODUCTION, |
| 274 l10n_util::GetStringUTF16(IDS_PRODUCT_NAME)); | 327 l10n_util::GetStringUTF16(IDS_PRODUCT_NAME)); |
| 275 dom_ui_->GetProfile()->GetBrowserSignin()->RequestSignin( | 328 dom_ui_->GetProfile()->GetBrowserSignin()->RequestSignin( |
| 276 dom_ui_->tab_contents(), UTF8ToUTF16(email), message, this); | 329 dom_ui_->tab_contents(), UTF8ToUTF16(email), message, this); |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 287 dom_ui_->GetProfile()->ClearTheme(); | 340 dom_ui_->GetProfile()->ClearTheme(); |
| 288 } | 341 } |
| 289 | 342 |
| 290 #if defined(TOOLKIT_GTK) | 343 #if defined(TOOLKIT_GTK) |
| 291 void PersonalOptionsHandler::ThemesSetGTK(const ListValue* args) { | 344 void PersonalOptionsHandler::ThemesSetGTK(const ListValue* args) { |
| 292 UserMetricsRecordAction(UserMetricsAction("Options_GtkThemeSet")); | 345 UserMetricsRecordAction(UserMetricsAction("Options_GtkThemeSet")); |
| 293 dom_ui_->GetProfile()->SetNativeTheme(); | 346 dom_ui_->GetProfile()->SetNativeTheme(); |
| 294 } | 347 } |
| 295 #endif | 348 #endif |
| 296 | 349 |
| 297 void PersonalOptionsHandler::OnLoginSuccess() { | 350 void PersonalOptionsHandler::OnPreferredDataTypesUpdated( |
| 298 OnStateChanged(); | 351 const ListValue* args) { |
| 352 NotificationService::current()->Notify( | |
| 353 NotificationType::SYNC_DATA_TYPES_UPDATED, | |
| 354 Source<Profile>(dom_ui_->GetProfile()), | |
| 355 NotificationService::NoDetails()); | |
| 299 } | 356 } |
| 300 | |
| 301 void PersonalOptionsHandler::OnLoginFailure( | |
| 302 const GoogleServiceAuthError& error) { | |
| 303 OnStateChanged(); | |
| 304 } | |
| OLD | NEW |