50 lines
1.7 KiB
JavaScript
50 lines
1.7 KiB
JavaScript
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
|
|
|
|
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }
|
|
|
|
import { createElement } from 'react';
|
|
import PropTypes from 'prop-types';
|
|
|
|
var Target = function Target(props, context) {
|
|
var _props$component = props.component,
|
|
component = _props$component === undefined ? 'div' : _props$component,
|
|
innerRef = props.innerRef,
|
|
children = props.children,
|
|
restProps = _objectWithoutProperties(props, ['component', 'innerRef', 'children']);
|
|
|
|
var popperManager = context.popperManager;
|
|
|
|
var targetRef = function targetRef(node) {
|
|
popperManager.setTargetNode(node);
|
|
if (typeof innerRef === 'function') {
|
|
innerRef(node);
|
|
}
|
|
};
|
|
|
|
if (typeof children === 'function') {
|
|
var targetProps = { ref: targetRef };
|
|
return children({ targetProps: targetProps, restProps: restProps });
|
|
}
|
|
|
|
var componentProps = _extends({}, restProps);
|
|
|
|
if (typeof component === 'string') {
|
|
componentProps.ref = targetRef;
|
|
} else {
|
|
componentProps.innerRef = targetRef;
|
|
}
|
|
|
|
return createElement(component, componentProps, children);
|
|
};
|
|
|
|
Target.contextTypes = {
|
|
popperManager: PropTypes.object.isRequired
|
|
};
|
|
|
|
Target.propTypes = {
|
|
component: PropTypes.oneOfType([PropTypes.node, PropTypes.func]),
|
|
innerRef: PropTypes.func,
|
|
children: PropTypes.oneOfType([PropTypes.node, PropTypes.func])
|
|
};
|
|
|
|
export default Target; |