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

Side by Side Diff: chrome/browser/resources/bluetooth_internals/bluetooth_internals.js

Issue 2446823002: bluetooth: Componentize device list in chrome://bluetooth-internals. (Closed)
Patch Set: Separate device.js and bluetooth_internals.js 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 unified diff | Download patch
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 /** 5 /**
6 * Javascript for bluetooth_internals.html, served from 6 * Javascript for bluetooth_internals.html, served from
7 * chrome://bluetooth-internals/. 7 * chrome://bluetooth-internals/.
8 */ 8 */
9 9
10 (function() { 10 cr.define('bluetooth_internals', function() {
scheib 2016/10/31 20:24:36 pardon my ignorance, but isn't part of the point o
mbrunson 2016/10/31 21:46:19 There's three kinds of defines that I've seen used
11 var adapter, adapterClient, bluetoothAdapter, bluetoothDevice, connection;
12
13 var REMOVED_CSS = 'removed';
14
15 /*
16 * Data model for a cached device.
17 * @constructor
18 * @param {!bluetoothDevice.DeviceInfo} info
19 */
20 var Device = function(info) { this.info = info; };
21
22 /** 11 /**
23 * The implementation of AdapterClient in 12 * The implementation of AdapterClient in
24 * device/bluetooth/public/interfaces/adapter.mojom. This also manages the 13 * device/bluetooth/public/interfaces/adapter.mojom. This also manages the
25 * client-side collection of devices. 14 * client-side collection of devices.
26 * @constructor 15 * @constructor
27 */ 16 */
28 var AdapterClient = function() { this.devices_ = new Map(); }; 17 var AdapterClient = function() {
18 this.devices = new device_collection.DeviceCollection([]);
19 };
29 AdapterClient.prototype = { 20 AdapterClient.prototype = {
30 /** 21 /**
31 * Caches the device info and updates the device list. 22 * Adds a device to the device collection.
32 * @param {!bluetoothDevice.DeviceInfo} deviceInfo 23 * @param {!interfaces.BluetoothDevice.DeviceInfo} deviceInfo
33 */ 24 */
34 deviceAdded: function(deviceInfo) { 25 deviceAdded: function(deviceInfo) {
35 if (this.devices_.has(deviceInfo.address)) { 26 this.devices.addOrUpdate(deviceInfo);
36 var deviceElement = $(deviceInfo.address);
37 deviceElement.classList.remove(REMOVED_CSS);
38 } else {
39 this.devices_.set(deviceInfo.address, new Device(deviceInfo));
40
41 var deviceRowTemplate = $('device-row-template');
42 var deviceRow = document.importNode(
43 deviceRowTemplate.content.children[0], true /* deep */);
44 deviceRow.id = deviceInfo.address;
45
46 var deviceList = $('device-list');
47 deviceList.appendChild(deviceRow);
48 }
49
50 this.deviceChanged(deviceInfo);
51 }, 27 },
52 28
53 /** 29 /**
54 * Marks device as removed. 30 * Marks device as removed.
55 * @param {!bluetoothDevice.DeviceInfo} deviceInfo 31 * @param {!interfaces.BluetoothDevice.DeviceInfo} deviceInfo
56 */ 32 */
57 deviceRemoved: function(deviceInfo) { 33 deviceRemoved: function(deviceInfo) {
58 $(deviceInfo.address).classList.add(REMOVED_CSS); 34 this.devices.remove(deviceInfo);
59 }, 35 },
60 36
61 /** 37 /**
62 * Updates cached device and updates the device list. 38 * Updates the cached device.
63 * @param {!bluetoothDevice.DeviceInfo} deviceInfo 39 * @param {!interfaces.BluetoothDevice.DeviceInfo} deviceInfo
64 */ 40 */
65 deviceChanged: function(deviceInfo) { 41 deviceChanged: function(deviceInfo) {
66 console.log(new Date(), deviceInfo); 42 console.log(new Date(), deviceInfo);
67 43 this.devices.addOrUpdate(deviceInfo);
68 assert(this.devices_.has(deviceInfo.address), 'Device does not exist.');
69
70 this.devices_.get(deviceInfo.address).info = deviceInfo;
71
72 var deviceRow = $(deviceInfo.address);
73 deviceRow.querySelector('.device-name').textContent =
74 deviceInfo.name_for_display;
75 deviceRow.querySelector('.device-address').textContent =
76 deviceInfo.address;
77
78 var rssi = (deviceInfo.rssi && deviceInfo.rssi.value) ||
79 deviceRow.querySelector('.device-rssi').textContent;
80 deviceRow.querySelector('.device-rssi').textContent = rssi;
81 } 44 }
82 }; 45 };
83 46
84 /** 47 var adapterClient = null;
85 * TODO(crbug.com/652361): Move to shared location.
86 * Helper to convert callback-based define() API to a promise-based API.
87 * @param {!Array<string>} moduleNames
88 * @return {!Promise}
89 */
90 function importModules(moduleNames) {
91 return new Promise(function(resolve, reject) {
92 define(moduleNames, function(var_args) {
93 resolve(Array.prototype.slice.call(arguments, 0));
94 });
95 });
96 }
97 48
98 /** 49 function initialize() {
99 * Initializes Mojo proxies for page and Bluetooth services. 50 interfaces.initialize()
100 * @return {!Promise} resolves if adapter is acquired, rejects if Bluetooth 51 .then(function() {
101 * is not supported. 52 // Hook up the instance properties.
102 */ 53 AdapterClient.prototype.__proto__ =
103 function initializeProxies() { 54 interfaces.BluetoothAdapter.AdapterClient.stubClass.prototype;
104 return importModules([
105 'content/public/renderer/frame_interfaces',
106 'device/bluetooth/public/interfaces/adapter.mojom',
107 'device/bluetooth/public/interfaces/device.mojom',
108 'mojo/public/js/connection',
109 ]).then(function([frameInterfaces, ...modules]) {
110 // Destructure here to assign global variables.
111 [bluetoothAdapter, bluetoothDevice, connection] = modules;
112 55
113 // Hook up the instance properties. 56 adapterClient = new AdapterClient();
114 AdapterClient.prototype.__proto__ = 57 interfaces.DefaultAdapter.setClient(
115 bluetoothAdapter.AdapterClient.stubClass.prototype; 58 interfaces.Connection.bindStubDerivedImpl(adapterClient));
116 59 })
117 var adapterFactory = connection.bindHandleToProxy(
118 frameInterfaces.getInterface(bluetoothAdapter.AdapterFactory.name),
119 bluetoothAdapter.AdapterFactory);
120
121 // Get an Adapter service.
122 return adapterFactory.getAdapter();
123 }).then(function(response) {
124 if (!response.adapter) {
125 throw new Error('Bluetooth Not Supported on this platform.');
126 }
127
128 adapter = connection.bindHandleToProxy(response.adapter,
129 bluetoothAdapter.Adapter);
130
131 // Create a message pipe and bind one end to client
132 // implementation and the other to the Adapter service.
133 adapterClient = new AdapterClient();
134 adapter.setClient(connection.bindStubDerivedImpl(adapterClient));
135 });
136 }
137
138 document.addEventListener('DOMContentLoaded', function() {
139 initializeProxies()
140 .then(function() { return adapter.getInfo(); }) 60 .then(function() { return adapter.getInfo(); })
141 .then(function(response) { console.log('adapter', response.info); }) 61 .then(function(response) { console.log('adapter', response.info); })
142 .then(function() { return adapter.getDevices(); }) 62 .then(function() { return adapter.getDevices(); })
143 .then(function(response) { 63 .then(function(response) {
144 response.devices.forEach(adapterClient.deviceAdded, adapterClient); 64 response.devices.forEach(adapterClient.deviceAdded,
65 adapterClient /** this */);
66
67 var deviceTable = new device_table.DeviceTable();
68 deviceTable.setDevices(adapterClient.devices);
69 document.body.appendChild(deviceTable);
145 }) 70 })
146 .catch(function(error) { console.error(error); }); 71 .catch(function(error) { console.error(error); });
147 }); 72 }
148 })(); 73
74 return {
75 initialize: initialize
76 };
77
78 });
79
80 document.addEventListener('DOMContentLoaded', bluetooth_internals.initialize);
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698