beta-parity-react
Version:
Beta Parity React Components
1 lines • 8.5 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.Chip=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 _useKeyboard=_interopRequireDefault(require("../hooks/useKeyboard"));var _jsxRuntime=require("react/jsx-runtime");var _excluded=["className","children","type","label","icon","kind","size","color","value","checked","defaultChecked","isActive","disabled","onChange","onRemove","onClick"];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 colorMap={neutral:"neutral",accent:"accent"};var sizeMap={sm:"small",md:"medium",lg:"large"};var kindMap={glass:"glass",outlined:"outlined"};var Chip=exports.Chip=_react["default"].forwardRef(function(props,ref){var className=props.className,children=props.children,_props$type=props.type,type=_props$type===void 0?"toggle":_props$type,label=props.label,icon=props.icon,_props$kind=props.kind,kind=_props$kind===void 0?"outlined":_props$kind,_props$size=props.size,size=_props$size===void 0?"md":_props$size,_props$color=props.color,color=_props$color===void 0?"neutral":_props$color,value=props.value,checked=props.checked,defaultChecked=props.defaultChecked,isActive=props.isActive,_props$disabled=props.disabled,disabled=_props$disabled===void 0?false:_props$disabled,onChange=props.onChange,onRemove=props.onRemove,onClick=props.onClick,rest=_objectWithoutProperties(props,_excluded);var kindChip=kindMap[kind];var sizeChip=sizeMap[size];var colorChip=colorMap[color];var defaultActive=type==="toggle"?!!checked:!!isActive;var _React$useState=_react["default"].useState(defaultActive||defaultChecked),_React$useState2=_slicedToArray(_React$useState,2),active=_React$useState2[0],setActive=_React$useState2[1];var handleToggleClick=function handleToggleClick(e){if(checked==undefined){setActive(!active)}onChange&&onChange({value:value||"",checked:!active});onClick&&onClick(e)};var handleDropdownClick=function handleDropdownClick(e){if(isActive==undefined){setActive(!active)}onChange&&onChange({value:value||"",active:!active});onClick&&onClick(e)};var clickHandlers={toggle:handleToggleClick,dropdown:handleDropdownClick};var ToggleKeyupHandler=(0,_useKeyboard["default"])("Enter",handleToggleClick);var DropdownKeyupHandler=(0,_useKeyboard["default"])("Enter",handleDropdownClick);var keyupHandlers={toggle:ToggleKeyupHandler,dropdown:DropdownKeyupHandler};var InnerChipContent=(0,_jsxRuntime.jsxs)(_jsxRuntime.Fragment,{children:[icon?(0,_jsxRuntime.jsx)("span",{className:"chip-icon",children:icon}):null,(0,_jsxRuntime.jsx)("span",{className:"chip-label",children:label||children})]});var eventHandlers={onClick:function onClick(e){if(disabled)return;var handler=clickHandlers[type]||clickHandlers.toggle;handler(e)},onKeyUp:function onKeyUp(e){if(disabled)return;var handler=keyupHandlers[type]||keyupHandlers.toggle;handler(e)}};var accessibilityProps={"aria-disabled":disabled,"aria-label":label.toLowerCase(),"aria-checked":type==="toggle"?active:undefined,"aria-selected":type==="dropdown"?!!value:undefined,role:type,tabIndex:disabled?-1:0};(0,_useDidMountEffect["default"])(function(){if(checked!==undefined&&type==="toggle"){setActive(checked)}if(isActive!==undefined&&type==="dropdown"){setActive(isActive)}},[checked,isActive]);switch(type){case"toggle":var toggleClassname=(0,_classnames["default"])("chip",className,kindChip,sizeChip,active?colorChip:"neutral");return(0,_jsxRuntime.jsxs)("span",_objectSpread(_objectSpread(_objectSpread(_objectSpread({className:toggleClassname,ref:ref},eventHandlers),accessibilityProps),rest),{},{children:[InnerChipContent,(0,_jsxRuntime.jsx)("span",{className:"check-icon ".concat(active?"active":""),children:(0,_jsxRuntime.jsx)(_lucideReact.Check,{})})]}));case"dropdown":var dropdownClassname=(0,_classnames["default"])("chip",className,kindChip,sizeChip,!!value?colorChip:"neutral");return(0,_jsxRuntime.jsxs)("span",_objectSpread(_objectSpread(_objectSpread(_objectSpread({className:dropdownClassname,ref:ref},eventHandlers),accessibilityProps),rest),{},{children:[!!value&&!icon?(0,_jsxRuntime.jsx)("span",{className:"chip-icon",children:(0,_jsxRuntime.jsx)(_lucideReact.Check,{})}):null,InnerChipContent,active?(0,_jsxRuntime.jsx)("span",{className:"chip-icon",children:(0,_jsxRuntime.jsx)(_lucideReact.ChevronUp,{})}):(0,_jsxRuntime.jsx)("span",{className:"chip-icon",children:(0,_jsxRuntime.jsx)(_lucideReact.ChevronDown,{})})]}));default:var btnClassName=(0,_classnames["default"])("chip",className,kindChip,sizeChip,_defineProperty({},colorChip,type==="button"));return(0,_jsxRuntime.jsx)("span",_objectSpread(_objectSpread(_objectSpread(_objectSpread({className:btnClassName,ref:ref},eventHandlers),accessibilityProps),rest),{},{children:InnerChipContent}))}});Chip.displayName="Chip";