UNPKG

beta-parity-react

Version:

Beta Parity React Components

1 lines 10.9 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.BreadcrumbMenu=exports.BreadcrumbItem=exports.BreadcrumbActive=exports.Breadcrumb=void 0;var _react=_interopRequireWildcard(require("react"));var _classnames=_interopRequireDefault(require("classnames"));require("./index.css");require("./variables.css");var _InlineLink=require("../InlineLink");var _Menu=require("../Menu");var _useOutsideClick=require("../hooks/useOutsideClick");var _useCombinedRefs=_interopRequireDefault(require("../hooks/useCombinedRefs"));var _jsxRuntime=require("react/jsx-runtime");var _excluded=["className","children","separator","breadcrumbList","limit","menuProps"],_excluded2=["children","isMenuItem"],_excluded3=["className","items","menuProps"],_excluded4=["className","item"];function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{"default":obj}}function _getRequireWildcardCache(e){if("function"!=typeof WeakMap)return null;var r=new WeakMap,t=new WeakMap;return(_getRequireWildcardCache=function _getRequireWildcardCache(e){return e?t:r})(e)}function _interopRequireWildcard(e,r){if(!r&&e&&e.__esModule)return e;if(null===e||"object"!=_typeof(e)&&"function"!=typeof e)return{"default":e};var t=_getRequireWildcardCache(r);if(t&&t.has(e))return t.get(e);var n={__proto__:null},a=Object.defineProperty&&Object.getOwnPropertyDescriptor;for(var u in e)if("default"!==u&&{}.hasOwnProperty.call(e,u)){var i=a?Object.getOwnPropertyDescriptor(e,u):null;i&&(i.get||i.set)?Object.defineProperty(n,u,i):n[u]=e[u]}return n["default"]=e,t&&t.set(e,n),n}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 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 _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 Breadcrumb=exports.Breadcrumb=_react["default"].forwardRef(function(_ref,ref){var className=_ref.className,children=_ref.children,_ref$separator=_ref.separator,separator=_ref$separator===void 0?"chevron":_ref$separator,breadcrumbList=_ref.breadcrumbList,limit=_ref.limit,menuProps=_ref.menuProps,props=_objectWithoutProperties(_ref,_excluded);var liList=breadcrumbList!==null&&breadcrumbList!==void 0?breadcrumbList:[];if(!breadcrumbList||breadcrumbList.length<=0){_react["default"].Children.forEach(children,function(child){if(_react["default"].isValidElement(child)&&child.type===BreadcrumbItem){var _props$size,_props$color,_props$disabled,_props$underline,_props$iconOnly;liList.push(_objectSpread(_objectSpread({},child.props),{},{size:(_props$size=props.size)!==null&&_props$size!==void 0?_props$size:"md",color:(_props$color=props.color)!==null&&_props$color!==void 0?_props$color:"standard",disabled:(_props$disabled=props.disabled)!==null&&_props$disabled!==void 0?_props$disabled:false,underline:(_props$underline=props.underline)!==null&&_props$underline!==void 0?_props$underline:"hover",iconOnly:(_props$iconOnly=props.iconOnly)!==null&&_props$iconOnly!==void 0?_props$iconOnly:false}))}})}else{liList=liList.map(function(item){var _props$size2,_props$color2,_props$disabled2,_props$underline2,_props$iconOnly2;return _objectSpread(_objectSpread({},item),{},{size:(_props$size2=props.size)!==null&&_props$size2!==void 0?_props$size2:"md",color:(_props$color2=props.color)!==null&&_props$color2!==void 0?_props$color2:"standard",disabled:(_props$disabled2=props.disabled)!==null&&_props$disabled2!==void 0?_props$disabled2:false,underline:(_props$underline2=props.underline)!==null&&_props$underline2!==void 0?_props$underline2:"hover",iconOnly:(_props$iconOnly2=props.iconOnly)!==null&&_props$iconOnly2!==void 0?_props$iconOnly2:false})})}if(liList.length===0)return null;var lastItem=liList[liList.length-1];var firstItem=liList[0];var menuItems=liList.slice(1,liList.length-1);var accessibility={"aria-label":"Breadcrumb"};return(0,_jsxRuntime.jsx)("nav",_objectSpread(_objectSpread(_objectSpread({className:(0,_classnames["default"])("breadcrumb",className,separator),ref:ref},props),accessibility),{},{children:(0,_jsxRuntime.jsx)("ol",{children:limit?(0,_jsxRuntime.jsxs)(_jsxRuntime.Fragment,{children:[(0,_jsxRuntime.jsx)(BreadcrumbItem,_objectSpread({},firstItem)),(0,_jsxRuntime.jsx)(BreadcrumbMenu,{items:menuItems,menuProps:menuProps}),(0,_jsxRuntime.jsx)(BreadcrumbActive,{item:lastItem})]}):(0,_jsxRuntime.jsxs)(_jsxRuntime.Fragment,{children:[(0,_jsxRuntime.jsx)(BreadcrumbItem,_objectSpread({},firstItem)),menuItems.map(function(item,index){var _item$href;var key=index.toString()+((_item$href=item.href)!==null&&_item$href!==void 0?_item$href:Date.now()).toString();return(0,_react.createElement)(BreadcrumbItem,_objectSpread(_objectSpread({},item),{},{key:key}))}),(0,_jsxRuntime.jsx)(BreadcrumbActive,{item:lastItem})]})})}))});Breadcrumb.displayName="Breadcrumb";var BreadcrumbItem=exports.BreadcrumbItem=_react["default"].forwardRef(function(_ref2,ref){var children=_ref2.children,_ref2$isMenuItem=_ref2.isMenuItem,isMenuItem=_ref2$isMenuItem===void 0?false:_ref2$isMenuItem,props=_objectWithoutProperties(_ref2,_excluded2);var menuProps=_objectSpread({},isMenuItem&&{role:"menuitem",underline:"none"});return(0,_jsxRuntime.jsx)("li",{className:(0,_classnames["default"])("breadcrumb-item"),children:(0,_jsxRuntime.jsx)(_InlineLink.InlineLink,_objectSpread(_objectSpread(_objectSpread({ref:ref},props),menuProps),{},{children:children}))})});BreadcrumbItem.displayName="BreadcrumbItem";var BreadcrumbMenu=exports.BreadcrumbMenu=_react["default"].forwardRef(function(_ref3,ref){var className=_ref3.className,items=_ref3.items,menuProps=_ref3.menuProps,props=_objectWithoutProperties(_ref3,_excluded3);var _React$useState=_react["default"].useState(false),_React$useState2=_slicedToArray(_React$useState,2),open=_React$useState2[0],setOpen=_React$useState2[1];var buttonRef=_react["default"].useRef(null);var combinedButtonRef=(0,_useCombinedRefs["default"])(buttonRef,ref);var refOutsideClick=(0,_useOutsideClick.useOutsideClick)(function(){return setOpen(false)},["click","touchstart"]);_react["default"].useEffect(function(){var handleGlobalKeyDown=function handleGlobalKeyDown(e){if(e.key==="Escape"){var _combinedButtonRef$cu;setOpen(false);(_combinedButtonRef$cu=combinedButtonRef.current)===null||_combinedButtonRef$cu===void 0||_combinedButtonRef$cu.focus()}};window.addEventListener("keydown",handleGlobalKeyDown);return function(){return window.removeEventListener("keydown",handleGlobalKeyDown)}},[combinedButtonRef.current]);return(0,_jsxRuntime.jsxs)(_jsxRuntime.Fragment,{children:[(0,_jsxRuntime.jsx)("button",_objectSpread(_objectSpread({ref:combinedButtonRef,className:(0,_classnames["default"])("breadcrumb-item",className),onClick:function onClick(){return setOpen(true)}},props),{},{children:". . ."})),(0,_jsxRuntime.jsx)(_Menu.Menu,_objectSpread(_objectSpread({},menuProps),{},{ref:refOutsideClick,anchor:buttonRef.current,className:"breadcrumb-menu",isOpen:open,children:items.map(function(item,index){return(0,_jsxRuntime.jsx)(BreadcrumbItem,_objectSpread(_objectSpread({className:"menu-item"},item),{},{isMenuItem:true}),index)})}))]})});BreadcrumbMenu.displayName="BreadcrumbMenu";var BreadcrumbActive=exports.BreadcrumbActive=_react["default"].forwardRef(function(_ref4,ref){var className=_ref4.className,item=_ref4.item,props=_objectWithoutProperties(_ref4,_excluded4);return(0,_jsxRuntime.jsx)("li",_objectSpread(_objectSpread({className:(0,_classnames["default"])("breadcrumb-item breadcrumb-active",className),ref:ref},props),{},{children:(0,_jsxRuntime.jsx)("span",{children:item.children})}))});BreadcrumbActive.displayName="BreadcrumbActive";