Chromium Code Reviews| Index: third_party/WebKit/Source/devtools/front_end/object_ui/ObjectPopoverHelper.js |
| diff --git a/third_party/WebKit/Source/devtools/front_end/object_ui/ObjectPopoverHelper.js b/third_party/WebKit/Source/devtools/front_end/object_ui/ObjectPopoverHelper.js |
| index 72df88108b802967696836c7e9a09b2c3f470ae6..e4ec7fba2003d71a0de2b2dd6eb66bcb9239fb6c 100644 |
| --- a/third_party/WebKit/Source/devtools/front_end/object_ui/ObjectPopoverHelper.js |
| +++ b/third_party/WebKit/Source/devtools/front_end/object_ui/ObjectPopoverHelper.js |
| @@ -31,30 +31,19 @@ |
| /** |
| * @unrestricted |
| */ |
| -ObjectUI.ObjectPopoverHelper = class extends UI.PopoverHelper { |
| - /** |
| - * @param {!Element} panelElement |
| - * @param {function(!Element, !Event):(!Element|!AnchorBox|undefined)} getAnchor |
| - * @param {function(!Element, function(!SDK.RemoteObject, boolean, !Element=):undefined, string):undefined} queryObject |
| - * @param {function()=} onHide |
| - * @param {boolean=} disableOnClick |
| - */ |
| - constructor(panelElement, getAnchor, queryObject, onHide, disableOnClick) { |
| - super(panelElement, disableOnClick); |
| - this.initializeCallbacks(getAnchor, this._showObjectPopover.bind(this), this._onHideObjectPopover.bind(this)); |
| - this.setHasPadding(true); |
| - this._queryObject = queryObject; |
| - this._onHideCallback = onHide; |
| - this._popoverObjectGroup = 'popover'; |
| - panelElement.addEventListener('scroll', this.hidePopover.bind(this), true); |
| +ObjectUI.ObjectPopoverHelper = class { |
| + constructor() { |
|
lushnikov
2017/03/13 17:55:02
let's create an instnace with popover and remote o
dgozman
2017/03/13 19:57:24
Done.
|
| + this._disposed = false; |
| } |
| /** |
| - * @param {!Element} element |
| + * @param {!SDK.RemoteObject} result |
| * @param {!UI.GlassPane} popover |
| * @return {!Promise<boolean>} |
| */ |
| - _showObjectPopover(element, popover) { |
| + buildObjectPopover(result, popover) { |
|
lushnikov
2017/03/13 17:55:02
maybe you can even make this a static factory whic
dgozman
2017/03/13 19:57:24
Done.
|
| + this._disposed = false; |
| + |
| var fulfill; |
| var promise = new Promise(x => fulfill = x); |
| @@ -108,79 +97,57 @@ ObjectUI.ObjectPopoverHelper = class extends UI.PopoverHelper { |
| fulfill(true); |
| } |
| - /** |
| - * @param {!SDK.RemoteObject} result |
| - * @param {boolean} wasThrown |
| - * @param {!Element|!AnchorBox=} anchorOverride |
| - * @this {ObjectUI.ObjectPopoverHelper} |
| - */ |
| - function didQueryObject(result, wasThrown, anchorOverride) { |
| - if (this._disposed) { |
| - fulfill(false); |
| - return; |
| + var description = result.description.trimEnd(ObjectUI.ObjectPopoverHelper.MaxPopoverTextLength); |
| + var popoverContentElement = null; |
| + if (result.type !== 'object') { |
|
lushnikov
2017/03/13 17:55:02
brief examination didn't reveal any code changes h
dgozman
2017/03/13 19:57:24
Exactly.
|
| + popoverContentElement = createElement('span'); |
| + UI.appendStyle(popoverContentElement, 'object_ui/objectValue.css'); |
| + UI.appendStyle(popoverContentElement, 'object_ui/objectPopover.css'); |
| + var valueElement = popoverContentElement.createChild('span', 'monospace object-value-' + result.type); |
| + valueElement.style.whiteSpace = 'pre'; |
| + |
| + if (result.type === 'string') |
| + valueElement.createTextChildren('"', description, '"'); |
| + else if (result.type !== 'function') |
| + valueElement.textContent = description; |
| + |
| + if (result.type === 'function') { |
| + result.getOwnProperties( |
| + false /* generatePreview */, |
| + didGetFunctionProperties.bind(this, result, popoverContentElement, valueElement)); |
| + return promise; |
| } |
| - if (wasThrown) { |
| - this.hidePopover(); |
| - fulfill(false); |
| - return; |
| + popover.contentElement.appendChild(popoverContentElement); |
| + fulfill(true); |
| + } else { |
| + if (result.subtype === 'node') { |
| + SDK.DOMModel.highlightObjectAsDOMNode(result); |
| + this._resultHighlightedAsDOM = true; |
| } |
| - this._objectTarget = result.target(); |
| - var anchor = anchorOverride || element; |
| - popover.setContentAnchorBox(anchor instanceof AnchorBox ? anchor : anchor.boxInWindow()); |
| - var description = result.description.trimEnd(ObjectUI.ObjectPopoverHelper.MaxPopoverTextLength); |
| - var popoverContentElement = null; |
| - if (result.type !== 'object') { |
| - popoverContentElement = createElement('span'); |
| - UI.appendStyle(popoverContentElement, 'object_ui/objectValue.css'); |
| - UI.appendStyle(popoverContentElement, 'object_ui/objectPopover.css'); |
| - var valueElement = popoverContentElement.createChild('span', 'monospace object-value-' + result.type); |
| - valueElement.style.whiteSpace = 'pre'; |
| - if (result.type === 'string') |
| - valueElement.createTextChildren('"', description, '"'); |
| - else if (result.type !== 'function') |
| - valueElement.textContent = description; |
| - |
| - if (result.type === 'function') { |
| - result.getOwnProperties( |
| - false /* generatePreview */, |
| - didGetFunctionProperties.bind(this, result, popoverContentElement, valueElement)); |
| - return; |
| - } |
| - popover.contentElement.appendChild(popoverContentElement); |
| - fulfill(true); |
| + if (result.customPreview()) { |
| + var customPreviewComponent = new ObjectUI.CustomPreviewComponent(result); |
| + customPreviewComponent.expandIfPossible(); |
| + popoverContentElement = customPreviewComponent.element; |
| } else { |
| - if (result.subtype === 'node') { |
| - SDK.DOMModel.highlightObjectAsDOMNode(result); |
| - this._resultHighlightedAsDOM = true; |
| - } |
| - |
| - if (result.customPreview()) { |
| - var customPreviewComponent = new ObjectUI.CustomPreviewComponent(result); |
| - customPreviewComponent.expandIfPossible(); |
| - popoverContentElement = customPreviewComponent.element; |
| - } else { |
| - popoverContentElement = createElementWithClass('div', 'object-popover-content'); |
| - UI.appendStyle(popoverContentElement, 'object_ui/objectPopover.css'); |
| - var titleElement = popoverContentElement.createChild('div', 'monospace object-popover-title'); |
| - titleElement.createChild('span').textContent = description; |
| - var section = new ObjectUI.ObjectPropertiesSection(result, '', this._lazyLinkifier()); |
| - section.element.classList.add('object-popover-tree'); |
| - section.titleLessMode(); |
| - popoverContentElement.appendChild(section.element); |
| - } |
| - popover.setMaxContentSize(new UI.Size(300, 250)); |
| - popover.setSizeBehavior(UI.GlassPane.SizeBehavior.SetExactSize); |
| - popover.contentElement.appendChild(popoverContentElement); |
| - fulfill(true); |
| + popoverContentElement = createElementWithClass('div', 'object-popover-content'); |
| + UI.appendStyle(popoverContentElement, 'object_ui/objectPopover.css'); |
| + var titleElement = popoverContentElement.createChild('div', 'monospace object-popover-title'); |
| + titleElement.createChild('span').textContent = description; |
| + var section = new ObjectUI.ObjectPropertiesSection(result, '', this._lazyLinkifier()); |
| + section.element.classList.add('object-popover-tree'); |
| + section.titleLessMode(); |
| + popoverContentElement.appendChild(section.element); |
| } |
| + popover.setMaxContentSize(new UI.Size(300, 250)); |
| + popover.setSizeBehavior(UI.GlassPane.SizeBehavior.SetExactSize); |
| + popover.contentElement.appendChild(popoverContentElement); |
| + fulfill(true); |
| } |
| - this._disposed = false; |
| - this._queryObject(element, didQueryObject.bind(this), this._popoverObjectGroup); |
| return promise; |
| } |
| - _onHideObjectPopover() { |
| + dispose() { |
| this._disposed = true; |
| if (this._resultHighlightedAsDOM) { |
| SDK.DOMModel.hideDOMNodeHighlight(); |
| @@ -190,12 +157,6 @@ ObjectUI.ObjectPopoverHelper = class extends UI.PopoverHelper { |
| this._linkifier.dispose(); |
| delete this._linkifier; |
| } |
| - if (this._onHideCallback) |
| - this._onHideCallback(); |
| - if (this._objectTarget) { |
| - this._objectTarget.runtimeModel.releaseObjectGroup(this._popoverObjectGroup); |
| - delete this._objectTarget; |
| - } |
| } |
| /** |