UNPKG

beta-parity-react

Version:

Beta Parity React Components

1 lines 12.7 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.NumberInput=void 0;var _react=_interopRequireDefault(require("react"));var _classnames=_interopRequireDefault(require("classnames"));var _reactNumberFormat=require("react-number-format");var _lucideReact=require("lucide-react");require("./index.css");var _BaseInput=require("../BaseInput");var _jsxRuntime=require("react/jsx-runtime");var _excluded=["className","value","defaultValue","unit","selectedUnit","min","max","stepControl","stepper","allowInput","type","isClearable","ActionBtn","onUnitChange","onClear","onValueChange","onChange"];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 NumberInput=exports.NumberInput=_react["default"].forwardRef(function(_ref,ref){var _ref2,_inputProps$wrapperPr;var className=_ref.className,value=_ref.value,defaultValue=_ref.defaultValue,unit=_ref.unit,selectedUnit=_ref.selectedUnit,min=_ref.min,max=_ref.max,_ref$stepControl=_ref.stepControl,stepControl=_ref$stepControl===void 0?1:_ref$stepControl,stepper=_ref.stepper,_ref$allowInput=_ref.allowInput,allowInput=_ref$allowInput===void 0?true:_ref$allowInput,type=_ref.type,isClearable=_ref.isClearable,ActionBtn=_ref.ActionBtn,onUnitChange=_ref.onUnitChange,onClear=_ref.onClear,onValueChange=_ref.onValueChange,onChange=_ref.onChange,props=_objectWithoutProperties(_ref,_excluded);var isControlled=value!==undefined;var isClearableNumberInput=!!stepper?false:isClearable;var _React$useState=_react["default"].useState((_ref2=value!==null&&value!==void 0?value:defaultValue)!==null&&_ref2!==void 0?_ref2:""),_React$useState2=_slicedToArray(_React$useState,2),currentValue=_React$useState2[0],setCurrentValue=_React$useState2[1];var handleChange=function handleChange(values,event){var newValue=values.floatValue;if(currentValue===newValue)return;if(!isControlled)setCurrentValue(newValue);onValueChange===null||onValueChange===void 0||onValueChange(_objectSpread({floatValue:newValue!==null&&newValue!==void 0?newValue:""},values),{event:event});onChange===null||onChange===void 0||onChange({target:{value:newValue!==null&&newValue!==void 0?newValue:""}})};var handleClear=function handleClear(){onClear===null||onClear===void 0||onClear()};var handleUnitChange=function handleUnitChange(e){onUnitChange===null||onUnitChange===void 0||onUnitChange(e.target.value)};var unitElement=(0,_jsxRuntime.jsx)(_BaseInput.UnitSelector,{unit:unit,onUnitChange:handleUnitChange,unitValue:selectedUnit,disabled:props.disabled,theme:props.theme});var inputProps=_objectSpread(_objectSpread({},props),{},{value:currentValue,onClear:handleClear});var stepperProps={value:isNaN(currentValue)||currentValue===undefined?0:+currentValue,min:min,max:max,handleValue:handleChange,stepControl:stepControl,disabled:props.disabled||props.readOnly,formatProps:{thousandSeparator:props.thousandSeparator,decimalSeparator:props.decimalSeparator,allowedDecimalSeparators:props.allowedDecimalSeparators,thousandsGroupStyle:props.thousandsGroupStyle,decimalScale:props.decimalScale,fixedDecimalScale:props.fixedDecimalScale,allowNegative:props.allowNegative,allowLeadingZeros:props.allowLeadingZeros,suffix:props.suffix,prefix:props.prefix}};var renderLeftElement=function renderLeftElement(originalElement){if(stepper==="separate"){return(0,_jsxRuntime.jsxs)(_jsxRuntime.Fragment,{children:[originalElement,(0,_jsxRuntime.jsx)(NumberButtonStepper,_objectSpread(_objectSpread({},stepperProps),{},{minusOnly:true}))]})}return inputProps.leftIcon?(0,_jsxRuntime.jsx)("span",{className:"input-icon",children:inputProps.leftIcon}):undefined};var renderRightElement=function renderRightElement(originalElement){switch(stepper){case"auto":return(0,_jsxRuntime.jsxs)(_jsxRuntime.Fragment,{children:[originalElement,(0,_jsxRuntime.jsx)(NumberButtonStepper,_objectSpread({},stepperProps))]});case"chevron":return(0,_jsxRuntime.jsxs)(_jsxRuntime.Fragment,{children:[originalElement,(0,_jsxRuntime.jsx)(NumberButtonStepper,_objectSpread(_objectSpread({},stepperProps),{},{isChevron:true}))]});case"separate":return(0,_jsxRuntime.jsxs)(_jsxRuntime.Fragment,{children:[originalElement,(0,_jsxRuntime.jsx)(NumberButtonStepper,_objectSpread(_objectSpread({},stepperProps),{},{plusOnly:true}))]});default:return unitElement||ActionBtn}};_react["default"].useEffect(function(){setCurrentValue(value)},[value]);return(0,_jsxRuntime.jsx)(_reactNumberFormat.NumericFormat,_objectSpread(_objectSpread(_objectSpread({},inputProps),{},{type:"text",customInput:_BaseInput.Input,isClearable:isClearableNumberInput,className:(0,_classnames["default"])("number-input",className,_defineProperty({},"".concat(stepper,"-stepper"),!!stepper)),getInputRef:ref,onValueChange:handleChange,isAllowed:function isAllowed(_ref3){var floatValue=_ref3.floatValue;if(!allowInput&&!!stepper)return false;if(isControlled&&!onValueChange)return false;if(floatValue===undefined||floatValue.toString()==="")return true;var isValidValue=(min===undefined||floatValue>=min)&&(max===undefined||floatValue<=max);return isValidValue},readOnly:props.readOnly||!allowInput&&!!stepper,wrapperProps:_objectSpread(_objectSpread({},inputProps.wrapperProps),{},{leftElement:renderLeftElement((_inputProps$wrapperPr=inputProps.wrapperProps)===null||_inputProps$wrapperPr===void 0?void 0:_inputProps$wrapperPr.leftElement)})},!allowInput&&!!stepper&&!props.readOnly?{"data-readonly":"not-allowed-input"}:{}),{},{ActionBtn:renderRightElement(inputProps.ActionBtn)}))});NumberInput.displayName="NumberInput";var NumberButtonStepper=function NumberButtonStepper(_ref4){var value=_ref4.value,handleValue=_ref4.handleValue,_ref4$stepControl=_ref4.stepControl,stepControl=_ref4$stepControl===void 0?1:_ref4$stepControl,min=_ref4.min,max=_ref4.max,_ref4$disabled=_ref4.disabled,disabled=_ref4$disabled===void 0?false:_ref4$disabled,_ref4$minusOnly=_ref4.minusOnly,minusOnly=_ref4$minusOnly===void 0?false:_ref4$minusOnly,_ref4$plusOnly=_ref4.plusOnly,plusOnly=_ref4$plusOnly===void 0?false:_ref4$plusOnly,_ref4$isChevron=_ref4.isChevron,isChevron=_ref4$isChevron===void 0?false:_ref4$isChevron,_ref4$formatProps=_ref4.formatProps,formatProps=_ref4$formatProps===void 0?{}:_ref4$formatProps;var intervalValue=_react["default"].useRef(value);var intervalRef=_react["default"].useRef(null);var debounceRef=_react["default"].useRef(null);var minusDisable=disabled||min!==undefined&&intervalValue.current<=min||isNaN(intervalValue.current);var plusDisable=disabled||max!==undefined&&intervalValue.current>=max||isNaN(intervalValue.current);var handleChange=function handleChange(type){var stepValue=type==="+"?stepControl:-stepControl;intervalValue.current=intervalValue.current+stepValue;if(min!==undefined&&intervalValue.current<=min){intervalValue.current=min}else if(max!==undefined&&intervalValue.current>=max){intervalValue.current=max}handleValue({floatValue:isNaN(value)?stepValue:intervalValue.current,value:intervalValue.current.toString(),formattedValue:(0,_reactNumberFormat.numericFormatter)(intervalValue.current.toString(),formatProps)})};var startInterval=function startInterval(type){handleChange(type);debounceRef.current=setTimeout(function(){return intervalRef.current=setInterval(function(){return handleChange(type)},100)},1000)};var stopInterval=function stopInterval(){if(intervalRef.current)clearInterval(intervalRef.current);if(debounceRef.current)clearInterval(debounceRef.current)};var generateProps=function generateProps(type){return{className:"square-icon",disabled:type==="-"?minusDisable:plusDisable,onKeyDown:function onKeyDown(e){if(e.key==="Enter"||e.key===" "){handleChange(type)}},onMouseDown:function onMouseDown(){return startInterval(type)},onMouseUp:function onMouseUp(){return stopInterval()},onMouseLeave:function onMouseLeave(){return stopInterval()}}};_react["default"].useEffect(function(){if(value!==intervalValue.current){intervalValue.current=value}},[value]);if(plusDisable||minusDisable)stopInterval();var MinusButton=(0,_jsxRuntime.jsx)("button",_objectSpread(_objectSpread({},generateProps("-")),{},{children:isChevron?(0,_jsxRuntime.jsx)(_lucideReact.ChevronDown,{}):(0,_jsxRuntime.jsx)(_lucideReact.MinusIcon,{})}));var PlusButton=(0,_jsxRuntime.jsx)("button",_objectSpread(_objectSpread({},generateProps("+")),{},{children:isChevron?(0,_jsxRuntime.jsx)(_lucideReact.ChevronUp,{}):(0,_jsxRuntime.jsx)(_lucideReact.PlusIcon,{})}));if(minusOnly){return(0,_jsxRuntime.jsxs)("div",{className:"number-stepper-wrapper",children:[MinusButton,(0,_jsxRuntime.jsx)("div",{className:"controller-divider"})]})}if(plusOnly){return(0,_jsxRuntime.jsxs)("div",{className:"number-stepper-wrapper",children:[(0,_jsxRuntime.jsx)("div",{className:"controller-divider"}),PlusButton]})}if(isChevron){return(0,_jsxRuntime.jsxs)("div",{className:"number-stepper-wrapper chevron-stepper",children:[(0,_jsxRuntime.jsx)("div",{className:"controller-divider"}),(0,_jsxRuntime.jsxs)("div",{className:"chevron-stepper-container",children:[PlusButton,MinusButton]})]})}return(0,_jsxRuntime.jsxs)("div",{className:"number-stepper-wrapper",children:[MinusButton,(0,_jsxRuntime.jsx)("div",{className:"controller-divider"}),PlusButton]})};