beta-parity-react
Version:
Beta Parity React Components
1 lines • 15.7 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.RecursiveCheckbox=exports.CheckboxGroup=exports.Checkbox=exports.CheckBoxWrapper=void 0;var _react=_interopRequireDefault(require("react"));var _classnames=_interopRequireDefault(require("classnames"));require("./variables.css");require("./index.css");var _useCombinedRefs=_interopRequireDefault(require("../hooks/useCombinedRefs"));var _jsxRuntime=require("react/jsx-runtime");var _excluded=["type","color","label","sublabel","checked","indeterminate","checkboxWrapperProps","onChange"],_excluded2=["tree","children","onChange","label","sublabel","value","checked","onParse"],_excluded3=["className","children"],_excluded4=["label","value","children","checked","indeterminate","sublabel"];function _interopRequireDefault(obj){return obj&&obj.__esModule?obj:{"default":obj}}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 _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 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 Checkbox=exports.Checkbox=_react["default"].forwardRef(function(_ref,ref){var _ref$type=_ref.type,type=_ref$type===void 0?"checkbox":_ref$type,_ref$color=_ref.color,color=_ref$color===void 0?"neutral":_ref$color,label=_ref.label,sublabel=_ref.sublabel,checked=_ref.checked,_ref$indeterminate=_ref.indeterminate,indeterminate=_ref$indeterminate===void 0?false:_ref$indeterminate,checkboxWrapperProps=_ref.checkboxWrapperProps,onChange=_ref.onChange,props=_objectWithoutProperties(_ref,_excluded);var checkboxRef=_react["default"].useRef(null);var combinedRef=(0,_useCombinedRefs["default"])(checkboxRef,ref);var _React$useState=_react["default"].useState(checked||false),_React$useState2=_slicedToArray(_React$useState,2),currentChecked=_React$useState2[0],setCurrentChecked=_React$useState2[1];var handleChange=function handleChange(e){if(props.disabled||props.readOnly)return;checked!==undefined?setCurrentChecked(checked||false):setCurrentChecked(e.target.checked);onChange===null||onChange===void 0||onChange(e)};_react["default"].useEffect(function(){if(combinedRef.current){combinedRef.current.indeterminate=indeterminate}},[indeterminate,combinedRef]);_react["default"].useEffect(function(){setCurrentChecked(checked||false)},[checked]);return(0,_jsxRuntime.jsxs)(CheckBoxWrapper,_objectSpread(_objectSpread({"aria-disabled":props.disabled},checkboxWrapperProps),{},{children:[(0,_jsxRuntime.jsxs)("div",{className:"checkbox-input",children:[(0,_jsxRuntime.jsx)(CheckboxIcon,{indeterminate:indeterminate,color:color,checked:currentChecked,disabled:props.disabled}),(0,_jsxRuntime.jsx)("input",_objectSpread({className:(0,_classnames["default"])("par-checkbox",colorMap[color]),type:"checkbox",ref:combinedRef,checked:currentChecked,onChange:handleChange},props))]}),label||sublabel?(0,_jsxRuntime.jsxs)("div",{className:"input-label-wrapper",children:[label&&(0,_jsxRuntime.jsx)("span",{className:"input-label",children:label}),sublabel&&(0,_jsxRuntime.jsx)("span",{className:"input-sublabel",children:sublabel})]}):(0,_jsxRuntime.jsx)(_jsxRuntime.Fragment,{})]}))});Checkbox.displayName="Checkbox";var CheckboxGroup=exports.CheckboxGroup=function CheckboxGroup(_ref2){var tree=_ref2.tree,children=_ref2.children,onChange=_ref2.onChange,label=_ref2.label,sublabel=_ref2.sublabel,value=_ref2.value,checked=_ref2.checked,onParse=_ref2.onParse,props=_objectWithoutProperties(_ref2,_excluded2);var rootData=_react["default"].useMemo(function(){var data=tree?_toConsumableArray(tree):[];var findNodeAndUpdate=function findNodeAndUpdate(nodes){nodes.forEach(function(n){if(n.checked){updateChildren(n,n.checked)}if(n.children){findNodeAndUpdate(n.children)}})};if(children&&data.length===0){data=transformChildrenToTree(children)}if(label&&value){data=[{value:value,label:label,sublabel:sublabel,checked:checked,children:data}]}findNodeAndUpdate(data);updateParents(data);return data},[tree,label,value,sublabel,children]);var _React$useState3=_react["default"].useState(rootData),_React$useState4=_slicedToArray(_React$useState3,2),treeData=_React$useState4[0],setTreeData=_React$useState4[1];function updateParents(nodes){var currentNode=arguments.length>1&&arguments[1]!==undefined?arguments[1]:null;nodes.forEach(function(node){if(node.children){updateParents(node.children,node)}if(currentNode!==null&¤tNode.children){var checkedChildren=currentNode.children.filter(function(child){return child.checked});var indeterminateChildren=currentNode.children.filter(function(child){return child.indeterminate});currentNode.checked=checkedChildren.length===currentNode.children.length;currentNode.indeterminate=checkedChildren.length>0&&checkedChildren.length<currentNode.children.length||indeterminateChildren.length>0}})}function updateChildren(node,isChecked){node.checked=isChecked;node.indeterminate=false;if(node.children){node.children.forEach(function(child){return updateChildren(child,isChecked)})}}var handleChange=function handleChange(clickedNode,e){var isChecked=e.target.checked;var newTreeData=treeData?_toConsumableArray(treeData):[];var findNodeAndUpdate=function findNodeAndUpdate(nodes){nodes.forEach(function(n){if(n.value===clickedNode.value){updateChildren(n,isChecked)}else if(n.children){findNodeAndUpdate(n.children)}})};findNodeAndUpdate(newTreeData);updateParents(newTreeData);setTreeData(newTreeData);onChange&&onChange({value:findCheckedValues(newTreeData),tree:newTreeData,getGroup:function getGroup(groupValue){return getGroupValue(newTreeData,groupValue)}})};_react["default"].useEffect(function(){setTreeData(_toConsumableArray(rootData))},[rootData]);_react["default"].useEffect(function(){if(onParse){onParse(_toConsumableArray(rootData))}},[]);return(0,_jsxRuntime.jsx)(RecursiveCheckbox,_objectSpread({tree:treeData||rootData||[],handleChange:handleChange},props))};var CheckBoxWrapper=exports.CheckBoxWrapper=_react["default"].forwardRef(function(_ref3,ref){var className=_ref3.className,children=_ref3.children,props=_objectWithoutProperties(_ref3,_excluded3);return(0,_jsxRuntime.jsx)("label",_objectSpread(_objectSpread({className:(0,_classnames["default"])("checkbox-wrapper",className),ref:ref},props),{},{children:children}))});CheckBoxWrapper.displayName="CheckBoxWrapper";var CheckboxIcon=function CheckboxIcon(_ref4){var indeterminate=_ref4.indeterminate,checked=_ref4.checked,color=_ref4.color,disabled=_ref4.disabled;var baseColor="var(--par-color-icon-checkbox-enabled)";var selectedColor="var(--par-color-icon-checkbox-".concat(color,"-selected)");var bgColor="var(--par-color-bg-checkbox-".concat(color,"-selected)");var indeterminateColor="var(--par-color-icon-checkbox-indeterminate)";var rectIndicator={x:1,y:1,width:14,height:14,rx:2,strokeWidth:2};var pathIndicator={strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,strokeDasharray:25,strokeDashoffset:25,opacity:0};var rectProps=_objectSpread(_objectSpread({},rectIndicator),{},{className:"checkbox-icon-rect",fill:"rgba(0, 0, 0, 0)",stroke:baseColor});var pathProps=_objectSpread(_objectSpread({},pathIndicator),{},{className:"checkbox-icon-path",d:"M4 8H12",stroke:baseColor});if(indeterminate){rectProps=_objectSpread(_objectSpread({},rectIndicator),{},{className:"checkbox-icon-rect indeterminate",fill:"rgba(0, 0, 0, 0)",stroke:indeterminateColor});pathProps=_objectSpread(_objectSpread({},pathIndicator),{},{className:"checkbox-icon-path indeterminate",d:"M4 8H12",stroke:indeterminateColor,strokeDashoffset:0,opacity:1})}if(checked){rectProps=_objectSpread(_objectSpread({},rectIndicator),{},{className:"checkbox-icon-rect checked",fill:bgColor,stroke:bgColor});pathProps=_objectSpread(_objectSpread({},pathIndicator),{},{className:"checkbox-icon-path checked",d:"M4 8L6.66353 11L12 5",stroke:selectedColor,strokeWidth:1.33,strokeDashoffset:0,opacity:1})}return(0,_jsxRuntime.jsxs)("svg",{className:"checkbox-icon",xmlns:"http://www.w3.org/2000/svg",width:16,height:16,viewBox:"0 0 16 16",fill:"none",style:{opacity:disabled?0.5:1},children:[(0,_jsxRuntime.jsx)("rect",_objectSpread({},rectProps)),(0,_jsxRuntime.jsx)("path",_objectSpread({},pathProps))]})};var RecursiveCheckbox=exports.RecursiveCheckbox=function RecursiveCheckbox(_ref5){var tree=_ref5.tree,handleChange=_ref5.handleChange,_ref5$indent=_ref5.indent,indent=_ref5$indent===void 0?false:_ref5$indent,_ref5$color=_ref5.color,color=_ref5$color===void 0?"neutral":_ref5$color;return(0,_jsxRuntime.jsx)("div",{className:(0,_classnames["default"])({"checkbox-group":tree.length>1}),children:tree.map(function(node){return(0,_jsxRuntime.jsxs)("div",{className:(0,_classnames["default"])("checkbox-group-item"),style:indent?{marginLeft:16+12}:{marginLeft:0},children:[node.label&&node.value?(0,_jsxRuntime.jsx)(Checkbox,_objectSpread({label:node.label,sublabel:node.sublabel,value:node.value||"",checked:node.checked||false,indeterminate:node.indeterminate||false,color:color,onChange:function onChange(e){return handleChange(node,e)}},node.checkboxProps)):null,node.children&&node.children.length>0?(0,_jsxRuntime.jsx)(RecursiveCheckbox,{tree:node.children,handleChange:handleChange,indent:true,color:color}):null]},node.value)})})};var transformChildrenToTree=function transformChildrenToTree(children){if(!children||!children.length){return[]}var tree=[];_react["default"].Children.forEach(children,function(child){var _child$props=child.props,label=_child$props.label,value=_child$props.value,children=_child$props.children,checked=_child$props.checked,indeterminate=_child$props.indeterminate,sublabel=_child$props.sublabel,rest=_objectWithoutProperties(_child$props,_excluded4);var node={label:label,value:value,checked:checked,indeterminate:indeterminate,sublabel:sublabel,checkboxProps:_objectSpread({},rest),children:children};if(_react["default"].Children.count(child.props.children)>0){node.children=transformChildrenToTree(child.props.children)}tree.push(node)});return tree};var findCheckedValues=function findCheckedValues(data){if(!data){return[]}var result=[];var traverse=function traverse(node){if(!node.children&&node.checked){result.push(node.value)}if(node.children){node.children.forEach(function(child){return traverse(child)})}};if(Array.isArray(data)){data.forEach(function(item){return traverse(item)})}if(!Array.isArray(data)){traverse(data)}return result};var getGroupValue=function getGroupValue(data,groupValue){var group=findGroup(data,groupValue);if(!group)return[];return findCheckedValues(group)};var findGroup=function findGroup(data,groupValue){var foundGroup=null;function traverse(node){if(node.value===groupValue){foundGroup=node;return}if(node.children){var _iterator=_createForOfIteratorHelper(node.children),_step;try{for(_iterator.s();!(_step=_iterator.n()).done;){var child=_step.value;traverse(child);if(foundGroup)return}}catch(err){_iterator.e(err)}finally{_iterator.f()}}}data.forEach(function(item){return traverse(item)});return foundGroup};