UNPKG

beta-parity-react

Version:

Beta Parity React Components

1 lines 10.8 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.PINField=void 0;var _react=_interopRequireDefault(require("react"));var _classnames=_interopRequireDefault(require("classnames"));require("./index.css");var _jsxRuntime=require("react/jsx-runtime");var _excluded=["className","value","groups","separator","masked","reset","readOnly","disabled","invalid","size","theme","placeholder","onChange","onComplete"];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 _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 _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 sizeMap={sm:"small",md:"medium"};var PINField=exports.PINField=_react["default"].forwardRef(function(_ref,ref){var className=_ref.className,_ref$value=_ref.value,value=_ref$value===void 0?"":_ref$value,_ref$groups=_ref.groups,groups=_ref$groups===void 0?[4]:_ref$groups,_ref$separator=_ref.separator,separator=_ref$separator===void 0?"-":_ref$separator,_ref$masked=_ref.masked,masked=_ref$masked===void 0?false:_ref$masked,_ref$reset=_ref.reset,reset=_ref$reset===void 0?false:_ref$reset,_ref$readOnly=_ref.readOnly,readOnly=_ref$readOnly===void 0?false:_ref$readOnly,_ref$disabled=_ref.disabled,disabled=_ref$disabled===void 0?false:_ref$disabled,_ref$invalid=_ref.invalid,invalid=_ref$invalid===void 0?false:_ref$invalid,_ref$size=_ref.size,size=_ref$size===void 0?"md":_ref$size,_ref$theme=_ref.theme,theme=_ref$theme===void 0?"default":_ref$theme,_ref$placeholder=_ref.placeholder,placeholder=_ref$placeholder===void 0?"\u2022":_ref$placeholder,onChange=_ref.onChange,onComplete=_ref.onComplete,props=_objectWithoutProperties(_ref,_excluded);var totalInputs=_react["default"].useMemo(function(){return groups.reduce(function(acc,curr){return acc+curr},0)},[groups]);var inputRefs=_react["default"].useRef([]);var initialValues=value?Array(totalInputs).fill("").map(function(_,i){return value[i]||""}):Array(totalInputs).fill("");var _React$useState=_react["default"].useState(initialValues),_React$useState2=_slicedToArray(_React$useState,2),values=_React$useState2[0],setValues=_React$useState2[1];var inputs=_react["default"].useMemo(function(){var result=[];var inputIndex=0;for(var i=0;i<groups.length;i++){for(var j=0;j<groups[i];j++){result.push({type:"input",index:inputIndex++})}if(i<groups.length-1){result.push({type:"separator"})}}return result},[groups]);var focusInput=_react["default"].useCallback(function(index){if(index>=0&&index<totalInputs&&inputRefs.current[index]&&!readOnly&&!disabled){var _inputRefs$current$in;(_inputRefs$current$in=inputRefs.current[index])===null||_inputRefs$current$in===void 0||_inputRefs$current$in.focus()}},[totalInputs,readOnly,disabled]);var handleChange=function handleChange(index,e){if(readOnly||disabled)return;var value=e.target.value;var lastChar=value.replace(/[^a-zA-Z0-9]/g,"").slice(-1);if(lastChar){var newValues=_toConsumableArray(values);newValues[index]=lastChar;setValues(newValues);var newPINValue=newValues.join("");onChange===null||onChange===void 0||onChange(newPINValue);if(index<totalInputs-1){focusInput(index+1)}}};var handleKeyDown=function handleKeyDown(index,e){if(readOnly||disabled)return;switch(e.key){case"Backspace":if(values[index]){var newValues=_toConsumableArray(values);newValues[index]="";setValues(newValues);onChange===null||onChange===void 0||onChange(newValues.join(""))}else if(index>0){focusInput(index-1)}break;case"ArrowLeft":if(index>0){e.preventDefault();focusInput(index-1)}break;case"ArrowRight":if(index<totalInputs-1){e.preventDefault();focusInput(index+1)}break;default:var _char=e.key;if(/^[a-zA-Z0-9]$/.test(_char)){if(values[index]===_char&&index<totalInputs-1){e.preventDefault();focusInput(index+1)}}break}};var handleSetText=function handleSetText(index,text){var alphanumeric=text.replace(/[^a-zA-Z0-9]/g,"");if(alphanumeric){var chars=alphanumeric.split("");var newValues=_toConsumableArray(values);var filledCount=0;for(var i=index;i<totalInputs&&filledCount<chars.length;i++){newValues[i]=chars[filledCount++]}setValues(newValues);onChange===null||onChange===void 0||onChange(newValues.join(""));var nextEmptyIndex=newValues.findIndex(function(val,idx){return idx>=index&&!val});if(nextEmptyIndex!==-1){focusInput(nextEmptyIndex)}else{focusInput(Math.min(index+chars.length,totalInputs-1))}}};var handlePaste=function handlePaste(index,e){if(readOnly||disabled)return;e.preventDefault();var pastedText=e.clipboardData.getData("text");handleSetText(index,pastedText)};var handleFocus=function handleFocus(e){if(!readOnly&&!disabled){e.target.select()}};var handleInputClick=function handleInputClick(index){if(!readOnly&&!disabled){focusInput(index)}};_react["default"].useEffect(function(){if(reset){setValues(Array(totalInputs).fill(""));setTimeout(function(){focusInput(0)},0)}},[reset,totalInputs,focusInput]);_react["default"].useEffect(function(){if(!values.includes("")&&onComplete){onComplete(values.join(""))}},[values]);_react["default"].useEffect(function(){inputRefs.current=inputRefs.current.slice(0,totalInputs);while(inputRefs.current.length<totalInputs){inputRefs.current.push(null)}},[totalInputs]);_react["default"].useEffect(function(){if(value!=values.join("")&&value.length>0){handleSetText(0,value)}},[value]);return(0,_jsxRuntime.jsx)("div",_objectSpread(_objectSpread({ref:ref,className:(0,_classnames["default"])("pinfield","pinfield-".concat(sizeMap[size]),{"pinfield-disabled":disabled,"pinfield-read-only":readOnly,"pinfield-invalid":invalid,"pinfield-masked":masked,"pinfield-alternative":theme==="alternative"},className)},props),{},{children:inputs.map(function(item,idx){if(item.type==="separator"){return(0,_jsxRuntime.jsx)("div",{className:"pinfield-separator",children:separator},"separator-".concat(idx))}var inputIndex=item.index;var isEmpty=!values[inputIndex];var isFilled=!!values[inputIndex];return(0,_jsxRuntime.jsxs)("div",{className:(0,_classnames["default"])("pinfield-item",{"pinfield-item-filled":isFilled,"pinfield-item-empty":isEmpty}),onClick:function onClick(){return handleInputClick(inputIndex)},children:[(0,_jsxRuntime.jsx)("input",{ref:function ref(el){return inputRefs.current[inputIndex]=el},type:masked?"password":"text",maxLength:1,value:values[inputIndex],onChange:function onChange(e){return handleChange(inputIndex,e)},onKeyDown:function onKeyDown(e){return handleKeyDown(inputIndex,e)},onPaste:function onPaste(e){return handlePaste(inputIndex,e)},onFocus:handleFocus,disabled:disabled,readOnly:readOnly,"aria-invalid":invalid,className:"pinfield-input",autoComplete:"off",inputMode:"numeric"}),masked?(0,_jsxRuntime.jsx)("span",{className:"pinfield-placeholder",children:placeholder}):isEmpty&&(0,_jsxRuntime.jsx)("span",{className:"pinfield-placeholder",children:placeholder})]},"input-".concat(inputIndex))})}))});PINField.displayName="PINField";