OLD | NEW |
1 // Copyright (c) 2015 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2015 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 * @extends {WebInspector.Object} | 6 * @extends {WebInspector.Object} |
7 * @constructor | 7 * @constructor |
8 */ | 8 */ |
9 WebInspector.ComputedStyleModel = function() | 9 WebInspector.ComputedStyleModel = function() |
10 { | 10 { |
(...skipping 13 matching lines...) Expand all Loading... |
24 node: function() | 24 node: function() |
25 { | 25 { |
26 return this._node; | 26 return this._node; |
27 }, | 27 }, |
28 | 28 |
29 /** | 29 /** |
30 * @return {?WebInspector.CSSModel} | 30 * @return {?WebInspector.CSSModel} |
31 */ | 31 */ |
32 cssModel: function() | 32 cssModel: function() |
33 { | 33 { |
34 return this._cssModel; | 34 return this._cssModel && this._cssModel.isEnabled() ? this._cssModel : n
ull; |
35 }, | 35 }, |
36 | 36 |
37 /** | 37 /** |
38 * @param {!WebInspector.Event} event | 38 * @param {!WebInspector.Event} event |
39 */ | 39 */ |
40 _onNodeChanged: function(event) | 40 _onNodeChanged: function(event) |
41 { | 41 { |
42 this._node = /** @type {?WebInspector.DOMNode} */(event.data); | 42 this._node = /** @type {?WebInspector.DOMNode} */(event.data); |
43 this._updateTarget(this._node ? this._node.target() : null); | 43 this._updateTarget(this._node ? this._node.target() : null); |
44 this._onComputedStyleChanged(); | 44 this._onComputedStyleChanged(null); |
45 }, | 45 }, |
46 | 46 |
47 /** | 47 /** |
48 * @param {?WebInspector.Target} target | 48 * @param {?WebInspector.Target} target |
49 */ | 49 */ |
50 _updateTarget: function(target) | 50 _updateTarget: function(target) |
51 { | 51 { |
52 if (this._target === target) | 52 if (this._target === target) |
53 return; | 53 return; |
54 if (this._targetEvents) { | 54 if (this._targetEvents) { |
55 WebInspector.EventTarget.removeEventListeners(this._targetEvents); | 55 WebInspector.EventTarget.removeEventListeners(this._targetEvents); |
56 this._targetEvents = null; | 56 this._targetEvents = null; |
57 } | 57 } |
58 this._target = target; | 58 this._target = target; |
| 59 |
59 var domModel = null; | 60 var domModel = null; |
| 61 var resourceTreeModel = null; |
60 if (target) { | 62 if (target) { |
61 this._cssModel = WebInspector.CSSModel.fromTarget(target); | 63 this._cssModel = WebInspector.CSSModel.fromTarget(target); |
62 domModel = WebInspector.DOMModel.fromTarget(target); | 64 domModel = WebInspector.DOMModel.fromTarget(target); |
| 65 resourceTreeModel = target.resourceTreeModel; |
63 } | 66 } |
64 | 67 |
65 if (domModel && this._cssModel) { | 68 if (this._cssModel && domModel && resourceTreeModel) { |
66 this._targetEvents = [ | 69 this._targetEvents = [ |
67 this._cssModel.addEventListener(WebInspector.CSSModel.Events.Sty
leSheetAdded, this._onComputedStyleChanged, this), | 70 this._cssModel.addEventListener(WebInspector.CSSModel.Events.Sty
leSheetAdded, this._onComputedStyleChanged, this), |
68 this._cssModel.addEventListener(WebInspector.CSSModel.Events.Sty
leSheetRemoved, this._onComputedStyleChanged, this), | 71 this._cssModel.addEventListener(WebInspector.CSSModel.Events.Sty
leSheetRemoved, this._onComputedStyleChanged, this), |
69 this._cssModel.addEventListener(WebInspector.CSSModel.Events.Sty
leSheetChanged, this._onComputedStyleChanged, this), | 72 this._cssModel.addEventListener(WebInspector.CSSModel.Events.Sty
leSheetChanged, this._onComputedStyleChanged, this), |
70 this._cssModel.addEventListener(WebInspector.CSSModel.Events.Med
iaQueryResultChanged, this._onComputedStyleChanged, this), | 73 this._cssModel.addEventListener(WebInspector.CSSModel.Events.Med
iaQueryResultChanged, this._onComputedStyleChanged, this), |
71 this._cssModel.addEventListener(WebInspector.CSSModel.Events.Pse
udoStateForced, this._onComputedStyleChanged, this), | 74 this._cssModel.addEventListener(WebInspector.CSSModel.Events.Pse
udoStateForced, this._onComputedStyleChanged, this), |
72 this._cssModel.addEventListener(WebInspector.CSSModel.Events.Mod
elWasEnabled, this._onComputedStyleChanged, this), | 75 this._cssModel.addEventListener(WebInspector.CSSModel.Events.Mod
elWasEnabled, this._onComputedStyleChanged, this), |
73 domModel.addEventListener(WebInspector.DOMModel.Events.DOMMutate
d, this._onComputedStyleChanged, this) | 76 domModel.addEventListener(WebInspector.DOMModel.Events.DOMMutate
d, this._onDOMModelChanged, this), |
| 77 resourceTreeModel.addEventListener(WebInspector.ResourceTreeMode
l.EventTypes.FrameResized, this._onFrameResized, this), |
74 ]; | 78 ]; |
75 } | 79 } |
76 }, | 80 }, |
77 | 81 |
| 82 /** |
| 83 * @param {?WebInspector.Event} event |
| 84 */ |
| 85 _onComputedStyleChanged: function(event) |
| 86 { |
| 87 delete this._computedStylePromise; |
| 88 this.dispatchEventToListeners(WebInspector.ComputedStyleModel.Events.Com
putedStyleChanged, event ? event.data : null); |
| 89 }, |
| 90 |
| 91 /** |
| 92 * @param {!WebInspector.Event} event |
| 93 */ |
| 94 _onDOMModelChanged: function(event) |
| 95 { |
| 96 // Any attribute removal or modification can affect the styles of "relat
ed" nodes. |
| 97 var node = /** @type {!WebInspector.DOMNode} */ (event.data); |
| 98 if (!this._node || this._node !== node && node.parentNode !== this._node
.parentNode && !node.isAncestor(this._node)) |
| 99 return; |
| 100 this._onComputedStyleChanged(null); |
| 101 }, |
| 102 |
| 103 /** |
| 104 * @param {!WebInspector.Event} event |
| 105 */ |
| 106 _onFrameResized: function(event) |
| 107 { |
| 108 /** |
| 109 * @this {WebInspector.ComputedStyleModel} |
| 110 */ |
| 111 function refreshContents() |
| 112 { |
| 113 this._onComputedStyleChanged(null); |
| 114 delete this._frameResizedTimer; |
| 115 } |
| 116 |
| 117 if (this._frameResizedTimer) |
| 118 clearTimeout(this._frameResizedTimer); |
| 119 |
| 120 this._frameResizedTimer = setTimeout(refreshContents.bind(this), 100); |
| 121 }, |
| 122 |
78 /** | 123 /** |
79 * @return {?WebInspector.DOMNode} | 124 * @return {?WebInspector.DOMNode} |
80 */ | 125 */ |
81 _elementNode: function() | 126 _elementNode: function() |
82 { | 127 { |
83 return this.node() ? this.node().enclosingElementOrSelf() : null; | 128 return this.node() ? this.node().enclosingElementOrSelf() : null; |
84 }, | 129 }, |
85 | 130 |
86 /** | 131 /** |
87 * @return {!Promise.<?WebInspector.ComputedStyleModel.ComputedStyle>} | 132 * @return {!Promise.<?WebInspector.ComputedStyleModel.ComputedStyle>} |
(...skipping 15 matching lines...) Expand all Loading... |
103 * @param {?Map.<string, string>} style | 148 * @param {?Map.<string, string>} style |
104 * @return {?WebInspector.ComputedStyleModel.ComputedStyle} | 149 * @return {?WebInspector.ComputedStyleModel.ComputedStyle} |
105 * @this {WebInspector.ComputedStyleModel} | 150 * @this {WebInspector.ComputedStyleModel} |
106 */ | 151 */ |
107 function verifyOutdated(elementNode, style) | 152 function verifyOutdated(elementNode, style) |
108 { | 153 { |
109 return elementNode === this._elementNode() && style ? new WebInspect
or.ComputedStyleModel.ComputedStyle(elementNode, style) : /** @type {?WebInspect
or.ComputedStyleModel.ComputedStyle} */(null); | 154 return elementNode === this._elementNode() && style ? new WebInspect
or.ComputedStyleModel.ComputedStyle(elementNode, style) : /** @type {?WebInspect
or.ComputedStyleModel.ComputedStyle} */(null); |
110 } | 155 } |
111 }, | 156 }, |
112 | 157 |
113 _onComputedStyleChanged: function() | |
114 { | |
115 delete this._computedStylePromise; | |
116 this.dispatchEventToListeners(WebInspector.ComputedStyleModel.Events.Com
putedStyleChanged); | |
117 }, | |
118 | |
119 __proto__: WebInspector.Object.prototype | 158 __proto__: WebInspector.Object.prototype |
120 } | 159 } |
121 | 160 |
122 /** | 161 /** |
123 * @constructor | 162 * @constructor |
124 * @param {!WebInspector.DOMNode} node | 163 * @param {!WebInspector.DOMNode} node |
125 * @param {!Map.<string, string>} computedStyle | 164 * @param {!Map.<string, string>} computedStyle |
126 */ | 165 */ |
127 WebInspector.ComputedStyleModel.ComputedStyle = function(node, computedStyle) | 166 WebInspector.ComputedStyleModel.ComputedStyle = function(node, computedStyle) |
128 { | 167 { |
129 this.node = node; | 168 this.node = node; |
130 this.computedStyle = computedStyle; | 169 this.computedStyle = computedStyle; |
131 } | 170 } |
OLD | NEW |