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

Unified Diff: chrome/browser/resources/settings/controls/settings_dropdown_menu.js

Issue 2446003002: settings-dropdown-menu must set <select>#value after its options change (Closed)
Patch Set: Hide custom option via CSS Created 4 years, 2 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/resources/settings/controls/settings_dropdown_menu.js
diff --git a/chrome/browser/resources/settings/controls/settings_dropdown_menu.js b/chrome/browser/resources/settings/controls/settings_dropdown_menu.js
index 06061fbffc0d797738e2980f8d4ea43bbf9e7498..aaf0834b585c9eeac1cb780d0356dfcd4243673a 100644
--- a/chrome/browser/resources/settings/controls/settings_dropdown_menu.js
+++ b/chrome/browser/resources/settings/controls/settings_dropdown_menu.js
@@ -47,18 +47,13 @@ Polymer({
},
/**
- * The current selected value, as a string.
- * @private
- */
- selected_: String,
-
- /**
- * The value of the 'custom' item.
+ * The value of the "custom" item.
* @private
*/
notFoundValue_: {
type: String,
value: 'SETTINGS_DROPDOWN_NOT_FOUND_ITEM',
+ readOnly: true,
},
},
@@ -75,13 +70,13 @@ Polymer({
* @private
*/
onChange_: function() {
- this.selected_ = this.$.dropdownMenu.value;
+ var selected = this.$.dropdownMenu.value;
- if (this.selected_ == this.notFoundValue_)
+ if (selected == this.notFoundValue_)
return;
var prefValue = Settings.PrefUtil.stringToPrefValue(
- this.selected_, assert(this.pref));
+ selected, assert(this.pref));
if (prefValue !== undefined)
this.set('pref.value', prefValue);
},
@@ -99,22 +94,30 @@ Polymer({
return menuItem.value == prefValue;
});
- // Need to wait for the dom-repeat to render, before assigning a value to
- // |selected_|, otherwise select#value is not populated correctly.
+ // Wait for the dom-repeat to populate the <select> before setting
+ // <select>#value so the correct option gets selected.
this.async(function() {
- this.selected_ = option == undefined ?
+ this.$.dropdownMenu.value = option == undefined ?
this.notFoundValue_ :
Settings.PrefUtil.prefToString(assert(this.pref));
}.bind(this));
},
/**
- * @param {string} selected
+ * @param {?DropdownMenuOptionList} menuOptions
+ * @param {string} prefValue
* @return {boolean}
* @private
*/
- isSelectedNotFound_: function(selected) {
- return this.menuOptions.length > 0 && selected == this.notFoundValue_;
+ showNotFoundValue_: function(menuOptions, prefValue) {
+ // Don't show "Custom" before the options load.
+ if (!menuOptions || !menuOptions.length)
+ return false;
+
+ var option = menuOptions.find(function(menuItem) {
+ return menuItem.value == prefValue;
+ });
+ return !option;
},
/**

Powered by Google App Engine
This is Rietveld 408576698