summaryrefslogtreecommitdiffstats
path: root/chrome/browser/webui/options/import_data_handler.cc
diff options
context:
space:
mode:
authortfarina@chromium.org <tfarina@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-02-19 14:12:23 +0000
committertfarina@chromium.org <tfarina@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-02-19 14:12:23 +0000
commit1ab7761d57f2144fac3f03958e571410b595a2b9 (patch)
treeb955a9d1e73f56d953339e852a7402faf9141a09 /chrome/browser/webui/options/import_data_handler.cc
parentc1338959f5d9fa970750a3007c52f3151b877232 (diff)
downloadchromium_src-1ab7761d57f2144fac3f03958e571410b595a2b9.zip
chromium_src-1ab7761d57f2144fac3f03958e571410b595a2b9.tar.gz
chromium_src-1ab7761d57f2144fac3f03958e571410b595a2b9.tar.bz2
WebUI: Move chrome/browser/dom_ui/options/ to chrome/browser/webui/options.
To reduce the size of this change I've left stub header files in chrome/browser/dom_ui/options. I'll updated the references and delete the stub files later. BUG=59945, 59946 TEST=trybots Review URL: http://codereview.chromium.org/6469067 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@75496 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser/webui/options/import_data_handler.cc')
-rw-r--r--chrome/browser/webui/options/import_data_handler.cc169
1 files changed, 169 insertions, 0 deletions
diff --git a/chrome/browser/webui/options/import_data_handler.cc b/chrome/browser/webui/options/import_data_handler.cc
new file mode 100644
index 0000000..3931d09
--- /dev/null
+++ b/chrome/browser/webui/options/import_data_handler.cc
@@ -0,0 +1,169 @@
+// 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/dom_ui/options/import_data_handler.h"
+
+#include <string>
+
+#include "base/basictypes.h"
+#include "base/callback.h"
+#include "base/scoped_ptr.h"
+#include "base/string16.h"
+#include "base/string_number_conversions.h"
+#include "base/string_util.h"
+#include "base/threading/thread_restrictions.h"
+#include "base/utf_string_conversions.h"
+#include "base/values.h"
+#include "chrome/browser/profiles/profile.h"
+#include "grit/chromium_strings.h"
+#include "grit/generated_resources.h"
+#include "chrome/browser/importer/importer_data_types.h"
+#include "ui/base/l10n/l10n_util.h"
+
+ImportDataHandler::ImportDataHandler() : importer_host_(NULL) {
+}
+
+ImportDataHandler::~ImportDataHandler() {
+ if (importer_list_)
+ importer_list_->SetObserver(NULL);
+
+ if (importer_host_)
+ importer_host_->SetObserver(NULL);
+}
+
+void ImportDataHandler::GetLocalizedValues(
+ DictionaryValue* localized_strings) {
+ DCHECK(localized_strings);
+ RegisterTitle(localized_strings, "importDataOverlay",
+ IDS_IMPORT_SETTINGS_TITLE);
+ localized_strings->SetString("importFromLabel",
+ l10n_util::GetStringUTF16(IDS_IMPORT_FROM_LABEL));
+ localized_strings->SetString("importLoading",
+ l10n_util::GetStringUTF16(IDS_IMPORT_LOADING_PROFILES));
+ localized_strings->SetString("importDescription",
+ l10n_util::GetStringUTF16(IDS_IMPORT_ITEMS_LABEL));
+ localized_strings->SetString("importHistory",
+ l10n_util::GetStringUTF16(IDS_IMPORT_HISTORY_CHKBOX));
+ localized_strings->SetString("importFavorites",
+ l10n_util::GetStringUTF16(IDS_IMPORT_FAVORITES_CHKBOX));
+ localized_strings->SetString("importSearch",
+ l10n_util::GetStringUTF16(IDS_IMPORT_SEARCH_ENGINES_CHKBOX));
+ localized_strings->SetString("importPasswords",
+ l10n_util::GetStringUTF16(IDS_IMPORT_PASSWORDS_CHKBOX));
+ localized_strings->SetString("importCommit",
+ l10n_util::GetStringUTF16(IDS_IMPORT_COMMIT));
+ localized_strings->SetString("noProfileFound",
+ l10n_util::GetStringUTF16(IDS_IMPORT_NO_PROFILE_FOUND));
+}
+
+void ImportDataHandler::Initialize() {
+ importer_list_ = new ImporterList;
+ importer_list_->DetectSourceProfiles(this);
+}
+
+void ImportDataHandler::RegisterMessages() {
+ web_ui_->RegisterMessageCallback(
+ "importData", NewCallback(this, &ImportDataHandler::ImportData));
+}
+
+void ImportDataHandler::ImportData(const ListValue* args) {
+ std::string string_value;
+
+ int browser_index;
+ if (!args->GetString(0, &string_value) ||
+ !base::StringToInt(string_value, &browser_index)) {
+ NOTREACHED();
+ return;
+ }
+
+ uint16 selected_items = importer::NONE;
+ if (args->GetString(1, &string_value) && string_value == "true") {
+ selected_items |= importer::HISTORY;
+ }
+ if (args->GetString(2, &string_value) && string_value == "true") {
+ selected_items |= importer::FAVORITES;
+ }
+ if (args->GetString(3, &string_value) && string_value == "true") {
+ selected_items |= importer::PASSWORDS;
+ }
+ if (args->GetString(4, &string_value) && string_value == "true") {
+ selected_items |= importer::SEARCH_ENGINES;
+ }
+
+ const ProfileInfo& source_profile =
+ importer_list_->GetSourceProfileInfoAt(browser_index);
+ uint16 supported_items = source_profile.services_supported;
+
+ uint16 import_services = (selected_items & supported_items);
+ if (import_services) {
+ FundamentalValue state(true);
+ web_ui_->CallJavascriptFunction(
+ L"ImportDataOverlay.setImportingState", state);
+
+ // TODO(csilv): Out-of-process import has only been qualified on MacOS X,
+ // so we will only use it on that platform since it is required. Remove this
+ // conditional logic once oop import is qualified for Linux/Windows.
+ // http://crbug.com/22142
+#if defined(OS_MACOSX)
+ importer_host_ = new ExternalProcessImporterHost;
+#else
+ importer_host_ = new ImporterHost;
+#endif
+ importer_host_->SetObserver(this);
+ Profile* profile = web_ui_->GetProfile();
+ importer_host_->StartImportSettings(source_profile, profile,
+ import_services,
+ new ProfileWriter(profile), false);
+ } else {
+ LOG(WARNING) << "There were no settings to import from '"
+ << source_profile.description << "'.";
+ }
+}
+
+void ImportDataHandler::ImportStarted() {
+}
+
+void ImportDataHandler::ImportItemStarted(importer::ImportItem item) {
+ // TODO(csilv): show progress detail in the web view.
+}
+
+void ImportDataHandler::ImportItemEnded(importer::ImportItem item) {
+ // TODO(csilv): show progress detail in the web view.
+}
+
+void ImportDataHandler::ImportEnded() {
+ importer_host_->SetObserver(NULL);
+ importer_host_ = NULL;
+
+ web_ui_->CallJavascriptFunction(L"ImportDataOverlay.dismiss");
+}
+
+void ImportDataHandler::SourceProfilesLoaded() {
+ ListValue browser_profiles;
+ int profiles_count = importer_list_->GetAvailableProfileCount();
+ for (int i = 0; i < profiles_count; i++) {
+ const importer::ProfileInfo& source_profile =
+ importer_list_->GetSourceProfileInfoAt(i);
+ string16 browser_name = WideToUTF16Hack(source_profile.description);
+ uint16 browser_services = source_profile.services_supported;
+
+ DictionaryValue* browser_profile = new DictionaryValue();
+ browser_profile->SetString("name", browser_name);
+ browser_profile->SetInteger("index", i);
+ browser_profile->SetBoolean("history",
+ (browser_services & importer::HISTORY) != 0);
+ browser_profile->SetBoolean("favorites",
+ (browser_services & importer::FAVORITES) != 0);
+ browser_profile->SetBoolean("passwords",
+ (browser_services & importer::PASSWORDS) != 0);
+ browser_profile->SetBoolean("search",
+ (browser_services & importer::SEARCH_ENGINES) != 0);
+
+ browser_profiles.Append(browser_profile);
+ }
+
+ web_ui_->CallJavascriptFunction(
+ L"options.ImportDataOverlay.updateSupportedBrowsers",
+ browser_profiles);
+}