diff --git a/lib/components/index.js b/lib/components/index.js index 11ed1c4..660a637 100644 --- a/lib/components/index.js +++ b/lib/components/index.js @@ -1 +1 @@ -!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("react")):"function"==typeof define&&define.amd?define(["react"],t):"object"==typeof exports?exports["react-inputs-validation"]=t(require("react")):e["react-inputs-validation"]=t(e.react)}(this,(function(e){return function(e){var t={};function n(r){if(t[r])return t[r].exports;var i=t[r]={i:r,l:!1,exports:{}};return e[r].call(i.exports,i,i.exports,n),i.l=!0,i.exports}return n.m=e,n.c=t,n.d=function(e,t,r){n.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:r})},n.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.t=function(e,t){if(1&t&&(e=n(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var i in e)n.d(r,i,function(t){return e[t]}.bind(null,i));return r},n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,"a",t),t},n.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},n.p="",n(n.s=6)}([function(t,n){t.exports=e},function(e,t,n){"use strict";var r=this&&this.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)Object.hasOwnProperty.call(e,n)&&(t[n]=e[n]);return t.default=e,t};Object.defineProperty(t,"__esModule",{value:!0});var i=r(n(0)),o=i.useEffect,a=i.useRef;t.LOCALE_OPTION_LIST=["en-US","zh-CN"],t.REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE="Invalid window.REACT_INPUTS_VALIDATION['customErrorMessage']. EXAMPLE: window.REACT_INPUTS_VALIDATION={customErrorMessage:{'en-US':{textbox:{empty:function empty(name){return getEnglishName(name)+'cannot be empty'},invalid:function invalid(name){return getEnglishName(name)+'invalid format'},invalidFormat:function invalidFormat(name){return getEnglishName(name)+'is not a number'},inBetween:function inBetween(name){return function(min){return function(max){return getEnglishName(name)+'must be '+min+'-'+max}}},lessThan:function lessThan(name){return function(min){return getEnglishName(name)+'cannot less than '+min}},greaterThan:function greaterThan(name){return function(max){return getEnglishName(name)+'cannot greater than '+max}},lengthEqual:function lengthEqual(name){return function(length){return getEnglishName(name)+'length must be '+length}},twoInputsNotEqual:function twoInputsNotEqual(){return'two inputs are not equal'}},radiobox:{empty:function empty(name){return'Please choose one '+getEnglishName(name)}},checkbox:{unchecked:function unchecked(name){return getEnglishName(name)+'must be checked'}},select:{empty:function empty(name){return'Please select a '+getEnglishName(name)}},textarea:{empty:function empty(name){return getEnglishName(name)+'cannot be empty'},invalid:function invalid(name){return getEnglishName(name)+'invalid format'},invalidFormat:function invalidFormat(name){return getEnglishName(name)+'is not a number'},inBetween:function inBetween(name){return function(min){return function(max){return getEnglishName(name)+'must be '+min+'-'+max}}},lessThan:function lessThan(name){return function(min){return getEnglishName(name)+'cannot less than '+min}},greaterThan:function greaterThan(name){return function(max){return getEnglishName(name)+'cannot greater than '+max}},lengthEqual:function lengthEqual(name){return function(length){return getEnglishName(name)+'length must be '+length}},twoInputsNotEqual:function twoInputsNotEqual(){return'two inputs are not equal'}}}}};",t.DEFAULT_LOCALE="en-US",t.WRAPPER_CLASS_IDENTITIFIER="react-inputs-validation__wrapper_identifier",t.CONTAINER_CLASS_IDENTITIFIER="react-inputs-validation__container_identifier",t.OPTION_LIST_ITEM_IDENTITIFIER="react-inputs-validation__option-list-item_identifier",t.MSG_CLASS_IDENTITIFIER="react-inputs-validation__msg_identifier",t.usePrevious=function(e){var t=a();return o((function(){t.current=e})),t.current}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=n(1),i=function(e){var t="";return e&&(t=e+" "),t},o={"zh-CN":{textbox:{empty:function(e){return e+"不能为空"},invalid:function(e){return e+"格式有误"},invalidFormat:function(e){return e+"不是数字"},inBetween:function(e){return function(t){return function(n){return e+"必须在"+t+"-"+n+"之间"}}},lessThan:function(e){return function(t){return e+"不可少于"+t}},greaterThan:function(e){return function(t){return e+"不可大于"+t}},lengthEqual:function(e){return function(t){return e+"长度必须为"+t}},twoInputsNotEqual:function(){return"两次输入不一致"}},radiobox:{empty:function(e){return"必须勾选一个"+e}},checkbox:{unchecked:function(e){return e+"必须勾选"}},select:{empty:function(e){return"请选择一个"+e}},textarea:{empty:function(e){return e+"不能为空"},invalid:function(e){return e+"格式有误"},invalidFormat:function(e){return e+"不是数字"},inBetween:function(e){return function(t){return function(n){return e+"必须在"+t+"-"+n+"之间"}}},lessThan:function(e){return function(t){return e+"不可少于"+t}},greaterThan:function(e){return function(t){return e+"不可大于"+t}},lengthEqual:function(e){return function(t){return e+"长度必须为"+t}},twoInputsNotEqual:function(){return"两次输入不一致"}}},"en-US":{textbox:{empty:function(e){return i(e)+"cannot be empty"},invalid:function(e){return i(e)+"invalid format"},invalidFormat:function(e){return i(e)+"is not a number"},inBetween:function(e){return function(t){return function(n){return i(e)+"must be "+t+"-"+n}}},lessThan:function(e){return function(t){return i(e)+"cannot less than "+t}},greaterThan:function(e){return function(t){return i(e)+"cannot greater than "+t}},lengthEqual:function(e){return function(t){return i(e)+"length must be "+t}},twoInputsNotEqual:function(){return"two inputs are not equal"}},radiobox:{empty:function(e){return"Please choose one "+i(e)}},checkbox:{unchecked:function(e){return i(e)+"must be checked"}},select:{empty:function(e){return"Please select a "+i(e)}},textarea:{empty:function(e){return i(e)+"cannot be empty"},invalid:function(e){return i(e)+"invalid format"},invalidFormat:function(e){return i(e)+"is not a number"},inBetween:function(e){return function(t){return function(n){return i(e)+"must be "+t+"-"+n}}},lessThan:function(e){return function(t){return i(e)+"cannot less than "+t}},greaterThan:function(e){return function(t){return i(e)+"cannot greater than "+t}},lengthEqual:function(e){return function(t){return i(e)+"length must be "+t}},twoInputsNotEqual:function(){return"two inputs are not equal"}}}};t.getCustomErrorMessage=function(e,t){return e&&"object"==typeof e&&e.constructor===Object&&Object.keys(e).length?(Object.keys(e).map((function(n){t[n]?Object.keys(e[n]).length&&Object.keys(e[n]).map((function(r){Object.keys(e[n][r]).length&&Object.keys(e[n][r]).map((function(i){t[n][r][i]=e[n][r][i]}))})):t[n]=e[n]})),t):(console.error(r.REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE),!1)},t.handleCustomErrorMessage=function(e,n){var r;return void 0!==n&&n.REACT_INPUTS_VALIDATION&&n.REACT_INPUTS_VALIDATION.customErrorMessage&&(r=t.getCustomErrorMessage(n.REACT_INPUTS_VALIDATION.customErrorMessage,e)),void 0===r||!1===r?e:r},"undefined"!=typeof window&&(window.REACT_INPUTS_VALIDATION=window.REACT_INPUTS_VALIDATION||{},o=t.handleCustomErrorMessage(o,window)),t.default=o},function(e,t,n){e.exports={ellipsis:"react-inputs-validation__ellipsis___3-Api",textbox__wrapper:"react-inputs-validation__textbox__wrapper___3tnXv",textbox__input:"react-inputs-validation__textbox__input___20hDL",error:"react-inputs-validation__error___2aXSp",success:"react-inputs-validation__success___3TpwE",disabled:"react-inputs-validation__disabled___1-57g",msg:"react-inputs-validation__msg___pxv8o",textarea__wrapper:"react-inputs-validation__textarea__wrapper___35GhF",textarea__input:"react-inputs-validation__textarea__input___1CFm_",radiobox__container:"react-inputs-validation__radiobox__container___FD4vb",radiobox__input:"react-inputs-validation__radiobox__input___2uX2-",radiobox__label:"react-inputs-validation__radiobox__label___2tQsB",radiobox__wrapper:"react-inputs-validation__radiobox__wrapper___1zZ30",checked:"react-inputs-validation__checked___2O0Ju",button:"react-inputs-validation__button___9JBRL",radiobox__item:"react-inputs-validation__radiobox__item___ejuz1",checkbox__input:"react-inputs-validation__checkbox__input___1yF4X",checkbox__container:"react-inputs-validation__checkbox__container___3I1rX",checkbox__box:"react-inputs-validation__checkbox__box___1uj8A",checkbox__wrapper:"react-inputs-validation__checkbox__wrapper___1c1rD",box:"react-inputs-validation__box___3E9nu",select__wrapper:"react-inputs-validation__select__wrapper___1B4OH",select__input:"react-inputs-validation__select__input___3h-P7",select__container:"react-inputs-validation__select__container___3jgUR",select__button:"react-inputs-validation__select__button___vEDoq","select__options-item":"react-inputs-validation__select__options-item___30yY4","select__options-item-show-cursor":"react-inputs-validation__select__options-item-show-cursor___1ZT3b",select__searchInputWrapper:"react-inputs-validation__select__searchInputWrapper___3R5P_",select__searchInputSearchIcon:"react-inputs-validation__select__searchInputSearchIcon___1Q8xX",select__searchInputRemoveIcon:"react-inputs-validation__select__searchInputRemoveIcon___1A1tR",select__searchInput:"react-inputs-validation__select__searchInput___1lN24","select__no-mouse":"react-inputs-validation__select__no-mouse___2uRg6","select__hover-active":"react-inputs-validation__select__hover-active___2z1MQ",active:"react-inputs-validation__active___3eZBB","select__options-container-animate":"react-inputs-validation__select__options-container-animate___2Rm--",show:"react-inputs-validation__show___2NI3u","select__options-container":"react-inputs-validation__select__options-container___d54qE",select__dropdown:"react-inputs-validation__select__dropdown___11yDr","select__dropdown-icon":"react-inputs-validation__select__dropdown-icon___1T5r2","select__dropdown-name":"react-inputs-validation__select__dropdown-name___3hghL","select__dropdown-icon-container":"react-inputs-validation__select__dropdown-icon-container___2ild-"}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=function(e){return e.replace(/(?:^\w|[A-Z]|\b\w|\s+)/g,(function(e,t){return 0==+e?"":0===t?e.toLowerCase():e.toUpperCase()}))},i={camelize:r,toCamelCase:function(e){return function(t){void 0===t&&(t=!1);var n=r(e);return t?n.substr(0,1).toUpperCase()+n.substr(1,n.length):n}},getRandomId:function(){return Math.random().toString(36).slice(-8)},getAlphanumeric:function(e){var t="";return String(e).split("").forEach((function(e){var n=e.toLowerCase().charCodeAt(0);(n>=48&&n<=57||n>=97&&n<=122)&&(t+=e)})),t},getAlpha:function(e){var t="";return String(e).split("").forEach((function(e){var n=e.toLowerCase().charCodeAt(0);n>=97&&n<=122&&(t+=e)})),t},getNumeric:function(e){var t="";return String(e).split("").forEach((function(e){var n=e.toLowerCase().charCodeAt(0);n>=48&&n<=57&&(t+=e)})),t},arraysEqual:function(e,t){if(e.length!==t.length)return!1;for(var n=e.length;n-=1;)if(JSON.stringify(e[n])!==JSON.stringify(t[n]))return!1;return!0}};t.default=i},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=function(e){return!isNaN(parseFloat(e))&&isFinite(e)},i={reg:function(e,t){var n=!0;return e.test(t)&&(n=!1),n},empty:function(e){return!e.replace(/\s/g,"").length},number:function(e,t,n){return null===t&&null===n||!!r(e)&&!(en)}};t.default=i},function(e,t,n){"use strict";var r=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(t,"__esModule",{value:!0});var i=r(n(7));t.Textbox=i.default;var o=r(n(8));t.Textarea=o.default;var a=r(n(9));t.Select=a.default;var u=r(n(10));t.Checkbox=u.default;var s=r(n(11));t.Radiobox=s.default},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n0&&i[i.length-1])||6!==o[0]&&2!==o[0])){a=0;continue}if(3===o[0]&&(!i||o[1]>i[0]&&o[1]Number(I.maxLength))){var n=Ee.type,r=Ee.numberType,i=Ee.mantissa;n===b[1]&&(t=String(function(e,t,n){var r="",i=!1,o=String(e).split("");o[0];if(t===y[2]&&"0"===o[0]&&"0"===o[1]&&o.shift(),o.forEach((function(e){var n=e.toLowerCase().charCodeAt(0);if(n>=48&&n<=57||46===n&&!i){if(46===n){if(t===y[1])return;i=!0}r+=e}})),i&&n>=0){var a=r.split(".");0===n?r=a[0]:(a[1]=a[1].slice(0,n),r=a.join("."))}return t!==y[0]&&t!==y[2]||r.length&&"."===r[0]&&(r="0"+r),r}(t,y.indexOf(r)>=0?r:y[0],i))),n===b[2]&&(t=p.default.getAlphanumeric(t)),n===b[3]&&(t=p.default.getAlpha(t)),he(t),J&&J(t,e),ue?se(!1):ve("")}}}),[ue,I,Ee]),Ce=d((function(){return i(void 0,void 0,void 0,(function(){var e,t,n,r,i,a,u,s,l,c,d,f,_,g,y,S;return o(this,(function(o){switch(o.label){case 0:if(e=Ee.reg,t=Ee.min,n=Ee.max,r=Ee.type,i=Ee.name,a=Ee.check,u=Ee.length,s=Ee.regMsg,l=Ee.locale,c=Ee.compare,d=Ee.required,f=Ee.msgOnSuccess,_=Ee.customFunc,!a)return[2];if(!r)return[3,5];if(-1===b.indexOf(r))return[3,3];if(!v.default[l]||!v.default[l][E])return console.error(h.REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE),[2];if(g=v.default[l][E],y=i||"",d&&m.default.empty(pe))return xe(!0,g.empty(y)),[2];if(""!==String(pe)){if(e&&m.default.reg(e,pe))return xe(!0,""!==s?s:g.invalid(y)),[2];if(r===b[0]){if(t||n)if(t&&n){if(String(pe).lengthn)return xe(!0,g.inBetween(y)(t)(n)),[2]}else{if(t&&String(pe).lengthn)return xe(!0,g.greaterThan(y)(n)),[2]}if(u&&String(pe).length!==u)return xe(!0,g.lengthEqual(y)(u)),[2]}if(r===b[1]){if(!m.default[r](pe,null,null))return xe(!0,g.invalid(y)),[2];if(t||n)if(t&&n){if(!m.default[r](pe,t,n))return xe(!0,g.inBetween(y)(t)(n)),[2]}else{if(t&&!m.default[r](pe,t))return xe(!0,g.lessThan(y)(t)),[2];if(n&&!m.default[r](pe,0,n))return xe(!0,g.greaterThan(y)(n)),[2]}if(u&&String(pe).length!==u)return xe(!0,g.lengthEqual(y)(u)),[2]}if(c&&""!==c&&pe!==c)return xe(!0,g.twoInputsNotEqual()),[2]}return _&&"function"==typeof _?[4,_(pe)]:[3,2];case 1:if("object"==typeof(S=o.sent()))return"boolean"==typeof S.error&&"string"==typeof S.message&&(!1===S.error&&!0===S.showOnSuccess&&ve(S.message),xe(S.error,S.message,!0)),[2];if(!0!==S)return xe(!0,S,!0),[2];o.label=2;case 2:return f&&ve(f),xe(!1,f),[3,4];case 3:console.error("The valid "+p.default.toCamelCase(E)(!0)+' "type" options in validationOption are ['+b.map((function(e){return e}))+"]"),o.label=4;case 4:return[3,6];case 5:console.error('Please provide "type" in validationOption'),o.label=6;case 6:return[2]}}))}))}),[pe,Ee]),xe=d((function(e,t,n){void 0===n&&(n=!1);var r=t,i=Ee.msgOnError;e&&i&&!n&&(r=i),se(e),de(r),oe&&oe(e)}),[]);c((function(){L&&Ce()}),[L]),c((function(){he(String(T))}),[T]),c((function(){void 0!==ge&&ge!==pe&&Ee.customFunc&&re&&Ce()}),[pe]),c((function(){be&&be.message&&(be.showOnError&&xe(be.error,be.message),!be.error&&be.showOnSuccess&&ve(be.message))}),[H]);var Me,Le=P+" "+g.default[E+"__wrapper"]+" "+(ue&&g.default.error)+" "+(""!==_e&&!ue&&g.default.success)+" "+(x&&g.default.disabled),Ae=D+" "+g.default[E+"__container"]+" "+(ue&&g.default.error)+" "+(""!==_e&&!ue&&g.default.success)+" "+(x&&g.default.disabled),ke=k+" "+g.default[E+"__input"]+" "+(ue&&g.default.error)+" "+(""!==_e&&!ue&&g.default.success)+" "+(x&&g.default.disabled),Re=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(ue&&g.default.error),Pe=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(!ue&&g.default.success),Fe=Ee.showMsg;return Fe&&ue&&ce&&(Me=s.createElement("div",{className:Re},ce)),Fe&&!ue&&""!==_e&&(Me=s.createElement("div",{className:Pe},_e)),s.createElement("div",r({className:Le,style:B},w),s.createElement("div",{className:Ae,style:W},s.createElement("input",r({type:"text",value:pe,disabled:x,onBlur:we,onKeyUp:Ne,onFocus:Oe,onClick:Ie,className:ke,onChange:Te,style:q,ref:ye},I))),Me)}))},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n0&&i[i.length-1])||6!==o[0]&&2!==o[0])){a=0;continue}if(3===o[0]&&(!i||o[1]>i[0]&&o[1]Number(O.maxLength)||(pe(t),K&&K(t,e),ae?ue(!1):_e(""))}}),[ae]),Te=d((function(){return i(void 0,void 0,void 0,(function(){var e,t,n,r,i,a,u,s,l,c,d,f,_,g,y;return o(this,(function(o){switch(o.label){case 0:if(e=ge.reg,t=ge.min,n=ge.max,r=ge.type,i=ge.name,a=ge.check,u=ge.length,s=ge.regMsg,l=ge.locale,c=ge.required,d=ge.msgOnSuccess,f=ge.customFunc,!a)return[2];if(!r)return[3,5];if(-1===b.indexOf(r))return[3,3];if(!v.default[l]||!v.default[l][E])return console.error(h.REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE),[2];if(_=v.default[l][E],g=i||"",c&&m.default.empty(me))return Ce(!0,_.empty(g)),[2];if(""!==String(me)){if(e&&m.default.reg(e,me))return Ce(!0,""!==s?s:_.invalid(g)),[2];if(t||n)if(t&&n){if(String(me).lengthn)return Ce(!0,_.inBetween(g)(t)(n)),[2]}else{if(t&&String(me).lengthn)return Ce(!0,_.greaterThan(g)(n)),[2]}if(u&&String(me).length!==u)return Ce(!0,_.lengthEqual(g)(u)),[2]}return f&&"function"==typeof f?[4,f(me)]:[3,2];case 1:if("object"==typeof(y=o.sent()))return"boolean"==typeof y.error&&"string"==typeof y.message&&(!1===y.error&&!0===y.showOnSuccess&&_e(y.message),Ce(y.error,y.message,!0)),[2];if(!0!==y)return Ce(!0,y,!0),[2];o.label=2;case 2:return d&&_e(d),Ce(!1,d),[3,4];case 3:console.error("The valid "+p.default.toCamelCase(E)(!0)+' "type" options in validationOption are ['+b.map((function(e){return e}))+"]"),o.label=4;case 4:return[3,6];case 5:console.error('Please provide "type" in validationOption'),o.label=6;case 6:return[2]}}))}))}),[me,ge]),Ce=d((function(e,t,n){void 0===n&&(n=!1);var r=t,i=ge.msgOnError;e&&i&&!n&&(r=i),ue(e),ce(r),ie&&ie(e)}),[]);c((function(){M&&Te()}),[M]),c((function(){pe(String(N))}),[N]),c((function(){void 0!==he&&he!==me&&ge.customFunc&&ne&&Te()}),[me]),c((function(){Ee&&Ee.message&&(Ee.showOnError&&Ce(Ee.error,Ee.message),!Ee.error&&Ee.showOnSuccess&&_e(Ee.message))}),[X]);var xe,Me=R+" "+g.default[E+"__wrapper"]+" "+(ae&&g.default.error)+" "+(""!==fe&&!ae&&g.default.success)+" "+(C&&g.default.disabled),Le=F+" "+g.default[E+"__container"]+" "+(ae&&g.default.error)+" "+(""!==fe&&!ae&&g.default.success)+" "+(C&&g.default.disabled),Ae=A+" "+g.default[E+"__input"]+" "+(ae&&g.default.error)+" "+(""!==fe&&!ae&&g.default.success)+" "+(C&&g.default.disabled),ke=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(ae&&g.default.error),Re=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(!ae&&g.default.success),Pe=ge.showMsg;return Pe&&ae&&le&&(xe=s.createElement("div",{className:ke},le)),Pe&&!ae&&""!==fe&&(xe=s.createElement("div",{className:Re},fe)),s.createElement("div",r({className:Me,style:U},S),s.createElement("div",{className:Le,style:V},s.createElement("textarea",r({value:me,disabled:C,onBlur:Se,onKeyUp:Ie,onFocus:we,onClick:Oe,className:Ae,onChange:Ne,style:j,ref:be},O))),xe)}))},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n=a){var u=Math.abs(o-a-i);u>=0&&!y?(rt.current.scrollTop=r+i-u,y=!0):rt.current.scrollTop=r+i}}"up"===e&&(y=!1,S*i<=r&&(rt.current.scrollTop=S*i))}else y=!1,rt.current.scrollTop=S*i}}),[]),gt=c((function(e,t){dt(e,t),Pe[1]("")}),[]),Et=c((function(e){S=e,St()}),[]),bt=c((function(){Ge(!1)}),[]),yt=c((function(){wt()}),[]),St=c((function(){if(Ye&&Ye.current&&Ye.current.children){var e=Ye.current.children;if(wt(),null===S)return;S>=e.length&&(S=0),S<0&&(S=e.length-1),e[S]&&(e[S].className+=" "+h.default[g+"__hover-active"])}}),[]),wt=c((function(){if(Ye&&Ye.current&&Ye.current.children)for(var e=Ye.current.children,t=0;tot.length-1&&(S=0,ht("up")),St();else if(38===e)(S-=1)<0&&(S=ot.length-1,ht("loop")),St();else if(13===e&&S>-1&&Ye&&Ye.current&&Ye.current.children){var t=Ye.current.children;if(!t[S])return;t[S].click()}}),[ot]),Nt=c((function(e){if(!F&&(Ge(!0),e.preventDefault&&e.preventDefault(),qe)){S=null===S?t.getIndex(ot,String(M)):S;var n=e.keyCode,r=Ot(n);if(-1!==E.indexOf(n))It(n);else{pt();var o=i(Xe,[n]),a=String.fromCharCode.apply(String,o).toLowerCase(),u=-1;ot.forEach((function(e,t){e.name.toLowerCase().startsWith(a)&&-1===u&&(u=t)})),-1!==u&&(S=u,St()),He(o)}return ht(r),S}}),[qe,M,Xe]);l((function(){return qe&&nt&&document.addEventListener("keydown",Nt),function(){document.removeEventListener("keydown",Nt)}}),[qe,M,Xe]),l((function(){R&&ft()}),[R]),l((function(){t.isValidValue(ot,ke)&&""!==ke&&"null"!==ke&&"undefined"!==ke?Ie(!1):Le("")}),[ke]),l((function(){Re(String(M))}),[M]),l((function(){De&&De&&!p.default.arraysEqual(De,U)&&Re(String(U[0].id))}),[U]),l((function(){void 0!==Fe&&Fe!==ke&&ft()}),[Fe,ke]),l((function(){Je&&Je.message&&(Je.showOnError&&_t(Je.error,Je.message),!Je.error&&Je.showOnSuccess&&Le(Je.message))}),[fe]),l((function(){qe&&(F&&et.current.focus(),S=null===S?t.getIndex(ot,String(M)):S,it[S]&&it[S].current.focus()),!0===Be&&!1===qe&&tt.current.focus(),mt()}),[qe]);var Tt,Ct,xt=m.WRAPPER_CLASS_IDENTITIFIER+" "+V+" "+h.default.select__wrapper+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Mt=m.CONTAINER_CLASS_IDENTITIFIER+" "+G+" "+h.default.select__container+" "+(Oe&&h.default.error)+" "+(qe&&h.default.show)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Lt=h.default.select__input+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),At=X+" "+h.default.ellipsis+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),kt=Z+" "+h.default[g+"__options-container"]+" "+(Oe&&h.default.error)+" "+(qe&&h.default.show)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Rt=h.default.button+" "+(!We&&h.default[g+"__options-item-show-cursor"])+" "+K+" "+h.default[g+"__options-item"]+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Pt=Y+" "+h.default[g+"__dropdown-icon"],Ft=m.MSG_CLASS_IDENTITIFIER+" "+h.default.msg+" "+(Oe&&h.default.error),Dt=m.MSG_CLASS_IDENTITIFIER+" "+h.default.msg+" "+(!Oe&&h.default.success),jt=Ke.showMsg;jt&&Oe&&Te&&(Tt=u.createElement("div",{className:Ft},Te)),jt&&!Oe&&""!==Me&&(Tt=u.createElement("div",{className:Dt},Me));var qt=t.getItem(U,String(M));ot.length?Ct=ot.map((function(e,n){return u.createElement(t.Option,{key:n,index:n,id:"react-inputs-validation__select_option-"+e.id,className:String(e.id)===String(M)?Rt+" "+h.default.active:""+Rt,item:e,customStyleOptionListItem:ae,onClick:gt,onMouseOver:Et,onMouseMove:bt,onMouseOut:yt})})):F&&(Ct=u.createElement("div",{style:{background:"#fff",textAlign:"center",padding:"20px"}},u.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24"},u.createElement("path",{d:"M0 0h24v24H0z",fill:"none"}),u.createElement("path",{fill:"#cdcdcd",d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zM4 12c0-4.42 3.58-8 8-8 1.85 0 3.55.63 4.9 1.69L5.69 16.9C4.63 15.55 4 13.85 4 12zm8 8c-1.85 0-3.55-.63-4.9-1.69L18.31 7.1C19.37 8.45 20 10.15 20 12c0 4.42-3.58 8-8 8z"}))));var Ut=u.createElement("div",{className:h.default.select__dropdown},u.createElement("div",{className:h.default[g+"__dropdown-name"]+" "+h.default.ellipsis},qt?qt.name:""),u.createElement("div",{className:Pt}));return u.createElement("button",r({ref:Ze,type:"button",className:h.default.button,onClick:function(e){if(ct(e),!A){if($e.current&&$e.current.contains(e.target))return void Ue(!0);Ue(!qe)}},onFocus:lt,onBlur:st},N),u.createElement("div",{ref:Qe,className:xt,style:ee},u.createElement("div",{className:Mt,style:ne},u.createElement("input",r({type:"hidden",value:ke,className:Lt,onChange:function(){}},C)),u.createElement("div",{className:At,style:ie},Ut),u.createElement("div",{className:kt},F&&u.createElement("div",{ref:$e},u.createElement("div",{className:h.default.select__searchInputWrapper},u.createElement("svg",{className:h.default.select__searchInputSearchIcon,xmlns:"http://www.w3.org/2000/svg",width:"20",height:"20",viewBox:"0 0 24 24"},u.createElement("path",{fill:"#cdcdcd",d:"M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z"}),u.createElement("path",{d:"M0 0h24v24H0z",fill:"none"})),u.createElement("input",{className:h.default.select__searchInput,ref:et,value:Pe[0],onChange:at,onKeyDown:ut}),Pe[0]&&u.createElement("svg",{className:h.default.select__searchInputRemoveIcon,xmlns:"http://www.w3.org/2000/svg",width:"15",height:"15",viewBox:"0 0 24 24",onClick:function(){Pe[1](""),et.current.focus()}},u.createElement("path",{fill:"#cdcdcd",d:"M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7 12 10.59 15.59 7 17 8.41 13.41 12 17 15.59z"}),u.createElement("path",{d:"M0 0h24v24H0z",fill:"none"})))),u.createElement("div",{ref:Ye,style:se},Ct))),Tt))}))},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n=48&&n<=57||n>=97&&n<=122)&&(t+=e)})),t},getAlpha:function(e){var t="";return String(e).split("").forEach((function(e){var n=e.toLowerCase().charCodeAt(0);n>=97&&n<=122&&(t+=e)})),t},getNumeric:function(e){var t="";return String(e).split("").forEach((function(e){var n=e.toLowerCase().charCodeAt(0);n>=48&&n<=57&&(t+=e)})),t},arraysEqual:function(e,t){if(e.length!==t.length)return!1;for(var n=e.length;n-=1;)if(JSON.stringify(e[n])!==JSON.stringify(t[n]))return!1;return!0}};t.default=i},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=function(e){return!isNaN(parseFloat(e))&&isFinite(e)},i={reg:function(e,t){var n=!0;return e.test(t)&&(n=!1),n},empty:function(e){return!e.replace(/\s/g,"").length},number:function(e,t,n){return null===t&&null===n||!!r(e)&&!(en)}};t.default=i},function(e,t,n){"use strict";var r=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(t,"__esModule",{value:!0});var i=r(n(7));t.Textbox=i.default;var o=r(n(8));t.Textarea=o.default;var a=r(n(9));t.Select=a.default;var u=r(n(10));t.Checkbox=u.default;var s=r(n(11));t.Radiobox=s.default},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n0&&i[i.length-1])||6!==o[0]&&2!==o[0])){a=0;continue}if(3===o[0]&&(!i||o[1]>i[0]&&o[1]Number(I.maxLength))){var n=Ee.type,r=Ee.numberType,i=Ee.mantissa;n===b[1]&&(t=String(function(e,t,n){var r="",i=!1,o=String(e).split("");o[0];if(t===y[2]&&"0"===o[0]&&"0"===o[1]&&o.shift(),o.forEach((function(e){var n=e.toLowerCase().charCodeAt(0);if(n>=48&&n<=57||46===n&&!i){if(46===n){if(t===y[1])return;i=!0}r+=e}})),i&&n>=0){var a=r.split(".");0===n?r=a[0]:(a[1]=a[1].slice(0,n),r=a.join("."))}return t!==y[0]&&t!==y[2]||r.length&&"."===r[0]&&(r="0"+r),r}(t,y.indexOf(r)>=0?r:y[0],i))),n===b[2]&&(t=p.default.getAlphanumeric(t)),n===b[3]&&(t=p.default.getAlpha(t)),he(t),J&&J(t,e),ue?se(!1):ve("")}}}),[ue,I,Ee]),Ce=d((function(){return i(void 0,void 0,void 0,(function(){var e,t,n,r,i,a,u,s,l,c,d,f,_,g,y,S;return o(this,(function(o){switch(o.label){case 0:if(e=Ee.reg,t=Ee.min,n=Ee.max,r=Ee.type,i=Ee.name,a=Ee.check,u=Ee.length,s=Ee.regMsg,l=Ee.locale,c=Ee.compare,d=Ee.required,f=Ee.msgOnSuccess,_=Ee.customFunc,!a)return[2];if(!r)return[3,5];if(-1===b.indexOf(r))return[3,3];if(!v.default[l]||!v.default[l][E])return console.error(h.REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE),[2];if(g=v.default[l][E],y=i||"",d&&m.default.empty(pe))return xe(!0,g.empty(y)),[2];if(""!==String(pe)){if(e&&m.default.reg(e,pe))return xe(!0,""!==s?s:g.invalid(y)),[2];if(r===b[0]){if(t||n)if(t&&n){if(String(pe).lengthn)return xe(!0,g.inBetween(y)(t)(n)),[2]}else{if(t&&String(pe).lengthn)return xe(!0,g.greaterThan(y)(n)),[2]}if(u&&String(pe).length!==u)return xe(!0,g.lengthEqual(y)(u)),[2]}if(r===b[1]){if(!m.default[r](pe,null,null))return xe(!0,g.invalid(y)),[2];if(t||n)if(t&&n){if(!m.default[r](pe,t,n))return xe(!0,g.inBetween(y)(t)(n)),[2]}else{if(t&&!m.default[r](pe,t))return xe(!0,g.lessThan(y)(t)),[2];if(n&&!m.default[r](pe,0,n))return xe(!0,g.greaterThan(y)(n)),[2]}if(u&&String(pe).length!==u)return xe(!0,g.lengthEqual(y)(u)),[2]}if(c&&""!==c&&pe!==c)return xe(!0,g.twoInputsNotEqual()),[2]}return _&&"function"==typeof _?[4,_(pe)]:[3,2];case 1:if("object"==typeof(S=o.sent()))return"boolean"==typeof S.error&&"string"==typeof S.message&&(!1===S.error&&!0===S.showOnSuccess&&ve(S.message),xe(S.error,S.message,!0)),[2];if(!0!==S)return xe(!0,S,!0),[2];o.label=2;case 2:return f&&ve(f),xe(!1,f),[3,4];case 3:console.error("The valid "+p.default.toCamelCase(E)(!0)+' "type" options in validationOption are ['+b.map((function(e){return e}))+"]"),o.label=4;case 4:return[3,6];case 5:console.error('Please provide "type" in validationOption'),o.label=6;case 6:return[2]}}))}))}),[pe,Ee]),xe=d((function(e,t,n){void 0===n&&(n=!1);var r=t,i=Ee.msgOnError;e&&i&&!n&&(r=i),se(e),de(r),oe&&oe(e)}),[Ee.msgOnError]);c((function(){L&&Ce()}),[L]),c((function(){he(String(T))}),[T]),c((function(){void 0!==ge&&ge!==pe&&Ee.customFunc&&re&&Ce()}),[pe]),c((function(){be&&be.message&&(be.showOnError&&xe(be.error,be.message),!be.error&&be.showOnSuccess&&ve(be.message))}),[H]);var Me,Le=P+" "+g.default[E+"__wrapper"]+" "+(ue&&g.default.error)+" "+(""!==_e&&!ue&&g.default.success)+" "+(x&&g.default.disabled),Ae=D+" "+g.default[E+"__container"]+" "+(ue&&g.default.error)+" "+(""!==_e&&!ue&&g.default.success)+" "+(x&&g.default.disabled),ke=k+" "+g.default[E+"__input"]+" "+(ue&&g.default.error)+" "+(""!==_e&&!ue&&g.default.success)+" "+(x&&g.default.disabled),Re=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(ue&&g.default.error),Pe=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(!ue&&g.default.success),Fe=Ee.showMsg;return Fe&&ue&&ce&&(Me=s.createElement("div",{className:Re},ce)),Fe&&!ue&&""!==_e&&(Me=s.createElement("div",{className:Pe},_e)),s.createElement("div",r({className:Le,style:B},w),s.createElement("div",{className:Ae,style:W},s.createElement("input",r({type:"text",value:pe,disabled:x,onBlur:we,onKeyUp:Ne,onFocus:Oe,onClick:Ie,className:ke,onChange:Te,style:q,ref:ye},I))),Me)}))},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n0&&i[i.length-1])||6!==o[0]&&2!==o[0])){a=0;continue}if(3===o[0]&&(!i||o[1]>i[0]&&o[1]Number(O.maxLength)||(pe(t),K&&K(t,e),ae?ue(!1):_e(""))}}),[ae]),Te=d((function(){return i(void 0,void 0,void 0,(function(){var e,t,n,r,i,a,u,s,l,c,d,f,_,g,y;return o(this,(function(o){switch(o.label){case 0:if(e=ge.reg,t=ge.min,n=ge.max,r=ge.type,i=ge.name,a=ge.check,u=ge.length,s=ge.regMsg,l=ge.locale,c=ge.required,d=ge.msgOnSuccess,f=ge.customFunc,!a)return[2];if(!r)return[3,5];if(-1===b.indexOf(r))return[3,3];if(!v.default[l]||!v.default[l][E])return console.error(h.REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE),[2];if(_=v.default[l][E],g=i||"",c&&m.default.empty(me))return Ce(!0,_.empty(g)),[2];if(""!==String(me)){if(e&&m.default.reg(e,me))return Ce(!0,""!==s?s:_.invalid(g)),[2];if(t||n)if(t&&n){if(String(me).lengthn)return Ce(!0,_.inBetween(g)(t)(n)),[2]}else{if(t&&String(me).lengthn)return Ce(!0,_.greaterThan(g)(n)),[2]}if(u&&String(me).length!==u)return Ce(!0,_.lengthEqual(g)(u)),[2]}return f&&"function"==typeof f?[4,f(me)]:[3,2];case 1:if("object"==typeof(y=o.sent()))return"boolean"==typeof y.error&&"string"==typeof y.message&&(!1===y.error&&!0===y.showOnSuccess&&_e(y.message),Ce(y.error,y.message,!0)),[2];if(!0!==y)return Ce(!0,y,!0),[2];o.label=2;case 2:return d&&_e(d),Ce(!1,d),[3,4];case 3:console.error("The valid "+p.default.toCamelCase(E)(!0)+' "type" options in validationOption are ['+b.map((function(e){return e}))+"]"),o.label=4;case 4:return[3,6];case 5:console.error('Please provide "type" in validationOption'),o.label=6;case 6:return[2]}}))}))}),[me,ge]),Ce=d((function(e,t,n){void 0===n&&(n=!1);var r=t,i=ge.msgOnError;e&&i&&!n&&(r=i),ue(e),ce(r),ie&&ie(e)}),[ge.msgOnError]);c((function(){M&&Te()}),[M]),c((function(){pe(String(N))}),[N]),c((function(){void 0!==he&&he!==me&&ge.customFunc&&ne&&Te()}),[me]),c((function(){Ee&&Ee.message&&(Ee.showOnError&&Ce(Ee.error,Ee.message),!Ee.error&&Ee.showOnSuccess&&_e(Ee.message))}),[X]);var xe,Me=R+" "+g.default[E+"__wrapper"]+" "+(ae&&g.default.error)+" "+(""!==fe&&!ae&&g.default.success)+" "+(C&&g.default.disabled),Le=F+" "+g.default[E+"__container"]+" "+(ae&&g.default.error)+" "+(""!==fe&&!ae&&g.default.success)+" "+(C&&g.default.disabled),Ae=A+" "+g.default[E+"__input"]+" "+(ae&&g.default.error)+" "+(""!==fe&&!ae&&g.default.success)+" "+(C&&g.default.disabled),ke=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(ae&&g.default.error),Re=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(!ae&&g.default.success),Pe=ge.showMsg;return Pe&&ae&&le&&(xe=s.createElement("div",{className:ke},le)),Pe&&!ae&&""!==fe&&(xe=s.createElement("div",{className:Re},fe)),s.createElement("div",r({className:Me,style:U},S),s.createElement("div",{className:Le,style:V},s.createElement("textarea",r({value:me,disabled:C,onBlur:Se,onKeyUp:Ie,onFocus:we,onClick:Oe,className:Ae,onChange:Ne,style:j,ref:be},O))),xe)}))},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n=a){var u=Math.abs(o-a-i);u>=0&&!y?(rt.current.scrollTop=r+i-u,y=!0):rt.current.scrollTop=r+i}}"up"===e&&(y=!1,S*i<=r&&(rt.current.scrollTop=S*i))}else y=!1,rt.current.scrollTop=S*i}}),[]),gt=c((function(e,t){dt(e,t),Pe[1]("")}),[]),Et=c((function(e){S=e,St()}),[]),bt=c((function(){Ge(!1)}),[]),yt=c((function(){wt()}),[]),St=c((function(){if(Ye&&Ye.current&&Ye.current.children){var e=Ye.current.children;if(wt(),null===S)return;S>=e.length&&(S=0),S<0&&(S=e.length-1),e[S]&&(e[S].className+=" "+h.default[g+"__hover-active"])}}),[]),wt=c((function(){if(Ye&&Ye.current&&Ye.current.children)for(var e=Ye.current.children,t=0;tot.length-1&&(S=0,ht("up")),St();else if(38===e)(S-=1)<0&&(S=ot.length-1,ht("loop")),St();else if(13===e&&S>-1&&Ye&&Ye.current&&Ye.current.children){var t=Ye.current.children;if(!t[S])return;t[S].click()}}),[ot]),Nt=c((function(e){if(!F&&(Ge(!0),e.preventDefault&&e.preventDefault(),qe)){S=null===S?t.getIndex(ot,String(M)):S;var n=e.keyCode,r=Ot(n);if(-1!==E.indexOf(n))It(n);else{pt();var o=i(Xe,[n]),a=String.fromCharCode.apply(String,o).toLowerCase(),u=-1;ot.forEach((function(e,t){e.name.toLowerCase().startsWith(a)&&-1===u&&(u=t)})),-1!==u&&(S=u,St()),He(o)}return ht(r),S}}),[qe,M,Xe]);l((function(){return qe&&nt&&document.addEventListener("keydown",Nt),function(){document.removeEventListener("keydown",Nt)}}),[qe,M,Xe]),l((function(){R&&ft()}),[R]),l((function(){t.isValidValue(ot,ke)&&""!==ke&&"null"!==ke&&"undefined"!==ke?Ie(!1):Le("")}),[ke]),l((function(){Re(String(M))}),[M]),l((function(){De&&De&&!p.default.arraysEqual(De,U)&&Re(String(U[0].id))}),[U]),l((function(){void 0!==Fe&&Fe!==ke&&ft()}),[Fe,ke]),l((function(){Je&&Je.message&&(Je.showOnError&&_t(Je.error,Je.message),!Je.error&&Je.showOnSuccess&&Le(Je.message))}),[fe]),l((function(){qe&&(F&&et.current.focus(),S=null===S?t.getIndex(ot,String(M)):S,it[S]&&it[S].current.focus()),!0===Be&&!1===qe&&tt.current.focus(),mt()}),[qe]);var Tt,Ct,xt=m.WRAPPER_CLASS_IDENTITIFIER+" "+V+" "+h.default.select__wrapper+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Mt=m.CONTAINER_CLASS_IDENTITIFIER+" "+G+" "+h.default.select__container+" "+(Oe&&h.default.error)+" "+(qe&&h.default.show)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Lt=h.default.select__input+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),At=X+" "+h.default.ellipsis+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),kt=Z+" "+h.default[g+"__options-container"]+" "+(Oe&&h.default.error)+" "+(qe&&h.default.show)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Rt=h.default.button+" "+(!We&&h.default[g+"__options-item-show-cursor"])+" "+K+" "+h.default[g+"__options-item"]+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Pt=Y+" "+h.default[g+"__dropdown-icon"],Ft=m.MSG_CLASS_IDENTITIFIER+" "+h.default.msg+" "+(Oe&&h.default.error),Dt=m.MSG_CLASS_IDENTITIFIER+" "+h.default.msg+" "+(!Oe&&h.default.success),jt=Ke.showMsg;jt&&Oe&&Te&&(Tt=u.createElement("div",{className:Ft},Te)),jt&&!Oe&&""!==Me&&(Tt=u.createElement("div",{className:Dt},Me));var qt=t.getItem(U,String(M));ot.length?Ct=ot.map((function(e,n){return u.createElement(t.Option,{key:n,index:n,id:"react-inputs-validation__select_option-"+e.id,className:String(e.id)===String(M)?Rt+" "+h.default.active:""+Rt,item:e,customStyleOptionListItem:ae,onClick:gt,onMouseOver:Et,onMouseMove:bt,onMouseOut:yt})})):F&&(Ct=u.createElement("div",{style:{background:"#fff",textAlign:"center",padding:"20px"}},u.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24"},u.createElement("path",{d:"M0 0h24v24H0z",fill:"none"}),u.createElement("path",{fill:"#cdcdcd",d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zM4 12c0-4.42 3.58-8 8-8 1.85 0 3.55.63 4.9 1.69L5.69 16.9C4.63 15.55 4 13.85 4 12zm8 8c-1.85 0-3.55-.63-4.9-1.69L18.31 7.1C19.37 8.45 20 10.15 20 12c0 4.42-3.58 8-8 8z"}))));var Ut=u.createElement("div",{className:h.default.select__dropdown},u.createElement("div",{className:h.default[g+"__dropdown-name"]+" "+h.default.ellipsis},qt?qt.name:""),u.createElement("div",{className:Pt}));return u.createElement("button",r({ref:Ze,type:"button",className:h.default.button,onClick:function(e){if(ct(e),!A){if($e.current&&$e.current.contains(e.target))return void Ue(!0);Ue(!qe)}},onFocus:lt,onBlur:st},N),u.createElement("div",{ref:Qe,className:xt,style:ee},u.createElement("div",{className:Mt,style:ne},u.createElement("input",r({type:"hidden",value:ke,className:Lt,onChange:function(){}},C)),u.createElement("div",{className:At,style:ie},Ut),u.createElement("div",{className:kt},F&&u.createElement("div",{ref:$e},u.createElement("div",{className:h.default.select__searchInputWrapper},u.createElement("svg",{className:h.default.select__searchInputSearchIcon,xmlns:"http://www.w3.org/2000/svg",width:"20",height:"20",viewBox:"0 0 24 24"},u.createElement("path",{fill:"#cdcdcd",d:"M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z"}),u.createElement("path",{d:"M0 0h24v24H0z",fill:"none"})),u.createElement("input",{className:h.default.select__searchInput,ref:et,value:Pe[0],onChange:at,onKeyDown:ut}),Pe[0]&&u.createElement("svg",{className:h.default.select__searchInputRemoveIcon,xmlns:"http://www.w3.org/2000/svg",width:"15",height:"15",viewBox:"0 0 24 24",onClick:function(){Pe[1](""),et.current.focus()}},u.createElement("path",{fill:"#cdcdcd",d:"M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7 12 10.59 15.59 7 17 8.41 13.41 12 17 15.59z"}),u.createElement("path",{d:"M0 0h24v24H0z",fill:"none"})))),u.createElement("div",{ref:Ye,style:se},Ct))),Tt))}))},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n=48&&n<=57||n>=97&&n<=122)&&(t+=e)})),t},getAlpha:function(e){var t="";return String(e).split("").forEach((function(e){var n=e.toLowerCase().charCodeAt(0);n>=97&&n<=122&&(t+=e)})),t},getNumeric:function(e){var t="";return String(e).split("").forEach((function(e){var n=e.toLowerCase().charCodeAt(0);n>=48&&n<=57&&(t+=e)})),t},arraysEqual:function(e,t){if(e.length!==t.length)return!1;for(var n=e.length;n-=1;)if(JSON.stringify(e[n])!==JSON.stringify(t[n]))return!1;return!0}};t.default=i},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=function(e){return!isNaN(parseFloat(e))&&isFinite(e)},i={reg:function(e,t){var n=!0;return e.test(t)&&(n=!1),n},empty:function(e){return!e.replace(/\s/g,"").length},number:function(e,t,n){return null===t&&null===n||!!r(e)&&!(en)}};t.default=i},function(e,t,n){"use strict";var r=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(t,"__esModule",{value:!0});var i=r(n(7));t.Textbox=i.default;var o=r(n(8));t.Textarea=o.default;var a=r(n(9));t.Select=a.default;var u=r(n(10));t.Checkbox=u.default;var s=r(n(11));t.Radiobox=s.default,"undefined"!=typeof window&&(window.Textbox=i.default,window.Textarea=o.default,window.Radiobox=s.default,window.Checkbox=u.default,window.Select=a.default)},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n0&&i[i.length-1])||6!==o[0]&&2!==o[0])){a=0;continue}if(3===o[0]&&(!i||o[1]>i[0]&&o[1]Number(I.maxLength))){var n=Ee.type,r=Ee.numberType,i=Ee.mantissa;n===b[1]&&(t=String(function(e,t,n){var r="",i=!1,o=String(e).split("");o[0];if(t===y[2]&&"0"===o[0]&&"0"===o[1]&&o.shift(),o.forEach((function(e){var n=e.toLowerCase().charCodeAt(0);if(n>=48&&n<=57||46===n&&!i){if(46===n){if(t===y[1])return;i=!0}r+=e}})),i&&n>=0){var a=r.split(".");0===n?r=a[0]:(a[1]=a[1].slice(0,n),r=a.join("."))}return t!==y[0]&&t!==y[2]||r.length&&"."===r[0]&&(r="0"+r),r}(t,y.indexOf(r)>=0?r:y[0],i))),n===b[2]&&(t=p.default.getAlphanumeric(t)),n===b[3]&&(t=p.default.getAlpha(t)),he(t),J&&J(t,e),ue?se(!1):ve("")}}}),[ue,I,Ee]),Ce=d((function(){return i(void 0,void 0,void 0,(function(){var e,t,n,r,i,a,u,s,l,c,d,f,_,g,y,S;return o(this,(function(o){switch(o.label){case 0:if(e=Ee.reg,t=Ee.min,n=Ee.max,r=Ee.type,i=Ee.name,a=Ee.check,u=Ee.length,s=Ee.regMsg,l=Ee.locale,c=Ee.compare,d=Ee.required,f=Ee.msgOnSuccess,_=Ee.customFunc,!a)return[2];if(!r)return[3,5];if(-1===b.indexOf(r))return[3,3];if(!v.default[l]||!v.default[l][E])return console.error(h.REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE),[2];if(g=v.default[l][E],y=i||"",d&&m.default.empty(pe))return xe(!0,g.empty(y)),[2];if(""!==String(pe)){if(e&&m.default.reg(e,pe))return xe(!0,""!==s?s:g.invalid(y)),[2];if(r===b[0]){if(t||n)if(t&&n){if(String(pe).lengthn)return xe(!0,g.inBetween(y)(t)(n)),[2]}else{if(t&&String(pe).lengthn)return xe(!0,g.greaterThan(y)(n)),[2]}if(u&&String(pe).length!==u)return xe(!0,g.lengthEqual(y)(u)),[2]}if(r===b[1]){if(!m.default[r](pe,null,null))return xe(!0,g.invalid(y)),[2];if(t||n)if(t&&n){if(!m.default[r](pe,t,n))return xe(!0,g.inBetween(y)(t)(n)),[2]}else{if(t&&!m.default[r](pe,t))return xe(!0,g.lessThan(y)(t)),[2];if(n&&!m.default[r](pe,0,n))return xe(!0,g.greaterThan(y)(n)),[2]}if(u&&String(pe).length!==u)return xe(!0,g.lengthEqual(y)(u)),[2]}if(c&&""!==c&&pe!==c)return xe(!0,g.twoInputsNotEqual()),[2]}return _&&"function"==typeof _?[4,_(pe)]:[3,2];case 1:if("object"==typeof(S=o.sent()))return"boolean"==typeof S.error&&"string"==typeof S.message&&(!1===S.error&&!0===S.showOnSuccess&&ve(S.message),xe(S.error,S.message,!0)),[2];if(!0!==S)return xe(!0,S,!0),[2];o.label=2;case 2:return f&&ve(f),xe(!1,f),[3,4];case 3:console.error("The valid "+p.default.toCamelCase(E)(!0)+' "type" options in validationOption are ['+b.map((function(e){return e}))+"]"),o.label=4;case 4:return[3,6];case 5:console.error('Please provide "type" in validationOption'),o.label=6;case 6:return[2]}}))}))}),[pe,Ee]),xe=d((function(e,t,n){void 0===n&&(n=!1);var r=t,i=Ee.msgOnError;e&&i&&!n&&(r=i),se(e),de(r),oe&&oe(e)}),[]);c((function(){L&&Ce()}),[L]),c((function(){he(String(T))}),[T]),c((function(){void 0!==ge&&ge!==pe&&Ee.customFunc&&re&&Ce()}),[pe]),c((function(){be&&be.message&&(be.showOnError&&xe(be.error,be.message),!be.error&&be.showOnSuccess&&ve(be.message))}),[H]);var Me,Le=P+" "+g.default[E+"__wrapper"]+" "+(ue&&g.default.error)+" "+(""!==_e&&!ue&&g.default.success)+" "+(x&&g.default.disabled),Ae=D+" "+g.default[E+"__container"]+" "+(ue&&g.default.error)+" "+(""!==_e&&!ue&&g.default.success)+" "+(x&&g.default.disabled),ke=k+" "+g.default[E+"__input"]+" "+(ue&&g.default.error)+" "+(""!==_e&&!ue&&g.default.success)+" "+(x&&g.default.disabled),Re=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(ue&&g.default.error),Pe=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(!ue&&g.default.success),Fe=Ee.showMsg;return Fe&&ue&&ce&&(Me=s.createElement("div",{className:Re},ce)),Fe&&!ue&&""!==_e&&(Me=s.createElement("div",{className:Pe},_e)),s.createElement("div",r({className:Le,style:B},w),s.createElement("div",{className:Ae,style:W},s.createElement("input",r({type:"text",value:pe,disabled:x,onBlur:we,onKeyUp:Ne,onFocus:Oe,onClick:Ie,className:ke,onChange:Te,style:q,ref:ye},I))),Me)}))},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n0&&i[i.length-1])||6!==o[0]&&2!==o[0])){a=0;continue}if(3===o[0]&&(!i||o[1]>i[0]&&o[1]Number(O.maxLength)||(pe(t),K&&K(t,e),ae?ue(!1):_e(""))}}),[ae]),Te=d((function(){return i(void 0,void 0,void 0,(function(){var e,t,n,r,i,a,u,s,l,c,d,f,_,g,y;return o(this,(function(o){switch(o.label){case 0:if(e=ge.reg,t=ge.min,n=ge.max,r=ge.type,i=ge.name,a=ge.check,u=ge.length,s=ge.regMsg,l=ge.locale,c=ge.required,d=ge.msgOnSuccess,f=ge.customFunc,!a)return[2];if(!r)return[3,5];if(-1===b.indexOf(r))return[3,3];if(!v.default[l]||!v.default[l][E])return console.error(h.REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE),[2];if(_=v.default[l][E],g=i||"",c&&m.default.empty(me))return Ce(!0,_.empty(g)),[2];if(""!==String(me)){if(e&&m.default.reg(e,me))return Ce(!0,""!==s?s:_.invalid(g)),[2];if(t||n)if(t&&n){if(String(me).lengthn)return Ce(!0,_.inBetween(g)(t)(n)),[2]}else{if(t&&String(me).lengthn)return Ce(!0,_.greaterThan(g)(n)),[2]}if(u&&String(me).length!==u)return Ce(!0,_.lengthEqual(g)(u)),[2]}return f&&"function"==typeof f?[4,f(me)]:[3,2];case 1:if("object"==typeof(y=o.sent()))return"boolean"==typeof y.error&&"string"==typeof y.message&&(!1===y.error&&!0===y.showOnSuccess&&_e(y.message),Ce(y.error,y.message,!0)),[2];if(!0!==y)return Ce(!0,y,!0),[2];o.label=2;case 2:return d&&_e(d),Ce(!1,d),[3,4];case 3:console.error("The valid "+p.default.toCamelCase(E)(!0)+' "type" options in validationOption are ['+b.map((function(e){return e}))+"]"),o.label=4;case 4:return[3,6];case 5:console.error('Please provide "type" in validationOption'),o.label=6;case 6:return[2]}}))}))}),[me,ge]),Ce=d((function(e,t,n){void 0===n&&(n=!1);var r=t,i=ge.msgOnError;e&&i&&!n&&(r=i),ue(e),ce(r),ie&&ie(e)}),[]);c((function(){M&&Te()}),[M]),c((function(){pe(String(N))}),[N]),c((function(){void 0!==he&&he!==me&&ge.customFunc&&ne&&Te()}),[me]),c((function(){Ee&&Ee.message&&(Ee.showOnError&&Ce(Ee.error,Ee.message),!Ee.error&&Ee.showOnSuccess&&_e(Ee.message))}),[X]);var xe,Me=R+" "+g.default[E+"__wrapper"]+" "+(ae&&g.default.error)+" "+(""!==fe&&!ae&&g.default.success)+" "+(C&&g.default.disabled),Le=F+" "+g.default[E+"__container"]+" "+(ae&&g.default.error)+" "+(""!==fe&&!ae&&g.default.success)+" "+(C&&g.default.disabled),Ae=A+" "+g.default[E+"__input"]+" "+(ae&&g.default.error)+" "+(""!==fe&&!ae&&g.default.success)+" "+(C&&g.default.disabled),ke=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(ae&&g.default.error),Re=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(!ae&&g.default.success),Pe=ge.showMsg;return Pe&&ae&&le&&(xe=s.createElement("div",{className:ke},le)),Pe&&!ae&&""!==fe&&(xe=s.createElement("div",{className:Re},fe)),s.createElement("div",r({className:Me,style:U},S),s.createElement("div",{className:Le,style:V},s.createElement("textarea",r({value:me,disabled:C,onBlur:Se,onKeyUp:Ie,onFocus:we,onClick:Oe,className:Ae,onChange:Ne,style:j,ref:be},O))),xe)}))},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n=a){var u=Math.abs(o-a-i);u>=0&&!y?(rt.current.scrollTop=r+i-u,y=!0):rt.current.scrollTop=r+i}}"up"===e&&(y=!1,S*i<=r&&(rt.current.scrollTop=S*i))}else y=!1,rt.current.scrollTop=S*i}}),[]),gt=c((function(e,t){dt(e,t),Pe[1]("")}),[]),Et=c((function(e){S=e,St()}),[]),bt=c((function(){Ge(!1)}),[]),yt=c((function(){wt()}),[]),St=c((function(){if(Ye&&Ye.current&&Ye.current.children){var e=Ye.current.children;if(wt(),null===S)return;S>=e.length&&(S=0),S<0&&(S=e.length-1),e[S]&&(e[S].className+=" "+h.default[g+"__hover-active"])}}),[]),wt=c((function(){if(Ye&&Ye.current&&Ye.current.children)for(var e=Ye.current.children,t=0;tot.length-1&&(S=0,ht("up")),St();else if(38===e)(S-=1)<0&&(S=ot.length-1,ht("loop")),St();else if(13===e&&S>-1&&Ye&&Ye.current&&Ye.current.children){var t=Ye.current.children;if(!t[S])return;t[S].click()}}),[ot]),Nt=c((function(e){if(!F&&(Ge(!0),e.preventDefault&&e.preventDefault(),qe)){S=null===S?t.getIndex(ot,String(M)):S;var n=e.keyCode,r=Ot(n);if(-1!==E.indexOf(n))It(n);else{pt();var o=i(Xe,[n]),a=String.fromCharCode.apply(String,o).toLowerCase(),u=-1;ot.forEach((function(e,t){e.name.toLowerCase().startsWith(a)&&-1===u&&(u=t)})),-1!==u&&(S=u,St()),He(o)}return ht(r),S}}),[qe,M,Xe]);l((function(){return qe&&nt&&document.addEventListener("keydown",Nt),function(){document.removeEventListener("keydown",Nt)}}),[qe,M,Xe]),l((function(){R&&ft()}),[R]),l((function(){t.isValidValue(ot,ke)&&""!==ke&&"null"!==ke&&"undefined"!==ke?Ie(!1):Le("")}),[ke]),l((function(){Re(String(M))}),[M]),l((function(){De&&De&&!p.default.arraysEqual(De,U)&&Re(String(U[0].id))}),[U]),l((function(){void 0!==Fe&&Fe!==ke&&ft()}),[Fe,ke]),l((function(){Je&&Je.message&&(Je.showOnError&&_t(Je.error,Je.message),!Je.error&&Je.showOnSuccess&&Le(Je.message))}),[fe]),l((function(){qe&&(F&&et.current.focus(),S=null===S?t.getIndex(ot,String(M)):S,it[S]&&it[S].current.focus()),!0===Be&&!1===qe&&tt.current.focus(),mt()}),[qe]);var Tt,Ct,xt=m.WRAPPER_CLASS_IDENTITIFIER+" "+V+" "+h.default.select__wrapper+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Mt=m.CONTAINER_CLASS_IDENTITIFIER+" "+G+" "+h.default.select__container+" "+(Oe&&h.default.error)+" "+(qe&&h.default.show)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Lt=h.default.select__input+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),At=X+" "+h.default.ellipsis+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),kt=Z+" "+h.default[g+"__options-container"]+" "+(Oe&&h.default.error)+" "+(qe&&h.default.show)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Rt=h.default.button+" "+(!We&&h.default[g+"__options-item-show-cursor"])+" "+K+" "+h.default[g+"__options-item"]+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Pt=Y+" "+h.default[g+"__dropdown-icon"],Ft=m.MSG_CLASS_IDENTITIFIER+" "+h.default.msg+" "+(Oe&&h.default.error),Dt=m.MSG_CLASS_IDENTITIFIER+" "+h.default.msg+" "+(!Oe&&h.default.success),jt=Ke.showMsg;jt&&Oe&&Te&&(Tt=u.createElement("div",{className:Ft},Te)),jt&&!Oe&&""!==Me&&(Tt=u.createElement("div",{className:Dt},Me));var qt=t.getItem(U,String(M));ot.length?Ct=ot.map((function(e,n){return u.createElement(t.Option,{key:n,index:n,id:"react-inputs-validation__select_option-"+e.id,className:String(e.id)===String(M)?Rt+" "+h.default.active:""+Rt,item:e,customStyleOptionListItem:ae,onClick:gt,onMouseOver:Et,onMouseMove:bt,onMouseOut:yt})})):F&&(Ct=u.createElement("div",{style:{background:"#fff",textAlign:"center",padding:"20px"}},u.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24"},u.createElement("path",{d:"M0 0h24v24H0z",fill:"none"}),u.createElement("path",{fill:"#cdcdcd",d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zM4 12c0-4.42 3.58-8 8-8 1.85 0 3.55.63 4.9 1.69L5.69 16.9C4.63 15.55 4 13.85 4 12zm8 8c-1.85 0-3.55-.63-4.9-1.69L18.31 7.1C19.37 8.45 20 10.15 20 12c0 4.42-3.58 8-8 8z"}))));var Ut=u.createElement("div",{className:h.default.select__dropdown},u.createElement("div",{className:h.default[g+"__dropdown-name"]+" "+h.default.ellipsis},qt?qt.name:""),u.createElement("div",{className:Pt}));return u.createElement("button",r({ref:Ze,type:"button",className:h.default.button,onClick:function(e){if(ct(e),!A){if($e.current&&$e.current.contains(e.target))return void Ue(!0);Ue(!qe)}},onFocus:lt,onBlur:st},N),u.createElement("div",{ref:Qe,className:xt,style:ee},u.createElement("div",{className:Mt,style:ne},u.createElement("input",r({type:"hidden",value:ke,className:Lt,onChange:function(){}},C)),u.createElement("div",{className:At,style:ie},Ut),u.createElement("div",{className:kt},F&&u.createElement("div",{ref:$e},u.createElement("div",{className:h.default.select__searchInputWrapper},u.createElement("svg",{className:h.default.select__searchInputSearchIcon,xmlns:"http://www.w3.org/2000/svg",width:"20",height:"20",viewBox:"0 0 24 24"},u.createElement("path",{fill:"#cdcdcd",d:"M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z"}),u.createElement("path",{d:"M0 0h24v24H0z",fill:"none"})),u.createElement("input",{className:h.default.select__searchInput,ref:et,value:Pe[0],onChange:at,onKeyDown:ut}),Pe[0]&&u.createElement("svg",{className:h.default.select__searchInputRemoveIcon,xmlns:"http://www.w3.org/2000/svg",width:"15",height:"15",viewBox:"0 0 24 24",onClick:function(){Pe[1](""),et.current.focus()}},u.createElement("path",{fill:"#cdcdcd",d:"M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7 12 10.59 15.59 7 17 8.41 13.41 12 17 15.59z"}),u.createElement("path",{d:"M0 0h24v24H0z",fill:"none"})))),u.createElement("div",{ref:Ye,style:se},Ct))),Tt))}))},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n=48&&n<=57||n>=97&&n<=122)&&(t+=e)})),t},getAlpha:function(e){var t="";return String(e).split("").forEach((function(e){var n=e.toLowerCase().charCodeAt(0);n>=97&&n<=122&&(t+=e)})),t},getNumeric:function(e){var t="";return String(e).split("").forEach((function(e){var n=e.toLowerCase().charCodeAt(0);n>=48&&n<=57&&(t+=e)})),t},arraysEqual:function(e,t){if(e.length!==t.length)return!1;for(var n=e.length;n-=1;)if(JSON.stringify(e[n])!==JSON.stringify(t[n]))return!1;return!0}};t.default=o},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=function(e){return!isNaN(parseFloat(e))&&isFinite(e)},o={reg:function(e,t){var n=!0;return e.test(t)&&(n=!1),n},empty:function(e){return!e.replace(/\s/g,"").length},number:function(e,t,n){return null===t&&null===n||!!r(e)&&!(en)}};t.default=o},function(e,t,n){"use strict";var r=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(t,"__esModule",{value:!0});var o=r(n(7));t.Textbox=o.default;var i=r(n(8));t.Textarea=i.default;var a=r(n(9));t.Select=a.default;var u=r(n(10));t.Checkbox=u.default;var s=r(n(11));t.Radiobox=s.default,"undefined"!=typeof window&&(window.Textbox=o.default,window.Textarea=i.default,window.Radiobox=s.default,window.Checkbox=u.default,window.Select=a.default)},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n0&&o[o.length-1])||6!==i[0]&&2!==i[0])){a=0;continue}if(3===i[0]&&(!o||i[1]>o[0]&&i[1]Number(I.maxLength))){var n=Ee.type,r=Ee.numberType,o=Ee.mantissa;n===b[1]&&(t=String(function(e,t,n){var r="",o=!1,i=String(e).split("");i[0];if(t===y[2]&&"0"===i[0]&&"0"===i[1]&&i.shift(),i.forEach((function(e){var n=e.toLowerCase().charCodeAt(0);if(n>=48&&n<=57||46===n&&!o){if(46===n){if(t===y[1])return;o=!0}r+=e}})),o&&n>=0){var a=r.split(".");0===n?r=a[0]:(a[1]=a[1].slice(0,n),r=a.join("."))}return t!==y[0]&&t!==y[2]||r.length&&"."===r[0]&&(r="0"+r),r}(t,y.indexOf(r)>=0?r:y[0],o))),n===b[2]&&(t=p.default.getAlphanumeric(t)),n===b[3]&&(t=p.default.getAlpha(t)),he(t),J&&J(t,e),ue?se(!1):ve("")}}}),[ue,I,Ee]),Ce=d((function(){return o(void 0,void 0,void 0,(function(){var e,t,n,r,o,a,u,s,l,c,d,f,_,g,y,S;return i(this,(function(i){switch(i.label){case 0:if(e=Ee.reg,t=Ee.min,n=Ee.max,r=Ee.type,o=Ee.name,a=Ee.check,u=Ee.length,s=Ee.regMsg,l=Ee.locale,c=Ee.compare,d=Ee.required,f=Ee.msgOnSuccess,_=Ee.customFunc,!a)return[2];if(!r)return[3,5];if(-1===b.indexOf(r))return[3,3];if(!v.default[l]||!v.default[l][E])return console.error(h.REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE),[2];if(g=v.default[l][E],y=o||"",d&&m.default.empty(pe))return xe(!0,g.empty(y)),[2];if(""!==String(pe)){if(e&&m.default.reg(e,pe))return xe(!0,""!==s?s:g.invalid(y)),[2];if(r===b[0]){if(t||n)if(t&&n){if(String(pe).lengthn)return xe(!0,g.inBetween(y)(t)(n)),[2]}else{if(t&&String(pe).lengthn)return xe(!0,g.greaterThan(y)(n)),[2]}if(u&&String(pe).length!==u)return xe(!0,g.lengthEqual(y)(u)),[2]}if(r===b[1]){if(!m.default[r](pe,null,null))return xe(!0,g.invalid(y)),[2];if(t||n)if(t&&n){if(!m.default[r](pe,t,n))return xe(!0,g.inBetween(y)(t)(n)),[2]}else{if(t&&!m.default[r](pe,t))return xe(!0,g.lessThan(y)(t)),[2];if(n&&!m.default[r](pe,0,n))return xe(!0,g.greaterThan(y)(n)),[2]}if(u&&String(pe).length!==u)return xe(!0,g.lengthEqual(y)(u)),[2]}if(c&&""!==c&&pe!==c)return xe(!0,g.twoInputsNotEqual()),[2]}return _&&"function"==typeof _?[4,_(pe)]:[3,2];case 1:if("object"==typeof(S=i.sent()))return"boolean"==typeof S.error&&"string"==typeof S.message&&(!1===S.error&&!0===S.showOnSuccess&&ve(S.message),xe(S.error,S.message,!0)),[2];if(!0!==S)return xe(!0,S,!0),[2];i.label=2;case 2:return f&&ve(f),xe(!1,f),[3,4];case 3:console.error("The valid "+p.default.toCamelCase(E)(!0)+' "type" options in validationOption are ['+b.map((function(e){return e}))+"]"),i.label=4;case 4:return[3,6];case 5:console.error('Please provide "type" in validationOption'),i.label=6;case 6:return[2]}}))}))}),[pe,Ee]),xe=d((function(e,t,n){void 0===n&&(n=!1);var r=t,o=Ee.msgOnError;e&&o&&!n&&(r=o),se(e),de(r),ie&&ie(e)}),[Ee.msgOnError]);c((function(){L&&Ce()}),[L]),c((function(){he(String(T))}),[T]),c((function(){void 0!==ge&&ge!==pe&&Ee.customFunc&&re&&Ce()}),[pe]),c((function(){be&&be.message&&(be.showOnError&&xe(be.error,be.message),!be.error&&be.showOnSuccess&&ve(be.message))}),[H]);var Me,Le=P+" "+g.default[E+"__wrapper"]+" "+(ue&&g.default.error)+" "+(""!==_e&&!ue&&g.default.success)+" "+(x&&g.default.disabled),Ae=D+" "+g.default[E+"__container"]+" "+(ue&&g.default.error)+" "+(""!==_e&&!ue&&g.default.success)+" "+(x&&g.default.disabled),ke=k+" "+g.default[E+"__input"]+" "+(ue&&g.default.error)+" "+(""!==_e&&!ue&&g.default.success)+" "+(x&&g.default.disabled),Re=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(ue&&g.default.error),Pe=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(!ue&&g.default.success),Fe=Ee.showMsg;return Fe&&ue&&ce&&(Me=s.createElement("div",{className:Re},ce)),Fe&&!ue&&""!==_e&&(Me=s.createElement("div",{className:Pe},_e)),s.createElement("div",r({className:Le,style:B},w),s.createElement("div",{className:Ae,style:W},s.createElement("input",r({type:"text",value:pe,disabled:x,onBlur:we,onKeyUp:Ne,onFocus:Oe,onClick:Ie,className:ke,onChange:Te,style:q,ref:ye},I))),Me)}))},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n0&&o[o.length-1])||6!==i[0]&&2!==i[0])){a=0;continue}if(3===i[0]&&(!o||i[1]>o[0]&&i[1]Number(O.maxLength)||(pe(t),K&&K(t,e),ae?ue(!1):_e(""))}}),[ae]),Te=d((function(){return o(void 0,void 0,void 0,(function(){var e,t,n,r,o,a,u,s,l,c,d,f,_,g,y;return i(this,(function(i){switch(i.label){case 0:if(e=ge.reg,t=ge.min,n=ge.max,r=ge.type,o=ge.name,a=ge.check,u=ge.length,s=ge.regMsg,l=ge.locale,c=ge.required,d=ge.msgOnSuccess,f=ge.customFunc,!a)return[2];if(!r)return[3,5];if(-1===b.indexOf(r))return[3,3];if(!v.default[l]||!v.default[l][E])return console.error(h.REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE),[2];if(_=v.default[l][E],g=o||"",c&&m.default.empty(me))return Ce(!0,_.empty(g)),[2];if(""!==String(me)){if(e&&m.default.reg(e,me))return Ce(!0,""!==s?s:_.invalid(g)),[2];if(t||n)if(t&&n){if(String(me).lengthn)return Ce(!0,_.inBetween(g)(t)(n)),[2]}else{if(t&&String(me).lengthn)return Ce(!0,_.greaterThan(g)(n)),[2]}if(u&&String(me).length!==u)return Ce(!0,_.lengthEqual(g)(u)),[2]}return f&&"function"==typeof f?[4,f(me)]:[3,2];case 1:if("object"==typeof(y=i.sent()))return"boolean"==typeof y.error&&"string"==typeof y.message&&(!1===y.error&&!0===y.showOnSuccess&&_e(y.message),Ce(y.error,y.message,!0)),[2];if(!0!==y)return Ce(!0,y,!0),[2];i.label=2;case 2:return d&&_e(d),Ce(!1,d),[3,4];case 3:console.error("The valid "+p.default.toCamelCase(E)(!0)+' "type" options in validationOption are ['+b.map((function(e){return e}))+"]"),i.label=4;case 4:return[3,6];case 5:console.error('Please provide "type" in validationOption'),i.label=6;case 6:return[2]}}))}))}),[me,ge]),Ce=d((function(e,t,n){void 0===n&&(n=!1);var r=t,o=ge.msgOnError;e&&o&&!n&&(r=o),ue(e),ce(r),oe&&oe(e)}),[ge.msgOnError]);c((function(){M&&Te()}),[M]),c((function(){pe(String(N))}),[N]),c((function(){void 0!==he&&he!==me&&ge.customFunc&&ne&&Te()}),[me]),c((function(){Ee&&Ee.message&&(Ee.showOnError&&Ce(Ee.error,Ee.message),!Ee.error&&Ee.showOnSuccess&&_e(Ee.message))}),[X]);var xe,Me=R+" "+g.default[E+"__wrapper"]+" "+(ae&&g.default.error)+" "+(""!==fe&&!ae&&g.default.success)+" "+(C&&g.default.disabled),Le=F+" "+g.default[E+"__container"]+" "+(ae&&g.default.error)+" "+(""!==fe&&!ae&&g.default.success)+" "+(C&&g.default.disabled),Ae=A+" "+g.default[E+"__input"]+" "+(ae&&g.default.error)+" "+(""!==fe&&!ae&&g.default.success)+" "+(C&&g.default.disabled),ke=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(ae&&g.default.error),Re=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(!ae&&g.default.success),Pe=ge.showMsg;return Pe&&ae&&le&&(xe=s.createElement("div",{className:ke},le)),Pe&&!ae&&""!==fe&&(xe=s.createElement("div",{className:Re},fe)),s.createElement("div",r({className:Me,style:U},S),s.createElement("div",{className:Le,style:V},s.createElement("textarea",r({value:me,disabled:C,onBlur:Se,onKeyUp:Ie,onFocus:we,onClick:Oe,className:Ae,onChange:Ne,style:j,ref:be},O))),xe)}))},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n=a){var u=Math.abs(i-a-o);u>=0&&!y?(rt.current.scrollTop=r+o-u,y=!0):rt.current.scrollTop=r+o}}"up"===e&&(y=!1,S*o<=r&&(rt.current.scrollTop=S*o))}else y=!1,rt.current.scrollTop=S*o}}),[]),gt=c((function(e,t){dt(e,t),Pe[1]("")}),[]),Et=c((function(e){S=e,St()}),[]),bt=c((function(){Ge(!1)}),[]),yt=c((function(){wt()}),[]),St=c((function(){if(Ye&&Ye.current&&Ye.current.children){var e=Ye.current.children;if(wt(),null===S)return;S>=e.length&&(S=0),S<0&&(S=e.length-1),e[S]&&(e[S].className+=" "+h.default[g+"__hover-active"])}}),[]),wt=c((function(){if(Ye&&Ye.current&&Ye.current.children)for(var e=Ye.current.children,t=0;tit.length-1&&(S=0,ht("up")),St();else if(38===e)(S-=1)<0&&(S=it.length-1,ht("loop")),St();else if(13===e&&S>-1&&Ye&&Ye.current&&Ye.current.children){var t=Ye.current.children;if(!t[S])return;t[S].click()}}),[it]),Nt=c((function(e){if(!F&&(Ge(!0),e.preventDefault&&e.preventDefault(),qe)){S=null===S?t.getIndex(it,String(M)):S;var n=e.keyCode,r=Ot(n);if(-1!==E.indexOf(n))It(n);else{pt();var i=o(Xe,[n]),a=String.fromCharCode.apply(String,i).toLowerCase(),u=-1;it.forEach((function(e,t){e.name.toLowerCase().startsWith(a)&&-1===u&&(u=t)})),-1!==u&&(S=u,St()),He(i)}return ht(r),S}}),[qe,M,Xe]);l((function(){return qe&&nt&&document.addEventListener("keydown",Nt),function(){document.removeEventListener("keydown",Nt)}}),[qe,M,Xe]),l((function(){R&&ft()}),[R]),l((function(){t.isValidValue(it,ke)&&""!==ke&&"null"!==ke&&"undefined"!==ke?Ie(!1):Le("")}),[ke]),l((function(){Re(String(M))}),[M]),l((function(){De&&De&&!p.default.arraysEqual(De,U)&&Re(String(U[0].id))}),[U]),l((function(){void 0!==Fe&&Fe!==ke&&ft()}),[Fe,ke]),l((function(){Je&&Je.message&&(Je.showOnError&&_t(Je.error,Je.message),!Je.error&&Je.showOnSuccess&&Le(Je.message))}),[fe]),l((function(){qe&&(F&&et.current.focus(),S=null===S?t.getIndex(it,String(M)):S,ot[S]&&ot[S].current.focus()),!0===Be&&!1===qe&&tt.current.focus(),mt()}),[qe]);var Tt,Ct,xt=m.WRAPPER_CLASS_IDENTITIFIER+" "+V+" "+h.default.select__wrapper+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Mt=m.CONTAINER_CLASS_IDENTITIFIER+" "+G+" "+h.default.select__container+" "+(Oe&&h.default.error)+" "+(qe&&h.default.show)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Lt=h.default.select__input+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),At=X+" "+h.default.ellipsis+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),kt=Z+" "+h.default[g+"__options-container"]+" "+(Oe&&h.default.error)+" "+(qe&&h.default.show)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Rt=h.default.button+" "+(!We&&h.default[g+"__options-item-show-cursor"])+" "+K+" "+h.default[g+"__options-item"]+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Pt=Y+" "+h.default[g+"__dropdown-icon"],Ft=m.MSG_CLASS_IDENTITIFIER+" "+h.default.msg+" "+(Oe&&h.default.error),Dt=m.MSG_CLASS_IDENTITIFIER+" "+h.default.msg+" "+(!Oe&&h.default.success),jt=Ke.showMsg;jt&&Oe&&Te&&(Tt=u.createElement("div",{className:Ft},Te)),jt&&!Oe&&""!==Me&&(Tt=u.createElement("div",{className:Dt},Me));var qt=t.getItem(U,String(M));it.length?Ct=it.map((function(e,n){return u.createElement(t.Option,{key:n,index:n,id:"react-inputs-validation__select_option-"+e.id,className:String(e.id)===String(M)?Rt+" "+h.default.active:""+Rt,item:e,customStyleOptionListItem:ae,onClick:gt,onMouseOver:Et,onMouseMove:bt,onMouseOut:yt})})):F&&(Ct=u.createElement("div",{style:{background:"#fff",textAlign:"center",padding:"20px"}},u.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24"},u.createElement("path",{d:"M0 0h24v24H0z",fill:"none"}),u.createElement("path",{fill:"#cdcdcd",d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zM4 12c0-4.42 3.58-8 8-8 1.85 0 3.55.63 4.9 1.69L5.69 16.9C4.63 15.55 4 13.85 4 12zm8 8c-1.85 0-3.55-.63-4.9-1.69L18.31 7.1C19.37 8.45 20 10.15 20 12c0 4.42-3.58 8-8 8z"}))));var Ut=u.createElement("div",{className:h.default.select__dropdown},u.createElement("div",{className:h.default[g+"__dropdown-name"]+" "+h.default.ellipsis},qt?qt.name:""),u.createElement("div",{className:Pt}));return u.createElement("button",r({ref:Ze,type:"button",className:h.default.button,onClick:function(e){if(ct(e),!A){if($e.current&&$e.current.contains(e.target))return void Ue(!0);Ue(!qe)}},onFocus:lt,onBlur:st},N),u.createElement("div",{ref:Qe,className:xt,style:ee},u.createElement("div",{className:Mt,style:ne},u.createElement("input",r({type:"hidden",value:ke,className:Lt,onChange:function(){}},C)),u.createElement("div",{className:At,style:oe},Ut),u.createElement("div",{className:kt},F&&u.createElement("div",{ref:$e},u.createElement("div",{className:h.default.select__searchInputWrapper},u.createElement("svg",{className:h.default.select__searchInputSearchIcon,xmlns:"http://www.w3.org/2000/svg",width:"20",height:"20",viewBox:"0 0 24 24"},u.createElement("path",{fill:"#cdcdcd",d:"M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z"}),u.createElement("path",{d:"M0 0h24v24H0z",fill:"none"})),u.createElement("input",{className:h.default.select__searchInput,ref:et,value:Pe[0],onChange:at,onKeyDown:ut}),Pe[0]&&u.createElement("svg",{className:h.default.select__searchInputRemoveIcon,xmlns:"http://www.w3.org/2000/svg",width:"15",height:"15",viewBox:"0 0 24 24",onClick:function(){Pe[1](""),et.current.focus()}},u.createElement("path",{fill:"#cdcdcd",d:"M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7 12 10.59 15.59 7 17 8.41 13.41 12 17 15.59z"}),u.createElement("path",{d:"M0 0h24v24H0z",fill:"none"})))),u.createElement("div",{ref:Ye,style:se},Ct))),Tt))}))},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n {\n const ref = useRef();\n useEffect(() => {\n ref.current = value;\n });\n return ref.current;\n};\n","import { REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE } from './const';\n\nconst getEnglishName = (name: string) => {\n let res = '';\n if (name) {\n res = `${name} `;\n }\n return res;\n};\n\nconst TEXT_BOX_VALIDATION_ZH_CN = {\n empty: (name: string) => `${name}不能为空`,\n invalid: (name: string) => `${name}格式有误`,\n invalidFormat: (name: string) => `${name}不是数字`,\n inBetween: (name: string) => (min: number) => (max: number) => `${name}必须在${min}-${max}之间`,\n lessThan: (name: string) => (min: number) => `${name}不可少于${min}`,\n greaterThan: (name: string) => (max: number) => `${name}不可大于${max}`,\n lengthEqual: (name: string) => (length: number) => `${name}长度必须为${length}`,\n twoInputsNotEqual: () => `两次输入不一致`,\n};\n\nconst TEXT_BOX_VALIDATION_EN_US = {\n empty: (name: string) => `${getEnglishName(name)}cannot be empty`,\n invalid: (name: string) => `${getEnglishName(name)}invalid format`,\n invalidFormat: (name: string) => `${getEnglishName(name)}is not a number`,\n inBetween: (name: string) => (min: number) => (max: number) => `${getEnglishName(name)}must be ${min}-${max}`,\n lessThan: (name: string) => (min: number) => `${getEnglishName(name)}cannot less than ${min}`,\n greaterThan: (name: string) => (max: number) => `${getEnglishName(name)}cannot greater than ${max}`,\n lengthEqual: (name: string) => (length: number) => `${getEnglishName(name)}length must be ${length}`,\n twoInputsNotEqual: () => `two inputs are not equal`,\n};\n\nconst TEXT_AREA_VALIDATION_ZH_CN = {\n empty: (name: string) => `${name}不能为空`,\n invalid: (name: string) => `${name}格式有误`,\n invalidFormat: (name: string) => `${name}不是数字`,\n inBetween: (name: string) => (min: number) => (max: number) => `${name}必须在${min}-${max}之间`,\n lessThan: (name: string) => (min: number) => `${name}不可少于${min}`,\n greaterThan: (name: string) => (max: number) => `${name}不可大于${max}`,\n lengthEqual: (name: string) => (length: number) => `${name}长度必须为${length}`,\n twoInputsNotEqual: () => `两次输入不一致`,\n};\n\nconst TEXT_AREA_VALIDATION_EN_US = {\n empty: (name: string) => `${getEnglishName(name)}cannot be empty`,\n invalid: (name: string) => `${getEnglishName(name)}invalid format`,\n invalidFormat: (name: string) => `${getEnglishName(name)}is not a number`,\n inBetween: (name: string) => (min: number) => (max: number) => `${getEnglishName(name)}must be ${min}-${max}`,\n lessThan: (name: string) => (min: number) => `${getEnglishName(name)}cannot less than ${min}`,\n greaterThan: (name: string) => (max: number) => `${getEnglishName(name)}cannot greater than ${max}`,\n lengthEqual: (name: string) => (length: number) => `${getEnglishName(name)}length must be ${length}`,\n twoInputsNotEqual: () => `two inputs are not equal`,\n};\n\nconst SELECT_VALIDATION_ZH_CN = {\n empty: (name: string) => `请选择一个${name}`,\n};\n\nconst SELECT_VALIDATION_EN_US = {\n empty: (name: string) => `Please select a ${getEnglishName(name)}`,\n};\n\nconst CHECK_BOX_VALIDATION_ZH_CN = {\n unchecked: (name: string) => `${name}必须勾选`,\n};\n\nconst CHECK_BOX_VALIDATION_EN_US = {\n unchecked: (name: string) => `${getEnglishName(name)}must be checked`,\n};\n\nconst RADIO_BOX_VALIDATION_ZH_CN = {\n empty: (name: string) => `必须勾选一个${name}`,\n};\n\nconst RADIO_BOX_VALIDATION_EN_US = {\n empty: (name: string) => `Please choose one ${getEnglishName(name)}`,\n};\n\ninterface Message {\n [key: string]: Key;\n}\n\ninterface Key {\n [key: string]: Func;\n}\n\ninterface Func {\n [key: string]: Function;\n}\n\nlet message: Message = {\n 'zh-CN': {\n textbox: TEXT_BOX_VALIDATION_ZH_CN,\n radiobox: RADIO_BOX_VALIDATION_ZH_CN,\n checkbox: CHECK_BOX_VALIDATION_ZH_CN,\n select: SELECT_VALIDATION_ZH_CN,\n textarea: TEXT_AREA_VALIDATION_ZH_CN,\n },\n 'en-US': {\n textbox: TEXT_BOX_VALIDATION_EN_US,\n radiobox: RADIO_BOX_VALIDATION_EN_US,\n checkbox: CHECK_BOX_VALIDATION_EN_US,\n select: SELECT_VALIDATION_EN_US,\n textarea: TEXT_AREA_VALIDATION_EN_US,\n },\n};\n\n// TODO: find a rewire way to handle non-export function\nexport const getCustomErrorMessage = (o: any, m: any) => {\n if (!o || typeof o !== 'object' || o.constructor !== Object || !Object.keys(o).length) {\n console.error(REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE);\n return false;\n }\n Object.keys(o).map(i => {\n if (!m[i]) {\n m[i] = o[i];\n } else {\n if (Object.keys(o[i]).length) {\n Object.keys(o[i]).map(j => {\n if (Object.keys(o[i][j]).length) {\n Object.keys(o[i][j]).map(k => {\n m[i][j][k] = o[i][j][k];\n });\n }\n });\n }\n }\n });\n return m;\n};\n\ndeclare global {\n interface Window {\n REACT_INPUTS_VALIDATION: any;\n }\n}\n\n// TODO: find a rewire way to handle non-export function\nexport const handleCustomErrorMessage = (message: any, w: Window) => {\n let res;\n if (typeof w !== 'undefined') {\n if (w.REACT_INPUTS_VALIDATION && w.REACT_INPUTS_VALIDATION['customErrorMessage']) {\n res = getCustomErrorMessage(w.REACT_INPUTS_VALIDATION['customErrorMessage'], message);\n }\n }\n if (typeof res === 'undefined' || res === false) {\n return message;\n }\n return res;\n};\n\n/* istanbul ignore else */\nif (typeof window !== 'undefined') {\n window.REACT_INPUTS_VALIDATION = window.REACT_INPUTS_VALIDATION || {};\n message = handleCustomErrorMessage(message, window);\n}\n\nexport default message;\n","// extracted by mini-css-extract-plugin\nmodule.exports = {\"ellipsis\":\"react-inputs-validation__ellipsis___3-Api\",\"textbox__wrapper\":\"react-inputs-validation__textbox__wrapper___3tnXv\",\"textbox__input\":\"react-inputs-validation__textbox__input___20hDL\",\"error\":\"react-inputs-validation__error___2aXSp\",\"success\":\"react-inputs-validation__success___3TpwE\",\"disabled\":\"react-inputs-validation__disabled___1-57g\",\"msg\":\"react-inputs-validation__msg___pxv8o\",\"textarea__wrapper\":\"react-inputs-validation__textarea__wrapper___35GhF\",\"textarea__input\":\"react-inputs-validation__textarea__input___1CFm_\",\"radiobox__container\":\"react-inputs-validation__radiobox__container___FD4vb\",\"radiobox__input\":\"react-inputs-validation__radiobox__input___2uX2-\",\"radiobox__label\":\"react-inputs-validation__radiobox__label___2tQsB\",\"radiobox__wrapper\":\"react-inputs-validation__radiobox__wrapper___1zZ30\",\"checked\":\"react-inputs-validation__checked___2O0Ju\",\"button\":\"react-inputs-validation__button___9JBRL\",\"radiobox__item\":\"react-inputs-validation__radiobox__item___ejuz1\",\"checkbox__input\":\"react-inputs-validation__checkbox__input___1yF4X\",\"checkbox__container\":\"react-inputs-validation__checkbox__container___3I1rX\",\"checkbox__box\":\"react-inputs-validation__checkbox__box___1uj8A\",\"checkbox__wrapper\":\"react-inputs-validation__checkbox__wrapper___1c1rD\",\"box\":\"react-inputs-validation__box___3E9nu\",\"select__wrapper\":\"react-inputs-validation__select__wrapper___1B4OH\",\"select__input\":\"react-inputs-validation__select__input___3h-P7\",\"select__container\":\"react-inputs-validation__select__container___3jgUR\",\"select__button\":\"react-inputs-validation__select__button___vEDoq\",\"select__options-item\":\"react-inputs-validation__select__options-item___30yY4\",\"select__options-item-show-cursor\":\"react-inputs-validation__select__options-item-show-cursor___1ZT3b\",\"select__searchInputWrapper\":\"react-inputs-validation__select__searchInputWrapper___3R5P_\",\"select__searchInputSearchIcon\":\"react-inputs-validation__select__searchInputSearchIcon___1Q8xX\",\"select__searchInputRemoveIcon\":\"react-inputs-validation__select__searchInputRemoveIcon___1A1tR\",\"select__searchInput\":\"react-inputs-validation__select__searchInput___1lN24\",\"select__no-mouse\":\"react-inputs-validation__select__no-mouse___2uRg6\",\"select__hover-active\":\"react-inputs-validation__select__hover-active___2z1MQ\",\"active\":\"react-inputs-validation__active___3eZBB\",\"select__options-container-animate\":\"react-inputs-validation__select__options-container-animate___2Rm--\",\"show\":\"react-inputs-validation__show___2NI3u\",\"select__options-container\":\"react-inputs-validation__select__options-container___d54qE\",\"select__dropdown\":\"react-inputs-validation__select__dropdown___11yDr\",\"select__dropdown-icon\":\"react-inputs-validation__select__dropdown-icon___1T5r2\",\"select__dropdown-name\":\"react-inputs-validation__select__dropdown-name___3hghL\",\"select__dropdown-icon-container\":\"react-inputs-validation__select__dropdown-icon-container___2ild-\"};","const camelize = (str: string) => {\n return str.replace(/(?:^\\w|[A-Z]|\\b\\w|\\s+)/g, (match, index) => {\n if (+match === 0) return '';\n return index === 0 ? match.toLowerCase() : match.toUpperCase();\n });\n};\n\nconst toCamelCase = (str: string) => (capitalLize: boolean = false) => {\n const res = camelize(str);\n return capitalLize ? res.substr(0, 1).toUpperCase() + res.substr(1, res.length) : res;\n};\n\ninterface Utils {\n [key: string]: Function;\n}\n\nconst getRandomId = () => {\n return Math.random()\n .toString(36)\n .slice(-8);\n};\n\nconst getAlphanumeric = (v: string) => {\n let res = '';\n String(v)\n .split('')\n .forEach(i => {\n const charCode = i.toLowerCase().charCodeAt(0);\n if ((charCode >= 48 && charCode <= 57) || (charCode >= 97 && charCode <= 122)) {\n res += i;\n }\n });\n return res;\n};\n\nconst getAlpha = (v: string) => {\n let res = '';\n String(v)\n .split('')\n .forEach(i => {\n const charCode = i.toLowerCase().charCodeAt(0);\n if (charCode >= 97 && charCode <= 122) {\n res += i;\n }\n });\n return res;\n};\n\nconst getNumeric = (v: string) => {\n let res = '';\n String(v)\n .split('')\n .forEach(i => {\n const charCode = i.toLowerCase().charCodeAt(0);\n if (charCode >= 48 && charCode <= 57) {\n res += i;\n }\n });\n return res;\n};\n\nconst arraysEqual = (arr1: any, arr2: any) => {\n if (arr1.length !== arr2.length) return false;\n for (let i = arr1.length; (i -= 1); ) {\n if (JSON.stringify(arr1[i]) !== JSON.stringify(arr2[i])) return false;\n }\n return true;\n};\n\nconst utils: Utils = {\n camelize,\n toCamelCase,\n getRandomId,\n getAlphanumeric,\n getAlpha,\n getNumeric,\n arraysEqual,\n};\nexport default utils;\n","const empty = (v: string) => (v.replace(/\\s/g, '').length ? false : true);\nconst number = (v: number, min: any, max: any) => {\n if (min === null && max === null){\n return true\n }\n if (!isNumeric(v)) {\n return false;\n }\n return v < min || v > max ? false : true;\n};\n// TODO: find a better type for regex\nconst reg = (reg: any, v: string) => {\n let err = true;\n if (reg.test(v)) {\n err = false;\n }\n return err;\n};\nconst isNumeric = (v: any) => {\n return !isNaN(parseFloat(v)) && isFinite(v);\n};\n\ninterface Validator {\n [key: string]: Function;\n}\n\nconst validator: Validator = {\n reg,\n empty,\n number,\n};\nexport default validator;\n","import Textbox from './Textbox';\nimport Textarea from './Textarea';\nimport Select from './Select';\nimport Checkbox from './Checkbox';\nimport Radiobox from './Radiobox';\n\nif (typeof window !== 'undefined') {\n (window).Textbox = Textbox;\n (window).Textarea = Textarea;\n (window).Radiobox = Radiobox;\n (window).Checkbox = Checkbox;\n (window).Select = Select;\n}\n\nexport { Textbox, Textarea, Select, Checkbox, Radiobox };\n","import * as React from 'react';\nconst { useState, useEffect, useCallback, useRef, memo } = React;\nimport message from './message';\nimport validator from './validator';\nimport utils from './utils';\nimport { REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE, DEFAULT_LOCALE, MSG_CLASS_IDENTITIFIER, usePrevious } from './const';\nimport reactInputsValidationCss from './react-inputs-validation.css';\nconst TYPE = 'textbox';\nconst VALIDATE_OPTION_TYPE_LIST = ['string', 'number', 'alphanumeric', 'alpha'];\nconst VALIDATE_NUMBER_TYPE_LIST = ['decimal', 'int', 'price'];\ninterface DefaultValidationOption {\n locale?: string;\n reg?: string;\n min?: number;\n max?: number;\n type?: string;\n numberType?: string;\n mantissa?: number;\n name?: string;\n check?: boolean;\n showMsg?: boolean;\n length?: number;\n regMsg?: string;\n compare?: string;\n required?: boolean;\n msgOnError?: string;\n msgOnSuccess?: string;\n customFunc?: Function | undefined;\n}\nconst getDefaultValidationOption = (obj: DefaultValidationOption) => {\n let { reg, min, max, type, numberType, mantissa, name, check, length, regMsg, compare, required, showMsg, locale, msgOnError, msgOnSuccess, customFunc } = obj;\n locale = typeof locale !== 'undefined' ? locale : DEFAULT_LOCALE;\n reg = typeof reg !== 'undefined' ? reg : '';\n min = typeof min !== 'undefined' ? min : 0;\n max = typeof max !== 'undefined' ? max : 0;\n type = typeof type !== 'undefined' ? type : 'string';\n numberType = typeof numberType !== 'undefined' ? numberType : 'string';\n mantissa = typeof mantissa !== 'undefined' ? mantissa : -1;\n name = typeof name !== 'undefined' ? name : '';\n check = typeof check !== 'undefined' ? check : true;\n showMsg = typeof showMsg !== 'undefined' ? showMsg : true;\n length = typeof length !== 'undefined' ? length : 0;\n regMsg = typeof regMsg !== 'undefined' ? regMsg : '';\n compare = typeof compare !== 'undefined' ? compare : '';\n required = typeof required !== 'undefined' ? required : true;\n msgOnError = typeof msgOnError !== 'undefined' ? msgOnError : '';\n msgOnSuccess = typeof msgOnSuccess !== 'undefined' ? msgOnSuccess : '';\n customFunc = typeof customFunc !== 'undefined' ? customFunc : undefined;\n return {\n reg,\n min,\n max,\n type,\n numberType,\n mantissa,\n name,\n check,\n length,\n regMsg,\n locale,\n compare,\n required,\n showMsg,\n msgOnError,\n msgOnSuccess,\n customFunc,\n };\n};\ninterface DefaultAsyncMsgObj {\n error?: boolean;\n message?: string;\n showOnError?: boolean;\n showOnSuccess?: boolean;\n}\nconst getDefaultAsyncObj = (obj: DefaultAsyncMsgObj) => {\n let { error, message, showOnError, showOnSuccess } = obj;\n error = typeof error !== 'undefined' ? error : false;\n message = typeof message !== 'undefined' ? message : '';\n showOnError = typeof showOnError !== 'undefined' ? showOnError : true;\n showOnSuccess = typeof showOnSuccess !== 'undefined' ? showOnSuccess : false;\n return {\n error,\n message,\n showOnError,\n showOnSuccess,\n };\n};\ninterface AttributesInputObj {\n maxLength?: number;\n}\ninterface Props {\n attributesWrapper?: object;\n attributesInput?: AttributesInputObj;\n value?: string;\n disabled?: boolean;\n validate?: boolean;\n classNameInput?: string;\n classNameWrapper?: string;\n classNameContainer?: string;\n customStyleInput?: object;\n customStyleWrapper?: object;\n customStyleContainer?: object;\n validationOption?: object;\n asyncMsgObj?: object;\n onChange: (res: string, e: React.ChangeEvent) => void;\n onBlur?: (e: React.FocusEvent) => void;\n onFocus?: (e: React.FocusEvent) => void;\n onClick?: (e: React.MouseEvent) => void;\n onKeyUp?: (e: React.KeyboardEvent) => void;\n validationCallback?: (res: boolean) => void;\n}\nconst autoFormatNumber = (v: number | string, numberType: string, mantissa: number) => {\n const DOT = '.';\n const ZERO = '0';\n let res = '';\n let hasDot = false;\n const splitStr = String(v).split('');\n const startedWithZero = splitStr[0] === '0';\n if (numberType === VALIDATE_NUMBER_TYPE_LIST[2] && splitStr[0] === ZERO && splitStr[1] === ZERO) {\n splitStr.shift();\n }\n splitStr.forEach(i => {\n const charCode = i.toLowerCase().charCodeAt(0);\n if ((charCode >= 48 && charCode <= 57) || (charCode === 46 && !hasDot)) {\n if (charCode === 46) {\n if (numberType === VALIDATE_NUMBER_TYPE_LIST[1]) {\n return;\n }\n hasDot = true;\n }\n res += i;\n }\n });\n if (hasDot && mantissa >= 0) {\n const resArr = res.split(DOT);\n if (mantissa === 0) {\n res = resArr[0];\n } else {\n resArr[1] = resArr[1].slice(0, mantissa);\n res = resArr.join('.');\n }\n }\n if (numberType === VALIDATE_NUMBER_TYPE_LIST[0] || numberType === VALIDATE_NUMBER_TYPE_LIST[2]) {\n if (res.length && res[0] === DOT) {\n res = `0${res}`;\n }\n }\n // if (numberType === VALIDATE_NUMBER_TYPE_LIST[2]) {\n // if (startedWithZero) {\n // if (hasDot) {\n // const resArr = res.split(DOT);\n // res = `${Number(resArr[0])}${DOT}${resArr[1]}`;\n // }\n // }\n // }\n return res;\n};\nconst component: React.FC = ({\n attributesWrapper = {},\n attributesInput = {},\n value = '',\n disabled = false,\n validate = false,\n classNameInput = '',\n classNameWrapper = '',\n classNameContainer = '',\n customStyleInput = {},\n customStyleWrapper = {},\n customStyleContainer = {},\n validationOption = {},\n asyncMsgObj = {},\n onChange = (v: string, e: React.ChangeEvent) => {},\n onBlur = null,\n onFocus = null,\n onClick = null,\n onKeyUp = null,\n validationCallback = null,\n}) => {\n const [err, setErr] = useState(false);\n const [msg, setMsg] = useState('');\n const [successMsg, setSuccessMsg] = useState('');\n const [internalValue, setInternalValue] = useState(String(value));\n const prevInternalValue = usePrevious(internalValue);\n const option = getDefaultValidationOption(validationOption);\n const asyncObj = getDefaultAsyncObj(asyncMsgObj);\n const $input = useRef(null);\n const $el: { [key: string]: any } | null = $input;\n const handleOnBlur = useCallback(\n (e: React.FocusEvent) => {\n if (onBlur) {\n check();\n onBlur(e);\n }\n },\n [internalValue, option],\n );\n const handleOnFocus = useCallback((e: React.FocusEvent) => {\n if (onFocus) {\n onFocus(e);\n }\n }, []);\n const handleOnClick = useCallback((e: React.MouseEvent) => {\n if (onClick) {\n onClick(e);\n }\n }, []);\n const handleOnKeyUp = useCallback(\n (e: React.KeyboardEvent) => {\n if (onKeyUp) {\n const { keyCode } = e;\n const keyCodeTab = 9;\n if (keyCode !== keyCodeTab) {\n check();\n }\n onKeyUp(e);\n }\n },\n [internalValue, option],\n );\n const handleOnChange = useCallback(\n (e: React.ChangeEvent) => {\n if (disabled || $el === null) {\n return;\n }\n let v = $el.current.value;\n if (typeof attributesInput.maxLength !== 'undefined') {\n if ((typeof attributesInput.maxLength === 'string' && attributesInput.maxLength !== '') || (typeof attributesInput.maxLength === 'number' && attributesInput.maxLength !== 0)) {\n if (v.length > Number(attributesInput.maxLength)) {\n return;\n }\n }\n }\n const { type, numberType, mantissa } = option;\n if (type === VALIDATE_OPTION_TYPE_LIST[1]) {\n v = String(autoFormatNumber(v, VALIDATE_NUMBER_TYPE_LIST.indexOf(numberType) >= 0 ? numberType : VALIDATE_NUMBER_TYPE_LIST[0], mantissa));\n }\n if (type === VALIDATE_OPTION_TYPE_LIST[2]) {\n v = utils.getAlphanumeric(v);\n }\n if (type === VALIDATE_OPTION_TYPE_LIST[3]) {\n v = utils.getAlpha(v);\n }\n setInternalValue(v);\n onChange && onChange(v, e);\n if (err) {\n setErr(false);\n } else {\n setSuccessMsg('');\n }\n },\n [err, attributesInput, option],\n );\n const check = useCallback(\n async () => {\n const { reg, min, max, type, name, check, length, regMsg, locale, compare, required, msgOnSuccess, customFunc } = option;\n if (!check) {\n return;\n }\n if (type) {\n if (VALIDATE_OPTION_TYPE_LIST.indexOf(type) !== -1) {\n if (!message[locale] || !message[locale][TYPE]) {\n console.error(REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE);\n return;\n }\n const msg = message[locale][TYPE];\n const nameText = name ? name : '';\n if (required) {\n if (validator.empty(internalValue)) {\n handleCheckEnd(true, msg.empty(nameText));\n return;\n }\n }\n if (String(internalValue) !== '') {\n if (reg) {\n if (validator['reg'](reg, internalValue)) {\n handleCheckEnd(true, regMsg !== '' ? regMsg : msg.invalid(nameText));\n return;\n }\n }\n if (type === VALIDATE_OPTION_TYPE_LIST[0]) {\n if (min || max) {\n if (min && max) {\n if (String(internalValue).length < min || String(internalValue).length > max) {\n handleCheckEnd(true, msg.inBetween(nameText)(min)(max));\n return;\n }\n } else {\n if (min) {\n if (String(internalValue).length < min) {\n handleCheckEnd(true, msg.lessThan(nameText)(min));\n return;\n }\n }\n if (max) {\n if (String(internalValue).length > max) {\n handleCheckEnd(true, msg.greaterThan(nameText)(max));\n return;\n }\n }\n }\n }\n if (length) {\n if (String(internalValue).length !== length) {\n handleCheckEnd(true, msg.lengthEqual(nameText)(length));\n return;\n }\n }\n }\n if (type === VALIDATE_OPTION_TYPE_LIST[1]) {\n if (!validator[type](internalValue, null, null)) {\n handleCheckEnd(true, msg.invalid(nameText));\n return;\n }\n if (min || max) {\n if (min && max) {\n if (!validator[type](internalValue, min, max)) {\n handleCheckEnd(true, msg.inBetween(nameText)(min)(max));\n return;\n }\n } else {\n if (min) {\n if (!validator[type](internalValue, min)) {\n handleCheckEnd(true, msg.lessThan(nameText)(min));\n return;\n }\n }\n if (max) {\n if (!validator[type](internalValue, 0, max)) {\n handleCheckEnd(true, msg.greaterThan(nameText)(max));\n return;\n }\n }\n }\n }\n if (length) {\n if (String(internalValue).length !== length) {\n handleCheckEnd(true, msg.lengthEqual(nameText)(length));\n return;\n }\n }\n }\n if (compare && compare !== '') {\n if (internalValue !== compare) {\n handleCheckEnd(true, msg.twoInputsNotEqual());\n return;\n }\n }\n }\n if (customFunc && typeof customFunc === 'function') {\n const customFuncResult = await customFunc(internalValue);\n /* istanbul ignore next because of async problem */\n if (typeof customFuncResult === 'object') {\n if (typeof customFuncResult.error === 'boolean' && typeof customFuncResult.message === 'string') {\n if (customFuncResult.error === false && customFuncResult.showOnSuccess === true) {\n setSuccessMsg(customFuncResult.message);\n }\n handleCheckEnd(customFuncResult.error, customFuncResult.message, true);\n }\n return;\n }\n /* istanbul ignore next because of async problem */\n if (customFuncResult !== true) {\n handleCheckEnd(true, customFuncResult, true);\n return;\n }\n }\n if (msgOnSuccess) {\n setSuccessMsg(msgOnSuccess);\n }\n handleCheckEnd(false, msgOnSuccess);\n } else {\n console.error(`The valid ${utils.toCamelCase(TYPE)(true)} \"type\" options in validationOption are [${VALIDATE_OPTION_TYPE_LIST.map(i => i)}]`);\n }\n } else {\n console.error('Please provide \"type\" in validationOption');\n }\n },\n [internalValue, option],\n );\n const handleCheckEnd = useCallback((err: boolean, message: string, fromCustomFunc: boolean = false) => {\n let msg = message;\n const { msgOnError } = option;\n if (err && msgOnError && !fromCustomFunc) {\n msg = msgOnError;\n }\n setErr(err);\n setMsg(msg);\n validationCallback && validationCallback(err);\n }, []);\n useEffect(\n () => {\n if (validate) {\n check();\n }\n },\n [validate],\n );\n useEffect(\n () => {\n setInternalValue(String(value));\n },\n [value],\n );\n useEffect(\n () => {\n /* istanbul ignore next because of https://github.com/airbnb/enzyme/issues/441 && https://github.com/airbnb/enzyme/blob/master/docs/future.md */\n if (typeof prevInternalValue !== 'undefined' && prevInternalValue !== internalValue) {\n if (option.customFunc && onKeyUp) {\n check();\n }\n }\n },\n [internalValue],\n );\n useEffect(\n () => {\n if (asyncObj) {\n if (asyncObj.message) {\n if (asyncObj.showOnError) {\n handleCheckEnd(asyncObj.error, asyncObj.message);\n }\n if (!asyncObj.error && asyncObj.showOnSuccess) {\n setSuccessMsg(asyncObj.message);\n }\n }\n }\n },\n [asyncMsgObj],\n );\n const wrapperClass = `${classNameWrapper} ${reactInputsValidationCss[`${TYPE}__wrapper`]} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const containerClass = `${classNameContainer} ${reactInputsValidationCss[`${TYPE}__container`]} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const inputClass = `${classNameInput} ${reactInputsValidationCss[`${TYPE}__input`]} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const errMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${err && reactInputsValidationCss['error']}`;\n const successMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${!err && reactInputsValidationCss['success']}`;\n let msgHtml;\n const { showMsg } = option;\n if (showMsg && err && msg) {\n msgHtml =
{msg}
;\n }\n if (showMsg && !err && successMsg !== '') {\n msgHtml =
{successMsg}
;\n }\n return (\n
\n
\n \n
\n {msgHtml}\n
\n );\n};\nexport default memo(component);\n","import * as React from 'react';\nconst { useState, useEffect, useCallback, useRef, memo } = React;\nimport message from './message';\nimport validator from './validator';\nimport utils from './utils';\nimport { REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE, DEFAULT_LOCALE, MSG_CLASS_IDENTITIFIER, usePrevious } from './const';\nimport reactInputsValidationCss from './react-inputs-validation.css';\nconst TYPE = 'textarea';\nconst VALIDATE_OPTION_TYPE_LIST = ['string'];\ninterface DefaultValidationOption {\n locale?: string;\n reg?: string;\n min?: number;\n max?: number;\n type?: string;\n name?: string;\n check?: boolean;\n showMsg?: boolean;\n length?: number;\n regMsg?: string;\n required?: boolean;\n msgOnError?: string;\n msgOnSuccess?: string;\n customFunc?: Function | undefined;\n}\nconst getDefaultValidationOption = (obj: DefaultValidationOption) => {\n let { reg, min, max, type, name, check, length, regMsg, required, showMsg, locale, msgOnError, msgOnSuccess, customFunc } = obj;\n locale = typeof locale !== 'undefined' ? locale : DEFAULT_LOCALE;\n reg = typeof reg !== 'undefined' ? reg : '';\n min = typeof min !== 'undefined' ? min : 0;\n max = typeof max !== 'undefined' ? max : 0;\n type = typeof type !== 'undefined' ? type : 'string';\n name = typeof name !== 'undefined' ? name : '';\n check = typeof check !== 'undefined' ? check : true;\n showMsg = typeof showMsg !== 'undefined' ? showMsg : true;\n length = typeof length !== 'undefined' ? length : 0;\n regMsg = typeof regMsg !== 'undefined' ? regMsg : '';\n required = typeof required !== 'undefined' ? required : true;\n msgOnError = typeof msgOnError !== 'undefined' ? msgOnError : '';\n msgOnSuccess = typeof msgOnSuccess !== 'undefined' ? msgOnSuccess : '';\n customFunc = typeof customFunc !== 'undefined' ? customFunc : undefined;\n return {\n reg,\n min,\n max,\n type,\n name,\n check,\n length,\n regMsg,\n locale,\n required,\n showMsg,\n msgOnError,\n msgOnSuccess,\n customFunc,\n };\n};\ninterface DefaultAsyncMsgObj {\n error?: boolean;\n message?: string;\n showOnError?: boolean;\n showOnSuccess?: boolean;\n}\nconst getDefaultAsyncObj = (obj: DefaultAsyncMsgObj) => {\n let { error, message, showOnError, showOnSuccess } = obj;\n error = typeof error !== 'undefined' ? error : false;\n message = typeof message !== 'undefined' ? message : '';\n showOnError = typeof showOnError !== 'undefined' ? showOnError : true;\n showOnSuccess = typeof showOnSuccess !== 'undefined' ? showOnSuccess : false;\n return {\n error,\n message,\n showOnError,\n showOnSuccess,\n };\n};\ninterface AttributesInputObj {\n maxLength?: number;\n}\ninterface Props {\n attributesWrapper?: object;\n attributesInput?: AttributesInputObj;\n value?: string;\n disabled?: boolean;\n validate?: boolean;\n classNameInput?: string;\n classNameWrapper?: string;\n classNameContainer?: string;\n customStyleInput?: object;\n customStyleWrapper?: object;\n customStyleContainer?: object;\n validationOption?: object;\n asyncMsgObj?: object;\n onChange: (res: string, e: React.ChangeEvent) => void;\n onBlur?: (e: React.FocusEvent) => void;\n onFocus?: (e: React.FocusEvent) => void;\n onClick?: (e: React.MouseEvent) => void;\n onKeyUp?: (e: React.KeyboardEvent) => void;\n validationCallback?: (res: boolean) => void;\n}\n\nconst component: React.FC = ({\n attributesWrapper = {},\n attributesInput = {},\n value = '',\n disabled = false,\n validate = false,\n classNameInput = '',\n classNameWrapper = '',\n classNameContainer = '',\n customStyleInput = {},\n customStyleWrapper = {},\n customStyleContainer = {},\n validationOption = {},\n asyncMsgObj = {},\n onChange = () => {},\n onBlur = null,\n onFocus = null,\n onClick = null,\n onKeyUp = null,\n validationCallback = null,\n}) => {\n const [err, setErr] = useState(false);\n const [msg, setMsg] = useState('');\n const [successMsg, setSuccessMsg] = useState('');\n const [internalValue, setInternalValue] = useState(String(value));\n const prevInternalValue = usePrevious(internalValue);\n const option = getDefaultValidationOption(validationOption);\n const asyncObj = getDefaultAsyncObj(asyncMsgObj);\n const $input = useRef(null);\n const $el: { [key: string]: any } | null = $input;\n const handleOnBlur = useCallback(\n (e: React.FocusEvent) => {\n if (onBlur) {\n check();\n onBlur(e);\n }\n },\n [internalValue, option],\n );\n const handleOnFocus = useCallback((e: React.FocusEvent) => {\n if (onFocus) {\n onFocus(e);\n }\n }, []);\n const handleOnClick = useCallback((e: React.MouseEvent) => {\n if (onClick) {\n onClick(e);\n }\n }, []);\n const handleOnKeyUp = useCallback(\n (e: React.KeyboardEvent) => {\n if (onKeyUp) {\n const { keyCode } = e;\n const keyCodeTab = 9;\n if (keyCode !== keyCodeTab) {\n check();\n }\n onKeyUp(e);\n }\n },\n [internalValue, option],\n );\n const handleOnChange = useCallback(\n (e: React.ChangeEvent) => {\n if (disabled || $el === null) {\n return;\n }\n const v = $el.current.value;\n if (typeof attributesInput.maxLength !== 'undefined') {\n if ((typeof attributesInput.maxLength === 'string' && attributesInput.maxLength !== '') || (typeof attributesInput.maxLength === 'number' && attributesInput.maxLength !== 0)) {\n if (v.length > Number(attributesInput.maxLength)) {\n return;\n }\n }\n }\n setInternalValue(v);\n onChange && onChange(v, e);\n if (err) {\n setErr(false);\n } else {\n setSuccessMsg('');\n }\n },\n [err],\n );\n const check = useCallback(\n async () => {\n const { reg, min, max, type, name, check, length, regMsg, locale, required, msgOnSuccess, customFunc } = option;\n if (!check) {\n return;\n }\n if (type) {\n if (VALIDATE_OPTION_TYPE_LIST.indexOf(type) !== -1) {\n if (!message[locale] || !message[locale][TYPE]) {\n console.error(REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE);\n return;\n }\n const msg = message[locale][TYPE];\n const nameText = name ? name : '';\n if (required) {\n if (validator.empty(internalValue)) {\n handleCheckEnd(true, msg.empty(nameText));\n return;\n }\n }\n if (String(internalValue) !== '') {\n if (reg) {\n if (validator['reg'](reg, internalValue)) {\n handleCheckEnd(true, regMsg !== '' ? regMsg : msg.invalid(nameText));\n return;\n }\n }\n if (min || max) {\n if (min && max) {\n if (String(internalValue).length < min || String(internalValue).length > max) {\n handleCheckEnd(true, msg.inBetween(nameText)(min)(max));\n return;\n }\n } else {\n if (min) {\n if (String(internalValue).length < min) {\n handleCheckEnd(true, msg.lessThan(nameText)(min));\n return;\n }\n }\n if (max) {\n if (String(internalValue).length > max) {\n handleCheckEnd(true, msg.greaterThan(nameText)(max));\n return;\n }\n }\n }\n }\n if (length) {\n if (String(internalValue).length !== length) {\n handleCheckEnd(true, msg.lengthEqual(nameText)(length));\n return;\n }\n }\n }\n if (customFunc && typeof customFunc === 'function') {\n const customFuncResult = await customFunc(internalValue);\n /* istanbul ignore next because of async problem */\n if (typeof customFuncResult === 'object') {\n if (typeof customFuncResult.error === 'boolean' && typeof customFuncResult.message === 'string') {\n if (customFuncResult.error === false && customFuncResult.showOnSuccess === true) {\n setSuccessMsg(customFuncResult.message);\n }\n handleCheckEnd(customFuncResult.error, customFuncResult.message, true);\n }\n return;\n }\n /* istanbul ignore next because of async problem */\n if (customFuncResult !== true) {\n handleCheckEnd(true, customFuncResult, true);\n return;\n }\n }\n if (msgOnSuccess) {\n setSuccessMsg(msgOnSuccess);\n }\n handleCheckEnd(false, msgOnSuccess);\n } else {\n console.error(`The valid ${utils.toCamelCase(TYPE)(true)} \"type\" options in validationOption are [${VALIDATE_OPTION_TYPE_LIST.map(i => i)}]`);\n }\n } else {\n console.error('Please provide \"type\" in validationOption');\n }\n },\n [internalValue, option],\n );\n const handleCheckEnd = useCallback((err: boolean, message: string, fromCustomFunc: boolean = false) => {\n let msg = message;\n const { msgOnError } = option;\n if (err && msgOnError && !fromCustomFunc) {\n msg = msgOnError;\n }\n setErr(err);\n setMsg(msg);\n validationCallback && validationCallback(err);\n }, []);\n useEffect(\n () => {\n if (validate) {\n check();\n }\n },\n [validate],\n );\n useEffect(\n () => {\n setInternalValue(String(value));\n },\n [value],\n );\n useEffect(\n () => {\n /* istanbul ignore next because of https://github.com/airbnb/enzyme/issues/441 && https://github.com/airbnb/enzyme/blob/master/docs/future.md */\n if (typeof prevInternalValue !== 'undefined' && prevInternalValue !== internalValue) {\n if (option.customFunc && onKeyUp) {\n check();\n }\n }\n },\n [internalValue],\n );\n useEffect(\n () => {\n if (asyncObj) {\n if (asyncObj.message) {\n if (asyncObj.showOnError) {\n handleCheckEnd(asyncObj.error, asyncObj.message);\n }\n if (!asyncObj.error && asyncObj.showOnSuccess) {\n setSuccessMsg(asyncObj.message);\n }\n }\n }\n },\n [asyncMsgObj],\n );\n const wrapperClass = `${classNameWrapper} ${reactInputsValidationCss[`${TYPE}__wrapper`]} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const containerClass = `${classNameContainer} ${reactInputsValidationCss[`${TYPE}__container`]} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const inputClass = `${classNameInput} ${reactInputsValidationCss[`${TYPE}__input`]} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const errMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${err && reactInputsValidationCss['error']}`;\n const successMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${!err && reactInputsValidationCss['success']}`;\n let msgHtml;\n const { showMsg } = option;\n if (showMsg && err && msg) {\n msgHtml =
{msg}
;\n }\n if (showMsg && !err && successMsg !== '') {\n msgHtml =
{successMsg}
;\n }\n return (\n
\n
\n \n
\n {msgHtml}\n
\n );\n};\nexport default memo(component);\n","import * as React from 'react';\nconst { useState, useEffect, useCallback, useRef, useMemo, memo } = React;\nimport message from './message';\nimport { REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE, DEFAULT_LOCALE, WRAPPER_CLASS_IDENTITIFIER, CONTAINER_CLASS_IDENTITIFIER, MSG_CLASS_IDENTITIFIER, usePrevious } from './const';\nimport utils from './utils';\nimport reactInputsValidationCss from './react-inputs-validation.css';\nconst TYPE = 'select';\nconst keyCodeEsc = 27;\nconst keyCodeDown = 40;\nconst keyCodeUp = 38;\nconst keyCodeEnter = 13;\nconst selectKeyList = [keyCodeEsc, keyCodeDown, keyCodeUp, keyCodeEnter];\n/* istanbul ignore next */\nif (!String.prototype.startsWith) {\n String.prototype.startsWith = function(searchString, position) {\n const p = position || 0;\n return this.indexOf(searchString, p) === p;\n };\n}\ninterface DefaultValidationOption {\n name?: string;\n check?: boolean;\n showMsg?: boolean;\n required?: boolean;\n locale?: string;\n msgOnError?: string;\n msgOnSuccess?: string;\n}\nconst getDefaultValidationOption = (obj: DefaultValidationOption) => {\n let { name, check, required, showMsg, locale, msgOnError, msgOnSuccess } = obj;\n locale = typeof locale !== 'undefined' ? locale : DEFAULT_LOCALE;\n name = typeof name !== 'undefined' ? name : '';\n check = typeof check !== 'undefined' ? check : true;\n showMsg = typeof showMsg !== 'undefined' ? showMsg : true;\n required = typeof required !== 'undefined' ? required : true;\n msgOnSuccess = typeof msgOnSuccess !== 'undefined' ? msgOnSuccess : '';\n msgOnError = typeof msgOnError !== 'undefined' ? msgOnError : '';\n return {\n name,\n check,\n showMsg,\n required,\n locale,\n msgOnError,\n msgOnSuccess,\n };\n};\ninterface DefaultAsyncMsgObj {\n error?: boolean;\n message?: string;\n showOnError?: boolean;\n showOnSuccess?: boolean;\n}\nconst getDefaultAsyncObj = (obj: DefaultAsyncMsgObj) => {\n let { error, message, showOnError, showOnSuccess } = obj;\n error = typeof error !== 'undefined' ? error : false;\n message = typeof message !== 'undefined' ? message : '';\n showOnError = typeof showOnError !== 'undefined' ? showOnError : true;\n showOnSuccess = typeof showOnSuccess !== 'undefined' ? showOnSuccess : false;\n return {\n error,\n message,\n showOnError,\n showOnSuccess,\n };\n};\nexport const isValidValue = (list: OptionListItem[], value: any) => {\n let res = false;\n if (list.length) {\n for (let i = 0; i < list.length; i += 1) {\n if (list[i].id === value) {\n res = true;\n break;\n }\n }\n }\n return res;\n};\nexport const getItem = (list: OptionListItem[], value: any) => {\n let res = null;\n if (list.length) {\n for (let i = 0; i < list.length; i += 1) {\n if (list[i].id === value) {\n res = list[i];\n break;\n }\n }\n }\n return res;\n};\nexport const getIndex = (list: OptionListItem[], value: string) => {\n let key = -1;\n for (let i = 0; i < list.length; i += 1) {\n if (list[i].id === value) {\n key = i;\n break;\n }\n }\n return key;\n};\ninterface OptionListItem {\n id: string;\n name: string;\n}\ninterface Props {\n attributesWrapper?: object;\n attributesInput?: object;\n value?: string | number;\n disabled?: boolean;\n validate?: boolean;\n showSearch?: boolean;\n keyword?: string;\n optionList: OptionListItem[];\n onChange: (res: object, e: React.MouseEvent) => void;\n onBlur?: (e: React.FocusEvent | Event) => void;\n onFocus?: (e: React.FocusEvent) => void;\n onClick?: (e: React.MouseEvent) => void;\n validationOption?: object;\n asyncMsgObj?: object;\n classNameWrapper?: string;\n classNameContainer?: string;\n classNameSelect?: string;\n classNameOptionListContainer?: string;\n classNameDropdownIconOptionListItem?: string;\n classNameOptionListItem?: string;\n customStyleWrapper?: object;\n customStyleContainer?: object;\n customStyleSelect?: object;\n customStyleOptionListContainer?: object;\n customStyleDropdownIcon?: object;\n customStyleOptionListItem?: object;\n validationCallback?: (res: boolean) => void;\n}\ninterface Node {\n [key: string]: any;\n}\nlet globalVariableIsFocusing: boolean = false;\nlet globalVariableIsCorrected: boolean = false;\nlet globalVariableCurrentFocus: any | null = null;\nlet globalVariableTypingTimeout: any | null = null;\nconst component: React.FC = ({\n attributesWrapper = {},\n attributesInput = {},\n value = '',\n disabled = false,\n validate = false,\n showSearch = false,\n keyword = '',\n optionList = [],\n classNameWrapper = '',\n classNameContainer = '',\n classNameSelect = '',\n classNameOptionListItem = '',\n classNameOptionListContainer = '',\n classNameDropdownIconOptionListItem = '',\n customStyleWrapper = {},\n customStyleContainer = {},\n customStyleSelect = {},\n customStyleOptionListItem = {},\n customStyleOptionListContainer = {},\n customStyleDropdownIcon = {},\n validationOption = {},\n asyncMsgObj = {},\n onChange = () => {},\n onBlur = null,\n onFocus = null,\n onClick = null,\n validationCallback = null,\n}) => {\n const [err, setErr] = useState(false);\n const [msg, setMsg] = useState('');\n const [successMsg, setSuccessMsg] = useState('');\n const [internalValue, setInternalValue] = useState(String(value));\n const stateKeyword = useState(keyword);\n const prevKeyword = usePrevious(stateKeyword[0]);\n const prevInternalValue = usePrevious(internalValue);\n const prevOptionList = usePrevious(optionList);\n const [show, setShow] = useState(false);\n const prevShow = usePrevious(show);\n const [isTyping, setIsTyping] = useState(false);\n const initKeycodeList: number[] = [];\n const [keycodeList, setKeycodeList] = useState(initKeycodeList);\n const option = getDefaultValidationOption(validationOption);\n const asyncObj = getDefaultAsyncObj(asyncMsgObj);\n const $button = useRef(null);\n const $wrapper = useRef(null);\n const $itemsWrapper = useRef(null);\n const $searchInputWrapper = useRef(null);\n const $searchInput = useRef(null);\n const $elButton: { [key: string]: any } | null = $button;\n const $elWrapper: { [key: string]: any } | null = $wrapper;\n const $elItemsWrapper: { [key: string]: any } | null = $itemsWrapper;\n const $itemsRef: { [key: string]: any } = [];\n const filteredOptionList = useMemo(() => {\n let res = optionList;\n if (res.length) {\n if (stateKeyword[0]) {\n res = optionList.filter(i => i.name.toLowerCase().includes(stateKeyword[0].toLowerCase()));\n }\n }\n return res;\n }, [stateKeyword[0], optionList]);\n const handleOnSearch = useCallback((e: any) => {\n stateKeyword[1](e.target.value);\n }, []);\n const handleOnSearchKeyDown = useCallback(\n (e: any) => {\n const { keyCode } = e;\n const direction = getDirection(keyCode);\n if (selectKeyList.indexOf(keyCode) !== -1) {\n e.preventDefault();\n handleOnKeyDown(keyCode);\n } else if (keyCode === 32) {\n // space\n stateKeyword[1](`${stateKeyword[0]} `);\n e.preventDefault();\n }\n scroll(direction);\n },\n [filteredOptionList],\n );\n useEffect(() => {\n if (show && showSearch) {\n globalVariableCurrentFocus = 0;\n scroll('up');\n addActive();\n }\n }, [stateKeyword[0]]);\n const handleOnBlur = useCallback(\n (e: React.FocusEvent | Event) => {\n if (onBlur) {\n check();\n onBlur(e);\n }\n },\n [internalValue, option],\n );\n const handleOnFocus = useCallback((e: React.FocusEvent) => {\n if (onFocus) {\n onFocus(e);\n }\n }, []);\n const handleOnClick = useCallback((e: React.MouseEvent) => {\n if (onClick) {\n onClick(e);\n }\n }, []);\n const handleOnChange = useCallback((item: object, e: React.MouseEvent) => {\n if (disabled) {\n return;\n }\n onChange && onChange(item, e);\n }, []);\n const check = useCallback(() => {\n const { name, check, locale, required, msgOnSuccess } = option;\n if (!check) {\n return;\n }\n if (!message[locale] || !message[locale][TYPE]) {\n console.error(REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE);\n return;\n }\n if (required) {\n const msg = message[locale][TYPE];\n const nameText = name ? name : '';\n if (!isValidValue(optionList, internalValue) || internalValue === '' || internalValue === 'null' || internalValue === 'undefined') {\n handleCheckEnd(true, msg.empty(nameText));\n return;\n }\n }\n if (msgOnSuccess) {\n setSuccessMsg(msgOnSuccess);\n }\n handleCheckEnd(false, msgOnSuccess);\n }, [internalValue, option]);\n const handleCheckEnd = useCallback((err: boolean, message: string) => {\n let msg = message;\n const { msgOnError } = option;\n if (err && msgOnError) {\n msg = msgOnError;\n }\n setErr(err);\n setMsg(msg);\n validationCallback && validationCallback(err);\n }, []);\n /* istanbul ignore next because of https://github.com/airbnb/enzyme/issues/441 && https://github.com/airbnb/enzyme/blob/master/docs/future.md */\n useEffect(() => {\n if (typeof window !== 'undefined') {\n window.addEventListener('mousedown', pageClick);\n window.addEventListener('touchstart', pageClick);\n return () => {\n window.removeEventListener('mousedown', pageClick);\n window.removeEventListener('touchstart', pageClick);\n $elWrapper.current.removeEventListener('keydown', onKeyDown);\n };\n }\n }, []);\n /* istanbul ignore next because of https://github.com/airbnb/enzyme/issues/441 && https://github.com/airbnb/enzyme/blob/master/docs/future.md */\n const pageClick = useCallback((e: Event) => {\n if ($elWrapper.current.contains(e.target)) {\n return;\n }\n if (globalVariableIsFocusing) {\n handleOnBlur(e);\n globalVariableIsFocusing = false;\n }\n setShow(false);\n }, []);\n /* istanbul ignore next because of https://github.com/airbnb/enzyme/issues/441 && https://github.com/airbnb/enzyme/blob/master/docs/future.md */\n const resetCurrentFocus = useCallback(() => {\n globalVariableCurrentFocus = getIndex(filteredOptionList, internalValue);\n scroll();\n }, [internalValue]);\n /* istanbul ignore next because of https://github.com/airbnb/enzyme/issues/441 && https://github.com/airbnb/enzyme/blob/master/docs/future.md */\n const setTimeoutTyping = useCallback(() => {\n if (globalVariableTypingTimeout) {\n clearTimeout(globalVariableTypingTimeout);\n }\n globalVariableTypingTimeout = setTimeout(() => {\n setKeycodeList([]);\n }, 250);\n }, []);\n /* istanbul ignore next because of https://github.com/airbnb/enzyme/issues/441 && https://github.com/airbnb/enzyme/blob/master/docs/future.md */\n const scroll = useCallback((direction: undefined | string = undefined) => {\n if ($itemsWrapper && $itemsWrapper.current && $itemsWrapper.current.children) {\n const $children = $itemsWrapper.current.children;\n const containerHeight = $elItemsWrapper.current.offsetHeight;\n const containerScrollTop = $elItemsWrapper.current.scrollTop;\n if (!$children[globalVariableCurrentFocus]) {\n return;\n }\n const itemHeight = $children[globalVariableCurrentFocus].offsetHeight;\n if (direction) {\n if (direction === 'loop') {\n $elItemsWrapper.current.scrollTop = $children.length * itemHeight;\n return;\n }\n if (direction === 'down') {\n const bound = containerScrollTop + containerHeight;\n const heightItems = globalVariableCurrentFocus * itemHeight;\n const heightContainer = bound - itemHeight;\n if (heightItems >= heightContainer) {\n const offset = Math.abs(heightItems - heightContainer - itemHeight);\n if (offset >= 0 && !globalVariableIsCorrected) {\n $elItemsWrapper.current.scrollTop = containerScrollTop + itemHeight - offset;\n globalVariableIsCorrected = true;\n } else {\n $elItemsWrapper.current.scrollTop = containerScrollTop + itemHeight;\n }\n }\n }\n if (direction === 'up') {\n globalVariableIsCorrected = false;\n if (globalVariableCurrentFocus * itemHeight <= containerScrollTop) {\n $elItemsWrapper.current.scrollTop = globalVariableCurrentFocus * itemHeight;\n }\n }\n } else {\n globalVariableIsCorrected = false;\n $elItemsWrapper.current.scrollTop = globalVariableCurrentFocus * itemHeight;\n }\n }\n }, []);\n const handleOnItemClick = useCallback((item: object, e: React.MouseEvent) => {\n handleOnChange(item, e);\n stateKeyword[1]('');\n }, []);\n const handleOnItemMouseOver = useCallback((index: number) => {\n globalVariableCurrentFocus = index;\n addActive();\n }, []);\n const handleOnItemMouseMove = useCallback(() => {\n setIsTyping(false);\n }, []);\n const handleOnItemMouseOut = useCallback(() => {\n removeActive();\n }, []);\n const addActive = useCallback(() => {\n if ($itemsWrapper && $itemsWrapper.current && $itemsWrapper.current.children) {\n const $children = $itemsWrapper.current.children;\n removeActive();\n if (globalVariableCurrentFocus === null) return;\n if (globalVariableCurrentFocus >= $children.length) globalVariableCurrentFocus = 0;\n if (globalVariableCurrentFocus < 0) globalVariableCurrentFocus = $children.length - 1;\n if ($children[globalVariableCurrentFocus]) $children[globalVariableCurrentFocus].className += ` ${reactInputsValidationCss[`${TYPE}__hover-active`]}`;\n }\n }, []);\n const removeActive = useCallback(() => {\n if ($itemsWrapper && $itemsWrapper.current && $itemsWrapper.current.children) {\n const $children = $itemsWrapper.current.children;\n for (let i = 0; i < $children.length; i += 1) {\n $children[i].className = $children[i].className.replace(reactInputsValidationCss[`${TYPE}__hover-active`], '');\n }\n }\n }, []);\n const getDirection = useCallback(keyCode => {\n switch (keyCode) {\n case keyCodeUp:\n return 'up';\n case keyCodeDown:\n return 'down';\n default:\n return undefined;\n }\n }, []);\n const handleOnKeyDown = useCallback(\n keyCode => {\n if (keyCode === keyCodeEsc) {\n setShow(false);\n resetCurrentFocus();\n return;\n }\n if (keyCode === keyCodeDown) {\n globalVariableCurrentFocus += 1;\n if (globalVariableCurrentFocus > filteredOptionList.length - 1) {\n globalVariableCurrentFocus = 0;\n scroll('up');\n }\n addActive();\n } else if (keyCode === keyCodeUp) {\n globalVariableCurrentFocus -= 1;\n if (globalVariableCurrentFocus < 0) {\n globalVariableCurrentFocus = filteredOptionList.length - 1;\n scroll('loop');\n }\n addActive();\n } else if (keyCode === keyCodeEnter) {\n if (globalVariableCurrentFocus > -1) {\n if ($itemsWrapper && $itemsWrapper.current && $itemsWrapper.current.children) {\n const $children = $itemsWrapper.current.children;\n if ($children[globalVariableCurrentFocus]) {\n $children[globalVariableCurrentFocus].click();\n } else {\n return;\n }\n }\n }\n }\n },\n [filteredOptionList],\n );\n /* istanbul ignore next because of https://github.com/airbnb/enzyme/issues/441 && https://github.com/airbnb/enzyme/blob/master/docs/future.md */\n const onKeyDown = useCallback(\n (e: any) => {\n if (showSearch) {\n return;\n }\n setIsTyping(true);\n if (e.preventDefault) {\n e.preventDefault();\n }\n if (!show) {\n return;\n }\n globalVariableCurrentFocus = globalVariableCurrentFocus === null ? getIndex(filteredOptionList, String(value)) : globalVariableCurrentFocus;\n const { keyCode } = e;\n const direction = getDirection(keyCode);\n if (selectKeyList.indexOf(keyCode) !== -1) {\n handleOnKeyDown(keyCode);\n } else {\n setTimeoutTyping();\n const newkeyCodeList = [...keycodeList, keyCode];\n const str = String.fromCharCode(...newkeyCodeList).toLowerCase();\n let index = -1;\n filteredOptionList.forEach((i, k) => {\n const { name } = i;\n if (name.toLowerCase().startsWith(str)) {\n if (index === -1) {\n index = k;\n }\n }\n });\n if (index !== -1) {\n globalVariableCurrentFocus = index;\n addActive();\n }\n setKeycodeList(newkeyCodeList);\n }\n scroll(direction);\n return globalVariableCurrentFocus;\n },\n [show, value, keycodeList],\n );\n useEffect(() => {\n if (show && $elWrapper) {\n document.addEventListener('keydown', onKeyDown);\n }\n return () => {\n document.removeEventListener('keydown', onKeyDown);\n };\n }, [show, value, keycodeList]);\n useEffect(() => {\n if (validate) {\n check();\n }\n }, [validate]);\n useEffect(() => {\n if (!(!isValidValue(filteredOptionList, internalValue) || internalValue === '' || internalValue === 'null' || internalValue === 'undefined')) {\n setErr(false);\n } else {\n setSuccessMsg('');\n }\n }, [internalValue]);\n useEffect(() => {\n setInternalValue(String(value));\n }, [value]);\n useEffect(() => {\n if (prevOptionList && prevOptionList && !utils.arraysEqual(prevOptionList, optionList)) {\n setInternalValue(String(optionList[0].id));\n }\n }, [optionList]);\n useEffect(() => {\n if (typeof prevInternalValue !== 'undefined' && prevInternalValue !== internalValue) {\n check();\n }\n }, [prevInternalValue, internalValue]);\n useEffect(() => {\n if (asyncObj) {\n if (asyncObj.message) {\n if (asyncObj.showOnError) {\n handleCheckEnd(asyncObj.error, asyncObj.message);\n }\n if (!asyncObj.error && asyncObj.showOnSuccess) {\n setSuccessMsg(asyncObj.message);\n }\n }\n }\n }, [asyncMsgObj]);\n useEffect(() => {\n if (show) {\n if (showSearch) {\n $searchInput.current.focus();\n }\n globalVariableCurrentFocus = globalVariableCurrentFocus === null ? getIndex(filteredOptionList, String(value)) : globalVariableCurrentFocus;\n $itemsRef[globalVariableCurrentFocus] && $itemsRef[globalVariableCurrentFocus].current.focus();\n }\n if (prevShow === true && show === false) {\n $elButton.current.focus();\n }\n resetCurrentFocus();\n }, [show]);\n const wrapperClass = `${WRAPPER_CLASS_IDENTITIFIER} ${classNameWrapper} ${reactInputsValidationCss[`${TYPE}__wrapper`]} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const containerClass = `${CONTAINER_CLASS_IDENTITIFIER} ${classNameContainer} ${reactInputsValidationCss[`${TYPE}__container`]} ${err && reactInputsValidationCss['error']} ${show &&\n reactInputsValidationCss['show']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const inputClass = `${reactInputsValidationCss[`${TYPE}__input`]} ${err && reactInputsValidationCss['error']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${disabled &&\n reactInputsValidationCss['disabled']}`;\n const selectClass = `${classNameSelect} ${reactInputsValidationCss['ellipsis']} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const selectOptionListContainerClass = `${classNameOptionListContainer} ${reactInputsValidationCss[`${TYPE}__options-container`]} ${err && reactInputsValidationCss['error']} ${show &&\n reactInputsValidationCss['show']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const selectOptionListItemClass = `${reactInputsValidationCss[`button`]} ${!isTyping && reactInputsValidationCss[`${TYPE}__options-item-show-cursor`]} ${classNameOptionListItem} ${\n reactInputsValidationCss[`${TYPE}__options-item`]\n } ${err && reactInputsValidationCss['error']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const dropdownIconClass = `${classNameDropdownIconOptionListItem} ${reactInputsValidationCss[`${TYPE}__dropdown-icon`]}`;\n const errMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${err && reactInputsValidationCss['error']}`;\n const successMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${!err && reactInputsValidationCss['success']}`;\n let msgHtml;\n const { showMsg } = option;\n if (showMsg && err && msg) {\n msgHtml =
{msg}
;\n }\n if (showMsg && !err && successMsg !== '') {\n msgHtml =
{successMsg}
;\n }\n let optionListHtml;\n const item = getItem(optionList, String(value));\n if (filteredOptionList.length) {\n optionListHtml = filteredOptionList.map((i, k) => (\n \n ));\n } else {\n if (showSearch) {\n optionListHtml = (\n
\n \n \n \n \n
\n );\n }\n }\n const selectorHtml = (\n
\n
{item ? item.name : ''}
\n
\n
\n );\n return (\n {\n handleOnClick(e);\n if (!disabled) {\n if ($searchInputWrapper.current) {\n if ($searchInputWrapper.current.contains(e.target)) {\n setShow(true);\n return;\n }\n }\n setShow(!show);\n }\n }}\n onFocus={handleOnFocus}\n onBlur={handleOnBlur}\n {...attributesWrapper}\n >\n
\n
\n {}} {...attributesInput} />\n
\n {selectorHtml}\n
\n
\n {showSearch && (\n
\n
\n \n \n \n \n \n {stateKeyword[0] && (\n {\n stateKeyword[1]('');\n $searchInput.current.focus();\n }}\n >\n \n \n \n )}\n
\n
\n )}\n
\n {optionListHtml}\n
\n
\n
\n {msgHtml}\n
\n \n );\n};\ninterface OptionProps {\n index?: number;\n id?: string;\n className?: string;\n item?: OptionListItem;\n customStyleOptionListItem?: object;\n onClick?: (res: object, e: React.MouseEvent) => void;\n onMouseOver?: (res: number) => void;\n onMouseMove?: () => void;\n onMouseOut?: () => void;\n}\nexport const Option: React.FC = memo(\n ({ index = -1, id = '', className = '', item = { id: '', name: '' }, customStyleOptionListItem = {}, onClick = () => {}, onMouseOver = () => {}, onMouseMove = () => {}, onMouseOut = () => {} }) => {\n const handleOnClick = useCallback(\n (e: React.MouseEvent) => {\n onClick(item, e);\n },\n [item],\n );\n const handleOnMouseOver = useCallback(() => {\n onMouseOver(index);\n }, []);\n const handleOnMouseMove = useCallback(() => {\n onMouseMove();\n }, []);\n const handleOnMouseOut = useCallback(() => {\n onMouseOut();\n }, []);\n return (\n \n {item.name}\n \n );\n },\n);\nexport default memo(component);\n","import * as React from 'react';\nconst { useState, useEffect, useCallback, useRef, memo } = React;\nimport message from './message';\nimport { REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE, DEFAULT_LOCALE, WRAPPER_CLASS_IDENTITIFIER, MSG_CLASS_IDENTITIFIER, usePrevious } from './const';\nimport utils from './utils';\nimport reactInputsValidationCss from './react-inputs-validation.css';\nconst TYPE = 'checkbox';\ninterface DefaultValidationOption {\n name?: string;\n check?: boolean;\n showMsg?: boolean;\n required?: boolean;\n locale?: string;\n msgOnError?: string;\n msgOnSuccess?: string;\n}\nconst getDefaultValidationOption = (obj: DefaultValidationOption) => {\n let { name, check, required, showMsg, locale, msgOnError, msgOnSuccess } = obj;\n locale = typeof locale !== 'undefined' ? locale : DEFAULT_LOCALE;\n name = typeof name !== 'undefined' ? name : '';\n check = typeof check !== 'undefined' ? check : true;\n showMsg = typeof showMsg !== 'undefined' ? showMsg : true;\n required = typeof required !== 'undefined' ? required : true;\n msgOnSuccess = typeof msgOnSuccess !== 'undefined' ? msgOnSuccess : '';\n msgOnError = typeof msgOnError !== 'undefined' ? msgOnError : '';\n return {\n name,\n check,\n showMsg,\n required,\n locale,\n msgOnError,\n msgOnSuccess,\n };\n};\ninterface DefaultAsyncMsgObj {\n error?: boolean;\n message?: string;\n showOnError?: boolean;\n showOnSuccess?: boolean;\n}\nconst getDefaultAsyncObj = (obj: DefaultAsyncMsgObj) => {\n let { error, message, showOnError, showOnSuccess } = obj;\n error = typeof error !== 'undefined' ? error : false;\n message = typeof message !== 'undefined' ? message : '';\n showOnError = typeof showOnError !== 'undefined' ? showOnError : true;\n showOnSuccess = typeof showOnSuccess !== 'undefined' ? showOnSuccess : false;\n return {\n error,\n message,\n showOnError,\n showOnSuccess,\n };\n};\ninterface Props {\n attributesWrapper?: object;\n attributesInput?: object;\n value?: string | boolean;\n checked?: boolean;\n disabled?: boolean;\n labelHtml?: React.ReactNode;\n validate?: boolean;\n onChange: (res: boolean, e: React.ChangeEvent | React.MouseEvent) => void;\n onBlur?: (e: React.FocusEvent) => void;\n onFocus?: (e: React.FocusEvent) => void;\n onClick?: (e: React.MouseEvent) => void;\n validationOption?: object;\n asyncMsgObj?: object;\n classNameInput?: string;\n classNameWrapper?: string;\n classNameInputBox?: string;\n classNameContainer?: string;\n customStyleInput?: object;\n customStyleWrapper?: object;\n customStyleContainer?: object;\n customStyleInputBox?: object;\n validationCallback?: (res: boolean) => void;\n}\nconst component: React.FC = ({\n attributesWrapper = {},\n attributesInput = {},\n value = '',\n checked = false,\n disabled = false,\n validate = false,\n labelHtml = null,\n classNameInput = '',\n classNameWrapper = '',\n classNameInputBox = '',\n classNameContainer = '',\n customStyleInput = {},\n customStyleWrapper = {},\n customStyleInputBox = {},\n customStyleContainer = {},\n validationOption = {},\n asyncMsgObj = {},\n onChange = () => {},\n onBlur = null,\n onFocus = null,\n onClick = null,\n validationCallback = null,\n}) => {\n const [err, setErr] = useState(false);\n const [msg, setMsg] = useState('');\n const [successMsg, setSuccessMsg] = useState('');\n const [internalChecked, setInternalChecked] = useState(checked);\n const prevInternalChecked = usePrevious(internalChecked);\n const option = getDefaultValidationOption(validationOption);\n const asyncObj = getDefaultAsyncObj(asyncMsgObj);\n const $input = useRef(null);\n const $el: { [key: string]: any } | null = $input;\n const handleOnBlur = useCallback(\n (e: React.FocusEvent) => {\n if (onBlur) {\n check();\n onBlur(e);\n }\n },\n [internalChecked, option],\n );\n const handleOnFocus = useCallback(\n (e: React.FocusEvent) => {\n if (onFocus) {\n onFocus(e);\n }\n },\n [internalChecked],\n );\n const handleOnClick = useCallback(\n (e: React.MouseEvent) => {\n handleOnChange(e);\n if (onClick) {\n onClick(e);\n }\n },\n [err, internalChecked],\n );\n const handleOnChange = useCallback(\n (e: React.ChangeEvent | React.MouseEvent) => {\n if (disabled || $el === null) {\n return;\n }\n setInternalChecked(!internalChecked);\n onChange && onChange(!internalChecked, e);\n if (err) {\n setErr(false);\n } else {\n setSuccessMsg('');\n }\n },\n [err, internalChecked],\n );\n const check = useCallback(\n () => {\n const { name, check, locale, required, msgOnSuccess } = option;\n if (!check) {\n return;\n }\n if (!message[locale] || !message[locale][TYPE]) {\n console.error(REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE);\n return;\n }\n if (required) {\n const msg = message[locale][TYPE];\n const nameText = name ? name : '';\n if (!internalChecked) {\n handleCheckEnd(true, msg.unchecked(nameText));\n return;\n }\n }\n if (msgOnSuccess) {\n setSuccessMsg(msgOnSuccess);\n }\n handleCheckEnd(false, msgOnSuccess);\n },\n [internalChecked, option],\n );\n const handleCheckEnd = useCallback((err: boolean, message: string) => {\n let msg = message;\n const { msgOnError } = option;\n if (err && msgOnError) {\n msg = msgOnError;\n }\n setErr(err);\n setMsg(msg);\n validationCallback && validationCallback(err);\n }, []);\n useEffect(\n () => {\n if (validate) {\n check();\n }\n },\n [validate, internalChecked],\n );\n useEffect(\n () => {\n setInternalChecked(checked);\n },\n [checked],\n );\n useEffect(\n () => {\n if (typeof prevInternalChecked !== 'undefined' && prevInternalChecked !== internalChecked) {\n check();\n }\n },\n [prevInternalChecked, internalChecked],\n );\n useEffect(\n () => {\n if (asyncObj) {\n if (asyncObj.message) {\n if (asyncObj.showOnError) {\n handleCheckEnd(asyncObj.error, asyncObj.message);\n }\n if (!asyncObj.error && asyncObj.showOnSuccess) {\n setSuccessMsg(asyncObj.message);\n }\n }\n }\n },\n [asyncMsgObj],\n );\n const wrapperClass = `${reactInputsValidationCss['button']} ${WRAPPER_CLASS_IDENTITIFIER} ${classNameWrapper} ${reactInputsValidationCss[`${TYPE}__wrapper`]} ${internalChecked && reactInputsValidationCss['checked']} ${err &&\n reactInputsValidationCss['error']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const containerClass = `${classNameContainer} ${reactInputsValidationCss[`${TYPE}__container`]} ${internalChecked && reactInputsValidationCss['checked']} ${err &&\n reactInputsValidationCss['error']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const boxClass = `${classNameInputBox} ${reactInputsValidationCss[`${TYPE}__box`]} ${err && reactInputsValidationCss['error']} ${internalChecked &&\n reactInputsValidationCss['checked']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const labelClass = `${internalChecked && reactInputsValidationCss['checked']} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const errMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${err && reactInputsValidationCss['error']}`;\n const successMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${!err && reactInputsValidationCss['success']}`;\n let msgHtml;\n const { showMsg } = option;\n if (showMsg && err && msg) {\n msgHtml =
{msg}
;\n }\n if (showMsg && !err && successMsg !== '') {\n msgHtml =
{successMsg}
;\n }\n return (\n \n );\n};\nexport default memo(component);\n","import * as React from 'react';\nconst { useState, useEffect, useCallback, useRef, memo } = React;\nimport message from './message';\nimport { REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE, DEFAULT_LOCALE, WRAPPER_CLASS_IDENTITIFIER, OPTION_LIST_ITEM_IDENTITIFIER, MSG_CLASS_IDENTITIFIER, usePrevious } from './const';\nimport utils from './utils';\nimport reactInputsValidationCss from './react-inputs-validation.css';\nconst TYPE = 'radiobox';\ninterface DefaultValidationOption {\n name?: string;\n check?: boolean;\n showMsg?: boolean;\n required?: boolean;\n locale?: string;\n msgOnError?: string;\n msgOnSuccess?: string;\n}\nconst getDefaultValidationOption = (obj: DefaultValidationOption) => {\n let { name, check, required, showMsg, locale, msgOnError, msgOnSuccess } = obj;\n locale = typeof locale !== 'undefined' ? locale : DEFAULT_LOCALE;\n name = typeof name !== 'undefined' ? name : '';\n check = typeof check !== 'undefined' ? check : true;\n showMsg = typeof showMsg !== 'undefined' ? showMsg : true;\n required = typeof required !== 'undefined' ? required : true;\n msgOnSuccess = typeof msgOnSuccess !== 'undefined' ? msgOnSuccess : '';\n msgOnError = typeof msgOnError !== 'undefined' ? msgOnError : '';\n return {\n name,\n check,\n showMsg,\n required,\n locale,\n msgOnError,\n msgOnSuccess,\n };\n};\ninterface DefaultAsyncMsgObj {\n error?: boolean;\n message?: string;\n showOnError?: boolean;\n showOnSuccess?: boolean;\n}\nconst getDefaultAsyncObj = (obj: DefaultAsyncMsgObj) => {\n let { error, message, showOnError, showOnSuccess } = obj;\n error = typeof error !== 'undefined' ? error : false;\n message = typeof message !== 'undefined' ? message : '';\n showOnError = typeof showOnError !== 'undefined' ? showOnError : true;\n showOnSuccess = typeof showOnSuccess !== 'undefined' ? showOnSuccess : false;\n return {\n error,\n message,\n showOnError,\n showOnSuccess,\n };\n};\nexport const isValidValue = (list: OptionListItem[], value: any) => {\n let res = false;\n if (list.length) {\n for (let i = 0; i < list.length; i += 1) {\n if (list[i].id === value) {\n res = true;\n break;\n }\n }\n }\n return res;\n};\ninterface OptionListItem {\n id: string;\n name: string;\n}\ninterface AttributesInput {}\ninterface Props {\n attributesWrapper: object;\n attributesInputs: AttributesInput[];\n value?: string | number;\n disabled?: boolean;\n validate?: boolean;\n optionList?: OptionListItem[];\n onChange: (res: string, e: React.ChangeEvent) => void;\n onBlur?: (e: React.FocusEvent) => void;\n onFocus?: (e: React.FocusEvent) => void;\n onClick?: (e: React.MouseEvent) => void;\n validationOption?: object;\n asyncMsgObj?: object;\n classNameWrapper?: string;\n classNameInput?: string;\n classNameContainer?: string;\n classNameOptionListItem?: string;\n customStyleWrapper?: object;\n customStyleContainer?: object;\n customStyleInput?: object;\n customStyleOptionListItem?: object;\n validationCallback?: (res: boolean) => void;\n}\nconst component: React.FC = ({\n attributesWrapper = {},\n attributesInputs = [],\n value = '',\n disabled = false,\n validate = false,\n optionList = [],\n classNameWrapper = '',\n classNameInput = '',\n classNameContainer = '',\n classNameOptionListItem = '',\n customStyleWrapper = {},\n customStyleContainer = {},\n customStyleInput = {},\n customStyleOptionListItem = {},\n validationOption = {},\n asyncMsgObj = {},\n onChange = () => {},\n onBlur = null,\n onFocus = null,\n onClick = null,\n validationCallback = null,\n}) => {\n const [err, setErr] = useState(false);\n const [msg, setMsg] = useState('');\n const [successMsg, setSuccessMsg] = useState('');\n const [internalValue, setInternalValue] = useState(String(value));\n const prevInternalValue = usePrevious(internalValue);\n const option = getDefaultValidationOption(validationOption);\n const asyncObj = getDefaultAsyncObj(asyncMsgObj);\n const $input = useRef(null);\n const $el: { [key: string]: any } | null = $input;\n const handleOnBlur = useCallback(\n (e: React.FocusEvent) => {\n if (onBlur) {\n check();\n onBlur(e);\n }\n },\n [internalValue, option],\n );\n const handleOnFocus = useCallback((e: React.FocusEvent) => {\n if (onFocus) {\n onFocus(e);\n }\n }, []);\n const handleOnClick = useCallback((e: React.MouseEvent) => {\n if (onClick) {\n onClick(e);\n }\n }, []);\n const handleOnChange = useCallback((val: string, e: React.ChangeEvent) => {\n if (disabled || $el === null) {\n return;\n }\n setInternalValue(val);\n onChange && onChange(val, e);\n }, []);\n const check = useCallback(\n () => {\n const { name, check, locale, required, msgOnSuccess } = option;\n if (!check) {\n return;\n }\n if (!message[locale] || !message[locale][TYPE]) {\n console.error(REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE);\n return;\n }\n if (required) {\n const msg = message[locale][TYPE];\n const nameText = name ? name : '';\n if (!isValidValue(optionList, internalValue)) {\n handleCheckEnd(true, msg.empty(nameText));\n return;\n }\n }\n if (msgOnSuccess) {\n setSuccessMsg(msgOnSuccess);\n }\n handleCheckEnd(false, msgOnSuccess);\n },\n [internalValue, option],\n );\n const handleCheckEnd = useCallback((err: boolean, message: string) => {\n let msg = message;\n const { msgOnError } = option;\n if (err && msgOnError) {\n msg = msgOnError;\n }\n setErr(err);\n setMsg(msg);\n validationCallback && validationCallback(err);\n }, []);\n useEffect(\n () => {\n if (validate) {\n check();\n }\n },\n [validate],\n );\n useEffect(\n () => {\n if (internalValue && isValidValue(optionList, internalValue)) {\n setErr(false);\n } else {\n setSuccessMsg('');\n }\n },\n [internalValue],\n );\n useEffect(\n () => {\n setInternalValue(String(value));\n },\n [value],\n );\n useEffect(\n () => {\n if (typeof prevInternalValue !== 'undefined' && prevInternalValue !== internalValue) {\n check();\n }\n },\n [prevInternalValue, internalValue],\n );\n useEffect(\n () => {\n if (asyncObj) {\n if (asyncObj.message) {\n if (asyncObj.showOnError) {\n handleCheckEnd(asyncObj.error, asyncObj.message);\n }\n if (!asyncObj.error && asyncObj.showOnSuccess) {\n setSuccessMsg(asyncObj.message);\n }\n }\n }\n },\n [asyncMsgObj],\n );\n const wrapperClass = `${WRAPPER_CLASS_IDENTITIFIER} ${classNameWrapper} ${err && reactInputsValidationCss['error']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${\n reactInputsValidationCss[`${TYPE}__wrapper`]\n } ${disabled && reactInputsValidationCss['disabled']}`;\n const containerClass = `${classNameContainer} ${err && reactInputsValidationCss['error']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${\n reactInputsValidationCss[`${TYPE}__container`]\n } ${disabled && reactInputsValidationCss['disabled']}`;\n const inputClass = `${classNameInput} ${err && reactInputsValidationCss['error']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${\n reactInputsValidationCss[`${TYPE}__input`]\n } ${disabled && reactInputsValidationCss['disabled']}`;\n const labelClass = `${err && reactInputsValidationCss['error']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${reactInputsValidationCss[`${TYPE}__label`]} ${disabled &&\n reactInputsValidationCss['disabled']}`;\n const optionListItemClass = `${reactInputsValidationCss['button']} ${OPTION_LIST_ITEM_IDENTITIFIER} ${classNameOptionListItem} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${reactInputsValidationCss[`${TYPE}__item`]} ${disabled && reactInputsValidationCss['disabled']}`;\n const errMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${err && reactInputsValidationCss['error']}`;\n const successMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${!err && reactInputsValidationCss['success']}`;\n let msgHtml;\n const { showMsg } = option;\n if (showMsg && err && msg) {\n msgHtml =
{msg}
;\n }\n if (showMsg && !err && successMsg !== '') {\n msgHtml =
{successMsg}
;\n }\n let optionHtml;\n if (optionList.length) {\n optionHtml = optionList.map((i, k) => {\n const checked = String(i.id) === String(internalValue) ? true : false;\n return (\n \n );\n });\n }\n return (\n
\n
\n {optionHtml}\n
\n {msgHtml}\n
\n );\n};\ninterface AttributesInput {\n id?: string;\n}\ninterface OptionProps {\n checked?: boolean;\n id?: string;\n optionListItemClass?: string;\n labelClass?: string;\n inputClass?: string;\n value?: string | number;\n disabled?: boolean;\n item?: OptionListItem;\n customStyleOptionListItem?: object;\n customStyleInput?: object;\n attributesInput: AttributesInput;\n onChange?: (res: string, e: React.ChangeEvent) => void;\n}\nexport const Option: React.FC = memo(\n ({\n checked = false,\n id = '',\n optionListItemClass = '',\n labelClass = '',\n inputClass = '',\n value = '',\n disabled = false,\n item = { id: '', name: '' },\n customStyleOptionListItem = {},\n customStyleInput = {},\n attributesInput = {},\n onChange = () => {},\n }) => {\n const handleOnChange = useCallback(e => {\n onChange(item.id, e);\n }, [item]);\n return (\n \n );\n },\n);\nexport default memo(component);\n"],"sourceRoot":""} \ No newline at end of file +{"version":3,"sources":["webpack://react-inputs-validation/webpack/universalModuleDefinition","webpack://react-inputs-validation/webpack/bootstrap","webpack://react-inputs-validation/external \"React\"","webpack://react-inputs-validation/./src/js/Inputs/const.ts","webpack://react-inputs-validation/./src/js/Inputs/message.ts","webpack://react-inputs-validation/./src/js/Inputs/react-inputs-validation.css?df4a","webpack://react-inputs-validation/./src/js/Inputs/utils.ts","webpack://react-inputs-validation/./src/js/Inputs/validator.ts","webpack://react-inputs-validation/./src/js/Inputs/index.global.ts","webpack://react-inputs-validation/./src/js/Inputs/Textbox.tsx","webpack://react-inputs-validation/./src/js/Inputs/Textarea.tsx","webpack://react-inputs-validation/./src/js/Inputs/Select.tsx","webpack://react-inputs-validation/./src/js/Inputs/Checkbox.tsx","webpack://react-inputs-validation/./src/js/Inputs/Radiobox.tsx"],"names":["root","factory","exports","module","require","define","amd","this","__WEBPACK_EXTERNAL_MODULE__0__","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","useEffect","useRef","LOCALE_OPTION_LIST","REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE","DEFAULT_LOCALE","WRAPPER_CLASS_IDENTITIFIER","CONTAINER_CLASS_IDENTITIFIER","OPTION_LIST_ITEM_IDENTITIFIER","MSG_CLASS_IDENTITIFIER","usePrevious","ref","current","getEnglishName","res","message","textbox","empty","invalid","invalidFormat","inBetween","min","max","lessThan","greaterThan","lengthEqual","length","twoInputsNotEqual","radiobox","checkbox","unchecked","select","textarea","getCustomErrorMessage","constructor","keys","map","j","k","console","error","handleCustomErrorMessage","w","REACT_INPUTS_VALIDATION","window","camelize","str","replace","match","index","toLowerCase","toUpperCase","utils","toCamelCase","capitalLize","substr","getRandomId","Math","random","toString","slice","getAlphanumeric","v","String","split","forEach","charCode","charCodeAt","getAlpha","getNumeric","arraysEqual","arr1","arr2","JSON","stringify","isNumeric","isNaN","parseFloat","isFinite","validator","reg","err","test","number","Textbox","Textarea","Select","Checkbox","Radiobox","useState","useCallback","memo","TYPE","VALIDATE_OPTION_TYPE_LIST","VALIDATE_NUMBER_TYPE_LIST","obj","showOnError","showOnSuccess","attributesWrapper","attributesInput","disabled","validate","classNameInput","classNameWrapper","classNameContainer","customStyleInput","customStyleWrapper","customStyleContainer","validationOption","asyncMsgObj","onChange","onBlur","onFocus","onClick","onKeyUp","validationCallback","setErr","msg","setMsg","successMsg","setSuccessMsg","internalValue","setInternalValue","prevInternalValue","option","type","numberType","mantissa","check","regMsg","compare","required","showMsg","locale","msgOnError","msgOnSuccess","customFunc","undefined","getDefaultValidationOption","asyncObj","$input","$el","handleOnBlur","e","handleOnFocus","handleOnClick","handleOnKeyUp","keyCode","handleOnChange","maxLength","Number","hasDot","splitStr","shift","resArr","join","autoFormatNumber","indexOf","nameText","handleCheckEnd","customFuncResult","fromCustomFunc","msgHtml","wrapperClass","containerClass","inputClass","errMsgClass","successMsgClass","className","style","useMemo","selectKeyList","startsWith","searchString","position","isValidValue","list","id","getItem","getIndex","globalVariableIsFocusing","globalVariableIsCorrected","globalVariableCurrentFocus","globalVariableTypingTimeout","Option","item","customStyleOptionListItem","onMouseOver","onMouseMove","onMouseOut","handleOnMouseOver","handleOnMouseMove","handleOnMouseOut","showSearch","keyword","optionList","classNameSelect","classNameOptionListItem","classNameOptionListContainer","classNameDropdownIconOptionListItem","customStyleSelect","customStyleOptionListContainer","customStyleDropdownIcon","stateKeyword","prevOptionList","show","setShow","prevShow","isTyping","setIsTyping","keycodeList","setKeycodeList","$button","$wrapper","$itemsWrapper","$searchInputWrapper","$searchInput","$elButton","$elWrapper","$elItemsWrapper","$itemsRef","filteredOptionList","filter","includes","handleOnSearch","target","handleOnSearchKeyDown","direction","getDirection","preventDefault","handleOnKeyDown","scroll","addActive","addEventListener","pageClick","removeEventListener","onKeyDown","contains","resetCurrentFocus","setTimeoutTyping","clearTimeout","setTimeout","children","$children","containerHeight","offsetHeight","containerScrollTop","scrollTop","itemHeight","heightItems","heightContainer","offset","abs","handleOnItemClick","handleOnItemMouseOver","handleOnItemMouseMove","handleOnItemMouseOut","removeActive","click","newkeyCodeList","fromCharCode","document","focus","optionListHtml","selectClass","selectOptionListContainerClass","selectOptionListItemClass","dropdownIconClass","background","textAlign","padding","xmlns","width","height","viewBox","fill","selectorHtml","checked","labelHtml","classNameInputBox","customStyleInputBox","internalChecked","setInternalChecked","prevInternalChecked","boxClass","labelClass","defaultChecked","optionListItemClass","htmlFor","attributesInputs","val","optionHtml"],"mappings":"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","file":"react-inputs-validation.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"React\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"React\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"react-inputs-validation\"] = factory(require(\"React\"));\n\telse\n\t\troot[\"react-inputs-validation\"] = factory(root[\"React\"]);\n})(this, function(__WEBPACK_EXTERNAL_MODULE__0__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 6);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__0__;","import * as React from 'react';\nconst { useEffect, useRef } = React;\nexport const LOCALE_OPTION_LIST = ['en-US', 'zh-CN'];\nexport const REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE =\n \"Invalid window.REACT_INPUTS_VALIDATION['customErrorMessage']. EXAMPLE: window.REACT_INPUTS_VALIDATION={customErrorMessage:{'en-US':{textbox:{empty:function empty(name){return getEnglishName(name)+'cannot be empty'},invalid:function invalid(name){return getEnglishName(name)+'invalid format'},invalidFormat:function invalidFormat(name){return getEnglishName(name)+'is not a number'},inBetween:function inBetween(name){return function(min){return function(max){return getEnglishName(name)+'must be '+min+'-'+max}}},lessThan:function lessThan(name){return function(min){return getEnglishName(name)+'cannot less than '+min}},greaterThan:function greaterThan(name){return function(max){return getEnglishName(name)+'cannot greater than '+max}},lengthEqual:function lengthEqual(name){return function(length){return getEnglishName(name)+'length must be '+length}},twoInputsNotEqual:function twoInputsNotEqual(){return'two inputs are not equal'}},radiobox:{empty:function empty(name){return'Please choose one '+getEnglishName(name)}},checkbox:{unchecked:function unchecked(name){return getEnglishName(name)+'must be checked'}},select:{empty:function empty(name){return'Please select a '+getEnglishName(name)}},textarea:{empty:function empty(name){return getEnglishName(name)+'cannot be empty'},invalid:function invalid(name){return getEnglishName(name)+'invalid format'},invalidFormat:function invalidFormat(name){return getEnglishName(name)+'is not a number'},inBetween:function inBetween(name){return function(min){return function(max){return getEnglishName(name)+'must be '+min+'-'+max}}},lessThan:function lessThan(name){return function(min){return getEnglishName(name)+'cannot less than '+min}},greaterThan:function greaterThan(name){return function(max){return getEnglishName(name)+'cannot greater than '+max}},lengthEqual:function lengthEqual(name){return function(length){return getEnglishName(name)+'length must be '+length}},twoInputsNotEqual:function twoInputsNotEqual(){return'two inputs are not equal'}}}}};\";\nexport const DEFAULT_LOCALE = 'en-US';\nexport const WRAPPER_CLASS_IDENTITIFIER = 'react-inputs-validation__wrapper_identifier';\nexport const CONTAINER_CLASS_IDENTITIFIER = 'react-inputs-validation__container_identifier';\nexport const OPTION_LIST_ITEM_IDENTITIFIER = 'react-inputs-validation__option-list-item_identifier';\nexport const MSG_CLASS_IDENTITIFIER = 'react-inputs-validation__msg_identifier';\nexport const usePrevious = (value: any) => {\n const ref = useRef();\n useEffect(() => {\n ref.current = value;\n });\n return ref.current;\n};\n","import { REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE } from './const';\n\nconst getEnglishName = (name: string) => {\n let res = '';\n if (name) {\n res = `${name} `;\n }\n return res;\n};\n\nconst TEXT_BOX_VALIDATION_ZH_CN = {\n empty: (name: string) => `${name}不能为空`,\n invalid: (name: string) => `${name}格式有误`,\n invalidFormat: (name: string) => `${name}不是数字`,\n inBetween: (name: string) => (min: number) => (max: number) => `${name}必须在${min}-${max}之间`,\n lessThan: (name: string) => (min: number) => `${name}不可少于${min}`,\n greaterThan: (name: string) => (max: number) => `${name}不可大于${max}`,\n lengthEqual: (name: string) => (length: number) => `${name}长度必须为${length}`,\n twoInputsNotEqual: () => `两次输入不一致`,\n};\n\nconst TEXT_BOX_VALIDATION_EN_US = {\n empty: (name: string) => `${getEnglishName(name)}cannot be empty`,\n invalid: (name: string) => `${getEnglishName(name)}invalid format`,\n invalidFormat: (name: string) => `${getEnglishName(name)}is not a number`,\n inBetween: (name: string) => (min: number) => (max: number) => `${getEnglishName(name)}must be ${min}-${max}`,\n lessThan: (name: string) => (min: number) => `${getEnglishName(name)}cannot less than ${min}`,\n greaterThan: (name: string) => (max: number) => `${getEnglishName(name)}cannot greater than ${max}`,\n lengthEqual: (name: string) => (length: number) => `${getEnglishName(name)}length must be ${length}`,\n twoInputsNotEqual: () => `two inputs are not equal`,\n};\n\nconst TEXT_AREA_VALIDATION_ZH_CN = {\n empty: (name: string) => `${name}不能为空`,\n invalid: (name: string) => `${name}格式有误`,\n invalidFormat: (name: string) => `${name}不是数字`,\n inBetween: (name: string) => (min: number) => (max: number) => `${name}必须在${min}-${max}之间`,\n lessThan: (name: string) => (min: number) => `${name}不可少于${min}`,\n greaterThan: (name: string) => (max: number) => `${name}不可大于${max}`,\n lengthEqual: (name: string) => (length: number) => `${name}长度必须为${length}`,\n twoInputsNotEqual: () => `两次输入不一致`,\n};\n\nconst TEXT_AREA_VALIDATION_EN_US = {\n empty: (name: string) => `${getEnglishName(name)}cannot be empty`,\n invalid: (name: string) => `${getEnglishName(name)}invalid format`,\n invalidFormat: (name: string) => `${getEnglishName(name)}is not a number`,\n inBetween: (name: string) => (min: number) => (max: number) => `${getEnglishName(name)}must be ${min}-${max}`,\n lessThan: (name: string) => (min: number) => `${getEnglishName(name)}cannot less than ${min}`,\n greaterThan: (name: string) => (max: number) => `${getEnglishName(name)}cannot greater than ${max}`,\n lengthEqual: (name: string) => (length: number) => `${getEnglishName(name)}length must be ${length}`,\n twoInputsNotEqual: () => `two inputs are not equal`,\n};\n\nconst SELECT_VALIDATION_ZH_CN = {\n empty: (name: string) => `请选择一个${name}`,\n};\n\nconst SELECT_VALIDATION_EN_US = {\n empty: (name: string) => `Please select a ${getEnglishName(name)}`,\n};\n\nconst CHECK_BOX_VALIDATION_ZH_CN = {\n unchecked: (name: string) => `${name}必须勾选`,\n};\n\nconst CHECK_BOX_VALIDATION_EN_US = {\n unchecked: (name: string) => `${getEnglishName(name)}must be checked`,\n};\n\nconst RADIO_BOX_VALIDATION_ZH_CN = {\n empty: (name: string) => `必须勾选一个${name}`,\n};\n\nconst RADIO_BOX_VALIDATION_EN_US = {\n empty: (name: string) => `Please choose one ${getEnglishName(name)}`,\n};\n\ninterface Message {\n [key: string]: Key;\n}\n\ninterface Key {\n [key: string]: Func;\n}\n\ninterface Func {\n [key: string]: Function;\n}\n\nlet message: Message = {\n 'zh-CN': {\n textbox: TEXT_BOX_VALIDATION_ZH_CN,\n radiobox: RADIO_BOX_VALIDATION_ZH_CN,\n checkbox: CHECK_BOX_VALIDATION_ZH_CN,\n select: SELECT_VALIDATION_ZH_CN,\n textarea: TEXT_AREA_VALIDATION_ZH_CN,\n },\n 'en-US': {\n textbox: TEXT_BOX_VALIDATION_EN_US,\n radiobox: RADIO_BOX_VALIDATION_EN_US,\n checkbox: CHECK_BOX_VALIDATION_EN_US,\n select: SELECT_VALIDATION_EN_US,\n textarea: TEXT_AREA_VALIDATION_EN_US,\n },\n};\n\n// TODO: find a rewire way to handle non-export function\nexport const getCustomErrorMessage = (o: any, m: any) => {\n if (!o || typeof o !== 'object' || o.constructor !== Object || !Object.keys(o).length) {\n console.error(REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE);\n return false;\n }\n Object.keys(o).map(i => {\n if (!m[i]) {\n m[i] = o[i];\n } else {\n if (Object.keys(o[i]).length) {\n Object.keys(o[i]).map(j => {\n if (Object.keys(o[i][j]).length) {\n Object.keys(o[i][j]).map(k => {\n m[i][j][k] = o[i][j][k];\n });\n }\n });\n }\n }\n });\n return m;\n};\n\ndeclare global {\n interface Window {\n REACT_INPUTS_VALIDATION: any;\n }\n}\n\n// TODO: find a rewire way to handle non-export function\nexport const handleCustomErrorMessage = (message: any, w: Window) => {\n let res;\n if (typeof w !== 'undefined') {\n if (w.REACT_INPUTS_VALIDATION && w.REACT_INPUTS_VALIDATION['customErrorMessage']) {\n res = getCustomErrorMessage(w.REACT_INPUTS_VALIDATION['customErrorMessage'], message);\n }\n }\n if (typeof res === 'undefined' || res === false) {\n return message;\n }\n return res;\n};\n\n/* istanbul ignore else */\nif (typeof window !== 'undefined') {\n window.REACT_INPUTS_VALIDATION = window.REACT_INPUTS_VALIDATION || {};\n message = handleCustomErrorMessage(message, window);\n}\n\nexport default message;\n","// extracted by mini-css-extract-plugin\nmodule.exports = {\"ellipsis\":\"react-inputs-validation__ellipsis___3-Api\",\"textbox__wrapper\":\"react-inputs-validation__textbox__wrapper___3tnXv\",\"textbox__input\":\"react-inputs-validation__textbox__input___20hDL\",\"error\":\"react-inputs-validation__error___2aXSp\",\"success\":\"react-inputs-validation__success___3TpwE\",\"disabled\":\"react-inputs-validation__disabled___1-57g\",\"msg\":\"react-inputs-validation__msg___pxv8o\",\"textarea__wrapper\":\"react-inputs-validation__textarea__wrapper___35GhF\",\"textarea__input\":\"react-inputs-validation__textarea__input___1CFm_\",\"radiobox__container\":\"react-inputs-validation__radiobox__container___FD4vb\",\"radiobox__input\":\"react-inputs-validation__radiobox__input___2uX2-\",\"radiobox__label\":\"react-inputs-validation__radiobox__label___2tQsB\",\"radiobox__wrapper\":\"react-inputs-validation__radiobox__wrapper___1zZ30\",\"checked\":\"react-inputs-validation__checked___2O0Ju\",\"button\":\"react-inputs-validation__button___9JBRL\",\"radiobox__item\":\"react-inputs-validation__radiobox__item___ejuz1\",\"checkbox__input\":\"react-inputs-validation__checkbox__input___1yF4X\",\"checkbox__container\":\"react-inputs-validation__checkbox__container___3I1rX\",\"checkbox__box\":\"react-inputs-validation__checkbox__box___1uj8A\",\"checkbox__wrapper\":\"react-inputs-validation__checkbox__wrapper___1c1rD\",\"box\":\"react-inputs-validation__box___3E9nu\",\"select__wrapper\":\"react-inputs-validation__select__wrapper___1B4OH\",\"select__input\":\"react-inputs-validation__select__input___3h-P7\",\"select__container\":\"react-inputs-validation__select__container___3jgUR\",\"select__button\":\"react-inputs-validation__select__button___vEDoq\",\"select__options-item\":\"react-inputs-validation__select__options-item___30yY4\",\"select__options-item-show-cursor\":\"react-inputs-validation__select__options-item-show-cursor___1ZT3b\",\"select__searchInputWrapper\":\"react-inputs-validation__select__searchInputWrapper___3R5P_\",\"select__searchInputSearchIcon\":\"react-inputs-validation__select__searchInputSearchIcon___1Q8xX\",\"select__searchInputRemoveIcon\":\"react-inputs-validation__select__searchInputRemoveIcon___1A1tR\",\"select__searchInput\":\"react-inputs-validation__select__searchInput___1lN24\",\"select__no-mouse\":\"react-inputs-validation__select__no-mouse___2uRg6\",\"select__hover-active\":\"react-inputs-validation__select__hover-active___2z1MQ\",\"active\":\"react-inputs-validation__active___3eZBB\",\"select__options-container-animate\":\"react-inputs-validation__select__options-container-animate___2Rm--\",\"show\":\"react-inputs-validation__show___2NI3u\",\"select__options-container\":\"react-inputs-validation__select__options-container___d54qE\",\"select__dropdown\":\"react-inputs-validation__select__dropdown___11yDr\",\"select__dropdown-icon\":\"react-inputs-validation__select__dropdown-icon___1T5r2\",\"select__dropdown-name\":\"react-inputs-validation__select__dropdown-name___3hghL\",\"select__dropdown-icon-container\":\"react-inputs-validation__select__dropdown-icon-container___2ild-\"};","const camelize = (str: string) => {\n return str.replace(/(?:^\\w|[A-Z]|\\b\\w|\\s+)/g, (match, index) => {\n if (+match === 0) return '';\n return index === 0 ? match.toLowerCase() : match.toUpperCase();\n });\n};\n\nconst toCamelCase = (str: string) => (capitalLize: boolean = false) => {\n const res = camelize(str);\n return capitalLize ? res.substr(0, 1).toUpperCase() + res.substr(1, res.length) : res;\n};\n\ninterface Utils {\n [key: string]: Function;\n}\n\nconst getRandomId = () => {\n return Math.random()\n .toString(36)\n .slice(-8);\n};\n\nconst getAlphanumeric = (v: string) => {\n let res = '';\n String(v)\n .split('')\n .forEach(i => {\n const charCode = i.toLowerCase().charCodeAt(0);\n if ((charCode >= 48 && charCode <= 57) || (charCode >= 97 && charCode <= 122)) {\n res += i;\n }\n });\n return res;\n};\n\nconst getAlpha = (v: string) => {\n let res = '';\n String(v)\n .split('')\n .forEach(i => {\n const charCode = i.toLowerCase().charCodeAt(0);\n if (charCode >= 97 && charCode <= 122) {\n res += i;\n }\n });\n return res;\n};\n\nconst getNumeric = (v: string) => {\n let res = '';\n String(v)\n .split('')\n .forEach(i => {\n const charCode = i.toLowerCase().charCodeAt(0);\n if (charCode >= 48 && charCode <= 57) {\n res += i;\n }\n });\n return res;\n};\n\nconst arraysEqual = (arr1: any, arr2: any) => {\n if (arr1.length !== arr2.length) return false;\n for (let i = arr1.length; (i -= 1); ) {\n if (JSON.stringify(arr1[i]) !== JSON.stringify(arr2[i])) return false;\n }\n return true;\n};\n\nconst utils: Utils = {\n camelize,\n toCamelCase,\n getRandomId,\n getAlphanumeric,\n getAlpha,\n getNumeric,\n arraysEqual,\n};\nexport default utils;\n","const empty = (v: string) => (v.replace(/\\s/g, '').length ? false : true);\nconst number = (v: number, min: any, max: any) => {\n if (min === null && max === null){\n return true\n }\n if (!isNumeric(v)) {\n return false;\n }\n return v < min || v > max ? false : true;\n};\n// TODO: find a better type for regex\nconst reg = (reg: any, v: string) => {\n let err = true;\n if (reg.test(v)) {\n err = false;\n }\n return err;\n};\nconst isNumeric = (v: any) => {\n return !isNaN(parseFloat(v)) && isFinite(v);\n};\n\ninterface Validator {\n [key: string]: Function;\n}\n\nconst validator: Validator = {\n reg,\n empty,\n number,\n};\nexport default validator;\n","import Textbox from './Textbox';\nimport Textarea from './Textarea';\nimport Select from './Select';\nimport Checkbox from './Checkbox';\nimport Radiobox from './Radiobox';\n\nif (typeof window !== 'undefined') {\n (window).Textbox = Textbox;\n (window).Textarea = Textarea;\n (window).Radiobox = Radiobox;\n (window).Checkbox = Checkbox;\n (window).Select = Select;\n}\n\nexport { Textbox, Textarea, Select, Checkbox, Radiobox };\n","import * as React from 'react';\nconst { useState, useEffect, useCallback, useRef, memo } = React;\nimport message from './message';\nimport validator from './validator';\nimport utils from './utils';\nimport { REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE, DEFAULT_LOCALE, MSG_CLASS_IDENTITIFIER, usePrevious } from './const';\nimport reactInputsValidationCss from './react-inputs-validation.css';\nconst TYPE = 'textbox';\nconst VALIDATE_OPTION_TYPE_LIST = ['string', 'number', 'alphanumeric', 'alpha'];\nconst VALIDATE_NUMBER_TYPE_LIST = ['decimal', 'int', 'price'];\ninterface DefaultValidationOption {\n locale?: string;\n reg?: string;\n min?: number;\n max?: number;\n type?: string;\n numberType?: string;\n mantissa?: number;\n name?: string;\n check?: boolean;\n showMsg?: boolean;\n length?: number;\n regMsg?: string;\n compare?: string;\n required?: boolean;\n msgOnError?: string;\n msgOnSuccess?: string;\n customFunc?: Function | undefined;\n}\nconst getDefaultValidationOption = (obj: DefaultValidationOption) => {\n let { reg, min, max, type, numberType, mantissa, name, check, length, regMsg, compare, required, showMsg, locale, msgOnError, msgOnSuccess, customFunc } = obj;\n locale = typeof locale !== 'undefined' ? locale : DEFAULT_LOCALE;\n reg = typeof reg !== 'undefined' ? reg : '';\n min = typeof min !== 'undefined' ? min : 0;\n max = typeof max !== 'undefined' ? max : 0;\n type = typeof type !== 'undefined' ? type : 'string';\n numberType = typeof numberType !== 'undefined' ? numberType : 'string';\n mantissa = typeof mantissa !== 'undefined' ? mantissa : -1;\n name = typeof name !== 'undefined' ? name : '';\n check = typeof check !== 'undefined' ? check : true;\n showMsg = typeof showMsg !== 'undefined' ? showMsg : true;\n length = typeof length !== 'undefined' ? length : 0;\n regMsg = typeof regMsg !== 'undefined' ? regMsg : '';\n compare = typeof compare !== 'undefined' ? compare : '';\n required = typeof required !== 'undefined' ? required : true;\n msgOnError = typeof msgOnError !== 'undefined' ? msgOnError : '';\n msgOnSuccess = typeof msgOnSuccess !== 'undefined' ? msgOnSuccess : '';\n customFunc = typeof customFunc !== 'undefined' ? customFunc : undefined;\n return {\n reg,\n min,\n max,\n type,\n numberType,\n mantissa,\n name,\n check,\n length,\n regMsg,\n locale,\n compare,\n required,\n showMsg,\n msgOnError,\n msgOnSuccess,\n customFunc,\n };\n};\ninterface DefaultAsyncMsgObj {\n error?: boolean;\n message?: string;\n showOnError?: boolean;\n showOnSuccess?: boolean;\n}\nconst getDefaultAsyncObj = (obj: DefaultAsyncMsgObj) => {\n let { error, message, showOnError, showOnSuccess } = obj;\n error = typeof error !== 'undefined' ? error : false;\n message = typeof message !== 'undefined' ? message : '';\n showOnError = typeof showOnError !== 'undefined' ? showOnError : true;\n showOnSuccess = typeof showOnSuccess !== 'undefined' ? showOnSuccess : false;\n return {\n error,\n message,\n showOnError,\n showOnSuccess,\n };\n};\ninterface AttributesInputObj {\n maxLength?: number;\n}\ninterface Props {\n attributesWrapper?: object;\n attributesInput?: AttributesInputObj;\n value?: string;\n disabled?: boolean;\n validate?: boolean;\n classNameInput?: string;\n classNameWrapper?: string;\n classNameContainer?: string;\n customStyleInput?: object;\n customStyleWrapper?: object;\n customStyleContainer?: object;\n validationOption?: object;\n asyncMsgObj?: object;\n onChange: (res: string, e: React.ChangeEvent) => void;\n onBlur?: (e: React.FocusEvent) => void;\n onFocus?: (e: React.FocusEvent) => void;\n onClick?: (e: React.MouseEvent) => void;\n onKeyUp?: (e: React.KeyboardEvent) => void;\n validationCallback?: (res: boolean) => void;\n}\nconst autoFormatNumber = (v: number | string, numberType: string, mantissa: number) => {\n const DOT = '.';\n const ZERO = '0';\n let res = '';\n let hasDot = false;\n const splitStr = String(v).split('');\n const startedWithZero = splitStr[0] === '0';\n if (numberType === VALIDATE_NUMBER_TYPE_LIST[2] && splitStr[0] === ZERO && splitStr[1] === ZERO) {\n splitStr.shift();\n }\n splitStr.forEach(i => {\n const charCode = i.toLowerCase().charCodeAt(0);\n if ((charCode >= 48 && charCode <= 57) || (charCode === 46 && !hasDot)) {\n if (charCode === 46) {\n if (numberType === VALIDATE_NUMBER_TYPE_LIST[1]) {\n return;\n }\n hasDot = true;\n }\n res += i;\n }\n });\n if (hasDot && mantissa >= 0) {\n const resArr = res.split(DOT);\n if (mantissa === 0) {\n res = resArr[0];\n } else {\n resArr[1] = resArr[1].slice(0, mantissa);\n res = resArr.join('.');\n }\n }\n if (numberType === VALIDATE_NUMBER_TYPE_LIST[0] || numberType === VALIDATE_NUMBER_TYPE_LIST[2]) {\n if (res.length && res[0] === DOT) {\n res = `0${res}`;\n }\n }\n // if (numberType === VALIDATE_NUMBER_TYPE_LIST[2]) {\n // if (startedWithZero) {\n // if (hasDot) {\n // const resArr = res.split(DOT);\n // res = `${Number(resArr[0])}${DOT}${resArr[1]}`;\n // }\n // }\n // }\n return res;\n};\nconst component: React.FC = ({\n attributesWrapper = {},\n attributesInput = {},\n value = '',\n disabled = false,\n validate = false,\n classNameInput = '',\n classNameWrapper = '',\n classNameContainer = '',\n customStyleInput = {},\n customStyleWrapper = {},\n customStyleContainer = {},\n validationOption = {},\n asyncMsgObj = {},\n onChange = (v: string, e: React.ChangeEvent) => {},\n onBlur = null,\n onFocus = null,\n onClick = null,\n onKeyUp = null,\n validationCallback = null,\n}) => {\n const [err, setErr] = useState(false);\n const [msg, setMsg] = useState('');\n const [successMsg, setSuccessMsg] = useState('');\n const [internalValue, setInternalValue] = useState(String(value));\n const prevInternalValue = usePrevious(internalValue);\n const option = getDefaultValidationOption(validationOption);\n const asyncObj = getDefaultAsyncObj(asyncMsgObj);\n const $input = useRef(null);\n const $el: { [key: string]: any } | null = $input;\n const handleOnBlur = useCallback(\n (e: React.FocusEvent) => {\n if (onBlur) {\n check();\n onBlur(e);\n }\n },\n [internalValue, option],\n );\n const handleOnFocus = useCallback((e: React.FocusEvent) => {\n if (onFocus) {\n onFocus(e);\n }\n }, []);\n const handleOnClick = useCallback((e: React.MouseEvent) => {\n if (onClick) {\n onClick(e);\n }\n }, []);\n const handleOnKeyUp = useCallback(\n (e: React.KeyboardEvent) => {\n if (onKeyUp) {\n const { keyCode } = e;\n const keyCodeTab = 9;\n if (keyCode !== keyCodeTab) {\n check();\n }\n onKeyUp(e);\n }\n },\n [internalValue, option],\n );\n const handleOnChange = useCallback(\n (e: React.ChangeEvent) => {\n if (disabled || $el === null) {\n return;\n }\n let v = $el.current.value;\n if (typeof attributesInput.maxLength !== 'undefined') {\n if ((typeof attributesInput.maxLength === 'string' && attributesInput.maxLength !== '') || (typeof attributesInput.maxLength === 'number' && attributesInput.maxLength !== 0)) {\n if (v.length > Number(attributesInput.maxLength)) {\n return;\n }\n }\n }\n const { type, numberType, mantissa } = option;\n if (type === VALIDATE_OPTION_TYPE_LIST[1]) {\n v = String(autoFormatNumber(v, VALIDATE_NUMBER_TYPE_LIST.indexOf(numberType) >= 0 ? numberType : VALIDATE_NUMBER_TYPE_LIST[0], mantissa));\n }\n if (type === VALIDATE_OPTION_TYPE_LIST[2]) {\n v = utils.getAlphanumeric(v);\n }\n if (type === VALIDATE_OPTION_TYPE_LIST[3]) {\n v = utils.getAlpha(v);\n }\n setInternalValue(v);\n onChange && onChange(v, e);\n if (err) {\n setErr(false);\n } else {\n setSuccessMsg('');\n }\n },\n [err, attributesInput, option],\n );\n const check = useCallback(\n async () => {\n const { reg, min, max, type, name, check, length, regMsg, locale, compare, required, msgOnSuccess, customFunc } = option;\n if (!check) {\n return;\n }\n if (type) {\n if (VALIDATE_OPTION_TYPE_LIST.indexOf(type) !== -1) {\n if (!message[locale] || !message[locale][TYPE]) {\n console.error(REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE);\n return;\n }\n const msg = message[locale][TYPE];\n const nameText = name ? name : '';\n if (required) {\n if (validator.empty(internalValue)) {\n handleCheckEnd(true, msg.empty(nameText));\n return;\n }\n }\n if (String(internalValue) !== '') {\n if (reg) {\n if (validator['reg'](reg, internalValue)) {\n handleCheckEnd(true, regMsg !== '' ? regMsg : msg.invalid(nameText));\n return;\n }\n }\n if (type === VALIDATE_OPTION_TYPE_LIST[0]) {\n if (min || max) {\n if (min && max) {\n if (String(internalValue).length < min || String(internalValue).length > max) {\n handleCheckEnd(true, msg.inBetween(nameText)(min)(max));\n return;\n }\n } else {\n if (min) {\n if (String(internalValue).length < min) {\n handleCheckEnd(true, msg.lessThan(nameText)(min));\n return;\n }\n }\n if (max) {\n if (String(internalValue).length > max) {\n handleCheckEnd(true, msg.greaterThan(nameText)(max));\n return;\n }\n }\n }\n }\n if (length) {\n if (String(internalValue).length !== length) {\n handleCheckEnd(true, msg.lengthEqual(nameText)(length));\n return;\n }\n }\n }\n if (type === VALIDATE_OPTION_TYPE_LIST[1]) {\n if (!validator[type](internalValue, null, null)) {\n handleCheckEnd(true, msg.invalid(nameText));\n return;\n }\n if (min || max) {\n if (min && max) {\n if (!validator[type](internalValue, min, max)) {\n handleCheckEnd(true, msg.inBetween(nameText)(min)(max));\n return;\n }\n } else {\n if (min) {\n if (!validator[type](internalValue, min)) {\n handleCheckEnd(true, msg.lessThan(nameText)(min));\n return;\n }\n }\n if (max) {\n if (!validator[type](internalValue, 0, max)) {\n handleCheckEnd(true, msg.greaterThan(nameText)(max));\n return;\n }\n }\n }\n }\n if (length) {\n if (String(internalValue).length !== length) {\n handleCheckEnd(true, msg.lengthEqual(nameText)(length));\n return;\n }\n }\n }\n if (compare && compare !== '') {\n if (internalValue !== compare) {\n handleCheckEnd(true, msg.twoInputsNotEqual());\n return;\n }\n }\n }\n if (customFunc && typeof customFunc === 'function') {\n const customFuncResult = await customFunc(internalValue);\n /* istanbul ignore next because of async problem */\n if (typeof customFuncResult === 'object') {\n if (typeof customFuncResult.error === 'boolean' && typeof customFuncResult.message === 'string') {\n if (customFuncResult.error === false && customFuncResult.showOnSuccess === true) {\n setSuccessMsg(customFuncResult.message);\n }\n handleCheckEnd(customFuncResult.error, customFuncResult.message, true);\n }\n return;\n }\n /* istanbul ignore next because of async problem */\n if (customFuncResult !== true) {\n handleCheckEnd(true, customFuncResult, true);\n return;\n }\n }\n if (msgOnSuccess) {\n setSuccessMsg(msgOnSuccess);\n }\n handleCheckEnd(false, msgOnSuccess);\n } else {\n console.error(`The valid ${utils.toCamelCase(TYPE)(true)} \"type\" options in validationOption are [${VALIDATE_OPTION_TYPE_LIST.map(i => i)}]`);\n }\n } else {\n console.error('Please provide \"type\" in validationOption');\n }\n },\n [internalValue, option],\n );\n const handleCheckEnd = useCallback((err: boolean, message: string, fromCustomFunc: boolean = false) => {\n let msg = message;\n const { msgOnError } = option;\n if (err && msgOnError && !fromCustomFunc) {\n msg = msgOnError;\n }\n setErr(err);\n setMsg(msg);\n validationCallback && validationCallback(err);\n }, [option.msgOnError]);\n useEffect(\n () => {\n if (validate) {\n check();\n }\n },\n [validate],\n );\n useEffect(\n () => {\n setInternalValue(String(value));\n },\n [value],\n );\n useEffect(\n () => {\n /* istanbul ignore next because of https://github.com/airbnb/enzyme/issues/441 && https://github.com/airbnb/enzyme/blob/master/docs/future.md */\n if (typeof prevInternalValue !== 'undefined' && prevInternalValue !== internalValue) {\n if (option.customFunc && onKeyUp) {\n check();\n }\n }\n },\n [internalValue],\n );\n useEffect(\n () => {\n if (asyncObj) {\n if (asyncObj.message) {\n if (asyncObj.showOnError) {\n handleCheckEnd(asyncObj.error, asyncObj.message);\n }\n if (!asyncObj.error && asyncObj.showOnSuccess) {\n setSuccessMsg(asyncObj.message);\n }\n }\n }\n },\n [asyncMsgObj],\n );\n const wrapperClass = `${classNameWrapper} ${reactInputsValidationCss[`${TYPE}__wrapper`]} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const containerClass = `${classNameContainer} ${reactInputsValidationCss[`${TYPE}__container`]} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const inputClass = `${classNameInput} ${reactInputsValidationCss[`${TYPE}__input`]} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const errMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${err && reactInputsValidationCss['error']}`;\n const successMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${!err && reactInputsValidationCss['success']}`;\n let msgHtml;\n const { showMsg } = option;\n if (showMsg && err && msg) {\n msgHtml =
{msg}
;\n }\n if (showMsg && !err && successMsg !== '') {\n msgHtml =
{successMsg}
;\n }\n return (\n
\n
\n \n
\n {msgHtml}\n
\n );\n};\nexport default memo(component);\n","import * as React from 'react';\nconst { useState, useEffect, useCallback, useRef, memo } = React;\nimport message from './message';\nimport validator from './validator';\nimport utils from './utils';\nimport { REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE, DEFAULT_LOCALE, MSG_CLASS_IDENTITIFIER, usePrevious } from './const';\nimport reactInputsValidationCss from './react-inputs-validation.css';\nconst TYPE = 'textarea';\nconst VALIDATE_OPTION_TYPE_LIST = ['string'];\ninterface DefaultValidationOption {\n locale?: string;\n reg?: string;\n min?: number;\n max?: number;\n type?: string;\n name?: string;\n check?: boolean;\n showMsg?: boolean;\n length?: number;\n regMsg?: string;\n required?: boolean;\n msgOnError?: string;\n msgOnSuccess?: string;\n customFunc?: Function | undefined;\n}\nconst getDefaultValidationOption = (obj: DefaultValidationOption) => {\n let { reg, min, max, type, name, check, length, regMsg, required, showMsg, locale, msgOnError, msgOnSuccess, customFunc } = obj;\n locale = typeof locale !== 'undefined' ? locale : DEFAULT_LOCALE;\n reg = typeof reg !== 'undefined' ? reg : '';\n min = typeof min !== 'undefined' ? min : 0;\n max = typeof max !== 'undefined' ? max : 0;\n type = typeof type !== 'undefined' ? type : 'string';\n name = typeof name !== 'undefined' ? name : '';\n check = typeof check !== 'undefined' ? check : true;\n showMsg = typeof showMsg !== 'undefined' ? showMsg : true;\n length = typeof length !== 'undefined' ? length : 0;\n regMsg = typeof regMsg !== 'undefined' ? regMsg : '';\n required = typeof required !== 'undefined' ? required : true;\n msgOnError = typeof msgOnError !== 'undefined' ? msgOnError : '';\n msgOnSuccess = typeof msgOnSuccess !== 'undefined' ? msgOnSuccess : '';\n customFunc = typeof customFunc !== 'undefined' ? customFunc : undefined;\n return {\n reg,\n min,\n max,\n type,\n name,\n check,\n length,\n regMsg,\n locale,\n required,\n showMsg,\n msgOnError,\n msgOnSuccess,\n customFunc,\n };\n};\ninterface DefaultAsyncMsgObj {\n error?: boolean;\n message?: string;\n showOnError?: boolean;\n showOnSuccess?: boolean;\n}\nconst getDefaultAsyncObj = (obj: DefaultAsyncMsgObj) => {\n let { error, message, showOnError, showOnSuccess } = obj;\n error = typeof error !== 'undefined' ? error : false;\n message = typeof message !== 'undefined' ? message : '';\n showOnError = typeof showOnError !== 'undefined' ? showOnError : true;\n showOnSuccess = typeof showOnSuccess !== 'undefined' ? showOnSuccess : false;\n return {\n error,\n message,\n showOnError,\n showOnSuccess,\n };\n};\ninterface AttributesInputObj {\n maxLength?: number;\n}\ninterface Props {\n attributesWrapper?: object;\n attributesInput?: AttributesInputObj;\n value?: string;\n disabled?: boolean;\n validate?: boolean;\n classNameInput?: string;\n classNameWrapper?: string;\n classNameContainer?: string;\n customStyleInput?: object;\n customStyleWrapper?: object;\n customStyleContainer?: object;\n validationOption?: object;\n asyncMsgObj?: object;\n onChange: (res: string, e: React.ChangeEvent) => void;\n onBlur?: (e: React.FocusEvent) => void;\n onFocus?: (e: React.FocusEvent) => void;\n onClick?: (e: React.MouseEvent) => void;\n onKeyUp?: (e: React.KeyboardEvent) => void;\n validationCallback?: (res: boolean) => void;\n}\n\nconst component: React.FC = ({\n attributesWrapper = {},\n attributesInput = {},\n value = '',\n disabled = false,\n validate = false,\n classNameInput = '',\n classNameWrapper = '',\n classNameContainer = '',\n customStyleInput = {},\n customStyleWrapper = {},\n customStyleContainer = {},\n validationOption = {},\n asyncMsgObj = {},\n onChange = () => {},\n onBlur = null,\n onFocus = null,\n onClick = null,\n onKeyUp = null,\n validationCallback = null,\n}) => {\n const [err, setErr] = useState(false);\n const [msg, setMsg] = useState('');\n const [successMsg, setSuccessMsg] = useState('');\n const [internalValue, setInternalValue] = useState(String(value));\n const prevInternalValue = usePrevious(internalValue);\n const option = getDefaultValidationOption(validationOption);\n const asyncObj = getDefaultAsyncObj(asyncMsgObj);\n const $input = useRef(null);\n const $el: { [key: string]: any } | null = $input;\n const handleOnBlur = useCallback(\n (e: React.FocusEvent) => {\n if (onBlur) {\n check();\n onBlur(e);\n }\n },\n [internalValue, option],\n );\n const handleOnFocus = useCallback((e: React.FocusEvent) => {\n if (onFocus) {\n onFocus(e);\n }\n }, []);\n const handleOnClick = useCallback((e: React.MouseEvent) => {\n if (onClick) {\n onClick(e);\n }\n }, []);\n const handleOnKeyUp = useCallback(\n (e: React.KeyboardEvent) => {\n if (onKeyUp) {\n const { keyCode } = e;\n const keyCodeTab = 9;\n if (keyCode !== keyCodeTab) {\n check();\n }\n onKeyUp(e);\n }\n },\n [internalValue, option],\n );\n const handleOnChange = useCallback(\n (e: React.ChangeEvent) => {\n if (disabled || $el === null) {\n return;\n }\n const v = $el.current.value;\n if (typeof attributesInput.maxLength !== 'undefined') {\n if ((typeof attributesInput.maxLength === 'string' && attributesInput.maxLength !== '') || (typeof attributesInput.maxLength === 'number' && attributesInput.maxLength !== 0)) {\n if (v.length > Number(attributesInput.maxLength)) {\n return;\n }\n }\n }\n setInternalValue(v);\n onChange && onChange(v, e);\n if (err) {\n setErr(false);\n } else {\n setSuccessMsg('');\n }\n },\n [err],\n );\n const check = useCallback(\n async () => {\n const { reg, min, max, type, name, check, length, regMsg, locale, required, msgOnSuccess, customFunc } = option;\n if (!check) {\n return;\n }\n if (type) {\n if (VALIDATE_OPTION_TYPE_LIST.indexOf(type) !== -1) {\n if (!message[locale] || !message[locale][TYPE]) {\n console.error(REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE);\n return;\n }\n const msg = message[locale][TYPE];\n const nameText = name ? name : '';\n if (required) {\n if (validator.empty(internalValue)) {\n handleCheckEnd(true, msg.empty(nameText));\n return;\n }\n }\n if (String(internalValue) !== '') {\n if (reg) {\n if (validator['reg'](reg, internalValue)) {\n handleCheckEnd(true, regMsg !== '' ? regMsg : msg.invalid(nameText));\n return;\n }\n }\n if (min || max) {\n if (min && max) {\n if (String(internalValue).length < min || String(internalValue).length > max) {\n handleCheckEnd(true, msg.inBetween(nameText)(min)(max));\n return;\n }\n } else {\n if (min) {\n if (String(internalValue).length < min) {\n handleCheckEnd(true, msg.lessThan(nameText)(min));\n return;\n }\n }\n if (max) {\n if (String(internalValue).length > max) {\n handleCheckEnd(true, msg.greaterThan(nameText)(max));\n return;\n }\n }\n }\n }\n if (length) {\n if (String(internalValue).length !== length) {\n handleCheckEnd(true, msg.lengthEqual(nameText)(length));\n return;\n }\n }\n }\n if (customFunc && typeof customFunc === 'function') {\n const customFuncResult = await customFunc(internalValue);\n /* istanbul ignore next because of async problem */\n if (typeof customFuncResult === 'object') {\n if (typeof customFuncResult.error === 'boolean' && typeof customFuncResult.message === 'string') {\n if (customFuncResult.error === false && customFuncResult.showOnSuccess === true) {\n setSuccessMsg(customFuncResult.message);\n }\n handleCheckEnd(customFuncResult.error, customFuncResult.message, true);\n }\n return;\n }\n /* istanbul ignore next because of async problem */\n if (customFuncResult !== true) {\n handleCheckEnd(true, customFuncResult, true);\n return;\n }\n }\n if (msgOnSuccess) {\n setSuccessMsg(msgOnSuccess);\n }\n handleCheckEnd(false, msgOnSuccess);\n } else {\n console.error(`The valid ${utils.toCamelCase(TYPE)(true)} \"type\" options in validationOption are [${VALIDATE_OPTION_TYPE_LIST.map(i => i)}]`);\n }\n } else {\n console.error('Please provide \"type\" in validationOption');\n }\n },\n [internalValue, option],\n );\n const handleCheckEnd = useCallback((err: boolean, message: string, fromCustomFunc: boolean = false) => {\n let msg = message;\n const { msgOnError } = option;\n if (err && msgOnError && !fromCustomFunc) {\n msg = msgOnError;\n }\n setErr(err);\n setMsg(msg);\n validationCallback && validationCallback(err);\n }, [option.msgOnError]);\n useEffect(\n () => {\n if (validate) {\n check();\n }\n },\n [validate],\n );\n useEffect(\n () => {\n setInternalValue(String(value));\n },\n [value],\n );\n useEffect(\n () => {\n /* istanbul ignore next because of https://github.com/airbnb/enzyme/issues/441 && https://github.com/airbnb/enzyme/blob/master/docs/future.md */\n if (typeof prevInternalValue !== 'undefined' && prevInternalValue !== internalValue) {\n if (option.customFunc && onKeyUp) {\n check();\n }\n }\n },\n [internalValue],\n );\n useEffect(\n () => {\n if (asyncObj) {\n if (asyncObj.message) {\n if (asyncObj.showOnError) {\n handleCheckEnd(asyncObj.error, asyncObj.message);\n }\n if (!asyncObj.error && asyncObj.showOnSuccess) {\n setSuccessMsg(asyncObj.message);\n }\n }\n }\n },\n [asyncMsgObj],\n );\n const wrapperClass = `${classNameWrapper} ${reactInputsValidationCss[`${TYPE}__wrapper`]} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const containerClass = `${classNameContainer} ${reactInputsValidationCss[`${TYPE}__container`]} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const inputClass = `${classNameInput} ${reactInputsValidationCss[`${TYPE}__input`]} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const errMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${err && reactInputsValidationCss['error']}`;\n const successMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${!err && reactInputsValidationCss['success']}`;\n let msgHtml;\n const { showMsg } = option;\n if (showMsg && err && msg) {\n msgHtml =
{msg}
;\n }\n if (showMsg && !err && successMsg !== '') {\n msgHtml =
{successMsg}
;\n }\n return (\n
\n
\n \n
\n {msgHtml}\n
\n );\n};\nexport default memo(component);\n","import * as React from 'react';\nconst { useState, useEffect, useCallback, useRef, useMemo, memo } = React;\nimport message from './message';\nimport { REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE, DEFAULT_LOCALE, WRAPPER_CLASS_IDENTITIFIER, CONTAINER_CLASS_IDENTITIFIER, MSG_CLASS_IDENTITIFIER, usePrevious } from './const';\nimport utils from './utils';\nimport reactInputsValidationCss from './react-inputs-validation.css';\nconst TYPE = 'select';\nconst keyCodeEsc = 27;\nconst keyCodeDown = 40;\nconst keyCodeUp = 38;\nconst keyCodeEnter = 13;\nconst selectKeyList = [keyCodeEsc, keyCodeDown, keyCodeUp, keyCodeEnter];\n/* istanbul ignore next */\nif (!String.prototype.startsWith) {\n String.prototype.startsWith = function(searchString, position) {\n const p = position || 0;\n return this.indexOf(searchString, p) === p;\n };\n}\ninterface DefaultValidationOption {\n name?: string;\n check?: boolean;\n showMsg?: boolean;\n required?: boolean;\n locale?: string;\n msgOnError?: string;\n msgOnSuccess?: string;\n}\nconst getDefaultValidationOption = (obj: DefaultValidationOption) => {\n let { name, check, required, showMsg, locale, msgOnError, msgOnSuccess } = obj;\n locale = typeof locale !== 'undefined' ? locale : DEFAULT_LOCALE;\n name = typeof name !== 'undefined' ? name : '';\n check = typeof check !== 'undefined' ? check : true;\n showMsg = typeof showMsg !== 'undefined' ? showMsg : true;\n required = typeof required !== 'undefined' ? required : true;\n msgOnSuccess = typeof msgOnSuccess !== 'undefined' ? msgOnSuccess : '';\n msgOnError = typeof msgOnError !== 'undefined' ? msgOnError : '';\n return {\n name,\n check,\n showMsg,\n required,\n locale,\n msgOnError,\n msgOnSuccess,\n };\n};\ninterface DefaultAsyncMsgObj {\n error?: boolean;\n message?: string;\n showOnError?: boolean;\n showOnSuccess?: boolean;\n}\nconst getDefaultAsyncObj = (obj: DefaultAsyncMsgObj) => {\n let { error, message, showOnError, showOnSuccess } = obj;\n error = typeof error !== 'undefined' ? error : false;\n message = typeof message !== 'undefined' ? message : '';\n showOnError = typeof showOnError !== 'undefined' ? showOnError : true;\n showOnSuccess = typeof showOnSuccess !== 'undefined' ? showOnSuccess : false;\n return {\n error,\n message,\n showOnError,\n showOnSuccess,\n };\n};\nexport const isValidValue = (list: OptionListItem[], value: any) => {\n let res = false;\n if (list.length) {\n for (let i = 0; i < list.length; i += 1) {\n if (list[i].id === value) {\n res = true;\n break;\n }\n }\n }\n return res;\n};\nexport const getItem = (list: OptionListItem[], value: any) => {\n let res = null;\n if (list.length) {\n for (let i = 0; i < list.length; i += 1) {\n if (list[i].id === value) {\n res = list[i];\n break;\n }\n }\n }\n return res;\n};\nexport const getIndex = (list: OptionListItem[], value: string) => {\n let key = -1;\n for (let i = 0; i < list.length; i += 1) {\n if (list[i].id === value) {\n key = i;\n break;\n }\n }\n return key;\n};\ninterface OptionListItem {\n id: string;\n name: string;\n}\ninterface Props {\n attributesWrapper?: object;\n attributesInput?: object;\n value?: string | number;\n disabled?: boolean;\n validate?: boolean;\n showSearch?: boolean;\n keyword?: string;\n optionList: OptionListItem[];\n onChange: (res: object, e: React.MouseEvent) => void;\n onBlur?: (e: React.FocusEvent | Event) => void;\n onFocus?: (e: React.FocusEvent) => void;\n onClick?: (e: React.MouseEvent) => void;\n validationOption?: object;\n asyncMsgObj?: object;\n classNameWrapper?: string;\n classNameContainer?: string;\n classNameSelect?: string;\n classNameOptionListContainer?: string;\n classNameDropdownIconOptionListItem?: string;\n classNameOptionListItem?: string;\n customStyleWrapper?: object;\n customStyleContainer?: object;\n customStyleSelect?: object;\n customStyleOptionListContainer?: object;\n customStyleDropdownIcon?: object;\n customStyleOptionListItem?: object;\n validationCallback?: (res: boolean) => void;\n}\ninterface Node {\n [key: string]: any;\n}\nlet globalVariableIsFocusing: boolean = false;\nlet globalVariableIsCorrected: boolean = false;\nlet globalVariableCurrentFocus: any | null = null;\nlet globalVariableTypingTimeout: any | null = null;\nconst component: React.FC = ({\n attributesWrapper = {},\n attributesInput = {},\n value = '',\n disabled = false,\n validate = false,\n showSearch = false,\n keyword = '',\n optionList = [],\n classNameWrapper = '',\n classNameContainer = '',\n classNameSelect = '',\n classNameOptionListItem = '',\n classNameOptionListContainer = '',\n classNameDropdownIconOptionListItem = '',\n customStyleWrapper = {},\n customStyleContainer = {},\n customStyleSelect = {},\n customStyleOptionListItem = {},\n customStyleOptionListContainer = {},\n customStyleDropdownIcon = {},\n validationOption = {},\n asyncMsgObj = {},\n onChange = () => {},\n onBlur = null,\n onFocus = null,\n onClick = null,\n validationCallback = null,\n}) => {\n const [err, setErr] = useState(false);\n const [msg, setMsg] = useState('');\n const [successMsg, setSuccessMsg] = useState('');\n const [internalValue, setInternalValue] = useState(String(value));\n const stateKeyword = useState(keyword);\n const prevKeyword = usePrevious(stateKeyword[0]);\n const prevInternalValue = usePrevious(internalValue);\n const prevOptionList = usePrevious(optionList);\n const [show, setShow] = useState(false);\n const prevShow = usePrevious(show);\n const [isTyping, setIsTyping] = useState(false);\n const initKeycodeList: number[] = [];\n const [keycodeList, setKeycodeList] = useState(initKeycodeList);\n const option = getDefaultValidationOption(validationOption);\n const asyncObj = getDefaultAsyncObj(asyncMsgObj);\n const $button = useRef(null);\n const $wrapper = useRef(null);\n const $itemsWrapper = useRef(null);\n const $searchInputWrapper = useRef(null);\n const $searchInput = useRef(null);\n const $elButton: { [key: string]: any } | null = $button;\n const $elWrapper: { [key: string]: any } | null = $wrapper;\n const $elItemsWrapper: { [key: string]: any } | null = $itemsWrapper;\n const $itemsRef: { [key: string]: any } = [];\n const filteredOptionList = useMemo(() => {\n let res = optionList;\n if (res.length) {\n if (stateKeyword[0]) {\n res = optionList.filter(i => i.name.toLowerCase().includes(stateKeyword[0].toLowerCase()));\n }\n }\n return res;\n }, [stateKeyword[0], optionList]);\n const handleOnSearch = useCallback((e: any) => {\n stateKeyword[1](e.target.value);\n }, []);\n const handleOnSearchKeyDown = useCallback(\n (e: any) => {\n const { keyCode } = e;\n const direction = getDirection(keyCode);\n if (selectKeyList.indexOf(keyCode) !== -1) {\n e.preventDefault();\n handleOnKeyDown(keyCode);\n } else if (keyCode === 32) {\n // space\n stateKeyword[1](`${stateKeyword[0]} `);\n e.preventDefault();\n }\n scroll(direction);\n },\n [filteredOptionList],\n );\n useEffect(() => {\n if (show && showSearch) {\n globalVariableCurrentFocus = 0;\n scroll('up');\n addActive();\n }\n }, [stateKeyword[0]]);\n const handleOnBlur = useCallback(\n (e: React.FocusEvent | Event) => {\n if (onBlur) {\n check();\n onBlur(e);\n }\n },\n [internalValue, option],\n );\n const handleOnFocus = useCallback((e: React.FocusEvent) => {\n if (onFocus) {\n onFocus(e);\n }\n }, []);\n const handleOnClick = useCallback((e: React.MouseEvent) => {\n if (onClick) {\n onClick(e);\n }\n }, []);\n const handleOnChange = useCallback((item: object, e: React.MouseEvent) => {\n if (disabled) {\n return;\n }\n onChange && onChange(item, e);\n }, []);\n const check = useCallback(() => {\n const { name, check, locale, required, msgOnSuccess } = option;\n if (!check) {\n return;\n }\n if (!message[locale] || !message[locale][TYPE]) {\n console.error(REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE);\n return;\n }\n if (required) {\n const msg = message[locale][TYPE];\n const nameText = name ? name : '';\n if (!isValidValue(optionList, internalValue) || internalValue === '' || internalValue === 'null' || internalValue === 'undefined') {\n handleCheckEnd(true, msg.empty(nameText));\n return;\n }\n }\n if (msgOnSuccess) {\n setSuccessMsg(msgOnSuccess);\n }\n handleCheckEnd(false, msgOnSuccess);\n }, [internalValue, option]);\n const handleCheckEnd = useCallback((err: boolean, message: string) => {\n let msg = message;\n const { msgOnError } = option;\n if (err && msgOnError) {\n msg = msgOnError;\n }\n setErr(err);\n setMsg(msg);\n validationCallback && validationCallback(err);\n }, [option.msgOnError]);\n /* istanbul ignore next because of https://github.com/airbnb/enzyme/issues/441 && https://github.com/airbnb/enzyme/blob/master/docs/future.md */\n useEffect(() => {\n if (typeof window !== 'undefined') {\n window.addEventListener('mousedown', pageClick);\n window.addEventListener('touchstart', pageClick);\n return () => {\n window.removeEventListener('mousedown', pageClick);\n window.removeEventListener('touchstart', pageClick);\n $elWrapper.current.removeEventListener('keydown', onKeyDown);\n };\n }\n }, []);\n /* istanbul ignore next because of https://github.com/airbnb/enzyme/issues/441 && https://github.com/airbnb/enzyme/blob/master/docs/future.md */\n const pageClick = useCallback((e: Event) => {\n if ($elWrapper.current.contains(e.target)) {\n return;\n }\n if (globalVariableIsFocusing) {\n handleOnBlur(e);\n globalVariableIsFocusing = false;\n }\n setShow(false);\n }, []);\n /* istanbul ignore next because of https://github.com/airbnb/enzyme/issues/441 && https://github.com/airbnb/enzyme/blob/master/docs/future.md */\n const resetCurrentFocus = useCallback(() => {\n globalVariableCurrentFocus = getIndex(filteredOptionList, internalValue);\n scroll();\n }, [internalValue]);\n /* istanbul ignore next because of https://github.com/airbnb/enzyme/issues/441 && https://github.com/airbnb/enzyme/blob/master/docs/future.md */\n const setTimeoutTyping = useCallback(() => {\n if (globalVariableTypingTimeout) {\n clearTimeout(globalVariableTypingTimeout);\n }\n globalVariableTypingTimeout = setTimeout(() => {\n setKeycodeList([]);\n }, 250);\n }, []);\n /* istanbul ignore next because of https://github.com/airbnb/enzyme/issues/441 && https://github.com/airbnb/enzyme/blob/master/docs/future.md */\n const scroll = useCallback((direction: undefined | string = undefined) => {\n if ($itemsWrapper && $itemsWrapper.current && $itemsWrapper.current.children) {\n const $children = $itemsWrapper.current.children;\n const containerHeight = $elItemsWrapper.current.offsetHeight;\n const containerScrollTop = $elItemsWrapper.current.scrollTop;\n if (!$children[globalVariableCurrentFocus]) {\n return;\n }\n const itemHeight = $children[globalVariableCurrentFocus].offsetHeight;\n if (direction) {\n if (direction === 'loop') {\n $elItemsWrapper.current.scrollTop = $children.length * itemHeight;\n return;\n }\n if (direction === 'down') {\n const bound = containerScrollTop + containerHeight;\n const heightItems = globalVariableCurrentFocus * itemHeight;\n const heightContainer = bound - itemHeight;\n if (heightItems >= heightContainer) {\n const offset = Math.abs(heightItems - heightContainer - itemHeight);\n if (offset >= 0 && !globalVariableIsCorrected) {\n $elItemsWrapper.current.scrollTop = containerScrollTop + itemHeight - offset;\n globalVariableIsCorrected = true;\n } else {\n $elItemsWrapper.current.scrollTop = containerScrollTop + itemHeight;\n }\n }\n }\n if (direction === 'up') {\n globalVariableIsCorrected = false;\n if (globalVariableCurrentFocus * itemHeight <= containerScrollTop) {\n $elItemsWrapper.current.scrollTop = globalVariableCurrentFocus * itemHeight;\n }\n }\n } else {\n globalVariableIsCorrected = false;\n $elItemsWrapper.current.scrollTop = globalVariableCurrentFocus * itemHeight;\n }\n }\n }, []);\n const handleOnItemClick = useCallback((item: object, e: React.MouseEvent) => {\n handleOnChange(item, e);\n stateKeyword[1]('');\n }, []);\n const handleOnItemMouseOver = useCallback((index: number) => {\n globalVariableCurrentFocus = index;\n addActive();\n }, []);\n const handleOnItemMouseMove = useCallback(() => {\n setIsTyping(false);\n }, []);\n const handleOnItemMouseOut = useCallback(() => {\n removeActive();\n }, []);\n const addActive = useCallback(() => {\n if ($itemsWrapper && $itemsWrapper.current && $itemsWrapper.current.children) {\n const $children = $itemsWrapper.current.children;\n removeActive();\n if (globalVariableCurrentFocus === null) return;\n if (globalVariableCurrentFocus >= $children.length) globalVariableCurrentFocus = 0;\n if (globalVariableCurrentFocus < 0) globalVariableCurrentFocus = $children.length - 1;\n if ($children[globalVariableCurrentFocus]) $children[globalVariableCurrentFocus].className += ` ${reactInputsValidationCss[`${TYPE}__hover-active`]}`;\n }\n }, []);\n const removeActive = useCallback(() => {\n if ($itemsWrapper && $itemsWrapper.current && $itemsWrapper.current.children) {\n const $children = $itemsWrapper.current.children;\n for (let i = 0; i < $children.length; i += 1) {\n $children[i].className = $children[i].className.replace(reactInputsValidationCss[`${TYPE}__hover-active`], '');\n }\n }\n }, []);\n const getDirection = useCallback(keyCode => {\n switch (keyCode) {\n case keyCodeUp:\n return 'up';\n case keyCodeDown:\n return 'down';\n default:\n return undefined;\n }\n }, []);\n const handleOnKeyDown = useCallback(\n keyCode => {\n if (keyCode === keyCodeEsc) {\n setShow(false);\n resetCurrentFocus();\n return;\n }\n if (keyCode === keyCodeDown) {\n globalVariableCurrentFocus += 1;\n if (globalVariableCurrentFocus > filteredOptionList.length - 1) {\n globalVariableCurrentFocus = 0;\n scroll('up');\n }\n addActive();\n } else if (keyCode === keyCodeUp) {\n globalVariableCurrentFocus -= 1;\n if (globalVariableCurrentFocus < 0) {\n globalVariableCurrentFocus = filteredOptionList.length - 1;\n scroll('loop');\n }\n addActive();\n } else if (keyCode === keyCodeEnter) {\n if (globalVariableCurrentFocus > -1) {\n if ($itemsWrapper && $itemsWrapper.current && $itemsWrapper.current.children) {\n const $children = $itemsWrapper.current.children;\n if ($children[globalVariableCurrentFocus]) {\n $children[globalVariableCurrentFocus].click();\n } else {\n return;\n }\n }\n }\n }\n },\n [filteredOptionList],\n );\n /* istanbul ignore next because of https://github.com/airbnb/enzyme/issues/441 && https://github.com/airbnb/enzyme/blob/master/docs/future.md */\n const onKeyDown = useCallback(\n (e: any) => {\n if (showSearch) {\n return;\n }\n setIsTyping(true);\n if (e.preventDefault) {\n e.preventDefault();\n }\n if (!show) {\n return;\n }\n globalVariableCurrentFocus = globalVariableCurrentFocus === null ? getIndex(filteredOptionList, String(value)) : globalVariableCurrentFocus;\n const { keyCode } = e;\n const direction = getDirection(keyCode);\n if (selectKeyList.indexOf(keyCode) !== -1) {\n handleOnKeyDown(keyCode);\n } else {\n setTimeoutTyping();\n const newkeyCodeList = [...keycodeList, keyCode];\n const str = String.fromCharCode(...newkeyCodeList).toLowerCase();\n let index = -1;\n filteredOptionList.forEach((i, k) => {\n const { name } = i;\n if (name.toLowerCase().startsWith(str)) {\n if (index === -1) {\n index = k;\n }\n }\n });\n if (index !== -1) {\n globalVariableCurrentFocus = index;\n addActive();\n }\n setKeycodeList(newkeyCodeList);\n }\n scroll(direction);\n return globalVariableCurrentFocus;\n },\n [show, value, keycodeList],\n );\n useEffect(() => {\n if (show && $elWrapper) {\n document.addEventListener('keydown', onKeyDown);\n }\n return () => {\n document.removeEventListener('keydown', onKeyDown);\n };\n }, [show, value, keycodeList]);\n useEffect(() => {\n if (validate) {\n check();\n }\n }, [validate]);\n useEffect(() => {\n if (!(!isValidValue(filteredOptionList, internalValue) || internalValue === '' || internalValue === 'null' || internalValue === 'undefined')) {\n setErr(false);\n } else {\n setSuccessMsg('');\n }\n }, [internalValue]);\n useEffect(() => {\n setInternalValue(String(value));\n }, [value]);\n useEffect(() => {\n if (prevOptionList && prevOptionList && !utils.arraysEqual(prevOptionList, optionList)) {\n setInternalValue(String(optionList[0].id));\n }\n }, [optionList]);\n useEffect(() => {\n if (typeof prevInternalValue !== 'undefined' && prevInternalValue !== internalValue) {\n check();\n }\n }, [prevInternalValue, internalValue]);\n useEffect(() => {\n if (asyncObj) {\n if (asyncObj.message) {\n if (asyncObj.showOnError) {\n handleCheckEnd(asyncObj.error, asyncObj.message);\n }\n if (!asyncObj.error && asyncObj.showOnSuccess) {\n setSuccessMsg(asyncObj.message);\n }\n }\n }\n }, [asyncMsgObj]);\n useEffect(() => {\n if (show) {\n if (showSearch) {\n $searchInput.current.focus();\n }\n globalVariableCurrentFocus = globalVariableCurrentFocus === null ? getIndex(filteredOptionList, String(value)) : globalVariableCurrentFocus;\n $itemsRef[globalVariableCurrentFocus] && $itemsRef[globalVariableCurrentFocus].current.focus();\n }\n if (prevShow === true && show === false) {\n $elButton.current.focus();\n }\n resetCurrentFocus();\n }, [show]);\n const wrapperClass = `${WRAPPER_CLASS_IDENTITIFIER} ${classNameWrapper} ${reactInputsValidationCss[`${TYPE}__wrapper`]} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const containerClass = `${CONTAINER_CLASS_IDENTITIFIER} ${classNameContainer} ${reactInputsValidationCss[`${TYPE}__container`]} ${err && reactInputsValidationCss['error']} ${show &&\n reactInputsValidationCss['show']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const inputClass = `${reactInputsValidationCss[`${TYPE}__input`]} ${err && reactInputsValidationCss['error']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${disabled &&\n reactInputsValidationCss['disabled']}`;\n const selectClass = `${classNameSelect} ${reactInputsValidationCss['ellipsis']} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const selectOptionListContainerClass = `${classNameOptionListContainer} ${reactInputsValidationCss[`${TYPE}__options-container`]} ${err && reactInputsValidationCss['error']} ${show &&\n reactInputsValidationCss['show']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const selectOptionListItemClass = `${reactInputsValidationCss[`button`]} ${!isTyping && reactInputsValidationCss[`${TYPE}__options-item-show-cursor`]} ${classNameOptionListItem} ${\n reactInputsValidationCss[`${TYPE}__options-item`]\n } ${err && reactInputsValidationCss['error']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const dropdownIconClass = `${classNameDropdownIconOptionListItem} ${reactInputsValidationCss[`${TYPE}__dropdown-icon`]}`;\n const errMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${err && reactInputsValidationCss['error']}`;\n const successMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${!err && reactInputsValidationCss['success']}`;\n let msgHtml;\n const { showMsg } = option;\n if (showMsg && err && msg) {\n msgHtml =
{msg}
;\n }\n if (showMsg && !err && successMsg !== '') {\n msgHtml =
{successMsg}
;\n }\n let optionListHtml;\n const item = getItem(optionList, String(value));\n if (filteredOptionList.length) {\n optionListHtml = filteredOptionList.map((i, k) => (\n \n ));\n } else {\n if (showSearch) {\n optionListHtml = (\n
\n \n \n \n \n
\n );\n }\n }\n const selectorHtml = (\n
\n
{item ? item.name : ''}
\n
\n
\n );\n return (\n {\n handleOnClick(e);\n if (!disabled) {\n if ($searchInputWrapper.current) {\n if ($searchInputWrapper.current.contains(e.target)) {\n setShow(true);\n return;\n }\n }\n setShow(!show);\n }\n }}\n onFocus={handleOnFocus}\n onBlur={handleOnBlur}\n {...attributesWrapper}\n >\n
\n
\n {}} {...attributesInput} />\n
\n {selectorHtml}\n
\n
\n {showSearch && (\n
\n
\n \n \n \n \n \n {stateKeyword[0] && (\n {\n stateKeyword[1]('');\n $searchInput.current.focus();\n }}\n >\n \n \n \n )}\n
\n
\n )}\n
\n {optionListHtml}\n
\n
\n
\n {msgHtml}\n
\n \n );\n};\ninterface OptionProps {\n index?: number;\n id?: string;\n className?: string;\n item?: OptionListItem;\n customStyleOptionListItem?: object;\n onClick?: (res: object, e: React.MouseEvent) => void;\n onMouseOver?: (res: number) => void;\n onMouseMove?: () => void;\n onMouseOut?: () => void;\n}\nexport const Option: React.FC = memo(\n ({ index = -1, id = '', className = '', item = { id: '', name: '' }, customStyleOptionListItem = {}, onClick = () => {}, onMouseOver = () => {}, onMouseMove = () => {}, onMouseOut = () => {} }) => {\n const handleOnClick = useCallback(\n (e: React.MouseEvent) => {\n onClick(item, e);\n },\n [item],\n );\n const handleOnMouseOver = useCallback(() => {\n onMouseOver(index);\n }, []);\n const handleOnMouseMove = useCallback(() => {\n onMouseMove();\n }, []);\n const handleOnMouseOut = useCallback(() => {\n onMouseOut();\n }, []);\n return (\n \n {item.name}\n \n );\n },\n);\nexport default memo(component);\n","import * as React from 'react';\nconst { useState, useEffect, useCallback, useRef, memo } = React;\nimport message from './message';\nimport { REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE, DEFAULT_LOCALE, WRAPPER_CLASS_IDENTITIFIER, MSG_CLASS_IDENTITIFIER, usePrevious } from './const';\nimport utils from './utils';\nimport reactInputsValidationCss from './react-inputs-validation.css';\nconst TYPE = 'checkbox';\ninterface DefaultValidationOption {\n name?: string;\n check?: boolean;\n showMsg?: boolean;\n required?: boolean;\n locale?: string;\n msgOnError?: string;\n msgOnSuccess?: string;\n}\nconst getDefaultValidationOption = (obj: DefaultValidationOption) => {\n let { name, check, required, showMsg, locale, msgOnError, msgOnSuccess } = obj;\n locale = typeof locale !== 'undefined' ? locale : DEFAULT_LOCALE;\n name = typeof name !== 'undefined' ? name : '';\n check = typeof check !== 'undefined' ? check : true;\n showMsg = typeof showMsg !== 'undefined' ? showMsg : true;\n required = typeof required !== 'undefined' ? required : true;\n msgOnSuccess = typeof msgOnSuccess !== 'undefined' ? msgOnSuccess : '';\n msgOnError = typeof msgOnError !== 'undefined' ? msgOnError : '';\n return {\n name,\n check,\n showMsg,\n required,\n locale,\n msgOnError,\n msgOnSuccess,\n };\n};\ninterface DefaultAsyncMsgObj {\n error?: boolean;\n message?: string;\n showOnError?: boolean;\n showOnSuccess?: boolean;\n}\nconst getDefaultAsyncObj = (obj: DefaultAsyncMsgObj) => {\n let { error, message, showOnError, showOnSuccess } = obj;\n error = typeof error !== 'undefined' ? error : false;\n message = typeof message !== 'undefined' ? message : '';\n showOnError = typeof showOnError !== 'undefined' ? showOnError : true;\n showOnSuccess = typeof showOnSuccess !== 'undefined' ? showOnSuccess : false;\n return {\n error,\n message,\n showOnError,\n showOnSuccess,\n };\n};\ninterface Props {\n attributesWrapper?: object;\n attributesInput?: object;\n value?: string | boolean;\n checked?: boolean;\n disabled?: boolean;\n labelHtml?: React.ReactNode;\n validate?: boolean;\n onChange: (res: boolean, e: React.ChangeEvent | React.MouseEvent) => void;\n onBlur?: (e: React.FocusEvent) => void;\n onFocus?: (e: React.FocusEvent) => void;\n onClick?: (e: React.MouseEvent) => void;\n validationOption?: object;\n asyncMsgObj?: object;\n classNameInput?: string;\n classNameWrapper?: string;\n classNameInputBox?: string;\n classNameContainer?: string;\n customStyleInput?: object;\n customStyleWrapper?: object;\n customStyleContainer?: object;\n customStyleInputBox?: object;\n validationCallback?: (res: boolean) => void;\n}\nconst component: React.FC = ({\n attributesWrapper = {},\n attributesInput = {},\n value = '',\n checked = false,\n disabled = false,\n validate = false,\n labelHtml = null,\n classNameInput = '',\n classNameWrapper = '',\n classNameInputBox = '',\n classNameContainer = '',\n customStyleInput = {},\n customStyleWrapper = {},\n customStyleInputBox = {},\n customStyleContainer = {},\n validationOption = {},\n asyncMsgObj = {},\n onChange = () => {},\n onBlur = null,\n onFocus = null,\n onClick = null,\n validationCallback = null,\n}) => {\n const [err, setErr] = useState(false);\n const [msg, setMsg] = useState('');\n const [successMsg, setSuccessMsg] = useState('');\n const [internalChecked, setInternalChecked] = useState(checked);\n const prevInternalChecked = usePrevious(internalChecked);\n const option = getDefaultValidationOption(validationOption);\n const asyncObj = getDefaultAsyncObj(asyncMsgObj);\n const $input = useRef(null);\n const $el: { [key: string]: any } | null = $input;\n const handleOnBlur = useCallback(\n (e: React.FocusEvent) => {\n if (onBlur) {\n check();\n onBlur(e);\n }\n },\n [internalChecked, option],\n );\n const handleOnFocus = useCallback(\n (e: React.FocusEvent) => {\n if (onFocus) {\n onFocus(e);\n }\n },\n [internalChecked],\n );\n const handleOnClick = useCallback(\n (e: React.MouseEvent) => {\n handleOnChange(e);\n if (onClick) {\n onClick(e);\n }\n },\n [err, internalChecked],\n );\n const handleOnChange = useCallback(\n (e: React.ChangeEvent | React.MouseEvent) => {\n if (disabled || $el === null) {\n return;\n }\n setInternalChecked(!internalChecked);\n onChange && onChange(!internalChecked, e);\n if (err) {\n setErr(false);\n } else {\n setSuccessMsg('');\n }\n },\n [err, internalChecked],\n );\n const check = useCallback(\n () => {\n const { name, check, locale, required, msgOnSuccess } = option;\n if (!check) {\n return;\n }\n if (!message[locale] || !message[locale][TYPE]) {\n console.error(REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE);\n return;\n }\n if (required) {\n const msg = message[locale][TYPE];\n const nameText = name ? name : '';\n if (!internalChecked) {\n handleCheckEnd(true, msg.unchecked(nameText));\n return;\n }\n }\n if (msgOnSuccess) {\n setSuccessMsg(msgOnSuccess);\n }\n handleCheckEnd(false, msgOnSuccess);\n },\n [internalChecked, option],\n );\n const handleCheckEnd = useCallback((err: boolean, message: string) => {\n let msg = message;\n const { msgOnError } = option;\n if (err && msgOnError) {\n msg = msgOnError;\n }\n setErr(err);\n setMsg(msg);\n validationCallback && validationCallback(err);\n }, [option.msgOnError]);\n useEffect(\n () => {\n if (validate) {\n check();\n }\n },\n [validate, internalChecked],\n );\n useEffect(\n () => {\n setInternalChecked(checked);\n },\n [checked],\n );\n useEffect(\n () => {\n if (typeof prevInternalChecked !== 'undefined' && prevInternalChecked !== internalChecked) {\n check();\n }\n },\n [prevInternalChecked, internalChecked],\n );\n useEffect(\n () => {\n if (asyncObj) {\n if (asyncObj.message) {\n if (asyncObj.showOnError) {\n handleCheckEnd(asyncObj.error, asyncObj.message);\n }\n if (!asyncObj.error && asyncObj.showOnSuccess) {\n setSuccessMsg(asyncObj.message);\n }\n }\n }\n },\n [asyncMsgObj],\n );\n const wrapperClass = `${reactInputsValidationCss['button']} ${WRAPPER_CLASS_IDENTITIFIER} ${classNameWrapper} ${reactInputsValidationCss[`${TYPE}__wrapper`]} ${internalChecked && reactInputsValidationCss['checked']} ${err &&\n reactInputsValidationCss['error']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const containerClass = `${classNameContainer} ${reactInputsValidationCss[`${TYPE}__container`]} ${internalChecked && reactInputsValidationCss['checked']} ${err &&\n reactInputsValidationCss['error']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const boxClass = `${classNameInputBox} ${reactInputsValidationCss[`${TYPE}__box`]} ${err && reactInputsValidationCss['error']} ${internalChecked &&\n reactInputsValidationCss['checked']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const labelClass = `${internalChecked && reactInputsValidationCss['checked']} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${disabled && reactInputsValidationCss['disabled']}`;\n const errMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${err && reactInputsValidationCss['error']}`;\n const successMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${!err && reactInputsValidationCss['success']}`;\n let msgHtml;\n const { showMsg } = option;\n if (showMsg && err && msg) {\n msgHtml =
{msg}
;\n }\n if (showMsg && !err && successMsg !== '') {\n msgHtml =
{successMsg}
;\n }\n return (\n \n );\n};\nexport default memo(component);\n","import * as React from 'react';\nconst { useState, useEffect, useCallback, useRef, memo } = React;\nimport message from './message';\nimport { REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE, DEFAULT_LOCALE, WRAPPER_CLASS_IDENTITIFIER, OPTION_LIST_ITEM_IDENTITIFIER, MSG_CLASS_IDENTITIFIER, usePrevious } from './const';\nimport utils from './utils';\nimport reactInputsValidationCss from './react-inputs-validation.css';\nconst TYPE = 'radiobox';\ninterface DefaultValidationOption {\n name?: string;\n check?: boolean;\n showMsg?: boolean;\n required?: boolean;\n locale?: string;\n msgOnError?: string;\n msgOnSuccess?: string;\n}\nconst getDefaultValidationOption = (obj: DefaultValidationOption) => {\n let { name, check, required, showMsg, locale, msgOnError, msgOnSuccess } = obj;\n locale = typeof locale !== 'undefined' ? locale : DEFAULT_LOCALE;\n name = typeof name !== 'undefined' ? name : '';\n check = typeof check !== 'undefined' ? check : true;\n showMsg = typeof showMsg !== 'undefined' ? showMsg : true;\n required = typeof required !== 'undefined' ? required : true;\n msgOnSuccess = typeof msgOnSuccess !== 'undefined' ? msgOnSuccess : '';\n msgOnError = typeof msgOnError !== 'undefined' ? msgOnError : '';\n return {\n name,\n check,\n showMsg,\n required,\n locale,\n msgOnError,\n msgOnSuccess,\n };\n};\ninterface DefaultAsyncMsgObj {\n error?: boolean;\n message?: string;\n showOnError?: boolean;\n showOnSuccess?: boolean;\n}\nconst getDefaultAsyncObj = (obj: DefaultAsyncMsgObj) => {\n let { error, message, showOnError, showOnSuccess } = obj;\n error = typeof error !== 'undefined' ? error : false;\n message = typeof message !== 'undefined' ? message : '';\n showOnError = typeof showOnError !== 'undefined' ? showOnError : true;\n showOnSuccess = typeof showOnSuccess !== 'undefined' ? showOnSuccess : false;\n return {\n error,\n message,\n showOnError,\n showOnSuccess,\n };\n};\nexport const isValidValue = (list: OptionListItem[], value: any) => {\n let res = false;\n if (list.length) {\n for (let i = 0; i < list.length; i += 1) {\n if (list[i].id === value) {\n res = true;\n break;\n }\n }\n }\n return res;\n};\ninterface OptionListItem {\n id: string;\n name: string;\n}\ninterface AttributesInput {}\ninterface Props {\n attributesWrapper: object;\n attributesInputs: AttributesInput[];\n value?: string | number;\n disabled?: boolean;\n validate?: boolean;\n optionList?: OptionListItem[];\n onChange: (res: string, e: React.ChangeEvent) => void;\n onBlur?: (e: React.FocusEvent) => void;\n onFocus?: (e: React.FocusEvent) => void;\n onClick?: (e: React.MouseEvent) => void;\n validationOption?: object;\n asyncMsgObj?: object;\n classNameWrapper?: string;\n classNameInput?: string;\n classNameContainer?: string;\n classNameOptionListItem?: string;\n customStyleWrapper?: object;\n customStyleContainer?: object;\n customStyleInput?: object;\n customStyleOptionListItem?: object;\n validationCallback?: (res: boolean) => void;\n}\nconst component: React.FC = ({\n attributesWrapper = {},\n attributesInputs = [],\n value = '',\n disabled = false,\n validate = false,\n optionList = [],\n classNameWrapper = '',\n classNameInput = '',\n classNameContainer = '',\n classNameOptionListItem = '',\n customStyleWrapper = {},\n customStyleContainer = {},\n customStyleInput = {},\n customStyleOptionListItem = {},\n validationOption = {},\n asyncMsgObj = {},\n onChange = () => {},\n onBlur = null,\n onFocus = null,\n onClick = null,\n validationCallback = null,\n}) => {\n const [err, setErr] = useState(false);\n const [msg, setMsg] = useState('');\n const [successMsg, setSuccessMsg] = useState('');\n const [internalValue, setInternalValue] = useState(String(value));\n const prevInternalValue = usePrevious(internalValue);\n const option = getDefaultValidationOption(validationOption);\n const asyncObj = getDefaultAsyncObj(asyncMsgObj);\n const $input = useRef(null);\n const $el: { [key: string]: any } | null = $input;\n const handleOnBlur = useCallback(\n (e: React.FocusEvent) => {\n if (onBlur) {\n check();\n onBlur(e);\n }\n },\n [internalValue, option],\n );\n const handleOnFocus = useCallback((e: React.FocusEvent) => {\n if (onFocus) {\n onFocus(e);\n }\n }, []);\n const handleOnClick = useCallback((e: React.MouseEvent) => {\n if (onClick) {\n onClick(e);\n }\n }, []);\n const handleOnChange = useCallback((val: string, e: React.ChangeEvent) => {\n if (disabled || $el === null) {\n return;\n }\n setInternalValue(val);\n onChange && onChange(val, e);\n }, []);\n const check = useCallback(\n () => {\n const { name, check, locale, required, msgOnSuccess } = option;\n if (!check) {\n return;\n }\n if (!message[locale] || !message[locale][TYPE]) {\n console.error(REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE);\n return;\n }\n if (required) {\n const msg = message[locale][TYPE];\n const nameText = name ? name : '';\n if (!isValidValue(optionList, internalValue)) {\n handleCheckEnd(true, msg.empty(nameText));\n return;\n }\n }\n if (msgOnSuccess) {\n setSuccessMsg(msgOnSuccess);\n }\n handleCheckEnd(false, msgOnSuccess);\n },\n [internalValue, option],\n );\n const handleCheckEnd = useCallback((err: boolean, message: string) => {\n let msg = message;\n const { msgOnError } = option;\n if (err && msgOnError) {\n msg = msgOnError;\n }\n setErr(err);\n setMsg(msg);\n validationCallback && validationCallback(err);\n }, [option.msgOnError]);\n useEffect(\n () => {\n if (validate) {\n check();\n }\n },\n [validate],\n );\n useEffect(\n () => {\n if (internalValue && isValidValue(optionList, internalValue)) {\n setErr(false);\n } else {\n setSuccessMsg('');\n }\n },\n [internalValue],\n );\n useEffect(\n () => {\n setInternalValue(String(value));\n },\n [value],\n );\n useEffect(\n () => {\n if (typeof prevInternalValue !== 'undefined' && prevInternalValue !== internalValue) {\n check();\n }\n },\n [prevInternalValue, internalValue],\n );\n useEffect(\n () => {\n if (asyncObj) {\n if (asyncObj.message) {\n if (asyncObj.showOnError) {\n handleCheckEnd(asyncObj.error, asyncObj.message);\n }\n if (!asyncObj.error && asyncObj.showOnSuccess) {\n setSuccessMsg(asyncObj.message);\n }\n }\n }\n },\n [asyncMsgObj],\n );\n const wrapperClass = `${WRAPPER_CLASS_IDENTITIFIER} ${classNameWrapper} ${err && reactInputsValidationCss['error']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${\n reactInputsValidationCss[`${TYPE}__wrapper`]\n } ${disabled && reactInputsValidationCss['disabled']}`;\n const containerClass = `${classNameContainer} ${err && reactInputsValidationCss['error']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${\n reactInputsValidationCss[`${TYPE}__container`]\n } ${disabled && reactInputsValidationCss['disabled']}`;\n const inputClass = `${classNameInput} ${err && reactInputsValidationCss['error']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${\n reactInputsValidationCss[`${TYPE}__input`]\n } ${disabled && reactInputsValidationCss['disabled']}`;\n const labelClass = `${err && reactInputsValidationCss['error']} ${successMsg !== '' && !err && reactInputsValidationCss['success']} ${reactInputsValidationCss[`${TYPE}__label`]} ${disabled &&\n reactInputsValidationCss['disabled']}`;\n const optionListItemClass = `${reactInputsValidationCss['button']} ${OPTION_LIST_ITEM_IDENTITIFIER} ${classNameOptionListItem} ${err && reactInputsValidationCss['error']} ${successMsg !== '' &&\n !err &&\n reactInputsValidationCss['success']} ${reactInputsValidationCss[`${TYPE}__item`]} ${disabled && reactInputsValidationCss['disabled']}`;\n const errMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${err && reactInputsValidationCss['error']}`;\n const successMsgClass = `${MSG_CLASS_IDENTITIFIER} ${reactInputsValidationCss['msg']} ${!err && reactInputsValidationCss['success']}`;\n let msgHtml;\n const { showMsg } = option;\n if (showMsg && err && msg) {\n msgHtml =
{msg}
;\n }\n if (showMsg && !err && successMsg !== '') {\n msgHtml =
{successMsg}
;\n }\n let optionHtml;\n if (optionList.length) {\n optionHtml = optionList.map((i, k) => {\n const checked = String(i.id) === String(internalValue) ? true : false;\n return (\n \n );\n });\n }\n return (\n
\n
\n {optionHtml}\n
\n {msgHtml}\n
\n );\n};\ninterface AttributesInput {\n id?: string;\n}\ninterface OptionProps {\n checked?: boolean;\n id?: string;\n optionListItemClass?: string;\n labelClass?: string;\n inputClass?: string;\n value?: string | number;\n disabled?: boolean;\n item?: OptionListItem;\n customStyleOptionListItem?: object;\n customStyleInput?: object;\n attributesInput: AttributesInput;\n onChange?: (res: string, e: React.ChangeEvent) => void;\n}\nexport const Option: React.FC = memo(\n ({\n checked = false,\n id = '',\n optionListItemClass = '',\n labelClass = '',\n inputClass = '',\n value = '',\n disabled = false,\n item = { id: '', name: '' },\n customStyleOptionListItem = {},\n customStyleInput = {},\n attributesInput = {},\n onChange = () => {},\n }) => {\n const handleOnChange = useCallback(e => {\n onChange(item.id, e);\n }, [item]);\n return (\n \n );\n },\n);\nexport default memo(component);\n"],"sourceRoot":""} \ No newline at end of file diff --git a/lib/react-inputs-validation.min.js b/lib/react-inputs-validation.min.js index 770f648..5146f74 100644 --- a/lib/react-inputs-validation.min.js +++ b/lib/react-inputs-validation.min.js @@ -1,2 +1,2 @@ -!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("React")):"function"==typeof define&&define.amd?define(["React"],t):"object"==typeof exports?exports["react-inputs-validation"]=t(require("React")):e["react-inputs-validation"]=t(e.React)}(this,(function(e){return function(e){var t={};function n(r){if(t[r])return t[r].exports;var i=t[r]={i:r,l:!1,exports:{}};return e[r].call(i.exports,i,i.exports,n),i.l=!0,i.exports}return n.m=e,n.c=t,n.d=function(e,t,r){n.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:r})},n.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.t=function(e,t){if(1&t&&(e=n(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var i in e)n.d(r,i,function(t){return e[t]}.bind(null,i));return r},n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,"a",t),t},n.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},n.p="",n(n.s=6)}([function(t,n){t.exports=e},function(e,t,n){"use strict";var r=this&&this.__importStar||function(e){if(e&&e.__esModule)return e;var t={};if(null!=e)for(var n in e)Object.hasOwnProperty.call(e,n)&&(t[n]=e[n]);return t.default=e,t};Object.defineProperty(t,"__esModule",{value:!0});var i=r(n(0)),o=i.useEffect,a=i.useRef;t.LOCALE_OPTION_LIST=["en-US","zh-CN"],t.REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE="Invalid window.REACT_INPUTS_VALIDATION['customErrorMessage']. EXAMPLE: window.REACT_INPUTS_VALIDATION={customErrorMessage:{'en-US':{textbox:{empty:function empty(name){return getEnglishName(name)+'cannot be empty'},invalid:function invalid(name){return getEnglishName(name)+'invalid format'},invalidFormat:function invalidFormat(name){return getEnglishName(name)+'is not a number'},inBetween:function inBetween(name){return function(min){return function(max){return getEnglishName(name)+'must be '+min+'-'+max}}},lessThan:function lessThan(name){return function(min){return getEnglishName(name)+'cannot less than '+min}},greaterThan:function greaterThan(name){return function(max){return getEnglishName(name)+'cannot greater than '+max}},lengthEqual:function lengthEqual(name){return function(length){return getEnglishName(name)+'length must be '+length}},twoInputsNotEqual:function twoInputsNotEqual(){return'two inputs are not equal'}},radiobox:{empty:function empty(name){return'Please choose one '+getEnglishName(name)}},checkbox:{unchecked:function unchecked(name){return getEnglishName(name)+'must be checked'}},select:{empty:function empty(name){return'Please select a '+getEnglishName(name)}},textarea:{empty:function empty(name){return getEnglishName(name)+'cannot be empty'},invalid:function invalid(name){return getEnglishName(name)+'invalid format'},invalidFormat:function invalidFormat(name){return getEnglishName(name)+'is not a number'},inBetween:function inBetween(name){return function(min){return function(max){return getEnglishName(name)+'must be '+min+'-'+max}}},lessThan:function lessThan(name){return function(min){return getEnglishName(name)+'cannot less than '+min}},greaterThan:function greaterThan(name){return function(max){return getEnglishName(name)+'cannot greater than '+max}},lengthEqual:function lengthEqual(name){return function(length){return getEnglishName(name)+'length must be '+length}},twoInputsNotEqual:function twoInputsNotEqual(){return'two inputs are not equal'}}}}};",t.DEFAULT_LOCALE="en-US",t.WRAPPER_CLASS_IDENTITIFIER="react-inputs-validation__wrapper_identifier",t.CONTAINER_CLASS_IDENTITIFIER="react-inputs-validation__container_identifier",t.OPTION_LIST_ITEM_IDENTITIFIER="react-inputs-validation__option-list-item_identifier",t.MSG_CLASS_IDENTITIFIER="react-inputs-validation__msg_identifier",t.usePrevious=function(e){var t=a();return o((function(){t.current=e})),t.current}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=n(1),i=function(e){var t="";return e&&(t=e+" "),t},o={"zh-CN":{textbox:{empty:function(e){return e+"不能为空"},invalid:function(e){return e+"格式有误"},invalidFormat:function(e){return e+"不是数字"},inBetween:function(e){return function(t){return function(n){return e+"必须在"+t+"-"+n+"之间"}}},lessThan:function(e){return function(t){return e+"不可少于"+t}},greaterThan:function(e){return function(t){return e+"不可大于"+t}},lengthEqual:function(e){return function(t){return e+"长度必须为"+t}},twoInputsNotEqual:function(){return"两次输入不一致"}},radiobox:{empty:function(e){return"必须勾选一个"+e}},checkbox:{unchecked:function(e){return e+"必须勾选"}},select:{empty:function(e){return"请选择一个"+e}},textarea:{empty:function(e){return e+"不能为空"},invalid:function(e){return e+"格式有误"},invalidFormat:function(e){return e+"不是数字"},inBetween:function(e){return function(t){return function(n){return e+"必须在"+t+"-"+n+"之间"}}},lessThan:function(e){return function(t){return e+"不可少于"+t}},greaterThan:function(e){return function(t){return e+"不可大于"+t}},lengthEqual:function(e){return function(t){return e+"长度必须为"+t}},twoInputsNotEqual:function(){return"两次输入不一致"}}},"en-US":{textbox:{empty:function(e){return i(e)+"cannot be empty"},invalid:function(e){return i(e)+"invalid format"},invalidFormat:function(e){return i(e)+"is not a number"},inBetween:function(e){return function(t){return function(n){return i(e)+"must be "+t+"-"+n}}},lessThan:function(e){return function(t){return i(e)+"cannot less than "+t}},greaterThan:function(e){return function(t){return i(e)+"cannot greater than "+t}},lengthEqual:function(e){return function(t){return i(e)+"length must be "+t}},twoInputsNotEqual:function(){return"two inputs are not equal"}},radiobox:{empty:function(e){return"Please choose one "+i(e)}},checkbox:{unchecked:function(e){return i(e)+"must be checked"}},select:{empty:function(e){return"Please select a "+i(e)}},textarea:{empty:function(e){return i(e)+"cannot be empty"},invalid:function(e){return i(e)+"invalid format"},invalidFormat:function(e){return i(e)+"is not a number"},inBetween:function(e){return function(t){return function(n){return i(e)+"must be "+t+"-"+n}}},lessThan:function(e){return function(t){return i(e)+"cannot less than "+t}},greaterThan:function(e){return function(t){return i(e)+"cannot greater than "+t}},lengthEqual:function(e){return function(t){return i(e)+"length must be "+t}},twoInputsNotEqual:function(){return"two inputs are not equal"}}}};t.getCustomErrorMessage=function(e,t){return e&&"object"==typeof e&&e.constructor===Object&&Object.keys(e).length?(Object.keys(e).map((function(n){t[n]?Object.keys(e[n]).length&&Object.keys(e[n]).map((function(r){Object.keys(e[n][r]).length&&Object.keys(e[n][r]).map((function(i){t[n][r][i]=e[n][r][i]}))})):t[n]=e[n]})),t):(console.error(r.REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE),!1)},t.handleCustomErrorMessage=function(e,n){var r;return void 0!==n&&n.REACT_INPUTS_VALIDATION&&n.REACT_INPUTS_VALIDATION.customErrorMessage&&(r=t.getCustomErrorMessage(n.REACT_INPUTS_VALIDATION.customErrorMessage,e)),void 0===r||!1===r?e:r},"undefined"!=typeof window&&(window.REACT_INPUTS_VALIDATION=window.REACT_INPUTS_VALIDATION||{},o=t.handleCustomErrorMessage(o,window)),t.default=o},function(e,t,n){e.exports={ellipsis:"react-inputs-validation__ellipsis___3-Api",textbox__wrapper:"react-inputs-validation__textbox__wrapper___3tnXv",textbox__input:"react-inputs-validation__textbox__input___20hDL",error:"react-inputs-validation__error___2aXSp",success:"react-inputs-validation__success___3TpwE",disabled:"react-inputs-validation__disabled___1-57g",msg:"react-inputs-validation__msg___pxv8o",textarea__wrapper:"react-inputs-validation__textarea__wrapper___35GhF",textarea__input:"react-inputs-validation__textarea__input___1CFm_",radiobox__container:"react-inputs-validation__radiobox__container___FD4vb",radiobox__input:"react-inputs-validation__radiobox__input___2uX2-",radiobox__label:"react-inputs-validation__radiobox__label___2tQsB",radiobox__wrapper:"react-inputs-validation__radiobox__wrapper___1zZ30",checked:"react-inputs-validation__checked___2O0Ju",button:"react-inputs-validation__button___9JBRL",radiobox__item:"react-inputs-validation__radiobox__item___ejuz1",checkbox__input:"react-inputs-validation__checkbox__input___1yF4X",checkbox__container:"react-inputs-validation__checkbox__container___3I1rX",checkbox__box:"react-inputs-validation__checkbox__box___1uj8A",checkbox__wrapper:"react-inputs-validation__checkbox__wrapper___1c1rD",box:"react-inputs-validation__box___3E9nu",select__wrapper:"react-inputs-validation__select__wrapper___1B4OH",select__input:"react-inputs-validation__select__input___3h-P7",select__container:"react-inputs-validation__select__container___3jgUR",select__button:"react-inputs-validation__select__button___vEDoq","select__options-item":"react-inputs-validation__select__options-item___30yY4","select__options-item-show-cursor":"react-inputs-validation__select__options-item-show-cursor___1ZT3b",select__searchInputWrapper:"react-inputs-validation__select__searchInputWrapper___3R5P_",select__searchInputSearchIcon:"react-inputs-validation__select__searchInputSearchIcon___1Q8xX",select__searchInputRemoveIcon:"react-inputs-validation__select__searchInputRemoveIcon___1A1tR",select__searchInput:"react-inputs-validation__select__searchInput___1lN24","select__no-mouse":"react-inputs-validation__select__no-mouse___2uRg6","select__hover-active":"react-inputs-validation__select__hover-active___2z1MQ",active:"react-inputs-validation__active___3eZBB","select__options-container-animate":"react-inputs-validation__select__options-container-animate___2Rm--",show:"react-inputs-validation__show___2NI3u","select__options-container":"react-inputs-validation__select__options-container___d54qE",select__dropdown:"react-inputs-validation__select__dropdown___11yDr","select__dropdown-icon":"react-inputs-validation__select__dropdown-icon___1T5r2","select__dropdown-name":"react-inputs-validation__select__dropdown-name___3hghL","select__dropdown-icon-container":"react-inputs-validation__select__dropdown-icon-container___2ild-"}},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=function(e){return e.replace(/(?:^\w|[A-Z]|\b\w|\s+)/g,(function(e,t){return 0==+e?"":0===t?e.toLowerCase():e.toUpperCase()}))},i={camelize:r,toCamelCase:function(e){return function(t){void 0===t&&(t=!1);var n=r(e);return t?n.substr(0,1).toUpperCase()+n.substr(1,n.length):n}},getRandomId:function(){return Math.random().toString(36).slice(-8)},getAlphanumeric:function(e){var t="";return String(e).split("").forEach((function(e){var n=e.toLowerCase().charCodeAt(0);(n>=48&&n<=57||n>=97&&n<=122)&&(t+=e)})),t},getAlpha:function(e){var t="";return String(e).split("").forEach((function(e){var n=e.toLowerCase().charCodeAt(0);n>=97&&n<=122&&(t+=e)})),t},getNumeric:function(e){var t="";return String(e).split("").forEach((function(e){var n=e.toLowerCase().charCodeAt(0);n>=48&&n<=57&&(t+=e)})),t},arraysEqual:function(e,t){if(e.length!==t.length)return!1;for(var n=e.length;n-=1;)if(JSON.stringify(e[n])!==JSON.stringify(t[n]))return!1;return!0}};t.default=i},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=function(e){return!isNaN(parseFloat(e))&&isFinite(e)},i={reg:function(e,t){var n=!0;return e.test(t)&&(n=!1),n},empty:function(e){return!e.replace(/\s/g,"").length},number:function(e,t,n){return null===t&&null===n||!!r(e)&&!(en)}};t.default=i},function(e,t,n){"use strict";var r=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(t,"__esModule",{value:!0});var i=r(n(7));t.Textbox=i.default;var o=r(n(8));t.Textarea=o.default;var a=r(n(9));t.Select=a.default;var u=r(n(10));t.Checkbox=u.default;var s=r(n(11));t.Radiobox=s.default,"undefined"!=typeof window&&(window.Textbox=i.default,window.Textarea=o.default,window.Radiobox=s.default,window.Checkbox=u.default,window.Select=a.default)},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n0&&i[i.length-1])||6!==o[0]&&2!==o[0])){a=0;continue}if(3===o[0]&&(!i||o[1]>i[0]&&o[1]Number(I.maxLength))){var n=Ee.type,r=Ee.numberType,i=Ee.mantissa;n===b[1]&&(t=String(function(e,t,n){var r="",i=!1,o=String(e).split("");o[0];if(t===y[2]&&"0"===o[0]&&"0"===o[1]&&o.shift(),o.forEach((function(e){var n=e.toLowerCase().charCodeAt(0);if(n>=48&&n<=57||46===n&&!i){if(46===n){if(t===y[1])return;i=!0}r+=e}})),i&&n>=0){var a=r.split(".");0===n?r=a[0]:(a[1]=a[1].slice(0,n),r=a.join("."))}return t!==y[0]&&t!==y[2]||r.length&&"."===r[0]&&(r="0"+r),r}(t,y.indexOf(r)>=0?r:y[0],i))),n===b[2]&&(t=p.default.getAlphanumeric(t)),n===b[3]&&(t=p.default.getAlpha(t)),he(t),J&&J(t,e),ue?se(!1):ve("")}}}),[ue,I,Ee]),Ce=d((function(){return i(void 0,void 0,void 0,(function(){var e,t,n,r,i,a,u,s,l,c,d,f,_,g,y,S;return o(this,(function(o){switch(o.label){case 0:if(e=Ee.reg,t=Ee.min,n=Ee.max,r=Ee.type,i=Ee.name,a=Ee.check,u=Ee.length,s=Ee.regMsg,l=Ee.locale,c=Ee.compare,d=Ee.required,f=Ee.msgOnSuccess,_=Ee.customFunc,!a)return[2];if(!r)return[3,5];if(-1===b.indexOf(r))return[3,3];if(!v.default[l]||!v.default[l][E])return console.error(h.REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE),[2];if(g=v.default[l][E],y=i||"",d&&m.default.empty(pe))return xe(!0,g.empty(y)),[2];if(""!==String(pe)){if(e&&m.default.reg(e,pe))return xe(!0,""!==s?s:g.invalid(y)),[2];if(r===b[0]){if(t||n)if(t&&n){if(String(pe).lengthn)return xe(!0,g.inBetween(y)(t)(n)),[2]}else{if(t&&String(pe).lengthn)return xe(!0,g.greaterThan(y)(n)),[2]}if(u&&String(pe).length!==u)return xe(!0,g.lengthEqual(y)(u)),[2]}if(r===b[1]){if(!m.default[r](pe,null,null))return xe(!0,g.invalid(y)),[2];if(t||n)if(t&&n){if(!m.default[r](pe,t,n))return xe(!0,g.inBetween(y)(t)(n)),[2]}else{if(t&&!m.default[r](pe,t))return xe(!0,g.lessThan(y)(t)),[2];if(n&&!m.default[r](pe,0,n))return xe(!0,g.greaterThan(y)(n)),[2]}if(u&&String(pe).length!==u)return xe(!0,g.lengthEqual(y)(u)),[2]}if(c&&""!==c&&pe!==c)return xe(!0,g.twoInputsNotEqual()),[2]}return _&&"function"==typeof _?[4,_(pe)]:[3,2];case 1:if("object"==typeof(S=o.sent()))return"boolean"==typeof S.error&&"string"==typeof S.message&&(!1===S.error&&!0===S.showOnSuccess&&ve(S.message),xe(S.error,S.message,!0)),[2];if(!0!==S)return xe(!0,S,!0),[2];o.label=2;case 2:return f&&ve(f),xe(!1,f),[3,4];case 3:console.error("The valid "+p.default.toCamelCase(E)(!0)+' "type" options in validationOption are ['+b.map((function(e){return e}))+"]"),o.label=4;case 4:return[3,6];case 5:console.error('Please provide "type" in validationOption'),o.label=6;case 6:return[2]}}))}))}),[pe,Ee]),xe=d((function(e,t,n){void 0===n&&(n=!1);var r=t,i=Ee.msgOnError;e&&i&&!n&&(r=i),se(e),de(r),oe&&oe(e)}),[]);c((function(){L&&Ce()}),[L]),c((function(){he(String(T))}),[T]),c((function(){void 0!==ge&&ge!==pe&&Ee.customFunc&&re&&Ce()}),[pe]),c((function(){be&&be.message&&(be.showOnError&&xe(be.error,be.message),!be.error&&be.showOnSuccess&&ve(be.message))}),[H]);var Me,Le=P+" "+g.default[E+"__wrapper"]+" "+(ue&&g.default.error)+" "+(""!==_e&&!ue&&g.default.success)+" "+(x&&g.default.disabled),Ae=D+" "+g.default[E+"__container"]+" "+(ue&&g.default.error)+" "+(""!==_e&&!ue&&g.default.success)+" "+(x&&g.default.disabled),ke=k+" "+g.default[E+"__input"]+" "+(ue&&g.default.error)+" "+(""!==_e&&!ue&&g.default.success)+" "+(x&&g.default.disabled),Re=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(ue&&g.default.error),Pe=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(!ue&&g.default.success),Fe=Ee.showMsg;return Fe&&ue&&ce&&(Me=s.createElement("div",{className:Re},ce)),Fe&&!ue&&""!==_e&&(Me=s.createElement("div",{className:Pe},_e)),s.createElement("div",r({className:Le,style:B},w),s.createElement("div",{className:Ae,style:W},s.createElement("input",r({type:"text",value:pe,disabled:x,onBlur:we,onKeyUp:Ne,onFocus:Oe,onClick:Ie,className:ke,onChange:Te,style:q,ref:ye},I))),Me)}))},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n0&&i[i.length-1])||6!==o[0]&&2!==o[0])){a=0;continue}if(3===o[0]&&(!i||o[1]>i[0]&&o[1]Number(O.maxLength)||(pe(t),K&&K(t,e),ae?ue(!1):_e(""))}}),[ae]),Te=d((function(){return i(void 0,void 0,void 0,(function(){var e,t,n,r,i,a,u,s,l,c,d,f,_,g,y;return o(this,(function(o){switch(o.label){case 0:if(e=ge.reg,t=ge.min,n=ge.max,r=ge.type,i=ge.name,a=ge.check,u=ge.length,s=ge.regMsg,l=ge.locale,c=ge.required,d=ge.msgOnSuccess,f=ge.customFunc,!a)return[2];if(!r)return[3,5];if(-1===b.indexOf(r))return[3,3];if(!v.default[l]||!v.default[l][E])return console.error(h.REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE),[2];if(_=v.default[l][E],g=i||"",c&&m.default.empty(me))return Ce(!0,_.empty(g)),[2];if(""!==String(me)){if(e&&m.default.reg(e,me))return Ce(!0,""!==s?s:_.invalid(g)),[2];if(t||n)if(t&&n){if(String(me).lengthn)return Ce(!0,_.inBetween(g)(t)(n)),[2]}else{if(t&&String(me).lengthn)return Ce(!0,_.greaterThan(g)(n)),[2]}if(u&&String(me).length!==u)return Ce(!0,_.lengthEqual(g)(u)),[2]}return f&&"function"==typeof f?[4,f(me)]:[3,2];case 1:if("object"==typeof(y=o.sent()))return"boolean"==typeof y.error&&"string"==typeof y.message&&(!1===y.error&&!0===y.showOnSuccess&&_e(y.message),Ce(y.error,y.message,!0)),[2];if(!0!==y)return Ce(!0,y,!0),[2];o.label=2;case 2:return d&&_e(d),Ce(!1,d),[3,4];case 3:console.error("The valid "+p.default.toCamelCase(E)(!0)+' "type" options in validationOption are ['+b.map((function(e){return e}))+"]"),o.label=4;case 4:return[3,6];case 5:console.error('Please provide "type" in validationOption'),o.label=6;case 6:return[2]}}))}))}),[me,ge]),Ce=d((function(e,t,n){void 0===n&&(n=!1);var r=t,i=ge.msgOnError;e&&i&&!n&&(r=i),ue(e),ce(r),ie&&ie(e)}),[]);c((function(){M&&Te()}),[M]),c((function(){pe(String(N))}),[N]),c((function(){void 0!==he&&he!==me&&ge.customFunc&&ne&&Te()}),[me]),c((function(){Ee&&Ee.message&&(Ee.showOnError&&Ce(Ee.error,Ee.message),!Ee.error&&Ee.showOnSuccess&&_e(Ee.message))}),[X]);var xe,Me=R+" "+g.default[E+"__wrapper"]+" "+(ae&&g.default.error)+" "+(""!==fe&&!ae&&g.default.success)+" "+(C&&g.default.disabled),Le=F+" "+g.default[E+"__container"]+" "+(ae&&g.default.error)+" "+(""!==fe&&!ae&&g.default.success)+" "+(C&&g.default.disabled),Ae=A+" "+g.default[E+"__input"]+" "+(ae&&g.default.error)+" "+(""!==fe&&!ae&&g.default.success)+" "+(C&&g.default.disabled),ke=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(ae&&g.default.error),Re=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(!ae&&g.default.success),Pe=ge.showMsg;return Pe&&ae&&le&&(xe=s.createElement("div",{className:ke},le)),Pe&&!ae&&""!==fe&&(xe=s.createElement("div",{className:Re},fe)),s.createElement("div",r({className:Me,style:U},S),s.createElement("div",{className:Le,style:V},s.createElement("textarea",r({value:me,disabled:C,onBlur:Se,onKeyUp:Ie,onFocus:we,onClick:Oe,className:Ae,onChange:Ne,style:j,ref:be},O))),xe)}))},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n=a){var u=Math.abs(o-a-i);u>=0&&!y?(rt.current.scrollTop=r+i-u,y=!0):rt.current.scrollTop=r+i}}"up"===e&&(y=!1,S*i<=r&&(rt.current.scrollTop=S*i))}else y=!1,rt.current.scrollTop=S*i}}),[]),gt=c((function(e,t){dt(e,t),Pe[1]("")}),[]),Et=c((function(e){S=e,St()}),[]),bt=c((function(){Ge(!1)}),[]),yt=c((function(){wt()}),[]),St=c((function(){if(Ye&&Ye.current&&Ye.current.children){var e=Ye.current.children;if(wt(),null===S)return;S>=e.length&&(S=0),S<0&&(S=e.length-1),e[S]&&(e[S].className+=" "+h.default[g+"__hover-active"])}}),[]),wt=c((function(){if(Ye&&Ye.current&&Ye.current.children)for(var e=Ye.current.children,t=0;tot.length-1&&(S=0,ht("up")),St();else if(38===e)(S-=1)<0&&(S=ot.length-1,ht("loop")),St();else if(13===e&&S>-1&&Ye&&Ye.current&&Ye.current.children){var t=Ye.current.children;if(!t[S])return;t[S].click()}}),[ot]),Nt=c((function(e){if(!F&&(Ge(!0),e.preventDefault&&e.preventDefault(),qe)){S=null===S?t.getIndex(ot,String(M)):S;var n=e.keyCode,r=Ot(n);if(-1!==E.indexOf(n))It(n);else{pt();var o=i(Xe,[n]),a=String.fromCharCode.apply(String,o).toLowerCase(),u=-1;ot.forEach((function(e,t){e.name.toLowerCase().startsWith(a)&&-1===u&&(u=t)})),-1!==u&&(S=u,St()),He(o)}return ht(r),S}}),[qe,M,Xe]);l((function(){return qe&&nt&&document.addEventListener("keydown",Nt),function(){document.removeEventListener("keydown",Nt)}}),[qe,M,Xe]),l((function(){R&&ft()}),[R]),l((function(){t.isValidValue(ot,ke)&&""!==ke&&"null"!==ke&&"undefined"!==ke?Ie(!1):Le("")}),[ke]),l((function(){Re(String(M))}),[M]),l((function(){De&&De&&!p.default.arraysEqual(De,U)&&Re(String(U[0].id))}),[U]),l((function(){void 0!==Fe&&Fe!==ke&&ft()}),[Fe,ke]),l((function(){Je&&Je.message&&(Je.showOnError&&_t(Je.error,Je.message),!Je.error&&Je.showOnSuccess&&Le(Je.message))}),[fe]),l((function(){qe&&(F&&et.current.focus(),S=null===S?t.getIndex(ot,String(M)):S,it[S]&&it[S].current.focus()),!0===Be&&!1===qe&&tt.current.focus(),mt()}),[qe]);var Tt,Ct,xt=m.WRAPPER_CLASS_IDENTITIFIER+" "+V+" "+h.default.select__wrapper+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Mt=m.CONTAINER_CLASS_IDENTITIFIER+" "+G+" "+h.default.select__container+" "+(Oe&&h.default.error)+" "+(qe&&h.default.show)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Lt=h.default.select__input+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),At=X+" "+h.default.ellipsis+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),kt=Z+" "+h.default[g+"__options-container"]+" "+(Oe&&h.default.error)+" "+(qe&&h.default.show)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Rt=h.default.button+" "+(!We&&h.default[g+"__options-item-show-cursor"])+" "+K+" "+h.default[g+"__options-item"]+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Pt=Y+" "+h.default[g+"__dropdown-icon"],Ft=m.MSG_CLASS_IDENTITIFIER+" "+h.default.msg+" "+(Oe&&h.default.error),Dt=m.MSG_CLASS_IDENTITIFIER+" "+h.default.msg+" "+(!Oe&&h.default.success),jt=Ke.showMsg;jt&&Oe&&Te&&(Tt=u.createElement("div",{className:Ft},Te)),jt&&!Oe&&""!==Me&&(Tt=u.createElement("div",{className:Dt},Me));var qt=t.getItem(U,String(M));ot.length?Ct=ot.map((function(e,n){return u.createElement(t.Option,{key:n,index:n,id:"react-inputs-validation__select_option-"+e.id,className:String(e.id)===String(M)?Rt+" "+h.default.active:""+Rt,item:e,customStyleOptionListItem:ae,onClick:gt,onMouseOver:Et,onMouseMove:bt,onMouseOut:yt})})):F&&(Ct=u.createElement("div",{style:{background:"#fff",textAlign:"center",padding:"20px"}},u.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24"},u.createElement("path",{d:"M0 0h24v24H0z",fill:"none"}),u.createElement("path",{fill:"#cdcdcd",d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zM4 12c0-4.42 3.58-8 8-8 1.85 0 3.55.63 4.9 1.69L5.69 16.9C4.63 15.55 4 13.85 4 12zm8 8c-1.85 0-3.55-.63-4.9-1.69L18.31 7.1C19.37 8.45 20 10.15 20 12c0 4.42-3.58 8-8 8z"}))));var Ut=u.createElement("div",{className:h.default.select__dropdown},u.createElement("div",{className:h.default[g+"__dropdown-name"]+" "+h.default.ellipsis},qt?qt.name:""),u.createElement("div",{className:Pt}));return u.createElement("button",r({ref:Ze,type:"button",className:h.default.button,onClick:function(e){if(ct(e),!A){if($e.current&&$e.current.contains(e.target))return void Ue(!0);Ue(!qe)}},onFocus:lt,onBlur:st},N),u.createElement("div",{ref:Qe,className:xt,style:ee},u.createElement("div",{className:Mt,style:ne},u.createElement("input",r({type:"hidden",value:ke,className:Lt,onChange:function(){}},C)),u.createElement("div",{className:At,style:ie},Ut),u.createElement("div",{className:kt},F&&u.createElement("div",{ref:$e},u.createElement("div",{className:h.default.select__searchInputWrapper},u.createElement("svg",{className:h.default.select__searchInputSearchIcon,xmlns:"http://www.w3.org/2000/svg",width:"20",height:"20",viewBox:"0 0 24 24"},u.createElement("path",{fill:"#cdcdcd",d:"M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z"}),u.createElement("path",{d:"M0 0h24v24H0z",fill:"none"})),u.createElement("input",{className:h.default.select__searchInput,ref:et,value:Pe[0],onChange:at,onKeyDown:ut}),Pe[0]&&u.createElement("svg",{className:h.default.select__searchInputRemoveIcon,xmlns:"http://www.w3.org/2000/svg",width:"15",height:"15",viewBox:"0 0 24 24",onClick:function(){Pe[1](""),et.current.focus()}},u.createElement("path",{fill:"#cdcdcd",d:"M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7 12 10.59 15.59 7 17 8.41 13.41 12 17 15.59z"}),u.createElement("path",{d:"M0 0h24v24H0z",fill:"none"})))),u.createElement("div",{ref:Ye,style:se},Ct))),Tt))}))},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n=48&&n<=57||n>=97&&n<=122)&&(t+=e)})),t},getAlpha:function(e){var t="";return String(e).split("").forEach((function(e){var n=e.toLowerCase().charCodeAt(0);n>=97&&n<=122&&(t+=e)})),t},getNumeric:function(e){var t="";return String(e).split("").forEach((function(e){var n=e.toLowerCase().charCodeAt(0);n>=48&&n<=57&&(t+=e)})),t},arraysEqual:function(e,t){if(e.length!==t.length)return!1;for(var n=e.length;n-=1;)if(JSON.stringify(e[n])!==JSON.stringify(t[n]))return!1;return!0}};t.default=o},function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=function(e){return!isNaN(parseFloat(e))&&isFinite(e)},o={reg:function(e,t){var n=!0;return e.test(t)&&(n=!1),n},empty:function(e){return!e.replace(/\s/g,"").length},number:function(e,t,n){return null===t&&null===n||!!r(e)&&!(en)}};t.default=o},function(e,t,n){"use strict";var r=this&&this.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(t,"__esModule",{value:!0});var o=r(n(7));t.Textbox=o.default;var i=r(n(8));t.Textarea=i.default;var a=r(n(9));t.Select=a.default;var u=r(n(10));t.Checkbox=u.default;var s=r(n(11));t.Radiobox=s.default,"undefined"!=typeof window&&(window.Textbox=o.default,window.Textarea=i.default,window.Radiobox=s.default,window.Checkbox=u.default,window.Select=a.default)},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n0&&o[o.length-1])||6!==i[0]&&2!==i[0])){a=0;continue}if(3===i[0]&&(!o||i[1]>o[0]&&i[1]Number(I.maxLength))){var n=Ee.type,r=Ee.numberType,o=Ee.mantissa;n===b[1]&&(t=String(function(e,t,n){var r="",o=!1,i=String(e).split("");i[0];if(t===y[2]&&"0"===i[0]&&"0"===i[1]&&i.shift(),i.forEach((function(e){var n=e.toLowerCase().charCodeAt(0);if(n>=48&&n<=57||46===n&&!o){if(46===n){if(t===y[1])return;o=!0}r+=e}})),o&&n>=0){var a=r.split(".");0===n?r=a[0]:(a[1]=a[1].slice(0,n),r=a.join("."))}return t!==y[0]&&t!==y[2]||r.length&&"."===r[0]&&(r="0"+r),r}(t,y.indexOf(r)>=0?r:y[0],o))),n===b[2]&&(t=p.default.getAlphanumeric(t)),n===b[3]&&(t=p.default.getAlpha(t)),he(t),J&&J(t,e),ue?se(!1):ve("")}}}),[ue,I,Ee]),Ce=d((function(){return o(void 0,void 0,void 0,(function(){var e,t,n,r,o,a,u,s,l,c,d,f,_,g,y,S;return i(this,(function(i){switch(i.label){case 0:if(e=Ee.reg,t=Ee.min,n=Ee.max,r=Ee.type,o=Ee.name,a=Ee.check,u=Ee.length,s=Ee.regMsg,l=Ee.locale,c=Ee.compare,d=Ee.required,f=Ee.msgOnSuccess,_=Ee.customFunc,!a)return[2];if(!r)return[3,5];if(-1===b.indexOf(r))return[3,3];if(!v.default[l]||!v.default[l][E])return console.error(h.REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE),[2];if(g=v.default[l][E],y=o||"",d&&m.default.empty(pe))return xe(!0,g.empty(y)),[2];if(""!==String(pe)){if(e&&m.default.reg(e,pe))return xe(!0,""!==s?s:g.invalid(y)),[2];if(r===b[0]){if(t||n)if(t&&n){if(String(pe).lengthn)return xe(!0,g.inBetween(y)(t)(n)),[2]}else{if(t&&String(pe).lengthn)return xe(!0,g.greaterThan(y)(n)),[2]}if(u&&String(pe).length!==u)return xe(!0,g.lengthEqual(y)(u)),[2]}if(r===b[1]){if(!m.default[r](pe,null,null))return xe(!0,g.invalid(y)),[2];if(t||n)if(t&&n){if(!m.default[r](pe,t,n))return xe(!0,g.inBetween(y)(t)(n)),[2]}else{if(t&&!m.default[r](pe,t))return xe(!0,g.lessThan(y)(t)),[2];if(n&&!m.default[r](pe,0,n))return xe(!0,g.greaterThan(y)(n)),[2]}if(u&&String(pe).length!==u)return xe(!0,g.lengthEqual(y)(u)),[2]}if(c&&""!==c&&pe!==c)return xe(!0,g.twoInputsNotEqual()),[2]}return _&&"function"==typeof _?[4,_(pe)]:[3,2];case 1:if("object"==typeof(S=i.sent()))return"boolean"==typeof S.error&&"string"==typeof S.message&&(!1===S.error&&!0===S.showOnSuccess&&ve(S.message),xe(S.error,S.message,!0)),[2];if(!0!==S)return xe(!0,S,!0),[2];i.label=2;case 2:return f&&ve(f),xe(!1,f),[3,4];case 3:console.error("The valid "+p.default.toCamelCase(E)(!0)+' "type" options in validationOption are ['+b.map((function(e){return e}))+"]"),i.label=4;case 4:return[3,6];case 5:console.error('Please provide "type" in validationOption'),i.label=6;case 6:return[2]}}))}))}),[pe,Ee]),xe=d((function(e,t,n){void 0===n&&(n=!1);var r=t,o=Ee.msgOnError;e&&o&&!n&&(r=o),se(e),de(r),ie&&ie(e)}),[Ee.msgOnError]);c((function(){L&&Ce()}),[L]),c((function(){he(String(T))}),[T]),c((function(){void 0!==ge&&ge!==pe&&Ee.customFunc&&re&&Ce()}),[pe]),c((function(){be&&be.message&&(be.showOnError&&xe(be.error,be.message),!be.error&&be.showOnSuccess&&ve(be.message))}),[H]);var Me,Le=P+" "+g.default[E+"__wrapper"]+" "+(ue&&g.default.error)+" "+(""!==_e&&!ue&&g.default.success)+" "+(x&&g.default.disabled),Ae=D+" "+g.default[E+"__container"]+" "+(ue&&g.default.error)+" "+(""!==_e&&!ue&&g.default.success)+" "+(x&&g.default.disabled),ke=k+" "+g.default[E+"__input"]+" "+(ue&&g.default.error)+" "+(""!==_e&&!ue&&g.default.success)+" "+(x&&g.default.disabled),Re=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(ue&&g.default.error),Pe=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(!ue&&g.default.success),Fe=Ee.showMsg;return Fe&&ue&&ce&&(Me=s.createElement("div",{className:Re},ce)),Fe&&!ue&&""!==_e&&(Me=s.createElement("div",{className:Pe},_e)),s.createElement("div",r({className:Le,style:B},w),s.createElement("div",{className:Ae,style:W},s.createElement("input",r({type:"text",value:pe,disabled:x,onBlur:we,onKeyUp:Ne,onFocus:Oe,onClick:Ie,className:ke,onChange:Te,style:q,ref:ye},I))),Me)}))},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n0&&o[o.length-1])||6!==i[0]&&2!==i[0])){a=0;continue}if(3===i[0]&&(!o||i[1]>o[0]&&i[1]Number(O.maxLength)||(pe(t),K&&K(t,e),ae?ue(!1):_e(""))}}),[ae]),Te=d((function(){return o(void 0,void 0,void 0,(function(){var e,t,n,r,o,a,u,s,l,c,d,f,_,g,y;return i(this,(function(i){switch(i.label){case 0:if(e=ge.reg,t=ge.min,n=ge.max,r=ge.type,o=ge.name,a=ge.check,u=ge.length,s=ge.regMsg,l=ge.locale,c=ge.required,d=ge.msgOnSuccess,f=ge.customFunc,!a)return[2];if(!r)return[3,5];if(-1===b.indexOf(r))return[3,3];if(!v.default[l]||!v.default[l][E])return console.error(h.REACT_INPUTS_VALIDATION_CUSTOM_ERROR_MESSAGE_EXAMPLE),[2];if(_=v.default[l][E],g=o||"",c&&m.default.empty(me))return Ce(!0,_.empty(g)),[2];if(""!==String(me)){if(e&&m.default.reg(e,me))return Ce(!0,""!==s?s:_.invalid(g)),[2];if(t||n)if(t&&n){if(String(me).lengthn)return Ce(!0,_.inBetween(g)(t)(n)),[2]}else{if(t&&String(me).lengthn)return Ce(!0,_.greaterThan(g)(n)),[2]}if(u&&String(me).length!==u)return Ce(!0,_.lengthEqual(g)(u)),[2]}return f&&"function"==typeof f?[4,f(me)]:[3,2];case 1:if("object"==typeof(y=i.sent()))return"boolean"==typeof y.error&&"string"==typeof y.message&&(!1===y.error&&!0===y.showOnSuccess&&_e(y.message),Ce(y.error,y.message,!0)),[2];if(!0!==y)return Ce(!0,y,!0),[2];i.label=2;case 2:return d&&_e(d),Ce(!1,d),[3,4];case 3:console.error("The valid "+p.default.toCamelCase(E)(!0)+' "type" options in validationOption are ['+b.map((function(e){return e}))+"]"),i.label=4;case 4:return[3,6];case 5:console.error('Please provide "type" in validationOption'),i.label=6;case 6:return[2]}}))}))}),[me,ge]),Ce=d((function(e,t,n){void 0===n&&(n=!1);var r=t,o=ge.msgOnError;e&&o&&!n&&(r=o),ue(e),ce(r),oe&&oe(e)}),[ge.msgOnError]);c((function(){M&&Te()}),[M]),c((function(){pe(String(N))}),[N]),c((function(){void 0!==he&&he!==me&&ge.customFunc&&ne&&Te()}),[me]),c((function(){Ee&&Ee.message&&(Ee.showOnError&&Ce(Ee.error,Ee.message),!Ee.error&&Ee.showOnSuccess&&_e(Ee.message))}),[X]);var xe,Me=R+" "+g.default[E+"__wrapper"]+" "+(ae&&g.default.error)+" "+(""!==fe&&!ae&&g.default.success)+" "+(C&&g.default.disabled),Le=F+" "+g.default[E+"__container"]+" "+(ae&&g.default.error)+" "+(""!==fe&&!ae&&g.default.success)+" "+(C&&g.default.disabled),Ae=A+" "+g.default[E+"__input"]+" "+(ae&&g.default.error)+" "+(""!==fe&&!ae&&g.default.success)+" "+(C&&g.default.disabled),ke=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(ae&&g.default.error),Re=h.MSG_CLASS_IDENTITIFIER+" "+g.default.msg+" "+(!ae&&g.default.success),Pe=ge.showMsg;return Pe&&ae&&le&&(xe=s.createElement("div",{className:ke},le)),Pe&&!ae&&""!==fe&&(xe=s.createElement("div",{className:Re},fe)),s.createElement("div",r({className:Me,style:U},S),s.createElement("div",{className:Le,style:V},s.createElement("textarea",r({value:me,disabled:C,onBlur:Se,onKeyUp:Ie,onFocus:we,onClick:Oe,className:Ae,onChange:Ne,style:j,ref:be},O))),xe)}))},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n=a){var u=Math.abs(i-a-o);u>=0&&!y?(rt.current.scrollTop=r+o-u,y=!0):rt.current.scrollTop=r+o}}"up"===e&&(y=!1,S*o<=r&&(rt.current.scrollTop=S*o))}else y=!1,rt.current.scrollTop=S*o}}),[]),gt=c((function(e,t){dt(e,t),Pe[1]("")}),[]),Et=c((function(e){S=e,St()}),[]),bt=c((function(){Ge(!1)}),[]),yt=c((function(){wt()}),[]),St=c((function(){if(Ye&&Ye.current&&Ye.current.children){var e=Ye.current.children;if(wt(),null===S)return;S>=e.length&&(S=0),S<0&&(S=e.length-1),e[S]&&(e[S].className+=" "+h.default[g+"__hover-active"])}}),[]),wt=c((function(){if(Ye&&Ye.current&&Ye.current.children)for(var e=Ye.current.children,t=0;tit.length-1&&(S=0,ht("up")),St();else if(38===e)(S-=1)<0&&(S=it.length-1,ht("loop")),St();else if(13===e&&S>-1&&Ye&&Ye.current&&Ye.current.children){var t=Ye.current.children;if(!t[S])return;t[S].click()}}),[it]),Nt=c((function(e){if(!F&&(Ge(!0),e.preventDefault&&e.preventDefault(),qe)){S=null===S?t.getIndex(it,String(M)):S;var n=e.keyCode,r=Ot(n);if(-1!==E.indexOf(n))It(n);else{pt();var i=o(Xe,[n]),a=String.fromCharCode.apply(String,i).toLowerCase(),u=-1;it.forEach((function(e,t){e.name.toLowerCase().startsWith(a)&&-1===u&&(u=t)})),-1!==u&&(S=u,St()),He(i)}return ht(r),S}}),[qe,M,Xe]);l((function(){return qe&&nt&&document.addEventListener("keydown",Nt),function(){document.removeEventListener("keydown",Nt)}}),[qe,M,Xe]),l((function(){R&&ft()}),[R]),l((function(){t.isValidValue(it,ke)&&""!==ke&&"null"!==ke&&"undefined"!==ke?Ie(!1):Le("")}),[ke]),l((function(){Re(String(M))}),[M]),l((function(){De&&De&&!p.default.arraysEqual(De,U)&&Re(String(U[0].id))}),[U]),l((function(){void 0!==Fe&&Fe!==ke&&ft()}),[Fe,ke]),l((function(){Je&&Je.message&&(Je.showOnError&&_t(Je.error,Je.message),!Je.error&&Je.showOnSuccess&&Le(Je.message))}),[fe]),l((function(){qe&&(F&&et.current.focus(),S=null===S?t.getIndex(it,String(M)):S,ot[S]&&ot[S].current.focus()),!0===Be&&!1===qe&&tt.current.focus(),mt()}),[qe]);var Tt,Ct,xt=m.WRAPPER_CLASS_IDENTITIFIER+" "+V+" "+h.default.select__wrapper+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Mt=m.CONTAINER_CLASS_IDENTITIFIER+" "+G+" "+h.default.select__container+" "+(Oe&&h.default.error)+" "+(qe&&h.default.show)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Lt=h.default.select__input+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),At=X+" "+h.default.ellipsis+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),kt=Z+" "+h.default[g+"__options-container"]+" "+(Oe&&h.default.error)+" "+(qe&&h.default.show)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Rt=h.default.button+" "+(!We&&h.default[g+"__options-item-show-cursor"])+" "+K+" "+h.default[g+"__options-item"]+" "+(Oe&&h.default.error)+" "+(""!==Me&&!Oe&&h.default.success)+" "+(A&&h.default.disabled),Pt=Y+" "+h.default[g+"__dropdown-icon"],Ft=m.MSG_CLASS_IDENTITIFIER+" "+h.default.msg+" "+(Oe&&h.default.error),Dt=m.MSG_CLASS_IDENTITIFIER+" "+h.default.msg+" "+(!Oe&&h.default.success),jt=Ke.showMsg;jt&&Oe&&Te&&(Tt=u.createElement("div",{className:Ft},Te)),jt&&!Oe&&""!==Me&&(Tt=u.createElement("div",{className:Dt},Me));var qt=t.getItem(U,String(M));it.length?Ct=it.map((function(e,n){return u.createElement(t.Option,{key:n,index:n,id:"react-inputs-validation__select_option-"+e.id,className:String(e.id)===String(M)?Rt+" "+h.default.active:""+Rt,item:e,customStyleOptionListItem:ae,onClick:gt,onMouseOver:Et,onMouseMove:bt,onMouseOut:yt})})):F&&(Ct=u.createElement("div",{style:{background:"#fff",textAlign:"center",padding:"20px"}},u.createElement("svg",{xmlns:"http://www.w3.org/2000/svg",width:"24",height:"24",viewBox:"0 0 24 24"},u.createElement("path",{d:"M0 0h24v24H0z",fill:"none"}),u.createElement("path",{fill:"#cdcdcd",d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zM4 12c0-4.42 3.58-8 8-8 1.85 0 3.55.63 4.9 1.69L5.69 16.9C4.63 15.55 4 13.85 4 12zm8 8c-1.85 0-3.55-.63-4.9-1.69L18.31 7.1C19.37 8.45 20 10.15 20 12c0 4.42-3.58 8-8 8z"}))));var Ut=u.createElement("div",{className:h.default.select__dropdown},u.createElement("div",{className:h.default[g+"__dropdown-name"]+" "+h.default.ellipsis},qt?qt.name:""),u.createElement("div",{className:Pt}));return u.createElement("button",r({ref:Ze,type:"button",className:h.default.button,onClick:function(e){if(ct(e),!A){if($e.current&&$e.current.contains(e.target))return void Ue(!0);Ue(!qe)}},onFocus:lt,onBlur:st},N),u.createElement("div",{ref:Qe,className:xt,style:ee},u.createElement("div",{className:Mt,style:ne},u.createElement("input",r({type:"hidden",value:ke,className:Lt,onChange:function(){}},C)),u.createElement("div",{className:At,style:oe},Ut),u.createElement("div",{className:kt},F&&u.createElement("div",{ref:$e},u.createElement("div",{className:h.default.select__searchInputWrapper},u.createElement("svg",{className:h.default.select__searchInputSearchIcon,xmlns:"http://www.w3.org/2000/svg",width:"20",height:"20",viewBox:"0 0 24 24"},u.createElement("path",{fill:"#cdcdcd",d:"M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z"}),u.createElement("path",{d:"M0 0h24v24H0z",fill:"none"})),u.createElement("input",{className:h.default.select__searchInput,ref:et,value:Pe[0],onChange:at,onKeyDown:ut}),Pe[0]&&u.createElement("svg",{className:h.default.select__searchInputRemoveIcon,xmlns:"http://www.w3.org/2000/svg",width:"15",height:"15",viewBox:"0 0 24 24",onClick:function(){Pe[1](""),et.current.focus()}},u.createElement("path",{fill:"#cdcdcd",d:"M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7 12 10.59 15.59 7 17 8.41 13.41 12 17 15.59z"}),u.createElement("path",{d:"M0 0h24v24H0z",fill:"none"})))),u.createElement("div",{ref:Ye,style:se},Ct))),Tt))}))},function(e,t,n){"use strict";var r=this&&this.__assign||function(){return(r=Object.assign||function(e){for(var t,n=1,r=arguments.length;n = ({ setErr(err); setMsg(msg); validationCallback && validationCallback(err); - }, []); + }, [option.msgOnError]); useEffect( () => { if (validate) { diff --git a/src/js/Inputs/Radiobox.tsx b/src/js/Inputs/Radiobox.tsx index e6ef30b..230bba1 100644 --- a/src/js/Inputs/Radiobox.tsx +++ b/src/js/Inputs/Radiobox.tsx @@ -184,7 +184,7 @@ const component: React.FC = ({ setErr(err); setMsg(msg); validationCallback && validationCallback(err); - }, []); + }, [option.msgOnError]); useEffect( () => { if (validate) { diff --git a/src/js/Inputs/Select.tsx b/src/js/Inputs/Select.tsx index fcf7cc6..52275b2 100644 --- a/src/js/Inputs/Select.tsx +++ b/src/js/Inputs/Select.tsx @@ -282,7 +282,7 @@ const component: React.FC = ({ setErr(err); setMsg(msg); validationCallback && validationCallback(err); - }, []); + }, [option.msgOnError]); /* istanbul ignore next because of https://github.com/airbnb/enzyme/issues/441 && https://github.com/airbnb/enzyme/blob/master/docs/future.md */ useEffect(() => { if (typeof window !== 'undefined') { diff --git a/src/js/Inputs/Textarea.tsx b/src/js/Inputs/Textarea.tsx index 60842d0..6c847c1 100644 --- a/src/js/Inputs/Textarea.tsx +++ b/src/js/Inputs/Textarea.tsx @@ -280,7 +280,7 @@ const component: React.FC = ({ setErr(err); setMsg(msg); validationCallback && validationCallback(err); - }, []); + }, [option.msgOnError]); useEffect( () => { if (validate) { diff --git a/src/js/Inputs/Textbox.tsx b/src/js/Inputs/Textbox.tsx index a4a1bdc..db21898 100644 --- a/src/js/Inputs/Textbox.tsx +++ b/src/js/Inputs/Textbox.tsx @@ -386,7 +386,7 @@ const component: React.FC = ({ setErr(err); setMsg(msg); validationCallback && validationCallback(err); - }, []); + }, [option.msgOnError]); useEffect( () => { if (validate) {