dbl-components
Version:
Framework based on bootstrap 5
2 lines • 8.12 kB
JavaScript
;function _typeof(o){"@babel/helpers - typeof";return _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(o){return typeof o}:function(o){return o&&"function"==typeof Symbol&&o.constructor===Symbol&&o!==Symbol.prototype?"symbol":typeof o},_typeof(o)}Object.defineProperty(exports,"__esModule",{value:true});exports["default"]=FloatingContainer;var _react=_interopRequireWildcard(require("react"));var _react2=require("@floating-ui/react");var _propTypes=_interopRequireDefault(require("prop-types"));var _dblUtils=require("dbl-utils");var _useEventHandler=_interopRequireDefault(require("../../hooks/use-event-handler"));var _component=_interopRequireDefault(require("../../component"));function _interopRequireDefault(e){return e&&e.__esModule?e:{"default":e}}function _interopRequireWildcard(e,t){if("function"==typeof WeakMap)var r=new WeakMap,n=new WeakMap;return(_interopRequireWildcard=function _interopRequireWildcard(e,t){if(!t&&e&&e.__esModule)return e;var o,i,f={__proto__:null,"default":e};if(null===e||"object"!=_typeof(e)&&"function"!=typeof e)return f;if(o=t?n:r){if(o.has(e))return o.get(e);o.set(e,f)}for(var _t in e)"default"!==_t&&{}.hasOwnProperty.call(e,_t)&&((i=(o=Object.defineProperty)&&Object.getOwnPropertyDescriptor(e,_t))&&(i.get||i.set)?o(f,_t,i):f[_t]=e[_t]);return f})(e,t)}function ownKeys(e,r){var t=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);r&&(o=o.filter(function(r){return Object.getOwnPropertyDescriptor(e,r).enumerable})),t.push.apply(t,o)}return t}function _objectSpread(e){for(var r=1;r<arguments.length;r++){var t=null!=arguments[r]?arguments[r]:{};r%2?ownKeys(Object(t),!0).forEach(function(r){_defineProperty(e,r,t[r])}):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(t)):ownKeys(Object(t)).forEach(function(r){Object.defineProperty(e,r,Object.getOwnPropertyDescriptor(t,r))})}return e}function _defineProperty(e,r,t){return(r=_toPropertyKey(r))in e?Object.defineProperty(e,r,{value:t,enumerable:!0,configurable:!0,writable:!0}):e[r]=t,e}function _toPropertyKey(t){var i=_toPrimitive(t,"string");return"symbol"==_typeof(i)?i:i+""}function _toPrimitive(t,r){if("object"!=_typeof(t)||!t)return t;var e=t[Symbol.toPrimitive];if(void 0!==e){var i=e.call(t,r||"default");if("object"!=_typeof(i))return i;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===r?String:Number)(t)}function _slicedToArray(r,e){return _arrayWithHoles(r)||_iterableToArrayLimit(r,e)||_unsupportedIterableToArray(r,e)||_nonIterableRest()}function _nonIterableRest(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _unsupportedIterableToArray(r,a){if(r){if("string"==typeof r)return _arrayLikeToArray(r,a);var t={}.toString.call(r).slice(8,-1);return"Object"===t&&r.constructor&&(t=r.constructor.name),"Map"===t||"Set"===t?Array.from(r):"Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t)?_arrayLikeToArray(r,a):void 0}}function _arrayLikeToArray(r,a){(null==a||a>r.length)&&(a=r.length);for(var e=0,n=Array(a);e<a;e++)n[e]=r[e];return n}function _iterableToArrayLimit(r,l){var t=null==r?null:"undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(null!=t){var e,n,i,u,a=[],f=!0,o=!1;try{if(i=(t=t.call(r)).next,0===l){if(Object(t)!==t)return;f=!1}else for(;!(f=(e=i.call(t)).done)&&(a.push(e.value),a.length!==l);f=!0);}catch(r){o=!0,n=r}finally{try{if(!f&&null!=t["return"]&&(u=t["return"](),Object(u)!==u))return}finally{if(o)throw n}}return a}}function _arrayWithHoles(r){if(Array.isArray(r))return r}function FloatingContainer(_ref){var name=_ref.name,floatAround=_ref.floatAround,children=_ref.children,placement=_ref.placement,_ref$card=_ref.card,card=_ref$card===void 0?true:_ref$card,offset=_ref.offset,alignment=_ref.alignment,allowedPlacements=_ref.allowedPlacements,fallbackPlacements=_ref.fallbackPlacements,_ref$classes=_ref.classes,classes=_ref$classes===void 0?_component["default"].defaultProps.classes:_ref$classes,_ref$style=_ref.style,style=_ref$style===void 0?_component["default"].defaultProps.style:_ref$style;var _useState=(0,_react.useState)(false),_useState2=_slicedToArray(_useState,2),open=_useState2[0],setOpen=_useState2[1];var _useState3=(0,_react.useState)(),_useState4=_slicedToArray(_useState3,2),reference=_useState4[0],setReference=_useState4[1];var floatingRef=(0,_react.useRef)(null);var changeOpen=(0,_react.useRef)(null);var onOpenChange=(0,_react.useCallback)(function(inOpen,event,reason){_dblUtils.eventHandler.dispatch(name,_defineProperty({},name,{open:inOpen,event:event}))});var selfUpdate=(0,_react.useCallback)(function(update,echo){if(update.open!==undefined){var newOpen=update.open==="toggle"?!open:update.open;clearTimeout(changeOpen.current);changeOpen.current=setTimeout(function(){setOpen(newOpen);if(echo)_dblUtils.eventHandler.dispatch(name,_defineProperty({},name,{open:newOpen}))},100)}},[]);var handleClickOutside=(0,_react.useCallback)(function(event){if(floatingRef.current&&!floatingRef.current.contains(event.target)){clearTimeout(changeOpen.current);changeOpen.current=setTimeout(function(){setOpen(false);_dblUtils.eventHandler.dispatch(name,_defineProperty({},name,{open:false}))},100)}},[name]);var handleKeyDown=(0,_react.useCallback)(function(event){if(event.key==="Escape"){clearTimeout(changeOpen.current);changeOpen.current=setTimeout(function(){setOpen(false);_dblUtils.eventHandler.dispatch(name,_defineProperty({},name,{open:false}))},100)}},[name]);(0,_react.useEffect)(function(){var _floatAround$current$;setReference(!!floatAround&&(floatAround.current?((_floatAround$current$=floatAround.current.ref)===null||_floatAround$current$===void 0?void 0:_floatAround$current$.current)||floatAround.current:floatAround)||document.body)},[floatAround,open]);var middleware=[];if(offset){middleware.push((0,_react2.offset)(offset))}if(allowedPlacements){middleware.push((0,_react2.autoPlacement)({alignment:alignment,autoAlignment:!alignment,allowedPlacements:allowedPlacements}))}else if(fallbackPlacements){middleware.push((0,_react2.flip)({fallbackPlacements:fallbackPlacements}))}var _useFloating=(0,_react2.useFloating)({elements:{reference:reference},strategy:"fixed",placement:placement,onOpenChange:onOpenChange,middleware:middleware}),refs=_useFloating.refs,floatingStyles=_useFloating.floatingStyles;(0,_useEventHandler["default"])([["update.".concat(name),selfUpdate]],"".concat(name,"-FloatingContainer"));(0,_react.useEffect)(function(){if(open&&refs.setFloating.current){refs.setFloating.current.focus()}},[open,refs.setFloating.current]);(0,_react.useEffect)(function(){document.addEventListener("mousedown",handleClickOutside);document.addEventListener("keydown",handleKeyDown);return function(){document.removeEventListener("mousedown",handleClickOutside);document.removeEventListener("keydown",handleKeyDown)}},[handleClickOutside,handleKeyDown]);(0,_react.useLayoutEffect)(function(){return function(){clearTimeout(changeOpen.current)}},[]);var cn=[name,name+"-FloatingContainer"];if(classes)cn.push(classes);if(card)cn.push("card shadow");return/*#__PURE__*/_react["default"].createElement("div",null,open&&/*#__PURE__*/_react["default"].createElement("div",{ref:function ref(node){floatingRef.current=node;refs.setFloating(node)},className:cn.flat().filter(Boolean).join(" "),style:_objectSpread(_objectSpread(_objectSpread({},style),floatingStyles),{},{zIndex:1050})},children))}var placements=_propTypes["default"].oneOf(["top","right","bottom","left","top-start","right-start","bottom-start","left-start","top-end","right-end","bottom-end","left-end"]);FloatingContainer.propTypes=_objectSpread(_objectSpread({},_component["default"].propTypes),{},{floatAround:_propTypes["default"].any,placement:placements,alignment:_propTypes["default"].oneOf(["start","end"]),allowedPlacements:_propTypes["default"].arrayOf(placements),card:_propTypes["default"].bool});
//# sourceMappingURL=floating-container.js.map