OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 | |
5 /** | 4 /** |
6 * @constructor | |
7 * @implements {WebInspector.TargetManager.Observer} | 5 * @implements {WebInspector.TargetManager.Observer} |
8 * @param {!Element} selectElement | 6 * @unrestricted |
9 * @param {!Element} elementToHide | |
10 */ | 7 */ |
11 WebInspector.TargetsComboBoxController = function(selectElement, elementToHide) | 8 WebInspector.TargetsComboBoxController = class { |
12 { | 9 /** |
13 elementToHide.classList.add("hidden"); | 10 * @param {!Element} selectElement |
14 selectElement.addEventListener("change", this._onComboBoxSelectionChange.bin
d(this), false); | 11 * @param {!Element} elementToHide |
| 12 */ |
| 13 constructor(selectElement, elementToHide) { |
| 14 elementToHide.classList.add('hidden'); |
| 15 selectElement.addEventListener('change', this._onComboBoxSelectionChange.bin
d(this), false); |
15 this._selectElement = selectElement; | 16 this._selectElement = selectElement; |
16 this._elementToHide = elementToHide; | 17 this._elementToHide = elementToHide; |
17 /** @type {!Map.<!WebInspector.Target, !Element>} */ | 18 /** @type {!Map.<!WebInspector.Target, !Element>} */ |
18 this._targetToOption = new Map(); | 19 this._targetToOption = new Map(); |
19 | 20 |
20 WebInspector.context.addFlavorChangeListener(WebInspector.Target, this._targ
etChangedExternally, this); | 21 WebInspector.context.addFlavorChangeListener(WebInspector.Target, this._targ
etChangedExternally, this); |
21 WebInspector.targetManager.addEventListener(WebInspector.TargetManager.Event
s.NameChanged, this._targetNameChanged, this); | 22 WebInspector.targetManager.addEventListener( |
| 23 WebInspector.TargetManager.Events.NameChanged, this._targetNameChanged,
this); |
22 WebInspector.targetManager.observeTargets(this, WebInspector.Target.Capabili
ty.JS); | 24 WebInspector.targetManager.observeTargets(this, WebInspector.Target.Capabili
ty.JS); |
| 25 } |
| 26 |
| 27 /** |
| 28 * @override |
| 29 * @param {!WebInspector.Target} target |
| 30 */ |
| 31 targetAdded(target) { |
| 32 var option = this._selectElement.createChild('option'); |
| 33 option.text = target.name(); |
| 34 option.__target = target; |
| 35 this._targetToOption.set(target, option); |
| 36 if (WebInspector.context.flavor(WebInspector.Target) === target) |
| 37 this._selectElement.selectedIndex = Array.prototype.indexOf.call(/** @type
{?} */ (this._selectElement), option); |
| 38 |
| 39 this._updateVisibility(); |
| 40 } |
| 41 |
| 42 /** |
| 43 * @override |
| 44 * @param {!WebInspector.Target} target |
| 45 */ |
| 46 targetRemoved(target) { |
| 47 var option = this._targetToOption.remove(target); |
| 48 this._selectElement.removeChild(option); |
| 49 this._updateVisibility(); |
| 50 } |
| 51 |
| 52 /** |
| 53 * @param {!WebInspector.Event} event |
| 54 */ |
| 55 _targetNameChanged(event) { |
| 56 var target = /** @type {!WebInspector.Target} */ (event.data); |
| 57 var option = this._targetToOption.get(target); |
| 58 option.text = target.name(); |
| 59 } |
| 60 |
| 61 _onComboBoxSelectionChange() { |
| 62 var selectedOption = this._selectElement[this._selectElement.selectedIndex]; |
| 63 if (!selectedOption) |
| 64 return; |
| 65 |
| 66 WebInspector.context.setFlavor(WebInspector.Target, selectedOption.__target)
; |
| 67 } |
| 68 |
| 69 _updateVisibility() { |
| 70 var hidden = this._selectElement.childElementCount === 1; |
| 71 this._elementToHide.classList.toggle('hidden', hidden); |
| 72 } |
| 73 |
| 74 /** |
| 75 * @param {!WebInspector.Event} event |
| 76 */ |
| 77 _targetChangedExternally(event) { |
| 78 var target = /** @type {?WebInspector.Target} */ (event.data); |
| 79 if (target) { |
| 80 var option = /** @type {!Element} */ (this._targetToOption.get(target)); |
| 81 this._select(option); |
| 82 } |
| 83 } |
| 84 |
| 85 /** |
| 86 * @param {!Element} option |
| 87 */ |
| 88 _select(option) { |
| 89 this._selectElement.selectedIndex = Array.prototype.indexOf.call(/** @type {
?} */ (this._selectElement), option); |
| 90 } |
23 }; | 91 }; |
24 | |
25 WebInspector.TargetsComboBoxController.prototype = { | |
26 | |
27 /** | |
28 * @override | |
29 * @param {!WebInspector.Target} target | |
30 */ | |
31 targetAdded: function(target) | |
32 { | |
33 var option = this._selectElement.createChild("option"); | |
34 option.text = target.name(); | |
35 option.__target = target; | |
36 this._targetToOption.set(target, option); | |
37 if (WebInspector.context.flavor(WebInspector.Target) === target) | |
38 this._selectElement.selectedIndex = Array.prototype.indexOf.call(/**
@type {?} */ (this._selectElement), option); | |
39 | |
40 this._updateVisibility(); | |
41 }, | |
42 | |
43 /** | |
44 * @override | |
45 * @param {!WebInspector.Target} target | |
46 */ | |
47 targetRemoved: function(target) | |
48 { | |
49 var option = this._targetToOption.remove(target); | |
50 this._selectElement.removeChild(option); | |
51 this._updateVisibility(); | |
52 }, | |
53 | |
54 /** | |
55 * @param {!WebInspector.Event} event | |
56 */ | |
57 _targetNameChanged: function(event) | |
58 { | |
59 var target = /** @type {!WebInspector.Target} */ (event.data); | |
60 var option = this._targetToOption.get(target); | |
61 option.text = target.name(); | |
62 }, | |
63 | |
64 _onComboBoxSelectionChange: function() | |
65 { | |
66 var selectedOption = this._selectElement[this._selectElement.selectedInd
ex]; | |
67 if (!selectedOption) | |
68 return; | |
69 | |
70 WebInspector.context.setFlavor(WebInspector.Target, selectedOption.__tar
get); | |
71 }, | |
72 | |
73 _updateVisibility: function() | |
74 { | |
75 var hidden = this._selectElement.childElementCount === 1; | |
76 this._elementToHide.classList.toggle("hidden", hidden); | |
77 }, | |
78 | |
79 /** | |
80 * @param {!WebInspector.Event} event | |
81 */ | |
82 _targetChangedExternally: function(event) | |
83 { | |
84 var target = /** @type {?WebInspector.Target} */ (event.data); | |
85 if (target) { | |
86 var option = /** @type {!Element} */ (this._targetToOption.get(targe
t)); | |
87 this._select(option); | |
88 } | |
89 }, | |
90 | |
91 /** | |
92 * @param {!Element} option | |
93 */ | |
94 _select: function(option) | |
95 { | |
96 this._selectElement.selectedIndex = Array.prototype.indexOf.call(/** @ty
pe {?} */ (this._selectElement), option); | |
97 } | |
98 | |
99 }; | |
OLD | NEW |