UNPKG

beta-parity-react

Version:

Beta Parity React Components

1 lines 8.55 kB
"use strict";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.ModalTrigger=exports.ModalHeader=exports.ModalFooter=exports.ModalDialog=exports.ModalBody=exports.Modal=void 0;var _react=_interopRequireDefault(require("react"));var _classnames=_interopRequireDefault(require("classnames"));require("./index.css");var _Portal=require("../Portal");var _jsxRuntime=require("react/jsx-runtime");var _excluded=["className","isStatic","size","isActive","onClose","onOpen","children"],_excluded2=["className","children"],_excluded3=["className","children"],_excluded4=["className","children"],_excluded5=["className","children"],_excluded6=["className","children"];function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{"default":obj}}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(obj,key,value){key=_toPropertyKey(key);if(key in obj){Object.defineProperty(obj,key,{value:value,enumerable:true,configurable:true,writable:true})}else{obj[key]=value}return obj}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(arr,i){return _arrayWithHoles(arr)||_iterableToArrayLimit(arr,i)||_unsupportedIterableToArray(arr,i)||_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(o,minLen){if(!o)return;if(typeof o==="string")return _arrayLikeToArray(o,minLen);var n=Object.prototype.toString.call(o).slice(8,-1);if(n==="Object"&&o.constructor)n=o.constructor.name;if(n==="Map"||n==="Set")return Array.from(o);if(n==="Arguments"||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n))return _arrayLikeToArray(o,minLen)}function _arrayLikeToArray(arr,len){if(len==null||len>arr.length)len=arr.length;for(var i=0,arr2=new Array(len);i<len;i++)arr2[i]=arr[i];return arr2}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(arr){if(Array.isArray(arr))return arr}function _objectWithoutProperties(source,excluded){if(source==null)return{};var target=_objectWithoutPropertiesLoose(source,excluded);var key,i;if(Object.getOwnPropertySymbols){var sourceSymbolKeys=Object.getOwnPropertySymbols(source);for(i=0;i<sourceSymbolKeys.length;i++){key=sourceSymbolKeys[i];if(excluded.indexOf(key)>=0)continue;if(!Object.prototype.propertyIsEnumerable.call(source,key))continue;target[key]=source[key]}}return target}function _objectWithoutPropertiesLoose(source,excluded){if(source==null)return{};var target={};for(var key in source){if(Object.prototype.hasOwnProperty.call(source,key)){if(excluded.indexOf(key)>=0)continue;target[key]=source[key]}}return target}var Modal=exports.Modal=_react["default"].forwardRef(function(_ref,ref){var className=_ref.className,_ref$isStatic=_ref.isStatic,isStatic=_ref$isStatic===void 0?false:_ref$isStatic,_ref$size=_ref.size,size=_ref$size===void 0?"medium":_ref$size,isActive=_ref.isActive,onClose=_ref.onClose,onOpen=_ref.onOpen,children=_ref.children,props=_objectWithoutProperties(_ref,_excluded);var _React$useState=_react["default"].useState(isActive),_React$useState2=_slicedToArray(_React$useState,2),isOpen=_React$useState2[0],setIsOpen=_React$useState2[1];var _React$useState3=_react["default"].useState(isActive),_React$useState4=_slicedToArray(_React$useState3,2),isDisplay=_React$useState4[0],setIsDisplay=_React$useState4[1];var _React$useState5=_react["default"].useState(false),_React$useState6=_slicedToArray(_React$useState5,2),isDialogWarning=_React$useState6[0],setIsDialogWarning=_React$useState6[1];var handleActive=_react["default"].useCallback(function(){setIsDisplay(true);var timeoutId=setTimeout(function(){setIsOpen(true)},100);onOpen&&onOpen();return function(){return clearTimeout(timeoutId)}},[onOpen]);var handleClose=_react["default"].useCallback(function(){setIsOpen(false);var timeoutId=setTimeout(function(){setIsDisplay(false)},100);onClose&&onClose();return function(){return clearTimeout(timeoutId)}},[onClose]);_react["default"].useEffect(function(){if(isActive){handleActive()}else{handleClose()}},[isActive,handleActive,handleClose]);_react["default"].useEffect(function(){var documentClickHandler=function documentClickHandler(event){var target=event.target;if(target&&!target.closest(".modal-dialog")&&isStatic){setIsDialogWarning(true);setTimeout(function(){return setIsDialogWarning(false)},100)}else if(target&&!target.closest(".modal-dialog")){handleClose()}};document.addEventListener("click",documentClickHandler);return function(){return document.removeEventListener("click",documentClickHandler)}},[isStatic,handleClose]);return isDisplay&&(0,_jsxRuntime.jsx)(_Portal.Portal,{children:(0,_jsxRuntime.jsx)("div",_objectSpread(_objectSpread({className:(0,_classnames["default"])("modal",className,size,{active:isOpen}),ref:ref},props),{},{children:(0,_jsxRuntime.jsx)(ModalDialog,{className:(0,_classnames["default"])({"modal-static-animation":isDialogWarning}),children:children})}))})});Modal.displayName="Modal";var ModalTrigger=exports.ModalTrigger=_react["default"].forwardRef(function(_ref2,ref){var className=_ref2.className,children=_ref2.children,props=_objectWithoutProperties(_ref2,_excluded2);return(0,_jsxRuntime.jsx)("button",_objectSpread(_objectSpread({className:(0,_classnames["default"])("modal-trigger",className),ref:ref},props),{},{children:children}))});ModalTrigger.displayName="ModalTrigger";var ModalDialog=exports.ModalDialog=_react["default"].forwardRef(function(_ref3,ref){var className=_ref3.className,children=_ref3.children,props=_objectWithoutProperties(_ref3,_excluded3);return(0,_jsxRuntime.jsx)("div",_objectSpread(_objectSpread({className:(0,_classnames["default"])("modal-dialog",className),ref:ref},props),{},{children:children}))});ModalDialog.displayName="ModalDialog";var ModalHeader=exports.ModalHeader=_react["default"].forwardRef(function(_ref4,ref){var className=_ref4.className,children=_ref4.children,props=_objectWithoutProperties(_ref4,_excluded4);return(0,_jsxRuntime.jsx)("div",_objectSpread(_objectSpread({className:(0,_classnames["default"])("modal-header",className),ref:ref},props),{},{children:children}))});ModalHeader.displayName="ModalHeader";var ModalBody=exports.ModalBody=_react["default"].forwardRef(function(_ref5,ref){var className=_ref5.className,children=_ref5.children,props=_objectWithoutProperties(_ref5,_excluded5);return(0,_jsxRuntime.jsx)("div",_objectSpread(_objectSpread({className:(0,_classnames["default"])("modal-body",className),ref:ref},props),{},{children:children}))});ModalBody.displayName="ModalBody";var ModalFooter=exports.ModalFooter=_react["default"].forwardRef(function(_ref6,ref){var className=_ref6.className,children=_ref6.children,props=_objectWithoutProperties(_ref6,_excluded6);return(0,_jsxRuntime.jsx)("div",_objectSpread(_objectSpread({className:(0,_classnames["default"])("modal-footer",className),ref:ref},props),{},{children:children}))});ModalFooter.displayName="ModalFooter";