Chromium Code Reviews| 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) | |
|
lushnikov
2016/07/14 00:58:14
nit: indent is off here (do you use eslint?)
pfeldman
2016/07/14 17:26:12
nope
| |
| 86 { | |
| 87 delete this._computedStylePromise; | |
| 88 this.dispatchEventToListeners(WebInspector.ComputedStyleModel.Events.Com putedStyleChanged, event); | |
|
lushnikov
2016/07/14 00:58:15
event.data || null
(This will save from writing u
pfeldman
2016/07/14 17:26:12
Done.
| |
| 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() | 158 __proto__: WebInspector.Object.prototype |
|
lushnikov
2016/07/14 00:58:15
nit: indent
pfeldman
2016/07/14 17:26:12
Done.
| |
| 114 { | |
| 115 delete this._computedStylePromise; | |
| 116 this.dispatchEventToListeners(WebInspector.ComputedStyleModel.Events.Com putedStyleChanged); | |
| 117 }, | |
| 118 | |
| 119 __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 |