| OLD | NEW |
| 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 Network.NetworkWaterfallColumn = class extends UI.VBox { | 4 Network.NetworkWaterfallColumn = class extends UI.VBox { |
| 5 /** | 5 /** |
| 6 * @param {number} rowHeight | 6 * @param {number} rowHeight |
| 7 * @param {!Network.NetworkTimeCalculator} calculator | 7 * @param {!Network.NetworkTimeCalculator} calculator |
| 8 */ | 8 */ |
| 9 constructor(rowHeight, calculator) { | 9 constructor(rowHeight, calculator) { |
| 10 // TODO(allada) Make this a shadowDOM when the NetworkWaterfallColumn gets m
oved into NetworkLogViewColumns. | 10 // TODO(allada) Make this a shadowDOM when the NetworkWaterfallColumn gets m
oved into NetworkLogViewColumns. |
| (...skipping 17 matching lines...) Expand all Loading... |
| 28 this._headerHeight = 0; | 28 this._headerHeight = 0; |
| 29 this._calculator = calculator; | 29 this._calculator = calculator; |
| 30 | 30 |
| 31 this._offsetWidth = 0; | 31 this._offsetWidth = 0; |
| 32 this._offsetHeight = 0; | 32 this._offsetHeight = 0; |
| 33 this._startTime = this._calculator.minimumBoundary(); | 33 this._startTime = this._calculator.minimumBoundary(); |
| 34 this._endTime = this._calculator.maximumBoundary(); | 34 this._endTime = this._calculator.maximumBoundary(); |
| 35 | 35 |
| 36 this._popoverHelper = new UI.PopoverHelper(this.element); | 36 this._popoverHelper = new UI.PopoverHelper(this.element); |
| 37 this._popoverHelper.initializeCallbacks(this._getPopoverAnchor.bind(this), t
his._showPopover.bind(this)); | 37 this._popoverHelper.initializeCallbacks(this._getPopoverAnchor.bind(this), t
his._showPopover.bind(this)); |
| 38 this._popoverHelper.setHasPadding(true); |
| 38 this._popoverHelper.setTimeout(300, 300); | 39 this._popoverHelper.setTimeout(300, 300); |
| 39 | 40 |
| 40 /** @type {!Array<!Network.NetworkNode>} */ | 41 /** @type {!Array<!Network.NetworkNode>} */ |
| 41 this._nodes = []; | 42 this._nodes = []; |
| 42 | 43 |
| 43 /** @type {?Network.NetworkNode} */ | 44 /** @type {?Network.NetworkNode} */ |
| 44 this._hoveredNode = null; | 45 this._hoveredNode = null; |
| 45 | 46 |
| 46 /** @type {!Map<string, !Array<number>>} */ | 47 /** @type {!Map<string, !Array<number>>} */ |
| 47 this._eventDividers = new Map(); | 48 this._eventDividers = new Map(); |
| (...skipping 113 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 161 var anchorBox = this.element.boxInWindow(); | 162 var anchorBox = this.element.boxInWindow(); |
| 162 anchorBox.x += start; | 163 anchorBox.x += start; |
| 163 anchorBox.y += y; | 164 anchorBox.y += y; |
| 164 anchorBox.width = end - start; | 165 anchorBox.width = end - start; |
| 165 anchorBox.height = barHeight; | 166 anchorBox.height = barHeight; |
| 166 return anchorBox; | 167 return anchorBox; |
| 167 } | 168 } |
| 168 | 169 |
| 169 /** | 170 /** |
| 170 * @param {!Element|!AnchorBox} anchor | 171 * @param {!Element|!AnchorBox} anchor |
| 171 * @param {!UI.Popover} popover | 172 * @param {!UI.GlassPane} popover |
| 173 * @return {!Promise<boolean>} |
| 172 */ | 174 */ |
| 173 _showPopover(anchor, popover) { | 175 _showPopover(anchor, popover) { |
| 174 if (!this._hoveredNode) | 176 if (!this._hoveredNode) |
| 175 return; | 177 return Promise.resolve(false); |
| 176 var request = this._hoveredNode.request(); | 178 var request = this._hoveredNode.request(); |
| 177 if (!request) | 179 if (!request) |
| 178 return; | 180 return Promise.resolve(false); |
| 179 var content = Network.RequestTimingView.createTimingTable(request, this._cal
culator); | 181 var content = Network.RequestTimingView.createTimingTable(request, this._cal
culator); |
| 180 popover.showForAnchor(content, anchor); | 182 popover.contentElement.appendChild(content); |
| 183 return Promise.resolve(true); |
| 181 } | 184 } |
| 182 | 185 |
| 183 /** | 186 /** |
| 184 * @param {?Network.NetworkNode} node | 187 * @param {?Network.NetworkNode} node |
| 185 * @param {boolean} highlightInitiatorChain | 188 * @param {boolean} highlightInitiatorChain |
| 186 */ | 189 */ |
| 187 _setHoveredNode(node, highlightInitiatorChain) { | 190 _setHoveredNode(node, highlightInitiatorChain) { |
| 188 if (this._hoveredNode) | 191 if (this._hoveredNode) |
| 189 this._hoveredNode.setHovered(false, false); | 192 this._hoveredNode.setHovered(false, false); |
| 190 this._hoveredNode = node; | 193 this._hoveredNode = node; |
| (...skipping 454 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 645 websocket: 'hsl(0, 0%, 95%)', | 648 websocket: 'hsl(0, 0%, 95%)', |
| 646 xhr: 'hsl(53, 100%, 80%)', | 649 xhr: 'hsl(53, 100%, 80%)', |
| 647 other: 'hsl(0, 0%, 95%)' | 650 other: 'hsl(0, 0%, 95%)' |
| 648 }; | 651 }; |
| 649 | 652 |
| 650 /** @typedef {!{fillStyle: (string|undefined), lineWidth: (number|undefined), bo
rderColor: (string|undefined)}} */ | 653 /** @typedef {!{fillStyle: (string|undefined), lineWidth: (number|undefined), bo
rderColor: (string|undefined)}} */ |
| 651 Network.NetworkWaterfallColumn._LayerStyles; | 654 Network.NetworkWaterfallColumn._LayerStyles; |
| 652 | 655 |
| 653 /** @typedef {!{x: number, y: number, text: string}} */ | 656 /** @typedef {!{x: number, y: number, text: string}} */ |
| 654 Network.NetworkWaterfallColumn._TextLayer; | 657 Network.NetworkWaterfallColumn._TextLayer; |
| OLD | NEW |