@blueprintjs/core
Version:
Core styles & components
383 lines (382 loc) • 67.1 kB
JavaScript
/*
* Copyright 2015 Palantir Technologies, Inc. All rights reserved.
* Licensed under the BSD-3 License as modified (the “License”); you may obtain a copy
* of the license at https://github.com/palantir/blueprint/blob/master/LICENSE
* and https://github.com/palantir/blueprint/blob/master/PATENTS
*/
"use strict";
var __extends = (this && this.__extends) || function (d, b) {
for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
var __assign = (this && this.__assign) || Object.assign || function(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
t[p] = s[p];
}
return t;
};
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var classNames = require("classnames");
var PureRender = require("pure-render-decorator");
var React = require("react");
var react_dom_1 = require("react-dom");
var Tether = require("tether");
var abstractComponent_1 = require("../../common/abstractComponent");
var Classes = require("../../common/classes");
var Errors = require("../../common/errors");
var PosUtils = require("../../common/position");
var TetherUtils = require("../../common/tetherUtils");
var Utils = require("../../common/utils");
var overlay_1 = require("../overlay/overlay");
var tooltip_1 = require("../tooltip/tooltip");
var Arrows = require("./arrows");
var SVG_SHADOW_PATH = "M8.11 6.302c1.015-.936 1.887-2.922 1.887-4.297v26c0-1.378" +
"-.868-3.357-1.888-4.297L.925 17.09c-1.237-1.14-1.233-3.034 0-4.17L8.11 6.302z";
var SVG_ARROW_PATH = "M8.787 7.036c1.22-1.125 2.21-3.376 2.21-5.03V0v30-2.005" +
"c0-1.654-.983-3.9-2.21-5.03l-7.183-6.616c-.81-.746-.802-1.96 0-2.7l7.183-6.614z";
(function (PopoverInteractionKind) {
PopoverInteractionKind[PopoverInteractionKind["CLICK"] = 0] = "CLICK";
PopoverInteractionKind[PopoverInteractionKind["CLICK_TARGET_ONLY"] = 1] = "CLICK_TARGET_ONLY";
PopoverInteractionKind[PopoverInteractionKind["HOVER"] = 2] = "HOVER";
PopoverInteractionKind[PopoverInteractionKind["HOVER_TARGET_ONLY"] = 3] = "HOVER_TARGET_ONLY";
})(exports.PopoverInteractionKind || (exports.PopoverInteractionKind = {}));
var PopoverInteractionKind = exports.PopoverInteractionKind;
var Popover = (function (_super) {
__extends(Popover, _super);
function Popover(props, context) {
var _this = this;
_super.call(this, props, context);
this.displayName = "Blueprint.Popover";
this.hasDarkParent = false;
// a flag that is set to true while we are waiting for the underlying Portal to complete rendering
this.isContentMounting = false;
this.refHandlers = {
popover: function (ref) {
_this.popoverElement = ref;
_this.updateTether();
_this.updateArrowPosition();
},
target: function (ref) {
_this.targetElement = ref;
},
};
this.handleContentMount = function () {
if (Utils.isFunction(_this.props.popoverDidOpen) && _this.isContentMounting) {
_this.props.popoverDidOpen();
_this.isContentMounting = false;
}
};
this.handleMouseEnter = function (e) {
// if we're entering the popover, and the mode is set to be HOVER_TARGET_ONLY, we want to manually
// trigger the mouse leave event, as hovering over the popover shouldn't count.
if (_this.props.inline
&& _this.isElementInPopover(e.target)
&& _this.props.interactionKind === PopoverInteractionKind.HOVER_TARGET_ONLY) {
_this.handleMouseLeave(e);
}
else if (!_this.props.isDisabled) {
// only begin opening popover when it is enabled
_this.setOpenState(true, e, _this.props.hoverOpenDelay);
}
};
this.handleMouseLeave = function (e) {
// user-configurable closing delay is helpful when moving mouse from target to popover
_this.setOpenState(false, e, _this.props.hoverCloseDelay);
};
this.handlePopoverClick = function (e) {
var eventTarget = e.target;
var shouldDismiss = eventTarget.closest("." + Classes.POPOVER_DISMISS) != null;
var overrideDismiss = eventTarget.closest("." + Classes.POPOVER_DISMISS_OVERRIDE) != null;
if (shouldDismiss && !overrideDismiss) {
_this.setOpenState(false, e);
}
};
this.handleOverlayClose = function (e) {
var eventTarget = e.target;
// if click was in target, target event listener will handle things, so don't close
if (!Utils.elementIsOrContains(_this.targetElement, eventTarget)
|| e.nativeEvent instanceof KeyboardEvent) {
_this.setOpenState(false, e);
}
};
this.handleTargetClick = function (e) {
// ensure click did not originate from within inline popover before closing
if (!_this.props.isDisabled && !_this.isElementInPopover(e.target)) {
if (_this.props.isOpen == null) {
_this.setState(function (prevState) { return ({ isOpen: !prevState.isOpen }); });
}
else {
_this.setOpenState(!_this.props.isOpen, e);
}
}
};
var isOpen = props.defaultIsOpen;
if (props.isOpen != null) {
isOpen = props.isOpen;
}
this.state = {
isOpen: isOpen,
ignoreTargetDimensions: false,
targetHeight: 0,
targetWidth: 0,
};
}
Popover.prototype.render = function () {
var _a = this.props, className = _a.className, interactionKind = _a.interactionKind;
var targetProps;
if (interactionKind === PopoverInteractionKind.HOVER
|| interactionKind === PopoverInteractionKind.HOVER_TARGET_ONLY) {
targetProps = {
onMouseEnter: this.handleMouseEnter,
onMouseLeave: this.handleMouseLeave,
};
}
else {
targetProps = {
onClick: this.handleTargetClick,
};
}
targetProps.className = classNames(Classes.POPOVER_TARGET, (_b = {},
_b[Classes.POPOVER_OPEN] = this.state.isOpen,
_b
), className);
targetProps.ref = this.refHandlers.target;
var children = this.props.children;
if (typeof this.props.children === "string") {
// wrap text in a <span> so that we have a consistent way to interact with the target node(s)
children = React.DOM.span({}, this.props.children);
}
else {
var child = React.Children.only(this.props.children);
// force disable single Tooltip child when popover is open (BLUEPRINT-552)
if (this.state.isOpen && child.type === tooltip_1.Tooltip) {
children = React.cloneElement(child, { isDisabled: true });
}
}
return React.createElement(this.props.rootElementTag, targetProps, children, React.createElement(overlay_1.Overlay, {autoFocus: this.props.autoFocus, backdropClassName: Classes.POPOVER_BACKDROP, backdropProps: this.props.backdropProps, canEscapeKeyClose: this.props.canEscapeKeyClose, canOutsideClickClose: this.props.interactionKind === PopoverInteractionKind.CLICK, className: this.props.portalClassName, didOpen: this.handleContentMount, enforceFocus: this.props.enforceFocus, hasBackdrop: this.props.isModal, inline: this.props.inline, isOpen: this.state.isOpen, lazy: this.props.lazy, onClose: this.handleOverlayClose, transitionDuration: this.props.transitionDuration, transitionName: Classes.POPOVER}, this.renderPopover()));
var _b;
};
Popover.prototype.componentDidMount = function () {
this.componentDOMChange();
};
Popover.prototype.componentWillReceiveProps = function (nextProps) {
_super.prototype.componentWillReceiveProps.call(this, nextProps);
if (nextProps.isDisabled) {
// ok to use setOpenState here because isDisabled and isOpen are mutex.
this.setOpenState(false);
}
else if (nextProps.isOpen !== this.props.isOpen) {
// propagate isOpen prop directly to state, circumventing onInteraction callback
// (which would be invoked if this went through setOpenState)
this.setState({ isOpen: nextProps.isOpen });
}
};
Popover.prototype.componentWillUpdate = function (_, nextState) {
if (!this.state.isOpen && nextState.isOpen) {
this.isContentMounting = true;
Utils.safeInvoke(this.props.popoverWillOpen);
}
else if (this.state.isOpen && !nextState.isOpen) {
Utils.safeInvoke(this.props.popoverWillClose);
}
};
Popover.prototype.componentDidUpdate = function () {
this.componentDOMChange();
};
Popover.prototype.componentWillUnmount = function () {
this.clearTimeout();
this.destroyTether();
};
Popover.prototype.validateProps = function (props) {
if (props.isOpen == null && props.onInteraction != null) {
console.warn(Errors.POPOVER_UNCONTROLLED_ONINTERACTION);
}
if (props.isOpen != null && props.isDisabled) {
throw new Error(Errors.POPOVER_CONTROLLED_DISABLED);
}
if (props.isModal && props.interactionKind !== PopoverInteractionKind.CLICK) {
throw new Error(Errors.POPOVER_MODAL_INTERACTION);
}
if (props.isModal && props.inline) {
throw new Error(Errors.POPOVER_MODAL_INLINE);
}
if (props.useSmartPositioning && props.inline) {
throw new Error(Errors.POPOVER_SMART_POSITIONING_INLINE);
}
if (typeof props.children !== "string") {
try {
React.Children.only(props.children);
}
catch (e) {
throw new Error(Errors.POPOVER_ONE_CHILD);
}
}
};
Popover.prototype.componentDOMChange = function () {
this.setState({
targetHeight: this.targetElement.clientHeight,
targetWidth: this.targetElement.clientWidth,
});
if (!this.props.inline) {
this.hasDarkParent = this.targetElement.closest("." + Classes.DARK) != null;
this.updateTether();
}
};
Popover.prototype.renderPopover = function () {
var _a = this.props, inline = _a.inline, interactionKind = _a.interactionKind;
var popoverHandlers = {
// always check popover clicks for dismiss class
onClick: this.handlePopoverClick,
};
if ((interactionKind === PopoverInteractionKind.HOVER)
|| (inline && interactionKind === PopoverInteractionKind.HOVER_TARGET_ONLY)) {
popoverHandlers.onMouseEnter = this.handleMouseEnter;
popoverHandlers.onMouseLeave = this.handleMouseLeave;
}
var positionClasses = TetherUtils.getAttachmentClasses(this.props.position).join(" ");
var containerClasses = classNames(Classes.TRANSITION_CONTAINER, (_b = {}, _b[positionClasses] = inline, _b));
var popoverClasses = classNames(Classes.POPOVER, (_c = {},
_c[Classes.DARK] = this.props.inheritDarkTheme && this.hasDarkParent && !inline,
_c
), this.props.popoverClassName);
var styles = this.getArrowPositionStyles();
var transform = { transformOrigin: this.getPopoverTransformOrigin() };
return (React.createElement("div", {className: containerClasses, ref: this.refHandlers.popover, style: styles.container},
React.createElement("div", __assign({className: popoverClasses, style: transform}, popoverHandlers),
React.createElement("div", {className: Classes.POPOVER_ARROW, style: styles.arrow},
React.createElement("svg", {viewBox: "0 0 30 30"},
React.createElement("path", {className: Classes.POPOVER_ARROW + "-border", d: SVG_SHADOW_PATH}),
React.createElement("path", {className: Classes.POPOVER_ARROW + "-fill", d: SVG_ARROW_PATH}))
),
React.createElement("div", {className: Classes.POPOVER_CONTENT}, this.props.content))
));
var _b, _c;
};
Popover.prototype.getArrowPositionStyles = function () {
if (this.props.useSmartArrowPositioning) {
var dimensions = { height: this.state.targetHeight, width: this.state.targetWidth };
return Arrows.getArrowPositionStyles(this.props.position, this.props.arrowSize, this.state.ignoreTargetDimensions, dimensions, this.props.inline);
}
else {
return {};
}
};
Popover.prototype.getPopoverTransformOrigin = function () {
// if smart positioning is enabled then we must rely CSS classes to put transform origin
// on the correct side and cannot override it in JS. (https://github.com/HubSpot/tether/issues/154)
if (this.props.useSmartArrowPositioning && !this.props.useSmartPositioning) {
var dimensions = { height: this.state.targetHeight, width: this.state.targetWidth };
return Arrows.getPopoverTransformOrigin(this.props.position, this.props.arrowSize, dimensions);
}
else {
return undefined;
}
};
Popover.prototype.updateArrowPosition = function () {
if (this.popoverElement != null) {
var arrow = this.popoverElement.getElementsByClassName(Classes.POPOVER_ARROW)[0];
var centerWidth = (this.state.targetWidth + arrow.clientWidth) / 2;
var centerHeight = (this.state.targetHeight + arrow.clientHeight) / 2;
var ignoreWidth = centerWidth > this.popoverElement.clientWidth
&& PosUtils.isPositionHorizontal(this.props.position);
var ignoreHeight = centerHeight > this.popoverElement.clientHeight
&& PosUtils.isPositionVertical(this.props.position);
if (!this.state.ignoreTargetDimensions && (ignoreWidth || ignoreHeight)) {
this.setState({ ignoreTargetDimensions: true });
}
else if (this.state.ignoreTargetDimensions && !ignoreWidth && !ignoreHeight) {
this.setState({ ignoreTargetDimensions: false });
}
}
};
Popover.prototype.updateTether = function () {
var _this = this;
if (this.state.isOpen && !this.props.inline && this.popoverElement != null) {
// the .pt-popover-target span we wrap the children in won't always be as big as its children
// so instead, we'll position tether based off of its first child.
// NOTE: use findDOMNode(this) directly because this.targetElement may not exist yet
var target = react_dom_1.findDOMNode(this).childNodes[0];
var tetherOptions = TetherUtils.createTetherOptions(this.popoverElement, target, this.props.position, this.props.useSmartPositioning, this.props.constraints);
if (this.tether == null) {
this.tether = new Tether(tetherOptions);
}
else {
this.tether.setOptions(tetherOptions);
}
// if props.position has just changed, Tether unfortunately positions the popover based
// on the margins from the previous position. delay a frame for styles to catch up.
setTimeout(function () { return _this.tether.position(); });
}
else {
this.destroyTether();
}
};
Popover.prototype.destroyTether = function () {
if (this.tether != null) {
this.tether.destroy();
}
};
// a wrapper around setState({isOpen}) that will call props.onInteraction instead when in controlled mode.
// starts a timeout to delay changing the state if a non-zero duration is provided.
Popover.prototype.setOpenState = function (isOpen, e, timeout) {
var _this = this;
// cancel any existing timeout because we have new state
this.clearTimeout();
if (timeout > 0) {
this.openStateTimeout = setTimeout(function () { return _this.setOpenState(isOpen, e); }, timeout);
}
else {
if (this.props.isOpen == null) {
this.setState({ isOpen: isOpen });
}
else {
Utils.safeInvoke(this.props.onInteraction, isOpen);
}
if (!isOpen) {
Utils.safeInvoke(this.props.onClose, e);
}
}
};
// clear the timeout that might be started by setOpenState()
Popover.prototype.clearTimeout = function () {
clearTimeout(this.openStateTimeout);
this.openStateTimeout = null;
};
Popover.prototype.isElementInPopover = function (element) {
return this.popoverElement != null && this.popoverElement.contains(element);
};
Popover.defaultProps = {
arrowSize: 30,
className: "",
content: React.createElement("span", null),
defaultIsOpen: false,
hoverCloseDelay: 300,
hoverOpenDelay: 150,
inheritDarkTheme: true,
inline: false,
interactionKind: PopoverInteractionKind.CLICK,
isDisabled: false,
isModal: false,
popoverClassName: "",
position: PosUtils.Position.RIGHT,
rootElementTag: "span",
transitionDuration: 300,
useSmartArrowPositioning: true,
useSmartPositioning: false,
};
Popover = __decorate([
PureRender
], Popover);
return Popover;
}(abstractComponent_1.AbstractComponent));
exports.Popover = Popover;
exports.PopoverFactory = React.createFactory(Popover);
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/components/popover/popover.tsx"],"names":[],"mappings":"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","file":"components/popover/popover.js","sourcesContent":["/*\n * Copyright 2015 Palantir Technologies, Inc. All rights reserved.\n * Licensed under the BSD-3 License as modified (the “License”); you may obtain a copy\n * of the license at https://github.com/palantir/blueprint/blob/master/LICENSE\n * and https://github.com/palantir/blueprint/blob/master/PATENTS\n */\n\nimport * as classNames from \"classnames\";\nimport * as PureRender from \"pure-render-decorator\";\nimport * as React from \"react\";\nimport { findDOMNode } from \"react-dom\";\nimport * as Tether from \"tether\";\n\nimport { AbstractComponent } from \"../../common/abstractComponent\";\nimport * as Classes from \"../../common/classes\";\nimport * as Errors from \"../../common/errors\";\nimport * as PosUtils from \"../../common/position\";\nimport { IProps } from \"../../common/props\";\nimport * as TetherUtils from \"../../common/tetherUtils\";\nimport * as Utils from \"../../common/utils\";\nimport { IOverlayableProps, Overlay } from \"../overlay/overlay\";\nimport { Tooltip } from \"../tooltip/tooltip\";\n\nimport * as Arrows from \"./arrows\";\n\nconst SVG_SHADOW_PATH = \"M8.11 6.302c1.015-.936 1.887-2.922 1.887-4.297v26c0-1.378\" +\n    \"-.868-3.357-1.888-4.297L.925 17.09c-1.237-1.14-1.233-3.034 0-4.17L8.11 6.302z\";\nconst SVG_ARROW_PATH = \"M8.787 7.036c1.22-1.125 2.21-3.376 2.21-5.03V0v30-2.005\" +\n    \"c0-1.654-.983-3.9-2.21-5.03l-7.183-6.616c-.81-.746-.802-1.96 0-2.7l7.183-6.614z\";\n\nexport enum PopoverInteractionKind {\n    CLICK,\n    CLICK_TARGET_ONLY,\n    HOVER,\n    HOVER_TARGET_ONLY,\n}\n\nexport interface IPopoverProps extends IOverlayableProps, IProps {\n    /** HTML props for the backdrop element. Can be combined with `backdropClassName`. */\n    backdropProps?: React.HTMLProps<HTMLDivElement>;\n\n    /**\n     * The content displayed inside the popover.\n     */\n    content?: JSX.Element | string;\n\n    /**\n     * The length of a side of the square used to render the arrow.\n     * @default 30\n     * @internal\n     */\n    arrowSize?: number;\n\n    /**\n     * Constraints for the underlying Tether instance.\n     * See http://tether.io/#constraints.\n     */\n    constraints?: TetherUtils.ITetherConstraint[];\n\n    /**\n     * Initial opened state when uncontrolled.\n     * @default false\n     */\n    defaultIsOpen?: boolean;\n\n    /**\n     * The amount of time in milliseconds the popover should remain open after the\n     * user hovers off the trigger. The timer is canceled if the user mouses over the\n     * target before it expires. This option only applies when `interactionKind` is `HOVER` or\n     * `HOVER_TARGET_ONLY`.\n     * @default 300\n     */\n    hoverCloseDelay?: number;\n\n    /**\n     * The amount of time in milliseconds the popover should wait before opening after the the\n     * user hovers over the trigger. The timer is canceled if the user mouses away from the\n     * target before it expires. This option only applies when `interactionKind` is `HOVER` or\n     * `HOVER_TARGET_ONLY`.\n     * @default 150\n     */\n    hoverOpenDelay?: number;\n\n    /**\n     * Whether a non-inline popover should automatically inherit the dark theme from its parent.\n     * @default true\n     */\n    inheritDarkTheme?: boolean;\n\n    /**\n     * The kind of interaction that triggers the display of the popover.\n     * @default PopoverInteractionKind.CLICK\n     */\n    interactionKind?: PopoverInteractionKind;\n\n    /**\n     * Prevents the popover from appearing when `true`.\n     * @default false\n     */\n    isDisabled?: boolean;\n\n    /**\n     * Enables an invisible overlay beneath the popover that captures clicks and prevents\n     * interaction with the rest of the document until the popover is closed.\n     * This prop is only available when `interactionKind` is `PopoverInteractionKind.CLICK`.\n     * When modal popovers are opened, they become focused.\n     * @default false\n     */\n    isModal?: boolean;\n\n    /**\n     * Whether the popover is visible. Passing this prop puts the popover in\n     * controlled mode, where the only way to change visibility is by updating this property.\n     * @default undefined\n     */\n    isOpen?: boolean;\n\n    /**\n     * Callback invoked in controlled mode when the popover open state *would* change due to\n     * user interaction based on the value of `interactionKind`.\n     */\n    onInteraction?: (nextOpenState: boolean) => void;\n\n    /**\n     * A space-delimited string of class names that are applied to the popover (but not the target).\n     */\n    popoverClassName?: string;\n\n    /**\n     * Callback invoked when the popover opens after it is added to the DOM.\n     */\n    popoverDidOpen?: () => void;\n\n    /**\n     * Callback invoked when a popover begins to close.\n     */\n    popoverWillClose?: () => void;\n\n    /**\n     * Callback invoked before the popover opens.\n     */\n    popoverWillOpen?: () => void;\n\n    /**\n     * Space-delimited string of class names applied to the\n     * portal that holds the popover if `inline = false`.\n     */\n    portalClassName?: string;\n\n    /**\n     * The position (relative to the target) at which the popover should appear.\n     * @default Blueprint.Common.Position.RIGHT\n     */\n    position?: PosUtils.Position;\n\n    /**\n     * The name of the HTML tag to use when rendering the popover target wrapper element (`.pt-popover-target`).\n     * @default \"span\"\n     */\n    rootElementTag?: string;\n\n    /**\n     * Whether the arrow's offset should be computed such that it always points at the center\n     * of the target. If false, arrow position is hardcoded via CSS, which expects a 30px target.\n     * @default true\n     */\n    useSmartArrowPositioning?: boolean;\n\n    /**\n     * Whether the popover will try to reposition itself\n     * if there isn't room for it in its current position.\n     * The popover will try to flip to the opposite side of the target element but\n     * will not move to an adjacent side.\n     * @default false\n     */\n    useSmartPositioning?: boolean;\n}\n\nexport interface IPopoverState {\n    isOpen?: boolean;\n    ignoreTargetDimensions?: boolean;\n    targetHeight?: number;\n    targetWidth?: number;\n}\n\n@PureRender\nexport class Popover extends AbstractComponent<IPopoverProps, IPopoverState> {\n    public static defaultProps: IPopoverProps = {\n        arrowSize: 30,\n        className: \"\",\n        content: <span/>,\n        defaultIsOpen: false,\n        hoverCloseDelay: 300,\n        hoverOpenDelay: 150,\n        inheritDarkTheme: true,\n        inline: false,\n        interactionKind: PopoverInteractionKind.CLICK,\n        isDisabled: false,\n        isModal: false,\n        popoverClassName: \"\",\n        position: PosUtils.Position.RIGHT,\n        rootElementTag: \"span\",\n        transitionDuration: 300,\n        useSmartArrowPositioning: true,\n        useSmartPositioning: false,\n    };\n\n    public displayName = \"Blueprint.Popover\";\n\n    private hasDarkParent = false;\n    // a flag that is set to true while we are waiting for the underlying Portal to complete rendering\n    private isContentMounting = false;\n    private openStateTimeout: number;\n    private popoverElement: HTMLElement;\n    private targetElement: HTMLElement;\n    private tether: Tether;\n\n    private refHandlers = {\n        popover: (ref: HTMLDivElement) => {\n            this.popoverElement = ref;\n            this.updateTether();\n            this.updateArrowPosition();\n        },\n        target: (ref: HTMLElement) => {\n            this.targetElement = ref;\n        },\n    };\n\n    public constructor(props?: IPopoverProps, context?: any) {\n        super(props, context);\n\n        let isOpen = props.defaultIsOpen;\n        if (props.isOpen != null) {\n            isOpen = props.isOpen;\n        }\n\n        this.state = {\n            isOpen,\n            ignoreTargetDimensions: false,\n            targetHeight: 0,\n            targetWidth: 0,\n        };\n    }\n\n    public render() {\n        const { className, interactionKind } = this.props;\n        let targetProps: React.HTMLProps<HTMLElement>;\n        if (interactionKind === PopoverInteractionKind.HOVER\n            || interactionKind === PopoverInteractionKind.HOVER_TARGET_ONLY) {\n            targetProps = {\n                onMouseEnter: this.handleMouseEnter,\n                onMouseLeave: this.handleMouseLeave,\n            };\n        // any one of the CLICK* values\n        } else {\n            targetProps = {\n                onClick: this.handleTargetClick,\n            };\n        }\n        targetProps.className = classNames(Classes.POPOVER_TARGET, {\n            [Classes.POPOVER_OPEN]: this.state.isOpen,\n        }, className);\n        targetProps.ref = this.refHandlers.target;\n\n        let children = this.props.children;\n        if (typeof this.props.children === \"string\") {\n            // wrap text in a <span> so that we have a consistent way to interact with the target node(s)\n            children = React.DOM.span({}, this.props.children);\n        } else {\n            const child = React.Children.only(this.props.children) as React.ReactElement<any>;\n            // force disable single Tooltip child when popover is open (BLUEPRINT-552)\n            if (this.state.isOpen && child.type === Tooltip) {\n                children = React.cloneElement(child, { isDisabled: true });\n            }\n        }\n\n        return React.createElement(this.props.rootElementTag, targetProps, children,\n            <Overlay\n        