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

Unified Diff: chrome/browser/resources/settings/people_page/import_data_dialog.js

Issue 2500653002: MD Settings: Add import data dialog. (Closed)
Patch Set: Make non-CrOS only Created 4 years, 1 month 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/resources/settings/people_page/import_data_dialog.js
diff --git a/chrome/browser/resources/settings/people_page/import_data_dialog.js b/chrome/browser/resources/settings/people_page/import_data_dialog.js
new file mode 100644
index 0000000000000000000000000000000000000000..d7a3e0b5a833999c845d5166229f883fae49c309
--- /dev/null
+++ b/chrome/browser/resources/settings/people_page/import_data_dialog.js
@@ -0,0 +1,78 @@
+// Copyright 2016 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.
+
+/**
+ * @fileoverview 'settings-import-data-dialog' is a component for importing
+ * bookmarks and other data from other sources.
+ */
+Polymer({
+ is: 'settings-import-data-dialog',
+
+ behaviors: [I18nBehavior, WebUIListenerBehavior],
+
+ properties: {
+ /** @private {!Array<!settings.BrowserProfile>} */
+ browserProfiles_: Array,
+
+ /** @private {!settings.BrowserProfile} */
+ selected_: Object,
+ },
+
+ /** @private {?settings.ImportDataBrowserProxy} */
+ browserProxy_: null,
+
+ /** @override */
+ attached: function() {
+ this.$.dialog.showModal();
+ },
+
+ /** @override */
+ ready: function() {
tommycli 2016/11/14 18:15:57 nit: but when is the earliest that we could do thi
dpapad 2016/11/14 20:35:22 No good reason. Moved to attached.
+ this.browserProxy_ = settings.ImportDataBrowserProxyImpl.getInstance();
+ this.browserProxy_.initializeImportDialog().then(function(data) {
+ this.browserProfiles_ = data;
+ // TODO(dpapad): Check old options to determine whether it is possible
+ // that no browser profile is found (including the "import from file"
+ // option).
+ this.selected_ = this.browserProfiles_[0];
+ }.bind(this));
+
+ this.addWebUIListener('import-data-status-changed', function(e) {
+ // TODO(dpapad): Handle events to show spinner or success message.
+ });
+ },
+
+ /** @private */
+ isImportFromFileSelected_: function() {
+ return this.selected_.index == this.browserProfiles_.length - 1;
tommycli 2016/11/14 18:15:57 The last item in the list of browser profiles is a
dpapad 2016/11/14 20:35:22 Did not look at the C++, but the old JS code impli
tommycli 2016/11/14 20:45:34 Hmm interesting. Maybe investigate and add a comme
dpapad 2016/11/14 21:47:57 Done. The answer is that the last browser profile
+ },
+
+ /**
+ * @return {string}
+ * @private
+ */
+ getActionButtonText_: function() {
+ return this.i18n(this.isImportFromFileSelected_() ?
+ 'importChooseFile' : 'importCommit');
+ },
+
+ /** @private */
+ onChange_: function() {
+ this.selected_ = this.browserProfiles_[this.$$('select').selectedIndex];
tommycli 2016/11/14 18:15:57 Maybe marginally faster to use event.target.value
dpapad 2016/11/14 20:35:22 In order to associate event.target.value with a se
+ },
+
+ /** @private */
+ onActionButtonTap_: function() {
+ if (this.isImportFromFileSelected_()) {
+ this.browserProxy_.importFromBookmarksFile();
+ } else {
+ // TODO(dpapad): Implement this.
+ }
+ },
+
+ /** @private */
+ onCancelTap_: function() {
+ this.$.dialog.close();
+ },
+});

Powered by Google App Engine
This is Rietveld 408576698