You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							76 lines
						
					
					
						
							2.6 KiB
						
					
					
				
			
		
		
	
	
							76 lines
						
					
					
						
							2.6 KiB
						
					
					
				import * as React from 'react';
 | 
						|
import { ManagerReferenceNodeContext } from './Manager';
 | 
						|
import { unwrapArray, setRef } from './utils';
 | 
						|
import { usePopper } from './usePopper';
 | 
						|
 | 
						|
var NOOP = function NOOP() {
 | 
						|
  return void 0;
 | 
						|
};
 | 
						|
 | 
						|
var NOOP_PROMISE = function NOOP_PROMISE() {
 | 
						|
  return Promise.resolve(null);
 | 
						|
};
 | 
						|
 | 
						|
var EMPTY_MODIFIERS = [];
 | 
						|
export function Popper(_ref) {
 | 
						|
  var _ref$placement = _ref.placement,
 | 
						|
      placement = _ref$placement === void 0 ? 'bottom' : _ref$placement,
 | 
						|
      _ref$strategy = _ref.strategy,
 | 
						|
      strategy = _ref$strategy === void 0 ? 'absolute' : _ref$strategy,
 | 
						|
      _ref$modifiers = _ref.modifiers,
 | 
						|
      modifiers = _ref$modifiers === void 0 ? EMPTY_MODIFIERS : _ref$modifiers,
 | 
						|
      referenceElement = _ref.referenceElement,
 | 
						|
      onFirstUpdate = _ref.onFirstUpdate,
 | 
						|
      innerRef = _ref.innerRef,
 | 
						|
      children = _ref.children;
 | 
						|
  var referenceNode = React.useContext(ManagerReferenceNodeContext);
 | 
						|
 | 
						|
  var _React$useState = React.useState(null),
 | 
						|
      popperElement = _React$useState[0],
 | 
						|
      setPopperElement = _React$useState[1];
 | 
						|
 | 
						|
  var _React$useState2 = React.useState(null),
 | 
						|
      arrowElement = _React$useState2[0],
 | 
						|
      setArrowElement = _React$useState2[1];
 | 
						|
 | 
						|
  React.useEffect(function () {
 | 
						|
    setRef(innerRef, popperElement);
 | 
						|
  }, [innerRef, popperElement]);
 | 
						|
  var options = React.useMemo(function () {
 | 
						|
    return {
 | 
						|
      placement: placement,
 | 
						|
      strategy: strategy,
 | 
						|
      onFirstUpdate: onFirstUpdate,
 | 
						|
      modifiers: [].concat(modifiers, [{
 | 
						|
        name: 'arrow',
 | 
						|
        enabled: arrowElement != null,
 | 
						|
        options: {
 | 
						|
          element: arrowElement
 | 
						|
        }
 | 
						|
      }])
 | 
						|
    };
 | 
						|
  }, [placement, strategy, onFirstUpdate, modifiers, arrowElement]);
 | 
						|
 | 
						|
  var _usePopper = usePopper(referenceElement || referenceNode, popperElement, options),
 | 
						|
      state = _usePopper.state,
 | 
						|
      styles = _usePopper.styles,
 | 
						|
      forceUpdate = _usePopper.forceUpdate,
 | 
						|
      update = _usePopper.update;
 | 
						|
 | 
						|
  var childrenProps = React.useMemo(function () {
 | 
						|
    return {
 | 
						|
      ref: setPopperElement,
 | 
						|
      style: styles.popper,
 | 
						|
      placement: state ? state.placement : placement,
 | 
						|
      hasPopperEscaped: state && state.modifiersData.hide ? state.modifiersData.hide.hasPopperEscaped : null,
 | 
						|
      isReferenceHidden: state && state.modifiersData.hide ? state.modifiersData.hide.isReferenceHidden : null,
 | 
						|
      arrowProps: {
 | 
						|
        style: styles.arrow,
 | 
						|
        ref: setArrowElement
 | 
						|
      },
 | 
						|
      forceUpdate: forceUpdate || NOOP,
 | 
						|
      update: update || NOOP_PROMISE
 | 
						|
    };
 | 
						|
  }, [setPopperElement, setArrowElement, placement, state, styles, update, forceUpdate]);
 | 
						|
  return unwrapArray(children)(childrenProps);
 | 
						|
} |