beta-parity-react
Version:
Beta Parity React Components
1 lines • 12.2 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.AccordionItemTrigger=exports.AccordionItemContent=exports.AccordionItem=exports.Accordion=void 0;var _react=_interopRequireDefault(require("react"));var _classnames=_interopRequireDefault(require("classnames"));var _lucideReact=require("lucide-react");require("./index.css");require("./variables.css");var _useDidMountEffect=_interopRequireDefault(require("../hooks/useDidMountEffect"));var _jsxRuntime=require("react/jsx-runtime");var _excluded=["className","children","type","kind","defaultValue","value","iconSide","icon","items","onChange"],_excluded2=["className","children","disabled","currentValue","value","handleChange","type"],_excluded3=["className","children","isExpanded","disabled","handleChange","icon","iconSide"],_excluded4=["className","children","isExpanded"];function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{"default":obj}}function _objectDestructuringEmpty(obj){if(obj==null)throw new TypeError("Cannot destructure "+obj)}function _extends(){_extends=Object.assign?Object.assign.bind():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};return _extends.apply(this,arguments)}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 _toConsumableArray(arr){return _arrayWithoutHoles(arr)||_iterableToArray(arr)||_unsupportedIterableToArray(arr)||_nonIterableSpread()}function _nonIterableSpread(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _iterableToArray(iter){if(typeof Symbol!=="undefined"&&iter[Symbol.iterator]!=null||iter["@@iterator"]!=null)return Array.from(iter)}function _arrayWithoutHoles(arr){if(Array.isArray(arr))return _arrayLikeToArray(arr)}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 Accordion=exports.Accordion=_react["default"].forwardRef(function(_ref,ref){var className=_ref.className,children=_ref.children,_ref$type=_ref.type,type=_ref$type===void 0?"single":_ref$type,_ref$kind=_ref.kind,kind=_ref$kind===void 0?"contained":_ref$kind,defaultValue=_ref.defaultValue,value=_ref.value,iconSide=_ref.iconSide,icon=_ref.icon,items=_ref.items,onChange=_ref.onChange,props=_objectWithoutProperties(_ref,_excluded);var initValue=value||defaultValue||"";if(type==="multiple"&&!Array.isArray(initValue)){initValue=[]}var _React$useState=_react["default"].useState(initValue),_React$useState2=_slicedToArray(_React$useState,2),currentValue=_React$useState2[0],setCurrentValue=_React$useState2[1];var handleChange=function handleChange(ItemValue){if(value||Array.isArray(value))return;var newValue="";if(type==="single"){newValue=currentValue===ItemValue?"":ItemValue}else if(type==="multiple"){newValue=currentValue.includes(ItemValue)&&Array.isArray(currentValue)?currentValue.filter(function(item){return item!==ItemValue}):[].concat(_toConsumableArray(currentValue),[ItemValue])}setCurrentValue(newValue);if(onChange)onChange(newValue)};var clonedChildren=cloneChildren(children,{type:type,currentValue:currentValue,handleChange:handleChange,iconSide:iconSide,kind:kind,icon:icon});(0,_useDidMountEffect["default"])(function(){var isArrayValue=Array.isArray(value);if(type==="single"&&!isArrayValue){setCurrentValue(value);if(onChange)onChange(value)}else if(type==="multiple"&&isArrayValue){setCurrentValue(value);if(onChange)onChange(value)}},[value]);if(items&&items.length){return(0,_jsxRuntime.jsx)(Accordion,_objectSpread(_objectSpread({className:className,ref:ref,value:value,icon:icon,iconSide:iconSide,type:type,kind:kind,defaultValue:defaultValue,onChange:onChange},props),{},{children:items.map(function(item,index){return(0,_jsxRuntime.jsxs)(AccordionItem,_objectSpread(_objectSpread({value:item.value},item.itemProps),{},{children:[(0,_jsxRuntime.jsx)(AccordionItemTrigger,{children:item.title}),(0,_jsxRuntime.jsx)(AccordionItemContent,{children:item.content})]}),item.value||index)})}))}return(0,_jsxRuntime.jsx)("div",_objectSpread(_objectSpread({className:(0,_classnames["default"])("accordion",className,kind),ref:ref},props),{},{children:clonedChildren}))});Accordion.displayName="Accordion";var AccordionItem=exports.AccordionItem=_react["default"].forwardRef(function(_ref2,ref){var className=_ref2.className,children=_ref2.children,_ref2$disabled=_ref2.disabled,disabled=_ref2$disabled===void 0?false:_ref2$disabled,currentValue=_ref2.currentValue,value=_ref2.value,_handleChange=_ref2.handleChange,_ref2$type=_ref2.type,type=_ref2$type===void 0?"single":_ref2$type,props=_objectWithoutProperties(_ref2,_excluded2);var isExpanded=type==="multiple"?currentValue===null||currentValue===void 0?void 0:currentValue.includes(value):value===currentValue;var cloneChildren=_react["default"].Children.map(children,function(child){if(_react["default"].isValidElement(child)){var rest=_extends({},(_objectDestructuringEmpty(child.props),child.props));var _props;if(child.type===AccordionItemTrigger){_props=_objectSpread(_objectSpread({},rest),{},{isExpanded:isExpanded,disabled:disabled,handleChange:function handleChange(){return!disabled&&_handleChange&&_handleChange(value)}})}if(child.type===AccordionItemContent){_props=_objectSpread(_objectSpread({},rest),{},{isExpanded:isExpanded})}return _react["default"].cloneElement(child,_props)}});return(0,_jsxRuntime.jsx)("div",_objectSpread(_objectSpread({className:(0,_classnames["default"])("accordion-item",className,{active:isExpanded}),"aria-disabled":disabled,ref:ref},props),{},{children:cloneChildren}))});AccordionItem.displayName="AccordionItem";var AccordionItemTrigger=exports.AccordionItemTrigger=_react["default"].forwardRef(function(_ref3,ref){var className=_ref3.className,children=_ref3.children,isExpanded=_ref3.isExpanded,disabled=_ref3.disabled,handleChange=_ref3.handleChange,_ref3$icon=_ref3.icon,icon=_ref3$icon===void 0?"chevron":_ref3$icon,_ref3$iconSide=_ref3.iconSide,iconSide=_ref3$iconSide===void 0?"right":_ref3$iconSide,props=_objectWithoutProperties(_ref3,_excluded3);var iconElement=!icon||icon==="chevron"?(0,_jsxRuntime.jsx)(_lucideReact.ChevronDown,{size:16}):isExpanded?(0,_jsxRuntime.jsx)(_lucideReact.Minus,{size:16}):(0,_jsxRuntime.jsx)(_lucideReact.Plus,{size:16});var iconWrapperClassName=(0,_classnames["default"])("accordion-item-trigger-icon",{"chevron-trigger":icon==="chevron"||!icon,"cross-trigger ":icon==="cross"});return(0,_jsxRuntime.jsxs)("button",_objectSpread(_objectSpread({className:(0,_classnames["default"])("accordion-item-trigger",className,{"icon-left":iconSide==="left","icon-right":iconSide==="right"}),"aria-expanded":isExpanded,disabled:disabled,onClick:function onClick(){return handleChange===null||handleChange===void 0?void 0:handleChange()},ref:ref},props),{},{children:[iconSide==="left"&&(0,_jsxRuntime.jsx)("span",{className:iconWrapperClassName,children:iconElement}),isPlainText(children)?(0,_jsxRuntime.jsx)("span",{className:"accordion-item-trigger-text",children:children}):children,iconSide==="right"&&(0,_jsxRuntime.jsx)("span",{className:iconWrapperClassName,children:iconElement})]}))});AccordionItemTrigger.displayName="AccordionItemTrigger";var AccordionItemContent=exports.AccordionItemContent=_react["default"].forwardRef(function(_ref4,ref){var className=_ref4.className,children=_ref4.children,isExpanded=_ref4.isExpanded,props=_objectWithoutProperties(_ref4,_excluded4);return(0,_jsxRuntime.jsx)("div",_objectSpread(_objectSpread({className:(0,_classnames["default"])("accordion-item-content",className),ref:ref},props),{},{children:children}))});AccordionItemContent.displayName="AccordionItemContent";var cloneChildren=function cloneChildren(children,extraProps){return _react["default"].Children.map(children,function(child){if(!_react["default"].isValidElement(child)||child.type===Accordion){return child}if(child.type===AccordionItem){return _react["default"].cloneElement(child,{currentValue:extraProps.currentValue?extraProps.currentValue:"",handleChange:extraProps.handleChange?extraProps.handleChange:function(){},type:extraProps.type?extraProps.type:"single",children:cloneChildren(child.props.children,extraProps)})}if(child.type===AccordionItemTrigger){return _react["default"].cloneElement(child,{handleChange:extraProps.handleChange?extraProps.handleChange:function(){},icon:extraProps.icon?extraProps.icon:null,iconSide:extraProps.iconSide?extraProps.iconSide:"right"})}if(child.type===AccordionItemContent){return _react["default"].cloneElement(child,{})}})};var isPlainText=function isPlainText(node){if(typeof node==="string"||typeof node==="number")return true;if(Array.isArray(node))return node.every(isPlainText);return false};