UNPKG

beta-parity-react

Version:

Beta Parity React Components

1 lines 14.4 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.Tabs=exports.TabContent=exports.TabButton=void 0;var _react=_interopRequireWildcard(require("react"));var _classnames=_interopRequireDefault(require("classnames"));var _lucideReact=require("lucide-react");require("./index.css");require("./variables.css");var _Button=require("../Button");var _useDebounce=_interopRequireDefault(require("../hooks/useDebounce"));var _jsxRuntime=require("react/jsx-runtime");var _excluded=["className","children","data","color","theme","size","side","flipped","indicatorSide","scrollValue","navProps","bodyProps"],_excluded2=["value","children","disabled","active"],_excluded3=["value","children"],_excluded4=["className","children","animationDirection"],_excluded5=["className","children"];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 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 sizeMap={sm:"small",md:"medium"};var colorMap={neutral:"neutral",accent:"accent"};var Tabs=exports.Tabs=_react["default"].forwardRef(function(_ref,ref){var className=_ref.className,children=_ref.children,_ref$data=_ref.data,data=_ref$data===void 0?[]:_ref$data,_ref$color=_ref.color,color=_ref$color===void 0?"neutral":_ref$color,_ref$theme=_ref.theme,theme=_ref$theme===void 0?"default":_ref$theme,_ref$size=_ref.size,size=_ref$size===void 0?"md":_ref$size,_ref$side=_ref.side,side=_ref$side===void 0?"left":_ref$side,_ref$flipped=_ref.flipped,flipped=_ref$flipped===void 0?false:_ref$flipped,_ref$indicatorSide=_ref.indicatorSide,indicatorSide=_ref$indicatorSide===void 0?"same":_ref$indicatorSide,_ref$scrollValue=_ref.scrollValue,scrollValue=_ref$scrollValue===void 0?{value:4,duration:1}:_ref$scrollValue,navProps=_ref.navProps,bodyProps=_ref.bodyProps,props=_objectWithoutProperties(_ref,_excluded);var _React$useState=_react["default"].useState(data.findIndex(function(item){return item.active})>0?data.findIndex(function(item){return item.active}):0),_React$useState2=_slicedToArray(_React$useState,2),activeTabIndex=_React$useState2[0],setActiveTabIndex=_React$useState2[1];var preIndex=_react["default"].useRef(0);var direction=["left","right"].includes(side)?"vertical":"horizontal";var handleClick=function handleClick(id){setActiveTabIndex(function(pre){preIndex.current=pre;return id})};if(children&&_react["default"].Children.count(children)>0){_react["default"].Children.forEach(children,function(child){if(_react["default"].isValidElement(child)){if(child.type===TabButton){var _child$props=child.props,value=_child$props.value,_children=_child$props.children,disabled=_child$props.disabled,active=_child$props.active,rest=_objectWithoutProperties(_child$props,_excluded2);var index=data.findIndex(function(item){return item.value===value});if(index>-1){data[index].title=_children;data[index].disabled=disabled;data[index].active=active;data[index].buttonProps=rest}else{data.push({value:value,title:_children,disabled:disabled,active:active,buttonProps:rest,content:"",contentProps:{}})}}if(child.type===TabContent){var _child$props2=child.props,_value=_child$props2.value,_children2=_child$props2.children,_rest=_objectWithoutProperties(_child$props2,_excluded3);var _index=data.findIndex(function(item){return item.value===_value});if(_index>-1){data[_index].content=_children2;data[_index].contentProps=_rest}else{data.push({value:_value,title:"",disabled:false,active:false,buttonProps:{},content:_children2||"",contentProps:_rest||{}})}}}})}var containerRef=_react["default"].useRef(null);var _React$useState3=_react["default"].useState(false),_React$useState4=_slicedToArray(_React$useState3,2),isScroll=_React$useState4[0],setIsScroll=_React$useState4[1];var _React$useState5=_react["default"].useState({left:false,right:false}),_React$useState6=_slicedToArray(_React$useState5,2),disableBtn=_React$useState6[0],setDisableBtn=_React$useState6[1];var checkOverflow=function checkOverflow(){if(containerRef.current){var _containerRef$current=containerRef.current,scrollWidth=_containerRef$current.scrollWidth,clientWidth=_containerRef$current.clientWidth;setIsScroll(scrollWidth>clientWidth)}};var intervalRef=_react["default"].useRef(null);var timeoutRef=_react["default"].useRef(null);var handleDisableBtn=function handleDisableBtn(container){if(container){var scrollWidth=container.scrollWidth,clientWidth=container.clientWidth,scrollLeft=container.scrollLeft;setDisableBtn({left:scrollLeft===0,right:scrollLeft+clientWidth+1>=scrollWidth})}};var handleScroll=function handleScroll(type,isInterval){if(containerRef.current&&!isInterval){containerRef.current.scrollBy({left:type==="+"?200:-200,behavior:"smooth"})}if(isInterval){var _containerRef$current2;(_containerRef$current2=containerRef.current)===null||_containerRef$current2===void 0||_containerRef$current2.scrollBy({left:type==="+"?scrollValue.value:-scrollValue.value,behavior:"instant"})}};var handleBtnWhenScroll=(0,_useDebounce["default"])(function(){return handleDisableBtn(containerRef.current)},150);var startInterval=function startInterval(type){handleScroll(type);timeoutRef.current=setTimeout(function(){return intervalRef.current=setInterval(function(){return handleScroll(type,true)},scrollValue.duration)},250)};var stopInterval=function stopInterval(){if(intervalRef.current)clearInterval(intervalRef.current);if(timeoutRef.current)clearTimeout(timeoutRef.current)};_react["default"].useEffect(function(){checkOverflow();var handleResize=function handleResize(){checkOverflow();handleDisableBtn(containerRef.current)};var resizeObserver=new ResizeObserver(function(){return handleResize()});if(containerRef.current){resizeObserver.observe(containerRef.current);containerRef.current.addEventListener("scroll",handleBtnWhenScroll)}return function(){var _containerRef$current3;resizeObserver.disconnect();(_containerRef$current3=containerRef.current)===null||_containerRef$current3===void 0||_containerRef$current3.removeEventListener("scroll",handleBtnWhenScroll)}},[]);var generateScrollBtnProps=function generateScrollBtnProps(type){return{iconOnly:true,className:type==="+"?"scroll-right":"scroll-left",onKeyDown:function onKeyDown(e){if(e.key==="Enter"||e.key===" "){handleScroll(type)}},onMouseDown:function onMouseDown(){return startInterval(type)},onMouseUp:function onMouseUp(){return stopInterval()},onMouseLeave:function onMouseLeave(){return stopInterval()},color:"neutral",kind:"ghost",size:"sm",disabled:type==="+"?disableBtn.right:disableBtn.left}};return(0,_jsxRuntime.jsxs)("div",_objectSpread(_objectSpread({className:(0,_classnames["default"])("tabs",className,theme,direction,side,colorMap[color],sizeMap[size]),ref:ref},props),{},{children:[(0,_jsxRuntime.jsxs)("div",{className:(0,_classnames["default"])("tabs-nav-wrapper",{flipped:flipped},indicatorSide),children:[(0,_jsxRuntime.jsx)("div",_objectSpread(_objectSpread({className:(0,_classnames["default"])("tabs-nav")},navProps),{},{ref:containerRef,children:data.map(function(item,index){var isActive=activeTabIndex===index;var otherAnimation=generateOtherAnimation({direction:direction,activeTabIndex:activeTabIndex,index:index});var activeAnimation=generateActiveAnimation({direction:direction,activeTabIndex:activeTabIndex,preIndex:preIndex});return(0,_react.createElement)(TabButton,_objectSpread(_objectSpread({},item.buttonProps),{},{key:item.value,value:item.value,animationDirection:isActive?activeAnimation:otherAnimation,onClick:function onClick(){return handleClick(index)},className:(0,_classnames["default"])(isActive?"active":""),disabled:item.disabled}),item.title)})})),isScroll&&direction==="horizontal"&&(0,_jsxRuntime.jsxs)("div",{className:"tabs-nav-scroll-actions",children:[(0,_jsxRuntime.jsx)(_Button.Button,_objectSpread(_objectSpread({},generateScrollBtnProps("-")),{},{children:(0,_jsxRuntime.jsx)(_lucideReact.ChevronLeft,{className:"arrow-right"})})),(0,_jsxRuntime.jsx)(_Button.Button,_objectSpread(_objectSpread({},generateScrollBtnProps("+")),{},{children:(0,_jsxRuntime.jsx)(_lucideReact.ChevronRight,{className:"arrow-right"})}))]})]}),(0,_jsxRuntime.jsx)("div",_objectSpread(_objectSpread({className:"tabs-body"},bodyProps),{},{children:data.map(function(item,index){var isActive=activeTabIndex===index;return isActive&&(0,_react.createElement)(TabContent,_objectSpread(_objectSpread({},item.contentProps),{},{key:item.value,value:item.value}),item.content)})}))]}))});Tabs.displayName="Tabs";var TabButton=exports.TabButton=_react["default"].forwardRef(function(_ref2,ref){var className=_ref2.className,children=_ref2.children,animationDirection=_ref2.animationDirection,props=_objectWithoutProperties(_ref2,_excluded4);return(0,_jsxRuntime.jsx)("button",_objectSpread(_objectSpread({className:(0,_classnames["default"])("tab-button",className,animationDirection),type:"button",ref:ref},props),{},{children:children}))});TabButton.displayName="TabButton";var TabContent=exports.TabContent=_react["default"].forwardRef(function(_ref3,ref){var className=_ref3.className,children=_ref3.children,props=_objectWithoutProperties(_ref3,_excluded5);return(0,_jsxRuntime.jsx)("div",_objectSpread(_objectSpread({className:(0,_classnames["default"])("tab-content",className),ref:ref},props),{},{children:children}))});TabContent.displayName="TabContent";var animationMap={horizontal:{larger:"from-left",smaller:"from-right"},vertical:{larger:"from-top",smaller:"from-bottom"}};var generateOtherAnimation=function generateOtherAnimation(_ref4){var direction=_ref4.direction,activeTabIndex=_ref4.activeTabIndex,index=_ref4.index;var animationDirection=activeTabIndex<index?animationMap[direction].larger:animationMap[direction].smaller;animationDirection=activeTabIndex>index?animationMap[direction].smaller:animationMap[direction].larger;return animationDirection};var generateActiveAnimation=function generateActiveAnimation(_ref5){var direction=_ref5.direction,activeTabIndex=_ref5.activeTabIndex,preIndex=_ref5.preIndex;var currentActiveAnimation=activeTabIndex>preIndex.current?animationMap[direction].larger:animationMap[direction].smaller;currentActiveAnimation=activeTabIndex<preIndex.current?animationMap[direction].smaller:animationMap[direction].larger;return currentActiveAnimation};