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

Unified Diff: chrome/browser/resources/options/chromeos/internet_detail.js

Issue 694533007: Add 'setProperties' to InternetOptionsHandler (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rebase + feedback Created 6 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/options/chromeos/internet_detail.js
diff --git a/chrome/browser/resources/options/chromeos/internet_detail.js b/chrome/browser/resources/options/chromeos/internet_detail.js
index 3fdc203184e4a3b658f36f364c861fb8ad9f6a08..31e5d5f0d7d6a4e997e96357e063672035dc6129 100644
--- a/chrome/browser/resources/options/chromeos/internet_detail.js
+++ b/chrome/browser/resources/options/chromeos/internet_detail.js
@@ -88,22 +88,6 @@ cr.define('options.internet', function() {
}
/**
- * Sends the 'checked' state of a control to chrome for a network.
- * @param {string} path The service path of the network.
- * @param {string} message The message to send to chrome.
- * @param {string} checkboxId The id of the checkbox with the value to send.
- * @param {string=} opt_action Optional action to record.
- */
- function sendCheckedIfEnabled(path, message, checkboxId, opt_action) {
- var checkbox = assertInstanceof($(checkboxId), HTMLInputElement);
- if (!checkbox.hidden && !checkbox.disabled) {
- chrome.send(message, [path, !!checkbox.checked]);
- if (opt_action)
- sendChromeMetricsAction(opt_action);
- }
- }
-
- /**
* Send metrics to Chrome when the detailed page is opened.
* @param {string} type The ONC type of the network being shown.
* @param {string} state The ONC network state.
@@ -834,7 +818,7 @@ cr.define('options.internet', function() {
stringFromValue(defaultApn['AccessPointName']);
activeApn['Username'] = stringFromValue(defaultApn['Username']);
activeApn['Password'] = stringFromValue(defaultApn['Password']);
- onc.setManagedProperty('Cellular.APN', activeApn);
+ onc.setProperty('Cellular.APN', activeApn);
chrome.send('setApn', [this.servicePath_,
activeApn['AccessPointName'],
activeApn['Username'],
@@ -862,7 +846,7 @@ cr.define('options.internet', function() {
activeApn['AccessPointName'] = stringFromValue(apnValue);
activeApn['Username'] = stringFromValue($('cellular-apn-username').value);
activeApn['Password'] = stringFromValue($('cellular-apn-password').value);
- onc.setManagedProperty('Cellular.APN', activeApn);
+ onc.setProperty('Cellular.APN', activeApn);
this.userApn_ = activeApn;
chrome.send('setApn', [this.servicePath_,
activeApn['AccessPointName'],
@@ -1086,32 +1070,34 @@ cr.define('options.internet', function() {
var detailsPage = DetailsInternetPage.getInstance();
var type = detailsPage.type_;
var servicePath = detailsPage.servicePath_;
+ var oncData = new OncData({});
+ var autoConnectCheckboxId = '';
if (type == 'WiFi') {
- sendCheckedIfEnabled(servicePath,
- 'setPreferNetwork',
- 'prefer-network-wifi',
- 'Options_NetworkSetPrefer');
- sendCheckedIfEnabled(servicePath,
- 'setAutoConnect',
- 'auto-connect-network-wifi',
- 'Options_NetworkAutoConnect');
+ var preferredCheckbox =
+ assertInstanceof($('prefer-network-wifi'), HTMLInputElement);
+ if (!preferredCheckbox.hidden && !preferredCheckbox.disabled) {
+ var kPreferredPriority = 1;
+ var priority = preferredCheckbox.checked ? kPreferredPriority : 0;
+ oncData.setProperty('Priority', priority);
+ sendChromeMetricsAction('Options_NetworkSetPrefer');
+ }
+ autoConnectCheckboxId = 'auto-connect-network-wifi';
} else if (type == 'WiMAX') {
- sendCheckedIfEnabled(servicePath,
- 'setAutoConnect',
- 'auto-connect-network-wimax',
- 'Options_NetworkAutoConnect');
+ autoConnectCheckboxId = 'auto-connect-network-wimax';
} else if (type == 'Cellular') {
- sendCheckedIfEnabled(servicePath,
- 'setAutoConnect',
- 'auto-connect-network-cellular',
- 'Options_NetworkAutoConnect');
+ autoConnectCheckboxId = 'auto-connect-network-cellular';
} else if (type == 'VPN') {
- chrome.send('setServerHostname',
- [servicePath, $('inet-server-hostname').value]);
- sendCheckedIfEnabled(servicePath,
- 'setAutoConnect',
- 'auto-connect-network-vpn',
- 'Options_NetworkAutoConnect');
+ oncData.setProperty('VPN.Host', $('inet-server-hostname').value);
+ autoConnectCheckboxId = 'auto-connect-network-vpn';
+ }
+ if (autoConnectCheckboxId != '') {
+ var autoConnectCheckbox =
+ assertInstanceof($(autoConnectCheckboxId), HTMLInputElement);
+ if (!autoConnectCheckbox.hidden && !autoConnectCheckbox.disabled) {
+ var autoConnectKey = type + '.AutoConnect';
+ oncData.setProperty(autoConnectKey, !!autoConnectCheckbox.checked);
+ sendChromeMetricsAction('Options_NetworkAutoConnect');
+ }
}
var nameServerTypes = ['automatic', 'google', 'user'];
@@ -1124,6 +1110,12 @@ cr.define('options.internet', function() {
}
detailsPage.sendIpConfig_(nameServerType);
+ var data = oncData.getData();
+ if (Object.keys(data).length > 0) {
+ // TODO(stevenjb): chrome.networkingPrivate.setProperties
+ chrome.send('setProperties', [servicePath, data]);
+ }
+
PageManager.closeOverlay();
};

Powered by Google App Engine
This is Rietveld 408576698