beta-parity-react
Version:
Beta Parity React Components
1 lines • 15.3 kB
JavaScript
"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.sizeInputMap=exports.ValueInputWrapper=exports.UnitSelector=exports.InputWrapper=exports.Input=exports.ErrorMessage=void 0;var _react=_interopRequireDefault(require("react"));var _classnames=_interopRequireDefault(require("classnames"));var _lucideReact=require("lucide-react");require("./index.css");require("./variables.css");var _FloatingLabel=require("../FloatingLabel");var _useCombinedRefs=_interopRequireDefault(require("../hooks/useCombinedRefs"));var _useOutsideClick=require("../hooks/useOutsideClick");var _jsxRuntime=require("react/jsx-runtime");var _excluded=["className","value","placeholder","type","disabled","readOnly","errorMessage","inputSize","theme","isClearable","ActionBtn","leftIcon","isError","wrapperProps","clearBtnProps","floatingLabel","onChange","onFocus","onBlur","onClear"],_excluded2=["className","onClick"],_excluded3=["className"],_excluded4=["className","children","leftElement","rightElement"],_excluded5=["children","className"],_excluded6=["children","className","theme"],_excluded7=["unit","theme","onUnitChange","unitValue","disabled"];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 sizeInputMap=exports.sizeInputMap={sm:"small",md:"medium"};var Input=exports.Input=_react["default"].forwardRef(function(_ref,ref){var className=_ref.className,value=_ref.value,_ref$placeholder=_ref.placeholder,placeholder=_ref$placeholder===void 0?"":_ref$placeholder,_ref$type=_ref.type,type=_ref$type===void 0?"text":_ref$type,_ref$disabled=_ref.disabled,disabled=_ref$disabled===void 0?false:_ref$disabled,_ref$readOnly=_ref.readOnly,readOnly=_ref$readOnly===void 0?false:_ref$readOnly,_ref$errorMessage=_ref.errorMessage,errorMessage=_ref$errorMessage===void 0?"":_ref$errorMessage,_ref$inputSize=_ref.inputSize,inputSize=_ref$inputSize===void 0?"sm":_ref$inputSize,_ref$theme=_ref.theme,theme=_ref$theme===void 0?"default":_ref$theme,_ref$isClearable=_ref.isClearable,isClearable=_ref$isClearable===void 0?false:_ref$isClearable,ActionBtn=_ref.ActionBtn,leftIcon=_ref.leftIcon,isError=_ref.isError,wrapperProps=_ref.wrapperProps,clearBtnProps=_ref.clearBtnProps,floatingLabel=_ref.floatingLabel,onChange=_ref.onChange,onFocus=_ref.onFocus,onBlur=_ref.onBlur,onClear=_ref.onClear,props=_objectWithoutProperties(_ref,_excluded);var _React$useState=_react["default"].useState(value||""),_React$useState2=_slicedToArray(_React$useState,2),currentValue=_React$useState2[0],setCurrentValue=_React$useState2[1];var _React$useState3=_react["default"].useState(false),_React$useState4=_slicedToArray(_React$useState3,2),isFocused=_React$useState4[0],setIsFocused=_React$useState4[1];var inputRef=_react["default"].useRef(null);var combinedRef=(0,_useCombinedRefs["default"])(inputRef,ref);var handleClear=function handleClear(){if(disabled||readOnly)return;if(combinedRef.current){setCurrentValue("");combinedRef.current.value="";var event=new Event("change",{bubbles:true});Object.defineProperty(event,"target",{value:combinedRef.current,writable:false});onChange&&onChange(event);combinedRef.current.focus()}onClear&&onClear()};var handleChange=function handleChange(e){setCurrentValue(e.target.value);onChange&&onChange(e)};var handleFocus=function handleFocus(e){setIsFocused(true);onFocus&&onFocus(e)};var handleBlur=function handleBlur(e){var _wrapperRef$current;var relatedTarget=e.relatedTarget;if(!relatedTarget||!((_wrapperRef$current=wrapperRef.current)!==null&&_wrapperRef$current!==void 0&&_wrapperRef$current.contains(relatedTarget))){setIsFocused(false);onBlur&&onBlur(e)}};var wrapperRef=(0,_useOutsideClick.useOutsideClick)(function(){if(floatingLabel&&isFocused){setIsFocused(false)}});_react["default"].useEffect(function(){setCurrentValue(value||"")},[value]);var addedClassname=isClearable&&ActionBtn?"input-actions":isClearable||ActionBtn?"input-action":"";var _ref2=clearBtnProps||{},clearBtnClassName=_ref2.className,clearBtnClick=_ref2.onClick,restClearBtnProps=_objectWithoutProperties(_ref2,_excluded2);var isHasRightInputAction=isClearable||ActionBtn;var isActiveRightInputAction=floatingLabel?(currentValue||isFocused)&&isHasRightInputAction:isHasRightInputAction;var isActiveClearButton=isClearable&¤tValue&&!readOnly&&!disabled;var isActiveFloatingLabel=readOnly||isFocused||!!currentValue;var RightInputActions=isActiveRightInputAction&&(0,_jsxRuntime.jsxs)(_jsxRuntime.Fragment,{children:[isActiveClearButton&&(0,_jsxRuntime.jsx)("button",_objectSpread(_objectSpread({type:"button",className:(0,_classnames["default"])("clear-button",clearBtnClassName),onClick:function onClick(e){handleClear();clearBtnClick&&clearBtnClick(e)},disabled:disabled||readOnly},restClearBtnProps),{},{children:(0,_jsxRuntime.jsx)(_lucideReact.X,{})})),ActionBtn?ActionBtn:null]});var _ref3=wrapperProps||{},wrapperClassName=_ref3.className,restWrapperProps=_objectWithoutProperties(_ref3,_excluded3);return(0,_jsxRuntime.jsxs)(InputWrapper,_objectSpread(_objectSpread({ref:floatingLabel?wrapperRef:undefined,className:(0,_classnames["default"])(addedClassname,wrapperClassName),rightElement:RightInputActions,leftElement:leftIcon&&(0,_jsxRuntime.jsx)("span",{className:"input-icon",children:leftIcon}),onFocus:handleFocus,onBlur:handleBlur},restWrapperProps),{},{children:[floatingLabel&&(!disabled?(0,_jsxRuntime.jsx)(_FloatingLabel.ContainedLabel,{isActive:isActiveFloatingLabel,children:floatingLabel}):(0,_jsxRuntime.jsx)(_FloatingLabel.ContainedLabel,{isActive:false})),(0,_jsxRuntime.jsx)("input",_objectSpread({type:type,placeholder:!disabled?placeholder:"",className:(0,_classnames["default"])("par-input",theme,_defineProperty({"error-state":isError},sizeInputMap[inputSize],inputSize),className),ref:combinedRef,value:value!==undefined&&!disabled?value:!disabled?currentValue:"",onChange:handleChange,disabled:disabled,readOnly:readOnly},props)),errorMessage&&isError&&(0,_jsxRuntime.jsx)(ErrorMessage,{children:errorMessage})]}))});Input.displayName="Input";var InputWrapper=exports.InputWrapper=_react["default"].forwardRef(function(_ref4,ref){var className=_ref4.className,children=_ref4.children,leftElement=_ref4.leftElement,rightElement=_ref4.rightElement,props=_objectWithoutProperties(_ref4,_excluded4);var DEFAULT_PADDING=16;var DEFAULT_PADDING_ICON=40;var leftElementRef=_react["default"].useRef(null);var rightElementRef=_react["default"].useRef(null);var _React$useState5=_react["default"].useState(leftElement?DEFAULT_PADDING_ICON:DEFAULT_PADDING),_React$useState6=_slicedToArray(_React$useState5,2),paddingLeft=_React$useState6[0],setPaddingLeft=_React$useState6[1];var _React$useState7=_react["default"].useState(rightElement?DEFAULT_PADDING_ICON:DEFAULT_PADDING),_React$useState8=_slicedToArray(_React$useState7,2),paddingRight=_React$useState8[0],setPaddingRight=_React$useState8[1];_react["default"].useLayoutEffect(function(){var resizeObserver=new ResizeObserver(function(){var _leftElementRef$curre,_rightElementRef$curr;var leftWidth=((_leftElementRef$curre=leftElementRef.current)===null||_leftElementRef$curre===void 0?void 0:_leftElementRef$curre.offsetWidth)||DEFAULT_PADDING;var rightWidth=((_rightElementRef$curr=rightElementRef.current)===null||_rightElementRef$curr===void 0?void 0:_rightElementRef$curr.offsetWidth)||DEFAULT_PADDING;setPaddingLeft(leftWidth);setPaddingRight(rightWidth)});if(leftElementRef.current){resizeObserver.observe(leftElementRef.current)}if(rightElementRef.current){resizeObserver.observe(rightElementRef.current)}return function(){resizeObserver.disconnect()}},[leftElement,rightElement,children]);var childrenWithPadding=_react["default"].Children.map(children,function(child){if(!_react["default"].isValidElement(child))return child;if(child.type==="input"||child.type==="select"){return _react["default"].cloneElement(child,{style:_objectSpread(_objectSpread(_objectSpread({},child.props.style||{}),leftElementRef.current&&{paddingLeft:paddingLeft}),rightElementRef.current&&{paddingRight:paddingRight})})}return child});return(0,_jsxRuntime.jsxs)("div",_objectSpread(_objectSpread({className:(0,_classnames["default"])("input-wrapper",className),ref:ref},props),{},{children:[leftElement&&(0,_jsxRuntime.jsx)("div",{className:"left-element-container",ref:leftElementRef,children:leftElement}),childrenWithPadding,rightElement&&(0,_jsxRuntime.jsx)("div",{className:"right-element-container",ref:rightElementRef,children:rightElement})]}))});InputWrapper.displayName="InputWrapper";var ErrorMessage=exports.ErrorMessage=_react["default"].forwardRef(function(_ref5,ref){var children=_ref5.children,className=_ref5.className,props=_objectWithoutProperties(_ref5,_excluded5);return(0,_jsxRuntime.jsx)("span",_objectSpread(_objectSpread({className:(0,_classnames["default"])("input-error-message",className)},props),{},{ref:ref,children:children}))});ErrorMessage.displayName="ErrorMessage";var ValueInputWrapper=exports.ValueInputWrapper=_react["default"].forwardRef(function(_ref6,ref){var children=_ref6.children,className=_ref6.className,_ref6$theme=_ref6.theme,theme=_ref6$theme===void 0?"default":_ref6$theme,props=_objectWithoutProperties(_ref6,_excluded6);return(0,_jsxRuntime.jsx)("div",_objectSpread(_objectSpread({className:(0,_classnames["default"])("value-input-wrapper",className,theme)},props),{},{ref:ref,children:children}))});ValueInputWrapper.displayName="ValueInputWrapper";var UnitSelector=exports.UnitSelector=function UnitSelector(_ref7){var unit=_ref7.unit,_ref7$theme=_ref7.theme,theme=_ref7$theme===void 0?"default":_ref7$theme,onUnitChange=_ref7.onUnitChange,unitValue=_ref7.unitValue,disabled=_ref7.disabled,props=_objectWithoutProperties(_ref7,_excluded7);var isSelectUnit=Array.isArray(unit);var initialValue=unitValue!==null&&unitValue!==void 0?unitValue:unit===null||unit===void 0?void 0:unit[0];var _React$useState9=_react["default"].useState(initialValue),_React$useState10=_slicedToArray(_React$useState9,2),selectedUnit=_React$useState10[0],setSelectedUnit=_React$useState10[1];var _React$useState11=_react["default"].useState(0),_React$useState12=_slicedToArray(_React$useState11,2),width=_React$useState12[0],setWidth=_React$useState12[1];var handleUnitChange=function handleUnitChange(e){if(disabled)return;setSelectedUnit(e.target.value);onUnitChange===null||onUnitChange===void 0||onUnitChange(e)};var calculateWidth=function calculateWidth(currentUnit){var _document;if(typeof document==="undefined")return;var termWidth=0;var tempSpan=document.createElement("span");tempSpan.style.visibility="hidden";tempSpan.style.position="absolute";tempSpan.style.whiteSpace="nowrap";tempSpan.textContent=currentUnit;(_document=document)===null||_document===void 0||(_document=_document.body)===null||_document===void 0||_document.appendChild(tempSpan);var textWidth=tempSpan.offsetWidth;termWidth=textWidth+24;document.body.removeChild(tempSpan);return termWidth};_react["default"].useEffect(function(){setSelectedUnit(unitValue)},[unitValue]);_react["default"].useLayoutEffect(function(){if(!selectedUnit)return;setWidth(calculateWidth(selectedUnit)||0)},[selectedUnit]);return!!unit?(0,_jsxRuntime.jsx)("span",{className:"input-unit ".concat(isSelectUnit?"selectable":""),children:isSelectUnit?(0,_jsxRuntime.jsxs)(_jsxRuntime.Fragment,{children:[(0,_jsxRuntime.jsx)("select",_objectSpread(_objectSpread({className:(0,_classnames["default"])("unit-selector",theme),value:selectedUnit,onChange:handleUnitChange,style:{width:width?"".concat(width,"px"):"auto"},disabled:disabled},props),{},{children:unit.map(function(unit){return(0,_jsxRuntime.jsx)("option",{value:unit,children:unit},unit)})})),(0,_jsxRuntime.jsx)("span",{className:"unit-selector-arrow input-icon",children:(0,_jsxRuntime.jsx)(_lucideReact.ChevronsUpDown,{})})]}):unit}):null};