beta-parity-react
Version:
Beta Parity React Components
1 lines • 9.75 kB
JavaScript
;"use client";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.TreeNavigation=void 0;var _react=_interopRequireWildcard(require("react"));var _classnames=_interopRequireDefault(require("classnames"));require("./index.css");require("./variables.css");var _lucideReact=require("lucide-react");var _Animation=require("../Animation");var _jsxRuntime=require("react/jsx-runtime");var _excluded=["className","color","items"];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 _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 _createForOfIteratorHelper(o,allowArrayLike){var it=typeof Symbol!=="undefined"&&o[Symbol.iterator]||o["@@iterator"];if(!it){if(Array.isArray(o)||(it=_unsupportedIterableToArray(o))||allowArrayLike&&o&&typeof o.length==="number"){if(it)o=it;var i=0;var F=function F(){};return{s:F,n:function n(){if(i>=o.length)return{done:true};return{done:false,value:o[i++]}},e:function e(_e){throw _e},f:F}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var normalCompletion=true,didErr=false,err;return{s:function s(){it=it.call(o)},n:function n(){var step=it.next();normalCompletion=step.done;return step},e:function e(_e2){didErr=true;err=_e2},f:function f(){try{if(!normalCompletion&&it["return"]!=null)it["return"]()}finally{if(didErr)throw err}}}}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 _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 TreeNavigation=exports.TreeNavigation=function TreeNavigation(_ref){var className=_ref.className,_ref$color=_ref.color,color=_ref$color===void 0?"neutral":_ref$color,items=_ref.items,props=_objectWithoutProperties(_ref,_excluded);var getInitialActiveAnchor=function getInitialActiveAnchor(items){var activeId=null;var findActiveItem=function findActiveItem(items){var _iterator=_createForOfIteratorHelper(items),_step;try{for(_iterator.s();!(_step=_iterator.n()).done;){var item=_step.value;if(item.defaultActive){activeId=item.id;return}if(item.children){findActiveItem(item.children)}}}catch(err){_iterator.e(err)}finally{_iterator.f()}};findActiveItem(items);return activeId};var getInitialExpandedItems=function getInitialExpandedItems(items){var expandedIds=new Set;var processItems=function processItems(items){items.forEach(function(item){if(item.defaultExpanded&&item.children){expandedIds.add(item.id)}if(item.children){processItems(item.children)}})};processItems(items);return expandedIds};var _useState=(0,_react.useState)(function(){return getInitialActiveAnchor(items)}),_useState2=_slicedToArray(_useState,2),activeAnchor=_useState2[0],setActiveAnchor=_useState2[1];var _useState3=(0,_react.useState)(function(){return getInitialExpandedItems(items)}),_useState4=_slicedToArray(_useState3,2),expandedItems=_useState4[0],setExpandedItems=_useState4[1];var handleNavItemClick=function handleNavItemClick(id){setActiveAnchor(id);var targetElement=document.getElementById(id);if(targetElement){var topSpace=targetElement.getBoundingClientRect().top+window.scrollY;window.scrollTo({top:topSpace,behavior:"smooth"})}};var toggleExpand=function toggleExpand(id,e){e.stopPropagation();setExpandedItems(function(prev){var newSet=new Set(prev);if(newSet.has(id)){newSet["delete"](id)}else{newSet.add(id)}return newSet})};var renderItems=function renderItems(items,isSub){return items.map(function(item){var isActive=activeAnchor===item.id;var isExpanded=expandedItems.has(item.id);var hasChildren=!!item.children;return(0,_jsxRuntime.jsxs)("li",{className:(0,_classnames["default"])("tree-navigation-item",{"tree-navigation-item-active":isActive,"tree-navigation-subitem":isSub,expanded:isExpanded}),role:"treeitem","aria-expanded":isExpanded,"aria-selected":isActive,children:[(0,_jsxRuntime.jsxs)("div",{className:(0,_classnames["default"])("tree-navigation-item-content",{active:isActive}),role:"presentation","aria-hidden":!isActive,children:[item.href?(0,_jsxRuntime.jsx)("a",{href:item.href,className:(0,_classnames["default"])("tree-navigation-item-text"),"aria-label":item.title,onClick:function onClick(e){var _item$href;if((_item$href=item.href)!==null&&_item$href!==void 0&&_item$href.startsWith("#")){e.preventDefault();handleNavItemClick(item.id)}setActiveAnchor(item.id)},children:(0,_jsxRuntime.jsx)("span",{children:item.title})}):(0,_jsxRuntime.jsx)("button",{className:(0,_classnames["default"])("tree-navigation-item-text"),"aria-label":item.title,onClick:function onClick(){return handleNavItemClick(item.id)},children:(0,_jsxRuntime.jsx)("span",{children:item.title})}),(0,_jsxRuntime.jsx)("button",_objectSpread(_objectSpread({className:"tree-navigation-icon-button",tabIndex:-1},hasChildren&&{tabIndex:0,onClick:function onClick(e){toggleExpand(item.id,e)}}),{},{children:(0,_jsxRuntime.jsx)("span",{className:(0,_classnames["default"])("tree-navigation-icon",{"icon-expanded":hasChildren&&isExpanded,"icon-collapsed":hasChildren&&!isExpanded,"icon-minus":!hasChildren}),children:hasChildren?(0,_jsxRuntime.jsx)(_lucideReact.ChevronRight,{}):(0,_jsxRuntime.jsx)(_lucideReact.Minus,{})})}))]}),hasChildren&&(0,_jsxRuntime.jsx)(_Animation.Animation,{"in":isExpanded,easing:"ease-in-out",timeout:150,duration:150,unmountOnExit:true,children:(0,_jsxRuntime.jsx)("ul",{className:"tree-navigation-sublist",children:renderItems(item.children||[],true)})})]},item.id)})};return(0,_jsxRuntime.jsx)("nav",_objectSpread(_objectSpread({className:(0,_classnames["default"])("tree-navigation",className,color),"aria-label":"Tree Navigation"},props),{},{children:(0,_jsxRuntime.jsx)("ul",{className:"tree-navigation-list",children:renderItems(items||[])})}))};