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

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: Fix issues, add comments, move Adapter code to AdapterBroker 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() {
11 var adapter, adapterClient, bluetoothAdapter, bluetoothDevice, connection; 11 function initialize() {
12 var adapterBroker = null;
13 adapter_broker.getAdapterBroker()
14 .then(function(broker) { adapterBroker = broker; })
15 .then(function() { return adapterBroker.getInfo(); })
16 .then(function(response) { console.log('adapter', response.info); })
17 .then(function() { return adapterBroker.getDevices(); })
18 .then(function(response) {
19 // Hook up device collection events.
20 var devices = new device_collection.DeviceCollection([]);
21 adapterBroker.addEventListener('deviceadded', function(event) {
22 devices.addOrUpdate(event.deviceInfo);
23 });
24 adapterBroker.addEventListener('devicechanged', function(event) {
25 devices.addOrUpdate(event.deviceInfo);
26 });
27 adapterBroker.addEventListener('deviceremoved', function(event) {
28 devices.remove(event.deviceInfo);
29 });
12 30
13 var REMOVED_CSS = 'removed'; 31 response.devices.forEach(devices.addOrUpdate,
32 devices /* this */);
14 33
15 /* 34 var deviceTable = new device_table.DeviceTable();
16 * Data model for a cached device. 35 deviceTable.setDevices(devices);
17 * @constructor 36 document.body.appendChild(deviceTable);
18 * @param {!bluetoothDevice.DeviceInfo} info 37 })
19 */ 38 .catch(function(error) { console.error(error); });
20 var Device = function(info) { this.info = info; }; 39 }
21 40
22 /** 41 return {
23 * The implementation of AdapterClient in 42 initialize: initialize
ortuno 2016/11/04 01:44:09 Maybe initializeViews
mbrunson 2016/11/04 02:37:40 Done.
24 * device/bluetooth/public/interfaces/adapter.mojom. This also manages the
25 * client-side collection of devices.
26 * @constructor
27 */
28 var AdapterClient = function() { this.devices_ = new Map(); };
29 AdapterClient.prototype = {
30 /**
31 * Caches the device info and updates the device list.
32 * @param {!bluetoothDevice.DeviceInfo} deviceInfo
33 */
34 deviceAdded: function(deviceInfo) {
35 if (this.devices_.has(deviceInfo.address)) {
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 },
52
53 /**
54 * Marks device as removed.
55 * @param {!bluetoothDevice.DeviceInfo} deviceInfo
56 */
57 deviceRemoved: function(deviceInfo) {
58 $(deviceInfo.address).classList.add(REMOVED_CSS);
59 },
60
61 /**
62 * Updates cached device and updates the device list.
63 * @param {!bluetoothDevice.DeviceInfo} deviceInfo
64 */
65 deviceChanged: function(deviceInfo) {
66 console.log(new Date(), deviceInfo);
67
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 }
82 }; 43 };
83 44
84 /** 45 });
85 * Initializes Mojo proxies for page and Bluetooth services.
86 * @return {!Promise} resolves if adapter is acquired, rejects if Bluetooth
87 * is not supported.
88 */
89 function initializeProxies() {
90 return importModules([
91 'content/public/renderer/frame_interfaces',
92 'device/bluetooth/public/interfaces/adapter.mojom',
93 'device/bluetooth/public/interfaces/device.mojom',
94 'mojo/public/js/connection',
95 ]).then(function([frameInterfaces, ...modules]) {
96 // Destructure here to assign global variables.
97 [bluetoothAdapter, bluetoothDevice, connection] = modules;
98 46
99 // Hook up the instance properties. 47 document.addEventListener('DOMContentLoaded', bluetooth_internals.initialize);
100 AdapterClient.prototype.__proto__ =
101 bluetoothAdapter.AdapterClient.stubClass.prototype;
102
103 var adapterFactory = connection.bindHandleToProxy(
104 frameInterfaces.getInterface(bluetoothAdapter.AdapterFactory.name),
105 bluetoothAdapter.AdapterFactory);
106
107 // Get an Adapter service.
108 return adapterFactory.getAdapter();
109 }).then(function(response) {
110 if (!response.adapter) {
111 throw new Error('Bluetooth Not Supported on this platform.');
112 }
113
114 adapter = connection.bindHandleToProxy(response.adapter,
115 bluetoothAdapter.Adapter);
116
117 // Create a message pipe and bind one end to client
118 // implementation and the other to the Adapter service.
119 adapterClient = new AdapterClient();
120 adapter.setClient(connection.bindStubDerivedImpl(adapterClient));
121 });
122 }
123
124 document.addEventListener('DOMContentLoaded', function() {
125 initializeProxies()
126 .then(function() { return adapter.getInfo(); })
127 .then(function(response) { console.log('adapter', response.info); })
128 .then(function() { return adapter.getDevices(); })
129 .then(function(response) {
130 response.devices.forEach(adapterClient.deviceAdded, adapterClient);
131 })
132 .catch(function(error) { console.error(error); });
133 });
134 })();
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698