react-hook-form 7.71.2 → 7.72.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/__tests__/useFieldArray/dirtyFields.test.d.ts +2 -0
- package/dist/__tests__/useFieldArray/dirtyFields.test.d.ts.map +1 -0
- package/dist/constants.d.ts +5 -0
- package/dist/constants.d.ts.map +1 -1
- package/dist/index.cjs.js +1 -1
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.esm.mjs +158 -59
- package/dist/index.esm.mjs.map +1 -1
- package/dist/index.umd.js +1 -1
- package/dist/index.umd.js.map +1 -1
- package/dist/logic/createFormControl.d.ts.map +1 -1
- package/dist/logic/isNameInFieldArray.d.ts.map +1 -1
- package/dist/logic/updateFieldArrayRootError.d.ts.map +1 -1
- package/dist/react-server.esm.mjs +123 -24
- package/dist/react-server.esm.mjs.map +1 -1
- package/dist/types/errors.d.ts +1 -0
- package/dist/types/errors.d.ts.map +1 -1
- package/dist/types/form.d.ts +7 -3
- package/dist/types/form.d.ts.map +1 -1
- package/dist/types/validator.d.ts +13 -1
- package/dist/types/validator.d.ts.map +1 -1
- package/dist/useFormContext.d.ts.map +1 -1
- package/package.json +21 -21
package/dist/index.umd.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("react")):"function"==typeof define&&define.amd?define(["exports","react"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).ReactHookForm={},e.React)}(this,function(e,t){"use strict";var r=e=>"checkbox"===e.type,s=e=>e instanceof Date,a=e=>null==e;const i=e=>"object"==typeof e;var n=e=>!a(e)&&!Array.isArray(e)&&i(e)&&!s(e),o=e=>n(e)&&e.target?r(e.target)?e.target.checked:e.target.value:e,l=(e,t)=>e.has((e=>e.substring(0,e.search(/\.\d+(\.|$)/))||e)(t)),u="undefined"!=typeof window&&void 0!==window.HTMLElement&&"undefined"!=typeof document;function d(e){if(e instanceof Date)return new Date(e);const t="undefined"!=typeof FileList&&e instanceof FileList;if(u&&(e instanceof Blob||t))return e;const r=Array.isArray(e);if(!(r||n(e)&&(e=>{const t=e.constructor&&e.constructor.prototype;return n(t)&&t.hasOwnProperty("isPrototypeOf")})(e)))return e;const s=r?[]:Object.create(Object.getPrototypeOf(e));for(const t in e)Object.prototype.hasOwnProperty.call(e,t)&&(s[t]=d(e[t]));return s}var c=e=>/^\w*$/.test(e),f=e=>void 0===e,m=e=>Array.isArray(e)?e.filter(Boolean):[],y=e=>m(e.replace(/["|']|\]/g,"").split(/\.|\[/)),g=(e,t,r)=>{if(!t||!n(e))return r;const s=(c(t)?[t]:y(t)).reduce((e,t)=>a(e)?e:e[t],e);return f(s)||s===e?f(e[t])?r:e[t]:s},b=e=>"boolean"==typeof e,_=e=>"function"==typeof e,p=(e,t,r)=>{let s=-1;const a=c(t)?[t]:y(t),i=a.length,o=i-1;for(;++s<i;){const t=a[s];let i=r;if(s!==o){const r=e[t];i=n(r)||Array.isArray(r)?r:isNaN(+a[s+1])?{}:[]}if("__proto__"===t||"constructor"===t||"prototype"===t)return;e[t]=i,e=e[t]}};const h="blur",v="onChange",V="onSubmit",F="all",x="pattern",A="required",S=t.createContext(null);S.displayName="HookFormControlContext";const k=()=>t.useContext(S);var w=(e,t,r,s=!0)=>{const a={defaultValues:t._defaultValues};for(const i in e)Object.defineProperty(a,i,{get:()=>{const a=i;return t._proxyFormState[a]!==F&&(t._proxyFormState[a]=!s||F),r&&(r[a]=!0),e[a]}});return a};const D="undefined"!=typeof window?t.useLayoutEffect:t.useEffect;function C(e){const r=k(),{control:s=r,disabled:a,name:i,exact:n}=e||{},[o,l]=t.useState(s._formState),u=t.useRef({isDirty:!1,isLoading:!1,dirtyFields:!1,touchedFields:!1,validatingFields:!1,isValidating:!1,isValid:!1,errors:!1});return D(()=>s._subscribe({name:i,formState:u.current,exact:n,callback:e=>{!a&&l({...s._formState,...e})}}),[i,a,n]),t.useEffect(()=>{u.current.isValid&&s._setValid(!0)},[s]),t.useMemo(()=>w(o,s,u.current,!1),[o,s])}var E=e=>"string"==typeof e,O=(e,t,r,s,a)=>E(e)?(s&&t.watch.add(e),g(r,e,a)):Array.isArray(e)?e.map(e=>(s&&t.watch.add(e),g(r,e))):(s&&(t.watchAll=!0),r),j=e=>a(e)||!i(e);function M(e,t,r=new WeakSet){if(j(e)||j(t))return Object.is(e,t);if(s(e)&&s(t))return Object.is(e.getTime(),t.getTime());const a=Object.keys(e),i=Object.keys(t);if(a.length!==i.length)return!1;if(r.has(e)||r.has(t))return!0;r.add(e),r.add(t);for(const o of a){const a=e[o];if(!i.includes(o))return!1;if("ref"!==o){const e=t[o];if(s(a)&&s(e)||n(a)&&n(e)||Array.isArray(a)&&Array.isArray(e)?!M(a,e,r):!Object.is(a,e))return!1}}return!0}function T(e){const r=k(),{control:s=r,name:a,defaultValue:i,disabled:n,exact:o,compute:l}=e||{},u=t.useRef(i),d=t.useRef(l),c=t.useRef(void 0),f=t.useRef(s),m=t.useRef(a);d.current=l;const[y,g]=t.useState(()=>{const e=s._getWatch(a,u.current);return d.current?d.current(e):e}),b=t.useCallback(e=>{const t=O(a,s._names,e||s._formValues,!1,u.current);return d.current?d.current(t):t},[s._formValues,s._names,a]),_=t.useCallback(e=>{if(!n){const t=O(a,s._names,e||s._formValues,!1,u.current);if(d.current){const e=d.current(t);M(e,c.current)||(g(e),c.current=e)}else g(t)}},[s._formValues,s._names,n,a]);D(()=>(f.current===s&&M(m.current,a)||(f.current=s,m.current=a,_()),s._subscribe({name:a,formState:{values:!0},exact:o,callback:e=>{_(e.values)}})),[s,o,a,_]),t.useEffect(()=>s._removeUnmounted());const p=f.current!==s,h=m.current,v=t.useMemo(()=>{if(n)return null;const e=!p&&!M(h,a);return p||e?b():null},[n,p,a,h,b]);return null!==v?v:y}function U(e){const r=k(),{name:s,disabled:a,control:i=r,shouldUnregister:n,defaultValue:u,exact:c=!0}=e,m=l(i._names.array,s),y=t.useMemo(()=>g(i._formValues,s,g(i._defaultValues,s,u)),[i,s,u]),v=T({control:i,name:s,defaultValue:y,exact:c}),V=C({control:i,name:s,exact:c}),F=t.useRef(e),x=t.useRef(void 0),A=t.useRef(i.register(s,{...e.rules,value:v,...b(e.disabled)?{disabled:e.disabled}:{}}));F.current=e;const S=t.useMemo(()=>Object.defineProperties({},{invalid:{enumerable:!0,get:()=>!!g(V.errors,s)},isDirty:{enumerable:!0,get:()=>!!g(V.dirtyFields,s)},isTouched:{enumerable:!0,get:()=>!!g(V.touchedFields,s)},isValidating:{enumerable:!0,get:()=>!!g(V.validatingFields,s)},error:{enumerable:!0,get:()=>g(V.errors,s)}}),[V,s]),w=t.useCallback(e=>A.current.onChange({target:{value:o(e),name:s},type:"change"}),[s]),D=t.useCallback(()=>A.current.onBlur({target:{value:g(i._formValues,s),name:s},type:h}),[s,i._formValues]),E=t.useCallback(e=>{const t=g(i._fields,s);t&&t._f&&e&&(t._f.ref={focus:()=>_(e.focus)&&e.focus(),select:()=>_(e.select)&&e.select(),setCustomValidity:t=>_(e.setCustomValidity)&&e.setCustomValidity(t),reportValidity:()=>_(e.reportValidity)&&e.reportValidity()})},[i._fields,s]),O=t.useMemo(()=>({name:s,value:v,...b(a)||V.disabled?{disabled:V.disabled||a}:{},onChange:w,onBlur:D,ref:E}),[s,a,V.disabled,w,D,E,v]);return t.useEffect(()=>{const e=i._options.shouldUnregister||n,t=x.current;t&&t!==s&&!m&&i.unregister(t),i.register(s,{...F.current.rules,...b(F.current.disabled)?{disabled:F.current.disabled}:{}});const r=(e,t)=>{const r=g(i._fields,e);r&&r._f&&(r._f.mount=t)};if(r(s,!0),e){const e=d(g(i._options.defaultValues,s,F.current.defaultValue));p(i._defaultValues,s,e),f(g(i._formValues,s))&&p(i._formValues,s,e)}return!m&&i.register(s),x.current=s,()=>{(m?e&&!i._state.action:e)?i.unregister(s):r(s,!1)}},[s,i,m,n]),t.useEffect(()=>{i._setDisabledField({disabled:a,name:s})},[a,s,i]),t.useMemo(()=>({field:O,formState:V,fieldState:S}),[O,V,S])}const R=e=>{const t={};for(const r of Object.keys(e))if(i(e[r])&&null!==e[r]){const s=R(e[r]);for(const e of Object.keys(s))t[`${r}.${e}`]=s[e]}else t[r]=e[r];return t},N=t.createContext(null);N.displayName="HookFormContext";const B=()=>t.useContext(N),L="post";var I=(e,t,r,s,a)=>t?{...r[e],types:{...r[e]&&r[e].types?r[e].types:{},[s]:a||!0}}:{},P=e=>Array.isArray(e)?e:[e],W=()=>{let e=[];return{get observers(){return e},next:t=>{for(const r of e)r.next&&r.next(t)},subscribe:t=>(e.push(t),{unsubscribe:()=>{e=e.filter(e=>e!==t)}}),unsubscribe:()=>{e=[]}}};function q(e,t){const r={};for(const s in e)if(e.hasOwnProperty(s)){const a=e[s],i=t[s];if(a&&n(a)&&i){const e=q(a,i);n(e)&&(r[s]=e)}else e[s]&&(r[s]=i)}return r}var $=e=>n(e)&&!Object.keys(e).length,H=e=>"file"===e.type,J=e=>{if(!u)return!1;const t=e?e.ownerDocument:0;return e instanceof(t&&t.defaultView?t.defaultView.HTMLElement:HTMLElement)},z=e=>"select-multiple"===e.type,G=e=>"radio"===e.type,K=e=>J(e)&&e.isConnected;function Q(e,t){const r=Array.isArray(t)?t:c(t)?[t]:y(t),s=1===r.length?e:function(e,t){const r=t.slice(0,-1).length;let s=0;for(;s<r;)e=f(e)?s++:e[t[s++]];return e}(e,r),a=r.length-1,i=r[a];return s&&delete s[i],0!==a&&(n(s)&&$(s)||Array.isArray(s)&&function(e){for(const t in e)if(e.hasOwnProperty(t)&&!f(e[t]))return!1;return!0}(s))&&Q(e,r.slice(0,-1)),e}function X(e){return Array.isArray(e)||n(e)&&!(e=>{for(const t in e)if(_(e[t]))return!0;return!1})(e)}function Y(e,t={}){for(const r in e){const s=e[r];X(s)?(t[r]=Array.isArray(s)?[]:{},Y(s,t[r])):f(s)||(t[r]=!0)}return t}function Z(e,t,r){r||(r=Y(t));for(const s in e){const i=e[s];if(X(i))f(t)||j(r[s])?r[s]=Y(i,Array.isArray(i)?[]:{}):Z(i,a(t)?{}:t[s],r[s]);else{const e=t[s];r[s]=!M(i,e)}}return r}const ee={value:!1,isValid:!1},te={value:!0,isValid:!0};var re=e=>{if(Array.isArray(e)){if(e.length>1){const t=e.filter(e=>e&&e.checked&&!e.disabled).map(e=>e.value);return{value:t,isValid:!!t.length}}return e[0].checked&&!e[0].disabled?e[0].attributes&&!f(e[0].attributes.value)?f(e[0].value)||""===e[0].value?te:{value:e[0].value,isValid:!0}:te:ee}return ee},se=(e,{valueAsNumber:t,valueAsDate:r,setValueAs:s})=>f(e)?e:t?""===e?NaN:e?+e:e:r&&E(e)?new Date(e):s?s(e):e;const ae={isValid:!1,value:null};var ie=e=>Array.isArray(e)?e.reduce((e,t)=>t&&t.checked&&!t.disabled?{isValid:!0,value:t.value}:e,ae):ae;function ne(e){const t=e.ref;return H(t)?t.files:G(t)?ie(e.refs).value:z(t)?[...t.selectedOptions].map(({value:e})=>e):r(t)?re(e.refs).value:se(f(t.value)?e.ref.value:t.value,e)}var oe=e=>e instanceof RegExp,le=e=>f(e)?e:oe(e)?e.source:n(e)?oe(e.value)?e.value.source:e.value:e,ue=e=>({isOnSubmit:!e||e===V,isOnBlur:"onBlur"===e,isOnChange:e===v,isOnAll:e===F,isOnTouch:"onTouched"===e});const de="AsyncFunction";var ce=e=>!!e&&!!e.validate&&!!(_(e.validate)&&e.validate.constructor.name===de||n(e.validate)&&Object.values(e.validate).find(e=>e.constructor.name===de)),fe=(e,t,r)=>!r&&(t.watchAll||t.watch.has(e)||[...t.watch].some(t=>e.startsWith(t)&&/^\.\w+/.test(e.slice(t.length))));const me=(e,t,r,s)=>{for(const a of r||Object.keys(e)){const r=g(e,a);if(r){const{_f:e,...i}=r;if(e){if(e.refs&&e.refs[0]&&t(e.refs[0],a)&&!s)return!0;if(e.ref&&t(e.ref,e.name)&&!s)return!0;if(me(i,t))break}else if(n(i)&&me(i,t))break}}};function ye(e,t,r){const s=g(e,r);if(s||c(r))return{error:s,name:r};const a=r.split(".");for(;a.length;){const s=a.join("."),i=g(t,s),n=g(e,s);if(i&&!Array.isArray(i)&&r!==s)return{name:r};if(n&&n.type)return{name:s,error:n};if(n&&n.root&&n.root.type)return{name:`${s}.root`,error:n.root};a.pop()}return{name:r}}var ge=(e,t,r)=>{const s=P(g(e,r));return p(s,"root",t[r]),p(e,r,s),e};function be(e,t,r="validate"){if(E(e)||Array.isArray(e)&&e.every(E)||b(e)&&!e)return{type:r,message:E(e)?e:"",ref:t}}var _e=e=>n(e)&&!oe(e)?e:{value:e,message:""},pe=async(e,t,s,i,o,l)=>{const{ref:u,refs:d,required:c,maxLength:m,minLength:y,min:p,max:h,pattern:v,validate:V,name:F,valueAsNumber:S,mount:k}=e._f,w=g(s,F);if(!k||t.has(F))return{};const D=d?d[0]:u,C=e=>{o&&D.reportValidity&&(D.setCustomValidity(b(e)?"":e||""),D.reportValidity())},O={},j=G(u),M=r(u),T=j||M,U=(S||H(u))&&f(u.value)&&f(w)||J(u)&&""===u.value||""===w||Array.isArray(w)&&!w.length,R=I.bind(null,F,i,O),N=(e,t,r,s="maxLength",a="minLength")=>{const i=e?t:r;O[F]={type:e?s:a,message:i,ref:u,...R(e?s:a,i)}};if(l?!Array.isArray(w)||!w.length:c&&(!T&&(U||a(w))||b(w)&&!w||M&&!re(d).isValid||j&&!ie(d).isValid)){const{value:e,message:t}=E(c)?{value:!!c,message:c}:_e(c);if(e&&(O[F]={type:A,message:t,ref:D,...R(A,t)},!i))return C(t),O}if(!(U||a(p)&&a(h))){let e,t;const r=_e(h),s=_e(p);if(a(w)||isNaN(w)){const a=u.valueAsDate||new Date(w),i=e=>new Date((new Date).toDateString()+" "+e),n="time"==u.type,o="week"==u.type;E(r.value)&&w&&(e=n?i(w)>i(r.value):o?w>r.value:a>new Date(r.value)),E(s.value)&&w&&(t=n?i(w)<i(s.value):o?w<s.value:a<new Date(s.value))}else{const i=u.valueAsNumber||(w?+w:w);a(r.value)||(e=i>r.value),a(s.value)||(t=i<s.value)}if((e||t)&&(N(!!e,r.message,s.message,"max","min"),!i))return C(O[F].message),O}if((m||y)&&!U&&(E(w)||l&&Array.isArray(w))){const e=_e(m),t=_e(y),r=!a(e.value)&&w.length>+e.value,s=!a(t.value)&&w.length<+t.value;if((r||s)&&(N(r,e.message,t.message),!i))return C(O[F].message),O}if(v&&!U&&E(w)){const{value:e,message:t}=_e(v);if(oe(e)&&!w.match(e)&&(O[F]={type:x,message:t,ref:u,...R(x,t)},!i))return C(t),O}if(V)if(_(V)){const e=be(await V(w,s),D);if(e&&(O[F]={...e,...R("validate",e.message)},!i))return C(e.message),O}else if(n(V)){let e={};for(const t in V){if(!$(e)&&!i)break;const r=be(await V[t](w,s),D,t);r&&(e={...r,...R(t,r.message)},C(r.message),i&&(O[F]=e))}if(!$(e)&&(O[F]={ref:D,...e},!i))return O}return C(!0),O};const he={mode:V,reValidateMode:v,shouldFocusError:!0};function ve(e={}){let t,i={...he,...e},c={submitCount:0,isDirty:!1,isReady:!1,isLoading:_(i.defaultValues),isValidating:!1,isSubmitted:!1,isSubmitting:!1,isSubmitSuccessful:!1,isValid:!1,touchedFields:{},dirtyFields:{},validatingFields:{},errors:i.errors||{},disabled:i.disabled||!1},y={},v=(n(i.defaultValues)||n(i.values))&&d(i.defaultValues||i.values)||{},V=i.shouldUnregister?{}:d(v),x={action:!1,mount:!1,watch:!1,keepIsValid:!1},A={mount:new Set,disabled:new Set,unMount:new Set,array:new Set,watch:new Set},S=0;const k={isDirty:!1,dirtyFields:!1,validatingFields:!1,touchedFields:!1,isValidating:!1,isValid:!1,errors:!1},w={...k};let D={...w};const C={array:W(),state:W()},j=i.criteriaMode===F,T=async e=>{if(!x.keepIsValid&&!i.disabled&&(w.isValid||D.isValid||e)){let e;i.resolver?(e=$((await B()).errors),U()):e=await L(y,!0),e!==c.isValid&&C.state.next({isValid:e})}},U=(e,t)=>{!i.disabled&&(w.isValidating||w.validatingFields||D.isValidating||D.validatingFields)&&((e||Array.from(A.mount)).forEach(e=>{e&&(t?p(c.validatingFields,e,t):Q(c.validatingFields,e))}),C.state.next({validatingFields:c.validatingFields,isValidating:!$(c.validatingFields)}))},R=(e,t,r,s)=>{const a=g(y,e);if(a){const i=g(V,e,f(r)?g(v,e):r);f(i)||s&&s.defaultChecked||t?p(V,e,t?i:ne(a._f)):Y(e,i),x.mount&&!x.action&&T()}},N=(e,t,r,s,a)=>{let n=!1,o=!1;const l={name:e};if(!i.disabled){if(!r||s){(w.isDirty||D.isDirty)&&(o=c.isDirty,c.isDirty=l.isDirty=I(),n=o!==l.isDirty);const r=M(g(v,e),t);o=!!g(c.dirtyFields,e),r?Q(c.dirtyFields,e):p(c.dirtyFields,e,!0),l.dirtyFields=c.dirtyFields,n=n||(w.dirtyFields||D.dirtyFields)&&o!==!r}if(r){const t=g(c.touchedFields,e);t||(p(c.touchedFields,e,r),l.touchedFields=c.touchedFields,n=n||(w.touchedFields||D.touchedFields)&&t!==r)}n&&a&&C.state.next(l)}return n?l:{}},B=async e=>{U(e,!0);const t=await i.resolver(V,i.context,((e,t,r,s)=>{const a={};for(const r of e){const e=g(t,r);e&&p(a,r,e._f)}return{criteriaMode:r,names:[...e],fields:a,shouldUseNativeValidation:s}})(e||A.mount,y,i.criteriaMode,i.shouldUseNativeValidation));return t},L=async(t,r,s={valid:!0})=>{for(const a in t){const n=t[a];if(n){const{_f:t,...a}=n;if(t){const a=A.array.has(t.name),o=n._f&&ce(n._f);o&&w.validatingFields&&U([t.name],!0);const l=await pe(n,A.disabled,V,j,i.shouldUseNativeValidation&&!r,a);if(o&&w.validatingFields&&U([t.name]),l[t.name]&&(s.valid=!1,r||e.shouldUseNativeValidation))break;!r&&(g(l,t.name)?a?ge(c.errors,l,t.name):p(c.errors,t.name,l[t.name]):Q(c.errors,t.name))}!$(a)&&await L(a,r,s)}}return s.valid},I=(e,t)=>!i.disabled&&(e&&t&&p(V,e,t),!M(oe(),v)),X=(e,t,r)=>O(e,A,{...x.mount?V:f(t)?v:E(e)?{[e]:t}:t},r,t),Y=(e,t,s={})=>{const i=g(y,e);let n=t;if(i){const s=i._f;s&&(!s.disabled&&p(V,e,se(t,s)),n=J(s.ref)&&a(t)?"":t,z(s.ref)?[...s.ref.options].forEach(e=>e.selected=n.includes(e.value)):s.refs?r(s.ref)?s.refs.forEach(e=>{e.defaultChecked&&e.disabled||(Array.isArray(n)?e.checked=!!n.find(t=>t===e.value):e.checked=n===e.value||!!n)}):s.refs.forEach(e=>e.checked=e.value===n):H(s.ref)?s.ref.value="":(s.ref.value=n,s.ref.type||C.state.next({name:e,values:d(V)})))}(s.shouldDirty||s.shouldTouch)&&N(e,n,s.shouldTouch,s.shouldDirty,!0),s.shouldValidate&&ie(e)},ee=(e,t,r)=>{for(const a in t){if(!t.hasOwnProperty(a))return;const i=t[a],o=e+"."+a,l=g(y,o);(A.array.has(e)||n(i)||l&&!l._f)&&!s(i)?ee(o,i,r):Y(o,i,r)}},te=(e,t,r={})=>{const s=g(y,e),i=A.array.has(e),n=d(t);p(V,e,n),i?(C.array.next({name:e,values:d(V)}),(w.isDirty||w.dirtyFields||D.isDirty||D.dirtyFields)&&r.shouldDirty&&C.state.next({name:e,dirtyFields:Z(v,V),isDirty:I(e,n)})):!s||s._f||a(n)?Y(e,n,r):ee(e,n,r),fe(e,A)?C.state.next({...c,name:e,values:d(V)}):C.state.next({name:x.mount?e:void 0,values:d(V)})},re=async e=>{x.mount=!0;const r=e.target;let a=r.name,n=!0;const l=g(y,a),u=e=>{n=Number.isNaN(e)||s(e)&&isNaN(e.getTime())||M(e,g(V,a,e))},f=ue(i.mode),m=ue(i.reValidateMode);if(l){let s,v;const F=r.type?ne(l._f):o(e),x=e.type===h||"focusout"===e.type,k=!((_=l._f).mount&&(_.required||_.min||_.max||_.maxLength||_.minLength||_.pattern||_.validate)||i.resolver||g(c.errors,a)||l._f.deps)||((e,t,r,s,a)=>!a.isOnAll&&(!r&&a.isOnTouch?!(t||e):(r?s.isOnBlur:a.isOnBlur)?!e:!(r?s.isOnChange:a.isOnChange)||e))(x,g(c.touchedFields,a),c.isSubmitted,m,f),E=fe(a,A,x);p(V,a,F),x?r&&r.readOnly||(l._f.onBlur&&l._f.onBlur(e),t&&t(0)):l._f.onChange&&l._f.onChange(e);const O=N(a,F,x),R=!$(O)||E;if(!x&&C.state.next({name:a,type:e.type,values:d(V)}),k)return(w.isValid||D.isValid)&&("onBlur"===i.mode?x&&T():x||T()),R&&C.state.next({name:a,...E?{}:O});if(!x&&E&&C.state.next({...c}),i.resolver){const{errors:e}=await B([a]);if(U([a]),u(F),n){const t=ye(c.errors,y,a),r=ye(e,y,t.name||a);s=r.error,a=r.name,v=$(e)}}else U([a],!0),s=(await pe(l,A.disabled,V,j,i.shouldUseNativeValidation))[a],U([a]),u(F),n&&(s?v=!1:(w.isValid||D.isValid)&&(v=await L(y,!0)));n&&(l._f.deps&&(!Array.isArray(l._f.deps)||l._f.deps.length>0)&&ie(l._f.deps),((e,r,s,a)=>{const n=g(c.errors,e),o=(w.isValid||D.isValid)&&b(r)&&c.isValid!==r;var l;if(i.delayError&&s?(l=()=>((e,t)=>{p(c.errors,e,t),C.state.next({errors:c.errors})})(e,s),t=e=>{clearTimeout(S),S=setTimeout(l,e)},t(i.delayError)):(clearTimeout(S),t=null,s?p(c.errors,e,s):Q(c.errors,e)),(s?!M(n,s):n)||!$(a)||o){const t={...a,...o&&b(r)?{isValid:r}:{},errors:c.errors,name:e};c={...c,...t},C.state.next(t)}})(a,v,s,O))}var _},ae=(e,t)=>{if(g(c.errors,t)&&e.focus)return e.focus(),1},ie=async(e,t={})=>{let r,s;const a=P(e);if(i.resolver){const t=await(async e=>{const{errors:t}=await B(e);if(U(e),e)for(const r of e){const e=g(t,r);e?p(c.errors,r,e):Q(c.errors,r)}else c.errors=t;return t})(f(e)?e:a);r=$(t),s=e?!a.some(e=>g(t,e)):r}else e?(s=(await Promise.all(a.map(async e=>{const t=g(y,e);return await L(t&&t._f?{[e]:t}:t)}))).every(Boolean),(s||c.isValid)&&T()):s=r=await L(y);return C.state.next({...!E(e)||(w.isValid||D.isValid)&&r!==c.isValid?{}:{name:e},...i.resolver||!e?{isValid:r}:{},errors:c.errors}),t.shouldFocus&&!s&&me(y,ae,e?a:A.mount),s},oe=(e,t)=>{let r={...x.mount?V:v};return t&&(r=q(t.dirtyFields?c.dirtyFields:c.touchedFields,r)),f(e)?r:E(e)?g(r,e):e.map(e=>g(r,e))},de=(e,t)=>({invalid:!!g((t||c).errors,e),isDirty:!!g((t||c).dirtyFields,e),error:g((t||c).errors,e),isValidating:!!g(c.validatingFields,e),isTouched:!!g((t||c).touchedFields,e)}),be=(e,t,r)=>{const s=(g(y,e,{_f:{}})._f||{}).ref,a=g(c.errors,e)||{},{ref:i,message:n,type:o,...l}=a;p(c.errors,e,{...l,...t,ref:s}),C.state.next({name:e,errors:c.errors,isValid:!1}),r&&r.shouldFocus&&s&&s.focus&&s.focus()},_e=e=>C.state.subscribe({next:t=>{var r,s,a;r=e.name,s=t.name,a=e.exact,r&&s&&r!==s&&!P(r).some(e=>e&&(a?e===s:e.startsWith(s)||s.startsWith(e)))||!((e,t,r,s)=>{r(e);const{name:a,...i}=e;return $(i)||Object.keys(i).length>=Object.keys(t).length||Object.keys(i).find(e=>t[e]===(!s||F))})(t,e.formState||w,we,e.reRenderRoot)||e.callback({values:{...V},...c,...t,defaultValues:v})}}).unsubscribe,ve=(e,t={})=>{for(const r of e?P(e):A.mount)A.mount.delete(r),A.array.delete(r),t.keepValue||(Q(y,r),Q(V,r)),!t.keepError&&Q(c.errors,r),!t.keepDirty&&Q(c.dirtyFields,r),!t.keepTouched&&Q(c.touchedFields,r),!t.keepIsValidating&&Q(c.validatingFields,r),!i.shouldUnregister&&!t.keepDefaultValue&&Q(v,r);C.state.next({values:d(V)}),C.state.next({...c,...t.keepDirty?{isDirty:I()}:{}}),!t.keepIsValid&&T()},Ve=({disabled:e,name:t})=>{if(b(e)&&x.mount||e||A.disabled.has(t)){const r=A.disabled.has(t)!==!!e;e?A.disabled.add(t):A.disabled.delete(t),r&&x.mount&&!x.action&&T()}},Fe=(e,t={})=>{let s=g(y,e);const a=b(t.disabled)||b(i.disabled);return p(y,e,{...s||{},_f:{...s&&s._f?s._f:{ref:{name:e}},name:e,mount:!0,...t}}),A.mount.add(e),s?Ve({disabled:b(t.disabled)?t.disabled:i.disabled,name:e}):R(e,!0,t.value),{...a?{disabled:t.disabled||i.disabled}:{},...i.progressive?{required:!!t.required,min:le(t.min),max:le(t.max),minLength:le(t.minLength),maxLength:le(t.maxLength),pattern:le(t.pattern)}:{},name:e,onChange:re,onBlur:re,ref:a=>{if(a){Fe(e,t),s=g(y,e);const i=f(a.value)&&a.querySelectorAll&&a.querySelectorAll("input,select,textarea")[0]||a,n=(e=>G(e)||r(e))(i),o=s._f.refs||[];if(n?o.find(e=>e===i):i===s._f.ref)return;p(y,e,{_f:{...s._f,...n?{refs:[...o.filter(K),i,...Array.isArray(g(v,e))?[{}]:[]],ref:{type:i.type,name:e}}:{ref:i}}}),R(e,!1,void 0,i)}else s=g(y,e,{}),s._f&&(s._f.mount=!1),(i.shouldUnregister||t.shouldUnregister)&&(!l(A.array,e)||!x.action)&&A.unMount.add(e)}}},xe=()=>i.shouldFocusError&&me(y,ae,A.mount),Ae=(e,t)=>async r=>{let s;r&&(r.preventDefault&&r.preventDefault(),r.persist&&r.persist());let a=d(V);if(C.state.next({isSubmitting:!0}),i.resolver){const{errors:e,values:t}=await B();U(),c.errors=e,a=d(t)}else await L(y);if(A.disabled.size)for(const e of A.disabled)Q(a,e);if(Q(c.errors,"root"),$(c.errors)){C.state.next({errors:{}});try{await e(a,r)}catch(e){s=e}}else t&&await t({...c.errors},r),xe(),setTimeout(xe);if(C.state.next({isSubmitted:!0,isSubmitting:!1,isSubmitSuccessful:$(c.errors)&&!s,submitCount:c.submitCount+1,errors:c.errors}),s)throw s},Se=(e,t={})=>{const r=e?d(e):v,s=d(r),a=$(e),n=a?v:s;if(t.keepDefaultValues||(v=r),!t.keepValues){if(t.keepDirtyValues){const e=new Set([...A.mount,...Object.keys(Z(v,V))]);for(const t of Array.from(e)){const e=g(c.dirtyFields,t),r=g(V,t),s=g(n,t);e&&!f(r)?p(n,t,r):e||f(s)||te(t,s)}}else{if(u&&f(e))for(const e of A.mount){const t=g(y,e);if(t&&t._f){const e=Array.isArray(t._f.refs)?t._f.refs[0]:t._f.ref;if(J(e)){const t=e.closest("form");if(t){t.reset();break}}}}if(t.keepFieldsRef)for(const e of A.mount)te(e,g(n,e));else y={}}V=i.shouldUnregister?t.keepDefaultValues?d(v):{}:d(n),C.array.next({values:{...n}}),C.state.next({values:{...n}})}A={mount:t.keepDirtyValues?A.mount:new Set,unMount:new Set,array:new Set,disabled:new Set,watch:new Set,watchAll:!1,focus:""},x.mount=!w.isValid||!!t.keepIsValid||!!t.keepDirtyValues||!i.shouldUnregister&&!$(n),x.watch=!!i.shouldUnregister,x.keepIsValid=!!t.keepIsValid,x.action=!1,t.keepErrors||(c.errors={}),C.state.next({submitCount:t.keepSubmitCount?c.submitCount:0,isDirty:!a&&(t.keepDirty?c.isDirty:!(!t.keepDefaultValues||M(e,v))),isSubmitted:!!t.keepIsSubmitted&&c.isSubmitted,dirtyFields:a?{}:t.keepDirtyValues?t.keepDefaultValues&&V?Z(v,V):c.dirtyFields:t.keepDefaultValues&&e?Z(v,e):t.keepDirty?c.dirtyFields:{},touchedFields:t.keepTouched?c.touchedFields:{},errors:t.keepErrors?c.errors:{},isSubmitSuccessful:!!t.keepIsSubmitSuccessful&&c.isSubmitSuccessful,isSubmitting:!1,defaultValues:v})},ke=(e,t)=>Se(_(e)?e(V):e,{...i.resetOptions,...t}),we=e=>{c={...c,...e}},De={control:{register:Fe,unregister:ve,getFieldState:de,handleSubmit:Ae,setError:be,_subscribe:_e,_runSchema:B,_updateIsValidating:U,_focusError:xe,_getWatch:X,_getDirty:I,_setValid:T,_setFieldArray:(e,t=[],r,s,a=!0,n=!0)=>{if(s&&r&&!i.disabled){if(x.action=!0,n&&Array.isArray(g(y,e))){const t=r(g(y,e),s.argA,s.argB);a&&p(y,e,t)}if(n&&Array.isArray(g(c.errors,e))){const t=r(g(c.errors,e),s.argA,s.argB);a&&p(c.errors,e,t),((e,t)=>{!m(g(e,t)).length&&Q(e,t)})(c.errors,e)}if((w.touchedFields||D.touchedFields)&&n&&Array.isArray(g(c.touchedFields,e))){const t=r(g(c.touchedFields,e),s.argA,s.argB);a&&p(c.touchedFields,e,t)}(w.dirtyFields||D.dirtyFields)&&(c.dirtyFields=Z(v,V)),C.state.next({name:e,isDirty:I(e,t),dirtyFields:c.dirtyFields,errors:c.errors,isValid:c.isValid})}else p(V,e,t)},_setDisabledField:Ve,_setErrors:e=>{c.errors=e,C.state.next({errors:c.errors,isValid:!1})},_getFieldArray:e=>m(g(x.mount?V:v,e,i.shouldUnregister?g(v,e,[]):[])),_reset:Se,_resetDefaultValues:()=>_(i.defaultValues)&&i.defaultValues().then(e=>{ke(e,i.resetOptions),C.state.next({isLoading:!1})}),_removeUnmounted:()=>{for(const e of A.unMount){const t=g(y,e);t&&(t._f.refs?t._f.refs.every(e=>!K(e)):!K(t._f.ref))&&ve(e)}A.unMount=new Set},_disableForm:e=>{b(e)&&(C.state.next({disabled:e}),me(y,(t,r)=>{const s=g(y,r);s&&(t.disabled=s._f.disabled||e,Array.isArray(s._f.refs)&&s._f.refs.forEach(t=>{t.disabled=s._f.disabled||e}))},0,!1))},_subjects:C,_proxyFormState:w,get _fields(){return y},get _formValues(){return V},get _state(){return x},set _state(e){x=e},get _defaultValues(){return v},get _names(){return A},set _names(e){A=e},get _formState(){return c},get _options(){return i},set _options(e){i={...i,...e}}},subscribe:e=>(x.mount=!0,D={...D,...e.formState},_e({...e,formState:{...k,...e.formState}})),trigger:ie,register:Fe,handleSubmit:Ae,watch:(e,t)=>_(e)?C.state.subscribe({next:r=>"values"in r&&e(X(void 0,t),r)}):X(e,t,!0),setValue:te,getValues:oe,reset:ke,resetField:(e,t={})=>{g(y,e)&&(f(t.defaultValue)?te(e,d(g(v,e))):(te(e,t.defaultValue),p(v,e,d(t.defaultValue))),t.keepTouched||Q(c.touchedFields,e),t.keepDirty||(Q(c.dirtyFields,e),c.isDirty=t.defaultValue?I(e,d(g(v,e))):I()),t.keepError||(Q(c.errors,e),w.isValid&&T()),C.state.next({...c}))},clearErrors:e=>{const t=e?P(e):void 0;null==t||t.forEach(e=>Q(c.errors,e)),t?t.forEach(e=>{C.state.next({name:e,errors:c.errors})}):C.state.next({errors:{}})},unregister:ve,setError:be,setFocus:(e,t={})=>{const r=g(y,e),s=r&&r._f;if(s){const e=s.refs?s.refs[0]:s.ref;e.focus&&setTimeout(()=>{e.focus(),t.shouldSelect&&_(e.select)&&e.select()})}},getFieldState:de};return{...De,formControl:De}}var Ve=()=>{if("undefined"!=typeof crypto&&crypto.randomUUID)return crypto.randomUUID();const e="undefined"==typeof performance?Date.now():1e3*performance.now();return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,t=>{const r=(16*Math.random()+e)%16|0;return("x"==t?r:3&r|8).toString(16)})},Fe=(e,t,r={})=>r.shouldFocus||f(r.shouldFocus)?r.focusName||`${e}.${f(r.focusIndex)?t:r.focusIndex}.`:"",xe=(e,t)=>[...e,...P(t)],Ae=e=>Array.isArray(e)?e.map(()=>{}):void 0;function Se(e,t,r){return[...e.slice(0,t),...P(r),...e.slice(t)]}var ke=(e,t,r)=>Array.isArray(e)?(f(e[r])&&(e[r]=void 0),e.splice(r,0,e.splice(t,1)[0]),e):[],we=(e,t)=>[...P(t),...P(e)],De=(e,t)=>f(t)?[]:function(e,t){let r=0;const s=[...e];for(const e of t)s.splice(e-r,1),r++;return m(s).length?s:[]}(e,P(t).sort((e,t)=>e-t)),Ce=(e,t,r)=>{[e[t],e[r]]=[e[r],e[t]]},Ee=(e,t,r)=>(e[t]=r,e);e.Controller=e=>e.render(U(e)),e.Form=function(e){const r=B(),[s,a]=t.useState(!1),{control:i=r.control,onSubmit:n,children:o,action:l,method:u=L,headers:d,encType:c,onError:f,render:m,onSuccess:y,validateStatus:g,...b}=e,_=async t=>{let r=!1,s="";await i.handleSubmit(async e=>{const a=new FormData;let o="";try{o=JSON.stringify(e)}catch(e){}const m=R(i._formValues);for(const e in m)a.append(e,m[e]);if(n&&await n({data:e,event:t,method:u,formData:a,formDataJson:o}),l)try{const e=[d&&d["Content-Type"],c].some(e=>e&&e.includes("json")),t=await fetch(String(l),{method:u,headers:{...d,...c&&"multipart/form-data"!==c?{"Content-Type":c}:{}},body:e?o:a});t&&(g?!g(t.status):t.status<200||t.status>=300)?(r=!0,f&&f({response:t}),s=String(t.status)):y&&y({response:t})}catch(e){r=!0,f&&f({error:e})}})(t),r&&e.control&&(e.control._subjects.state.next({isSubmitSuccessful:!1}),e.control.setError("root.server",{type:s}))};return t.useEffect(()=>{a(!0)},[]),m?t.createElement(t.Fragment,null,m({submit:_})):t.createElement("form",{noValidate:s,action:l,method:u,encType:c,onSubmit:_,...b},o)},e.FormProvider=e=>{const{children:r,watch:s,getValues:a,getFieldState:i,setError:n,clearErrors:o,setValue:l,trigger:u,formState:d,resetField:c,reset:f,handleSubmit:m,unregister:y,control:g,register:b,setFocus:_,subscribe:p}=e;return t.createElement(N.Provider,{value:t.useMemo(()=>({watch:s,getValues:a,getFieldState:i,setError:n,clearErrors:o,setValue:l,trigger:u,formState:d,resetField:c,reset:f,handleSubmit:m,unregister:y,control:g,register:b,setFocus:_,subscribe:p}),[o,g,d,i,a,m,b,f,c,n,_,l,p,u,y,s])},t.createElement(S.Provider,{value:g},r))},e.FormStateSubscribe=({control:e,disabled:t,exact:r,name:s,render:a})=>a(C({control:e,name:s,disabled:t,exact:r})),e.Watch=e=>e.render(T({name:e.names,...e})),e.appendErrors=I,e.createFormControl=ve,e.get=g,e.set=p,e.useController=U,e.useFieldArray=function(e){const r=k(),{control:s=r,name:a,keyName:i="id",shouldUnregister:n,rules:o}=e,[l,u]=t.useState(s._getFieldArray(a)),c=t.useRef(s._getFieldArray(a).map(Ve)),f=t.useRef(!1);s._names.array.add(a),t.useMemo(()=>o&&l.length>=0&&s.register(a,o),[s,a,l.length,o]),D(()=>s._subjects.array.subscribe({next:({values:e,name:t})=>{if(t===a||!t){const t=g(e,a);Array.isArray(t)&&(u(t),c.current=t.map(Ve))}}}).unsubscribe,[s,a]);const m=t.useCallback(e=>{f.current=!0,s._setFieldArray(a,e)},[s,a]);return t.useEffect(()=>{if(s._state.action=!1,fe(a,s._names)&&s._subjects.state.next({...s._formState}),f.current&&(!ue(s._options.mode).isOnSubmit||s._formState.isSubmitted)&&!ue(s._options.reValidateMode).isOnSubmit)if(s._options.resolver)s._runSchema([a]).then(e=>{s._updateIsValidating([a]);const t=g(e.errors,a),r=g(s._formState.errors,a);(r?!t&&r.type||t&&(r.type!==t.type||r.message!==t.message):t&&t.type)&&(t?p(s._formState.errors,a,t):Q(s._formState.errors,a),s._subjects.state.next({errors:s._formState.errors}))});else{const e=g(s._fields,a);!e||!e._f||ue(s._options.reValidateMode).isOnSubmit&&ue(s._options.mode).isOnSubmit||pe(e,s._names.disabled,s._formValues,s._options.criteriaMode===F,s._options.shouldUseNativeValidation,!0).then(e=>!$(e)&&s._subjects.state.next({errors:ge(s._formState.errors,e,a)}))}s._subjects.state.next({name:a,values:d(s._formValues)}),s._names.focus&&me(s._fields,(e,t)=>{if(s._names.focus&&t.startsWith(s._names.focus)&&e.focus)return e.focus(),1}),s._names.focus="",s._setValid(),f.current=!1},[l,a,s]),t.useEffect(()=>(!g(s._formValues,a)&&s._setFieldArray(a),()=>{s._options.shouldUnregister||n?s.unregister(a):(e=>{const t=g(s._fields,e);t&&t._f&&(t._f.mount=!1)})(a)}),[a,s,i,n]),{swap:t.useCallback((e,t)=>{const r=s._getFieldArray(a);Ce(r,e,t),Ce(c.current,e,t),m(r),u(r),s._setFieldArray(a,r,Ce,{argA:e,argB:t},!1)},[m,a,s]),move:t.useCallback((e,t)=>{const r=s._getFieldArray(a);ke(r,e,t),ke(c.current,e,t),m(r),u(r),s._setFieldArray(a,r,ke,{argA:e,argB:t},!1)},[m,a,s]),prepend:t.useCallback((e,t)=>{const r=P(d(e)),i=we(s._getFieldArray(a),r);s._names.focus=Fe(a,0,t),c.current=we(c.current,r.map(Ve)),m(i),u(i),s._setFieldArray(a,i,we,{argA:Ae(e)})},[m,a,s]),append:t.useCallback((e,t)=>{const r=P(d(e)),i=xe(s._getFieldArray(a),r);s._names.focus=Fe(a,i.length-1,t),c.current=xe(c.current,r.map(Ve)),m(i),u(i),s._setFieldArray(a,i,xe,{argA:Ae(e)})},[m,a,s]),remove:t.useCallback(e=>{const t=De(s._getFieldArray(a),e);c.current=De(c.current,e),m(t),u(t),!Array.isArray(g(s._fields,a))&&p(s._fields,a,void 0),s._setFieldArray(a,t,De,{argA:e})},[m,a,s]),insert:t.useCallback((e,t,r)=>{const i=P(d(t)),n=Se(s._getFieldArray(a),e,i);s._names.focus=Fe(a,e,r),c.current=Se(c.current,e,i.map(Ve)),m(n),u(n),s._setFieldArray(a,n,Se,{argA:e,argB:Ae(t)})},[m,a,s]),update:t.useCallback((e,t)=>{const r=d(t),i=Ee(s._getFieldArray(a),e,r);c.current=[...i].map((t,r)=>t&&r!==e?c.current[r]:Ve()),m(i),u([...i]),s._setFieldArray(a,i,Ee,{argA:e,argB:r},!0,!1)},[m,a,s]),replace:t.useCallback(e=>{const t=P(d(e));c.current=t.map(Ve),m([...t]),u([...t]),s._setFieldArray(a,[...t],e=>e,{},!0,!1)},[m,a,s]),fields:t.useMemo(()=>l.map((e,t)=>({...e,[i]:c.current[t]||Ve()})),[l,i])}},e.useForm=function(e={}){const r=t.useRef(void 0),s=t.useRef(void 0),[a,i]=t.useState({isDirty:!1,isValidating:!1,isLoading:_(e.defaultValues),isSubmitted:!1,isSubmitting:!1,isSubmitSuccessful:!1,isValid:!1,submitCount:0,dirtyFields:{},touchedFields:{},validatingFields:{},errors:e.errors||{},disabled:e.disabled||!1,isReady:!1,defaultValues:_(e.defaultValues)?void 0:e.defaultValues});if(!r.current)if(e.formControl)r.current={...e.formControl,formState:a},e.defaultValues&&!_(e.defaultValues)&&e.formControl.reset(e.defaultValues,e.resetOptions);else{const{formControl:t,...s}=ve(e);r.current={...s,formState:a}}const n=r.current.control;return n._options=e,D(()=>{const e=n._subscribe({formState:n._proxyFormState,callback:()=>i({...n._formState}),reRenderRoot:!0});return i(e=>({...e,isReady:!0})),n._formState.isReady=!0,e},[n]),t.useEffect(()=>n._disableForm(e.disabled),[n,e.disabled]),t.useEffect(()=>{e.mode&&(n._options.mode=e.mode),e.reValidateMode&&(n._options.reValidateMode=e.reValidateMode)},[n,e.mode,e.reValidateMode]),t.useEffect(()=>{e.errors&&(n._setErrors(e.errors),n._focusError())},[n,e.errors]),t.useEffect(()=>{e.shouldUnregister&&n._subjects.state.next({values:n._getWatch()})},[n,e.shouldUnregister]),t.useEffect(()=>{if(n._proxyFormState.isDirty){const e=n._getDirty();e!==a.isDirty&&n._subjects.state.next({isDirty:e})}},[n,a.isDirty]),t.useEffect(()=>{var t;e.values&&!M(e.values,s.current)?(n._reset(e.values,{keepFieldsRef:!0,...n._options.resetOptions}),(null===(t=n._options.resetOptions)||void 0===t?void 0:t.keepIsValid)||n._setValid(),s.current=e.values,i(e=>({...e}))):n._resetDefaultValues()},[n,e.values]),t.useEffect(()=>{n._state.mount||(n._setValid(),n._state.mount=!0),n._state.watch&&(n._state.watch=!1,n._subjects.state.next({...n._formState})),n._removeUnmounted()}),r.current.formState=t.useMemo(()=>w(a,n),[n,a]),r.current},e.useFormContext=B,e.useFormState=C,e.useWatch=T});
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("react")):"function"==typeof define&&define.amd?define(["exports","react"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).ReactHookForm={},e.React)}(this,function(e,t){"use strict";var r=e=>"checkbox"===e.type,s=e=>e instanceof Date,a=e=>null==e;const i=e=>"object"==typeof e;var n=e=>!a(e)&&!Array.isArray(e)&&i(e)&&!s(e),o=e=>n(e)&&e.target?r(e.target)?e.target.checked:e.target.value:e,l=(e,t)=>t.split(".").some((t,r,s)=>!isNaN(Number(t))&&e.has(s.slice(0,r).join("."))),u="undefined"!=typeof window&&void 0!==window.HTMLElement&&"undefined"!=typeof document;function d(e){if(e instanceof Date)return new Date(e);const t="undefined"!=typeof FileList&&e instanceof FileList;if(u&&(e instanceof Blob||t))return e;const r=Array.isArray(e);if(!(r||n(e)&&(e=>{const t=e.constructor&&e.constructor.prototype;return n(t)&&t.hasOwnProperty("isPrototypeOf")})(e)))return e;const s=r?[]:Object.create(Object.getPrototypeOf(e));for(const t in e)Object.prototype.hasOwnProperty.call(e,t)&&(s[t]=d(e[t]));return s}var c=e=>/^\w*$/.test(e),f=e=>void 0===e,m=e=>Array.isArray(e)?e.filter(Boolean):[],y=e=>m(e.replace(/["|']|\]/g,"").split(/\.|\[/)),g=(e,t,r)=>{if(!t||!n(e))return r;const s=(c(t)?[t]:y(t)).reduce((e,t)=>a(e)?e:e[t],e);return f(s)||s===e?f(e[t])?r:e[t]:s},p=e=>"boolean"==typeof e,b=e=>"function"==typeof e,_=(e,t,r)=>{let s=-1;const a=c(t)?[t]:y(t),i=a.length,o=i-1;for(;++s<i;){const t=a[s];let i=r;if(s!==o){const r=e[t];i=n(r)||Array.isArray(r)?r:isNaN(+a[s+1])?{}:[]}if("__proto__"===t||"constructor"===t||"prototype"===t)return;e[t]=i,e=e[t]}};const v="blur",h="trigger",V="onChange",F="onSubmit",x="all",S="pattern",A="required",k="validate",w="form",D="root",C=t.createContext(null);C.displayName="HookFormControlContext";const E=()=>t.useContext(C);var O=(e,t,r,s=!0)=>{const a={defaultValues:t._defaultValues};for(const i in e)Object.defineProperty(a,i,{get:()=>{const a=i;return t._proxyFormState[a]!==x&&(t._proxyFormState[a]=!s||x),r&&(r[a]=!0),e[a]}});return a};const T="undefined"!=typeof window?t.useLayoutEffect:t.useEffect;function j(e){const r=E(),{control:s=r,disabled:a,name:i,exact:n}=e||{},[o,l]=t.useState(s._formState),u=t.useRef({isDirty:!1,isLoading:!1,dirtyFields:!1,touchedFields:!1,validatingFields:!1,isValidating:!1,isValid:!1,errors:!1});return T(()=>s._subscribe({name:i,formState:u.current,exact:n,callback:e=>{!a&&l({...s._formState,...e})}}),[i,a,n]),t.useEffect(()=>{u.current.isValid&&s._setValid(!0)},[s]),t.useMemo(()=>O(o,s,u.current,!1),[o,s])}var N=e=>"string"==typeof e,M=(e,t,r,s,a)=>N(e)?(s&&t.watch.add(e),g(r,e,a)):Array.isArray(e)?e.map(e=>(s&&t.watch.add(e),g(r,e))):(s&&(t.watchAll=!0),r),R=e=>a(e)||!i(e);function U(e,t,r=new WeakSet){if(R(e)||R(t))return Object.is(e,t);if(s(e)&&s(t))return Object.is(e.getTime(),t.getTime());const a=Object.keys(e),i=Object.keys(t);if(a.length!==i.length)return!1;if(r.has(e)||r.has(t))return!0;r.add(e),r.add(t);for(const o of a){const a=e[o];if(!i.includes(o))return!1;if("ref"!==o){const e=t[o];if(s(a)&&s(e)||(n(a)||Array.isArray(a))&&(n(e)||Array.isArray(e))?!U(a,e,r):!Object.is(a,e))return!1}}return!0}function B(e){const r=E(),{control:s=r,name:a,defaultValue:i,disabled:n,exact:o,compute:l}=e||{},u=t.useRef(i),d=t.useRef(l),c=t.useRef(void 0),f=t.useRef(s),m=t.useRef(a);d.current=l;const[y,g]=t.useState(()=>{const e=s._getWatch(a,u.current);return d.current?d.current(e):e}),p=t.useCallback(e=>{const t=M(a,s._names,e||s._formValues,!1,u.current);return d.current?d.current(t):t},[s._formValues,s._names,a]),b=t.useCallback(e=>{if(!n){const t=M(a,s._names,e||s._formValues,!1,u.current);if(d.current){const e=d.current(t);U(e,c.current)||(g(e),c.current=e)}else g(t)}},[s._formValues,s._names,n,a]);T(()=>(f.current===s&&U(m.current,a)||(f.current=s,m.current=a,b()),s._subscribe({name:a,formState:{values:!0},exact:o,callback:e=>{b(e.values)}})),[s,o,a,b]),t.useEffect(()=>s._removeUnmounted());const _=f.current!==s,v=m.current,h=t.useMemo(()=>{if(n)return null;const e=!_&&!U(v,a);return _||e?p():null},[n,_,a,v,p]);return null!==h?h:y}function L(e){const r=E(),{name:s,disabled:a,control:i=r,shouldUnregister:n,defaultValue:u,exact:c=!0}=e,m=l(i._names.array,s),y=t.useMemo(()=>g(i._formValues,s,g(i._defaultValues,s,u)),[i,s,u]),h=B({control:i,name:s,defaultValue:y,exact:c}),V=j({control:i,name:s,exact:c}),F=t.useRef(e),x=t.useRef(void 0),S=t.useRef(i.register(s,{...e.rules,value:h,...p(e.disabled)?{disabled:e.disabled}:{}}));F.current=e;const A=t.useMemo(()=>Object.defineProperties({},{invalid:{enumerable:!0,get:()=>!!g(V.errors,s)},isDirty:{enumerable:!0,get:()=>!!g(V.dirtyFields,s)},isTouched:{enumerable:!0,get:()=>!!g(V.touchedFields,s)},isValidating:{enumerable:!0,get:()=>!!g(V.validatingFields,s)},error:{enumerable:!0,get:()=>g(V.errors,s)}}),[V,s]),k=t.useCallback(e=>S.current.onChange({target:{value:o(e),name:s},type:"change"}),[s]),w=t.useCallback(()=>S.current.onBlur({target:{value:g(i._formValues,s),name:s},type:v}),[s,i._formValues]),D=t.useCallback(e=>{const t=g(i._fields,s);t&&t._f&&e&&(t._f.ref={focus:()=>b(e.focus)&&e.focus(),select:()=>b(e.select)&&e.select(),setCustomValidity:t=>b(e.setCustomValidity)&&e.setCustomValidity(t),reportValidity:()=>b(e.reportValidity)&&e.reportValidity()})},[i._fields,s]),C=t.useMemo(()=>({name:s,value:h,...p(a)||V.disabled?{disabled:V.disabled||a}:{},onChange:k,onBlur:w,ref:D}),[s,a,V.disabled,k,w,D,h]);return t.useEffect(()=>{const e=i._options.shouldUnregister||n,t=x.current;t&&t!==s&&!m&&i.unregister(t),i.register(s,{...F.current.rules,...p(F.current.disabled)?{disabled:F.current.disabled}:{}});const r=(e,t)=>{const r=g(i._fields,e);r&&r._f&&(r._f.mount=t)};if(r(s,!0),e){const e=d(g(i._options.defaultValues,s,F.current.defaultValue));_(i._defaultValues,s,e),f(g(i._formValues,s))&&_(i._formValues,s,e)}return!m&&i.register(s),x.current=s,()=>{(m?e&&!i._state.action:e)?i.unregister(s):r(s,!1)}},[s,i,m,n]),t.useEffect(()=>{i._setDisabledField({disabled:a,name:s})},[a,s,i]),t.useMemo(()=>({field:C,formState:V,fieldState:A}),[C,V,A])}const I=e=>{const t={};for(const r of Object.keys(e))if(i(e[r])&&null!==e[r]){const s=I(e[r]);for(const e of Object.keys(s))t[`${r}.${e}`]=s[e]}else t[r]=e[r];return t},P=t.createContext(null);P.displayName="HookFormContext";const W=()=>t.useContext(P),$="post";var q=(e,t,r,s,a)=>t?{...r[e],types:{...r[e]&&r[e].types?r[e].types:{},[s]:a||!0}}:{},H=e=>Array.isArray(e)?e:[e],J=()=>{let e=[];return{get observers(){return e},next:t=>{for(const r of e)r.next&&r.next(t)},subscribe:t=>(e.push(t),{unsubscribe:()=>{e=e.filter(e=>e!==t)}}),unsubscribe:()=>{e=[]}}};function z(e,t){const r={};for(const s in e)if(e.hasOwnProperty(s)){const a=e[s],i=t[s];if(a&&n(a)&&i){const e=z(a,i);n(e)&&(r[s]=e)}else e[s]&&(r[s]=i)}return r}var G=e=>n(e)&&!Object.keys(e).length,K=e=>"file"===e.type,Q=e=>{if(!u)return!1;const t=e?e.ownerDocument:0;return e instanceof(t&&t.defaultView?t.defaultView.HTMLElement:HTMLElement)},X=e=>"select-multiple"===e.type,Y=e=>"radio"===e.type,Z=e=>Q(e)&&e.isConnected;function ee(e,t){const r=Array.isArray(t)?t:c(t)?[t]:y(t),s=1===r.length?e:function(e,t){const r=t.slice(0,-1).length;let s=0;for(;s<r;)e=f(e)?s++:e[t[s++]];return e}(e,r),a=r.length-1,i=r[a];return s&&delete s[i],0!==a&&(n(s)&&G(s)||Array.isArray(s)&&function(e){for(const t in e)if(e.hasOwnProperty(t)&&!f(e[t]))return!1;return!0}(s))&&ee(e,r.slice(0,-1)),e}function te(e){return Array.isArray(e)||n(e)&&!(e=>{for(const t in e)if(b(e[t]))return!0;return!1})(e)}function re(e,t={}){for(const r in e){const s=e[r];te(s)?(t[r]=Array.isArray(s)?[]:{},re(s,t[r])):f(s)||(t[r]=!0)}return t}function se(e,t,r){r||(r=re(t));for(const s in e){const i=e[s];if(te(i))f(t)||R(r[s])?r[s]=re(i,Array.isArray(i)?[]:{}):se(i,a(t)?{}:t[s],r[s]);else{const e=t[s];r[s]=!U(i,e)}}return r}const ae={value:!1,isValid:!1},ie={value:!0,isValid:!0};var ne=e=>{if(Array.isArray(e)){if(e.length>1){const t=e.filter(e=>e&&e.checked&&!e.disabled).map(e=>e.value);return{value:t,isValid:!!t.length}}return e[0].checked&&!e[0].disabled?e[0].attributes&&!f(e[0].attributes.value)?f(e[0].value)||""===e[0].value?ie:{value:e[0].value,isValid:!0}:ie:ae}return ae},oe=(e,{valueAsNumber:t,valueAsDate:r,setValueAs:s})=>f(e)?e:t?""===e?NaN:e?+e:e:r&&N(e)?new Date(e):s?s(e):e;const le={isValid:!1,value:null};var ue=e=>Array.isArray(e)?e.reduce((e,t)=>t&&t.checked&&!t.disabled?{isValid:!0,value:t.value}:e,le):le;function de(e){const t=e.ref;return K(t)?t.files:Y(t)?ue(e.refs).value:X(t)?[...t.selectedOptions].map(({value:e})=>e):r(t)?ne(e.refs).value:oe(f(t.value)?e.ref.value:t.value,e)}var ce=e=>e instanceof RegExp,fe=e=>f(e)?e:ce(e)?e.source:n(e)?ce(e.value)?e.value.source:e.value:e,me=e=>({isOnSubmit:!e||e===F,isOnBlur:"onBlur"===e,isOnChange:e===V,isOnAll:e===x,isOnTouch:"onTouched"===e});const ye="AsyncFunction";var ge=e=>!!e&&!!e.validate&&!!(b(e.validate)&&e.validate.constructor.name===ye||n(e.validate)&&Object.values(e.validate).find(e=>e.constructor.name===ye)),pe=(e,t,r)=>!r&&(t.watchAll||t.watch.has(e)||[...t.watch].some(t=>e.startsWith(t)&&/^\.\w+/.test(e.slice(t.length))));const be=(e,t,r,s)=>{for(const a of r||Object.keys(e)){const r=g(e,a);if(r){const{_f:e,...i}=r;if(e){if(e.refs&&e.refs[0]&&t(e.refs[0],a)&&!s)return!0;if(e.ref&&t(e.ref,e.name)&&!s)return!0;if(be(i,t))break}else if(n(i)&&be(i,t))break}}};function _e(e,t,r){const s=g(e,r);if(s||c(r))return{error:s,name:r};const a=r.split(".");for(;a.length;){const s=a.join("."),i=g(t,s),n=g(e,s);if(i&&!Array.isArray(i)&&r!==s)return{name:r};if(n&&n.type)return{name:s,error:n};if(n&&n.root&&n.root.type)return{name:`${s}.root`,error:n.root};a.pop()}return{name:r}}var ve=(e,t,r)=>{const s=H(g(e,r));return _(s,D,t[r]),_(e,r,s),e};function he(e,t,r="validate"){if(N(e)||Array.isArray(e)&&e.every(N)||p(e)&&!e)return{type:r,message:N(e)?e:"",ref:t}}var Ve=e=>n(e)&&!ce(e)?e:{value:e,message:""},Fe=async(e,t,s,i,o,l)=>{const{ref:u,refs:d,required:c,maxLength:m,minLength:y,min:_,max:v,pattern:h,validate:V,name:F,valueAsNumber:x,mount:w}=e._f,D=g(s,F);if(!w||t.has(F))return{};const C=d?d[0]:u,E=e=>{o&&C.reportValidity&&(C.setCustomValidity(p(e)?"":e||""),C.reportValidity())},O={},T=Y(u),j=r(u),M=T||j,R=(x||K(u))&&f(u.value)&&f(D)||Q(u)&&""===u.value||""===D||Array.isArray(D)&&!D.length,U=q.bind(null,F,i,O),B=(e,t,r,s="maxLength",a="minLength")=>{const i=e?t:r;O[F]={type:e?s:a,message:i,ref:u,...U(e?s:a,i)}};if(l?!Array.isArray(D)||!D.length:c&&(!M&&(R||a(D))||p(D)&&!D||j&&!ne(d).isValid||T&&!ue(d).isValid)){const{value:e,message:t}=N(c)?{value:!!c,message:c}:Ve(c);if(e&&(O[F]={type:A,message:t,ref:C,...U(A,t)},!i))return E(t),O}if(!(R||a(_)&&a(v))){let e,t;const r=Ve(v),s=Ve(_);if(a(D)||isNaN(D)){const a=u.valueAsDate||new Date(D),i=e=>new Date((new Date).toDateString()+" "+e),n="time"==u.type,o="week"==u.type;N(r.value)&&D&&(e=n?i(D)>i(r.value):o?D>r.value:a>new Date(r.value)),N(s.value)&&D&&(t=n?i(D)<i(s.value):o?D<s.value:a<new Date(s.value))}else{const i=u.valueAsNumber||(D?+D:D);a(r.value)||(e=i>r.value),a(s.value)||(t=i<s.value)}if((e||t)&&(B(!!e,r.message,s.message,"max","min"),!i))return E(O[F].message),O}if((m||y)&&!R&&(N(D)||l&&Array.isArray(D))){const e=Ve(m),t=Ve(y),r=!a(e.value)&&D.length>+e.value,s=!a(t.value)&&D.length<+t.value;if((r||s)&&(B(r,e.message,t.message),!i))return E(O[F].message),O}if(h&&!R&&N(D)){const{value:e,message:t}=Ve(h);if(ce(e)&&!D.match(e)&&(O[F]={type:S,message:t,ref:u,...U(S,t)},!i))return E(t),O}if(V)if(b(V)){const e=he(await V(D,s),C);if(e&&(O[F]={...e,...U(k,e.message)},!i))return E(e.message),O}else if(n(V)){let e={};for(const t in V){if(!G(e)&&!i)break;const r=he(await V[t](D,s),C,t);r&&(e={...r,...U(t,r.message)},E(r.message),i&&(O[F]=e))}if(!G(e)&&(O[F]={ref:C,...e},!i))return O}return E(!0),O};const xe={mode:F,reValidateMode:V,shouldFocusError:!0};function Se(e={}){let t,i={...xe,...e},c={submitCount:0,isDirty:!1,isReady:!1,isLoading:b(i.defaultValues),isValidating:!1,isSubmitted:!1,isSubmitting:!1,isSubmitSuccessful:!1,isValid:!1,touchedFields:{},dirtyFields:{},validatingFields:{},errors:i.errors||{},disabled:i.disabled||!1},y={},V=(n(i.defaultValues)||n(i.values))&&d(i.defaultValues||i.values)||{},F=i.shouldUnregister?{}:d(V),S={action:!1,mount:!1,watch:!1,keepIsValid:!1},A={mount:new Set,disabled:new Set,unMount:new Set,array:new Set,watch:new Set,registerName:new Set},C=0;const E={isDirty:!1,dirtyFields:!1,validatingFields:!1,touchedFields:!1,isValidating:!1,isValid:!1,errors:!1},O={...E};let T={...O};const j={array:J(),state:J()},R=i.criteriaMode===x,B=async e=>{if(!S.keepIsValid&&!i.disabled&&(O.isValid||T.isValid||e)){let e;i.resolver?(e=G((await $()).errors),L()):e=await te({fields:y,onlyCheckValid:!0,eventType:"valid"}),e!==c.isValid&&j.state.next({isValid:e})}},L=(e,t)=>{!i.disabled&&(O.isValidating||O.validatingFields||T.isValidating||T.validatingFields)&&((e||Array.from(A.mount)).forEach(e=>{e&&(t?_(c.validatingFields,e,t):ee(c.validatingFields,e))}),j.state.next({validatingFields:c.validatingFields,isValidating:!G(c.validatingFields)}))},I=e=>{const t=se(V,F),r=(e=>e.substring(0,e.search(/\.\d+(\.|$)/))||e)(e);_(c.dirtyFields,r,g(t,r))},P=(e,t,r,s)=>{const a=g(y,e);if(a){const i=g(F,e,f(r)?g(V,e):r);f(i)||s&&s.defaultChecked||t?_(F,e,t?i:de(a._f)):ie(e,i),S.mount&&!S.action&&B()}},W=(e,t,r,s,a)=>{let n=!1,o=!1;const l={name:e};if(!i.disabled){if(!r||s){(O.isDirty||T.isDirty)&&(o=c.isDirty,c.isDirty=l.isDirty=re(),n=o!==l.isDirty);const r=U(g(V,e),t);o=!!g(c.dirtyFields,e),r?ee(c.dirtyFields,e):_(c.dirtyFields,e,!0),l.dirtyFields=c.dirtyFields,n=n||(O.dirtyFields||T.dirtyFields)&&o!==!r}if(r){const t=g(c.touchedFields,e);t||(_(c.touchedFields,e,r),l.touchedFields=c.touchedFields,n=n||(O.touchedFields||T.touchedFields)&&t!==r)}n&&a&&j.state.next(l)}return n?l:{}},$=async e=>(L(e,!0),await i.resolver(F,i.context,((e,t,r,s)=>{const a={};for(const r of e){const e=g(t,r);e&&_(a,r,e._f)}return{criteriaMode:r,names:[...e],fields:a,shouldUseNativeValidation:s}})(e||A.mount,y,i.criteriaMode,i.shouldUseNativeValidation))),q=async({name:t,eventType:r})=>{if(e.validate){const s=await e.validate({formValues:F,formState:c,name:t,eventType:r});if(n(s))for(const e in s)s[e]&&Ae(`${w}.${e}`,{message:N(s.message)?s.message:"",type:k});else N(s)||!s?Ae(w,{message:s||"",type:k}):Se(w);return s}return!0},te=async({fields:t,onlyCheckValid:r,name:s,eventType:a,context:n={valid:!0,runRootValidation:!1}})=>{if(e.validate&&(n.runRootValidation=!0,!await q({name:s,eventType:a})&&(n.valid=!1,r)))return n.valid;for(const s in t){const o=t[s];if(o){const{_f:t,...l}=o;if(t){const s=A.array.has(t.name),a=o._f&&ge(o._f);a&&O.validatingFields&&L([t.name],!0);const l=await Fe(o,A.disabled,F,R,i.shouldUseNativeValidation&&!r,s);if(a&&O.validatingFields&&L([t.name]),l[t.name]&&(n.valid=!1,r))break;if(!r&&(g(l,t.name)?s?ve(c.errors,l,t.name):_(c.errors,t.name,l[t.name]):ee(c.errors,t.name)),e.shouldUseNativeValidation&&l[t.name])break}!G(l)&&await te({context:n,onlyCheckValid:r,fields:l,name:s,eventType:a})}}return n.valid},re=(e,t)=>!i.disabled&&(e&&t&&_(F,e,t),!U(he(),V)),ae=(e,t,r)=>M(e,A,{...S.mount?F:f(t)?V:N(e)?{[e]:t}:t},r,t),ie=(e,t,s={})=>{const i=g(y,e);let n=t;if(i){const s=i._f;s&&(!s.disabled&&_(F,e,oe(t,s)),n=Q(s.ref)&&a(t)?"":t,X(s.ref)?[...s.ref.options].forEach(e=>e.selected=n.includes(e.value)):s.refs?r(s.ref)?s.refs.forEach(e=>{e.defaultChecked&&e.disabled||(Array.isArray(n)?e.checked=!!n.find(t=>t===e.value):e.checked=n===e.value||!!n)}):s.refs.forEach(e=>e.checked=e.value===n):K(s.ref)?s.ref.value="":(s.ref.value=n,s.ref.type||j.state.next({name:e,values:d(F)})))}(s.shouldDirty||s.shouldTouch)&&W(e,n,s.shouldTouch,s.shouldDirty,!0),s.shouldValidate&&ye(e)},ne=(e,t,r)=>{for(const a in t){if(!t.hasOwnProperty(a))return;const i=t[a],o=e+"."+a,l=g(y,o);(A.array.has(e)||n(i)||l&&!l._f)&&!s(i)?ne(o,i,r):ie(o,i,r)}},le=(e,t,r={})=>{const s=g(y,e),i=A.array.has(e),n=d(t);_(F,e,n),i?(j.array.next({name:e,values:d(F)}),(O.isDirty||O.dirtyFields||T.isDirty||T.dirtyFields)&&r.shouldDirty&&(I(e),j.state.next({name:e,dirtyFields:c.dirtyFields,isDirty:re(e,n)}))):!s||s._f||a(n)?ie(e,n,r):ne(e,n,r),pe(e,A)?j.state.next({...c,name:e,values:d(F)}):j.state.next({name:S.mount?e:void 0,values:d(F)})},ue=async r=>{S.mount=!0;const a=r.target;let n=a.name,l=!0;const u=g(y,n),f=e=>{l=Number.isNaN(e)||s(e)&&isNaN(e.getTime())||U(e,g(F,n,e))},m=me(i.mode),b=me(i.reValidateMode);if(u){let s,V;const x=a.type?de(u._f):o(r),S=r.type===v||"focusout"===r.type,k=!((h=u._f).mount&&(h.required||h.min||h.max||h.maxLength||h.minLength||h.pattern||h.validate)||e.validate||i.resolver||g(c.errors,n)||u._f.deps)||((e,t,r,s,a)=>!a.isOnAll&&(!r&&a.isOnTouch?!(t||e):(r?s.isOnBlur:a.isOnBlur)?!e:!(r?s.isOnChange:a.isOnChange)||e))(S,g(c.touchedFields,n),c.isSubmitted,b,m),w=pe(n,A,S);_(F,n,x),S?a&&a.readOnly||(u._f.onBlur&&u._f.onBlur(r),t&&t(0)):u._f.onChange&&u._f.onChange(r);const D=W(n,x,S),E=!G(D)||w;if(!S&&j.state.next({name:n,type:r.type,values:d(F)}),k)return(O.isValid||T.isValid)&&("onBlur"===i.mode?S&&B():S||B()),E&&j.state.next({name:n,...w?{}:D});if(!i.resolver&&e.validate&&await q({name:n,eventType:r.type}),!S&&w&&j.state.next({...c}),i.resolver){const{errors:e}=await $([n]);if(L([n]),f(x),l){const t=_e(c.errors,y,n),r=_e(e,y,t.name||n);s=r.error,n=r.name,V=G(e)}}else L([n],!0),s=(await Fe(u,A.disabled,F,R,i.shouldUseNativeValidation))[n],L([n]),f(x),l&&(s?V=!1:(O.isValid||T.isValid)&&(V=await te({fields:y,onlyCheckValid:!0,name:n,eventType:r.type})));l&&(u._f.deps&&(!Array.isArray(u._f.deps)||u._f.deps.length>0)&&ye(u._f.deps),((e,r,s,a)=>{const n=g(c.errors,e),o=(O.isValid||T.isValid)&&p(r)&&c.isValid!==r;var l;if(i.delayError&&s?(l=()=>((e,t)=>{_(c.errors,e,t),j.state.next({errors:c.errors})})(e,s),t=e=>{clearTimeout(C),C=setTimeout(l,e)},t(i.delayError)):(clearTimeout(C),t=null,s?_(c.errors,e,s):ee(c.errors,e)),(s?!U(n,s):n)||!G(a)||o){const t={...a,...o&&p(r)?{isValid:r}:{},errors:c.errors,name:e};c={...c,...t},j.state.next(t)}})(n,V,s,D))}var h},ce=(e,t)=>{if(g(c.errors,t)&&e.focus)return e.focus(),1},ye=async(e,t={})=>{let r,s;const a=H(e);if(i.resolver){const t=await(async e=>{const{errors:t}=await $(e);if(L(e),e)for(const r of e){const e=g(t,r);e?_(c.errors,r,e):ee(c.errors,r)}else c.errors=t;return t})(f(e)?e:a);r=G(t),s=e?!a.some(e=>g(t,e)):r}else e?(s=(await Promise.all(a.map(async e=>{const t=g(y,e);return await te({fields:t&&t._f?{[e]:t}:t,eventType:h})}))).every(Boolean),(s||c.isValid)&&B()):s=r=await te({fields:y,name:e,eventType:h});return j.state.next({...!N(e)||(O.isValid||T.isValid)&&r!==c.isValid?{}:{name:e},...i.resolver||!e?{isValid:r}:{},errors:c.errors}),t.shouldFocus&&!s&&be(y,ce,e?a:A.mount),s},he=(e,t)=>{let r={...S.mount?F:V};return t&&(r=z(t.dirtyFields?c.dirtyFields:c.touchedFields,r)),f(e)?r:N(e)?g(r,e):e.map(e=>g(r,e))},Ve=(e,t)=>({invalid:!!g((t||c).errors,e),isDirty:!!g((t||c).dirtyFields,e),error:g((t||c).errors,e),isValidating:!!g(c.validatingFields,e),isTouched:!!g((t||c).touchedFields,e)}),Se=e=>{const t=e?H(e):void 0;null==t||t.forEach(e=>ee(c.errors,e)),t?t.forEach(e=>{j.state.next({name:e,errors:c.errors})}):j.state.next({errors:{}})},Ae=(e,t,r)=>{const s=(g(y,e,{_f:{}})._f||{}).ref,a=g(c.errors,e)||{},{ref:i,message:n,type:o,...l}=a;_(c.errors,e,{...l,...t,ref:s}),j.state.next({name:e,errors:c.errors,isValid:!1}),r&&r.shouldFocus&&s&&s.focus&&s.focus()},ke=e=>j.state.subscribe({next:t=>{var r,s,a;r=e.name,s=t.name,a=e.exact,r&&s&&r!==s&&!H(r).some(e=>e&&(a?e===s:e.startsWith(s)||s.startsWith(e)))||!((e,t,r,s)=>{r(e);const{name:a,...i}=e;return G(i)||Object.keys(i).length>=Object.keys(t).length||Object.keys(i).find(e=>t[e]===(!s||x))})(t,e.formState||O,Ne,e.reRenderRoot)||e.callback({values:{...F},...c,...t,defaultValues:V})}}).unsubscribe,we=(e,t={})=>{for(const r of e?H(e):A.mount)A.mount.delete(r),A.array.delete(r),t.keepValue||(ee(y,r),ee(F,r)),!t.keepError&&ee(c.errors,r),!t.keepDirty&&ee(c.dirtyFields,r),!t.keepTouched&&ee(c.touchedFields,r),!t.keepIsValidating&&ee(c.validatingFields,r),!i.shouldUnregister&&!t.keepDefaultValue&&ee(V,r);j.state.next({values:d(F)}),j.state.next({...c,...t.keepDirty?{isDirty:re()}:{}}),!t.keepIsValid&&B()},De=({disabled:e,name:t})=>{if(p(e)&&S.mount||e||A.disabled.has(t)){const r=A.disabled.has(t)!==!!e;e?A.disabled.add(t):A.disabled.delete(t),r&&S.mount&&!S.action&&B()}},Ce=(e,t={})=>{let s=g(y,e);const a=p(t.disabled)||p(i.disabled),n=!A.registerName.has(e)&&s&&!s._f.mount;return _(y,e,{...s||{},_f:{...s&&s._f?s._f:{ref:{name:e}},name:e,mount:!0,...t}}),A.mount.add(e),s&&!n?De({disabled:p(t.disabled)?t.disabled:i.disabled,name:e}):P(e,!0,t.value),{...a?{disabled:t.disabled||i.disabled}:{},...i.progressive?{required:!!t.required,min:fe(t.min),max:fe(t.max),minLength:fe(t.minLength),maxLength:fe(t.maxLength),pattern:fe(t.pattern)}:{},name:e,onChange:ue,onBlur:ue,ref:a=>{if(a){A.registerName.add(e),Ce(e,t),A.registerName.delete(e),s=g(y,e);const i=f(a.value)&&a.querySelectorAll&&a.querySelectorAll("input,select,textarea")[0]||a,n=(e=>Y(e)||r(e))(i),o=s._f.refs||[];if(n?o.find(e=>e===i):i===s._f.ref)return;_(y,e,{_f:{...s._f,...n?{refs:[...o.filter(Z),i,...Array.isArray(g(V,e))?[{}]:[]],ref:{type:i.type,name:e}}:{ref:i}}}),P(e,!1,void 0,i)}else s=g(y,e,{}),s._f&&(s._f.mount=!1),(i.shouldUnregister||t.shouldUnregister)&&(!l(A.array,e)||!S.action)&&A.unMount.add(e)}}},Ee=()=>i.shouldFocusError&&be(y,ce,A.mount),Oe=(e,t)=>async r=>{let s;r&&(r.preventDefault&&r.preventDefault(),r.persist&&r.persist());let a=d(F);if(j.state.next({isSubmitting:!0}),i.resolver){const{errors:e,values:t}=await $();L(),c.errors=e,a=d(t)}else await te({fields:y,eventType:"submit"});if(A.disabled.size)for(const e of A.disabled)ee(a,e);if(ee(c.errors,D),G(c.errors)){j.state.next({errors:{}});try{await e(a,r)}catch(e){s=e}}else t&&await t({...c.errors},r),Ee(),setTimeout(Ee);if(j.state.next({isSubmitted:!0,isSubmitting:!1,isSubmitSuccessful:G(c.errors)&&!s,submitCount:c.submitCount+1,errors:c.errors}),s)throw s},Te=(e,t={})=>{const r=e?d(e):V,s=d(r),a=G(e),n=a?V:s;if(t.keepDefaultValues||(V=r),!t.keepValues){if(t.keepDirtyValues){const e=new Set([...A.mount,...Object.keys(se(V,F))]);for(const t of Array.from(e)){const e=g(c.dirtyFields,t),r=g(F,t),s=g(n,t);e&&!f(r)?_(n,t,r):e||f(s)||le(t,s)}}else{if(u&&f(e))for(const e of A.mount){const t=g(y,e);if(t&&t._f){const e=Array.isArray(t._f.refs)?t._f.refs[0]:t._f.ref;if(Q(e)){const t=e.closest("form");if(t){t.reset();break}}}}if(t.keepFieldsRef)for(const e of A.mount)le(e,g(n,e));else y={}}F=i.shouldUnregister?t.keepDefaultValues?d(V):{}:d(n),j.array.next({values:{...n}}),j.state.next({values:{...n}})}A={mount:t.keepDirtyValues?A.mount:new Set,unMount:new Set,array:new Set,registerName:new Set,disabled:new Set,watch:new Set,watchAll:!1,focus:""},S.mount=!O.isValid||!!t.keepIsValid||!!t.keepDirtyValues||!i.shouldUnregister&&!G(n),S.watch=!!i.shouldUnregister,S.keepIsValid=!!t.keepIsValid,S.action=!1,t.keepErrors||(c.errors={}),j.state.next({submitCount:t.keepSubmitCount?c.submitCount:0,isDirty:!a&&(t.keepDirty?c.isDirty:!(!t.keepDefaultValues||U(e,V))),isSubmitted:!!t.keepIsSubmitted&&c.isSubmitted,dirtyFields:a?{}:t.keepDirtyValues?t.keepDefaultValues&&F?se(V,F):c.dirtyFields:t.keepDefaultValues&&e?se(V,e):t.keepDirty?c.dirtyFields:{},touchedFields:t.keepTouched?c.touchedFields:{},errors:t.keepErrors?c.errors:{},isSubmitSuccessful:!!t.keepIsSubmitSuccessful&&c.isSubmitSuccessful,isSubmitting:!1,defaultValues:V})},je=(e,t)=>Te(b(e)?e(F):e,{...i.resetOptions,...t}),Ne=e=>{c={...c,...e}},Me={control:{register:Ce,unregister:we,getFieldState:Ve,handleSubmit:Oe,setError:Ae,_subscribe:ke,_runSchema:$,_updateIsValidating:L,_focusError:Ee,_getWatch:ae,_getDirty:re,_setValid:B,_setFieldArray:(e,t=[],r,s,a=!0,n=!0)=>{if(s&&r&&!i.disabled){if(S.action=!0,n&&Array.isArray(g(y,e))){const t=r(g(y,e),s.argA,s.argB);a&&_(y,e,t)}if(n&&Array.isArray(g(c.errors,e))){const t=r(g(c.errors,e),s.argA,s.argB);a&&_(c.errors,e,t),((e,t)=>{!m(g(e,t)).length&&ee(e,t)})(c.errors,e)}if((O.touchedFields||T.touchedFields)&&n&&Array.isArray(g(c.touchedFields,e))){const t=r(g(c.touchedFields,e),s.argA,s.argB);a&&_(c.touchedFields,e,t)}(O.dirtyFields||T.dirtyFields)&&I(e),j.state.next({name:e,isDirty:re(e,t),dirtyFields:c.dirtyFields,errors:c.errors,isValid:c.isValid})}else _(F,e,t)},_setDisabledField:De,_setErrors:e=>{c.errors=e,j.state.next({errors:c.errors,isValid:!1})},_getFieldArray:e=>m(g(S.mount?F:V,e,i.shouldUnregister?g(V,e,[]):[])),_reset:Te,_resetDefaultValues:()=>b(i.defaultValues)&&i.defaultValues().then(e=>{je(e,i.resetOptions),j.state.next({isLoading:!1})}),_removeUnmounted:()=>{for(const e of A.unMount){const t=g(y,e);t&&(t._f.refs?t._f.refs.every(e=>!Z(e)):!Z(t._f.ref))&&we(e)}A.unMount=new Set},_disableForm:e=>{p(e)&&(j.state.next({disabled:e}),be(y,(t,r)=>{const s=g(y,r);s&&(t.disabled=s._f.disabled||e,Array.isArray(s._f.refs)&&s._f.refs.forEach(t=>{t.disabled=s._f.disabled||e}))},0,!1))},_subjects:j,_proxyFormState:O,get _fields(){return y},get _formValues(){return F},get _state(){return S},set _state(e){S=e},get _defaultValues(){return V},get _names(){return A},set _names(e){A=e},get _formState(){return c},get _options(){return i},set _options(e){i={...i,...e}}},subscribe:e=>(S.mount=!0,T={...T,...e.formState},ke({...e,formState:{...E,...e.formState}})),trigger:ye,register:Ce,handleSubmit:Oe,watch:(e,t)=>b(e)?j.state.subscribe({next:r=>"values"in r&&e(ae(void 0,t),r)}):ae(e,t,!0),setValue:le,getValues:he,reset:je,resetField:(e,t={})=>{g(y,e)&&(f(t.defaultValue)?le(e,d(g(V,e))):(le(e,t.defaultValue),_(V,e,d(t.defaultValue))),t.keepTouched||ee(c.touchedFields,e),t.keepDirty||(ee(c.dirtyFields,e),c.isDirty=t.defaultValue?re(e,d(g(V,e))):re()),t.keepError||(ee(c.errors,e),O.isValid&&B()),j.state.next({...c}))},clearErrors:Se,unregister:we,setError:Ae,setFocus:(e,t={})=>{const r=g(y,e),s=r&&r._f;if(s){const e=s.refs?s.refs[0]:s.ref;e.focus&&setTimeout(()=>{e.focus(),t.shouldSelect&&b(e.select)&&e.select()})}},getFieldState:Ve};return{...Me,formControl:Me}}var Ae=()=>{if("undefined"!=typeof crypto&&crypto.randomUUID)return crypto.randomUUID();const e="undefined"==typeof performance?Date.now():1e3*performance.now();return"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,t=>{const r=(16*Math.random()+e)%16|0;return("x"==t?r:3&r|8).toString(16)})},ke=(e,t,r={})=>r.shouldFocus||f(r.shouldFocus)?r.focusName||`${e}.${f(r.focusIndex)?t:r.focusIndex}.`:"",we=(e,t)=>[...e,...H(t)],De=e=>Array.isArray(e)?e.map(()=>{}):void 0;function Ce(e,t,r){return[...e.slice(0,t),...H(r),...e.slice(t)]}var Ee=(e,t,r)=>Array.isArray(e)?(f(e[r])&&(e[r]=void 0),e.splice(r,0,e.splice(t,1)[0]),e):[],Oe=(e,t)=>[...H(t),...H(e)],Te=(e,t)=>f(t)?[]:function(e,t){let r=0;const s=[...e];for(const e of t)s.splice(e-r,1),r++;return m(s).length?s:[]}(e,H(t).sort((e,t)=>e-t)),je=(e,t,r)=>{[e[t],e[r]]=[e[r],e[t]]},Ne=(e,t,r)=>(e[t]=r,e);e.Controller=e=>e.render(L(e)),e.Form=function(e){const r=W(),[s,a]=t.useState(!1),{control:i=r.control,onSubmit:n,children:o,action:l,method:u=$,headers:d,encType:c,onError:f,render:m,onSuccess:y,validateStatus:g,...p}=e,b=async t=>{let r=!1,s="";await i.handleSubmit(async e=>{const a=new FormData;let o="";try{o=JSON.stringify(e)}catch(e){}const m=I(i._formValues);for(const e in m)a.append(e,m[e]);if(n&&await n({data:e,event:t,method:u,formData:a,formDataJson:o}),l)try{const e=[d&&d["Content-Type"],c].some(e=>e&&e.includes("json")),t=await fetch(String(l),{method:u,headers:{...d,...c&&"multipart/form-data"!==c?{"Content-Type":c}:{}},body:e?o:a});t&&(g?!g(t.status):t.status<200||t.status>=300)?(r=!0,f&&f({response:t}),s=String(t.status)):y&&y({response:t})}catch(e){r=!0,f&&f({error:e})}})(t),r&&e.control&&(e.control._subjects.state.next({isSubmitSuccessful:!1}),e.control.setError("root.server",{type:s}))};return t.useEffect(()=>{a(!0)},[]),m?t.createElement(t.Fragment,null,m({submit:b})):t.createElement("form",{noValidate:s,action:l,method:u,encType:c,onSubmit:b,...p},o)},e.FormProvider=e=>{const{children:r,watch:s,getValues:a,getFieldState:i,setError:n,clearErrors:o,setValue:l,trigger:u,formState:d,resetField:c,reset:f,handleSubmit:m,unregister:y,control:g,register:p,setFocus:b,subscribe:_}=e,v=t.useMemo(()=>({watch:s,getValues:a,getFieldState:i,setError:n,clearErrors:o,setValue:l,trigger:u,formState:d,resetField:c,reset:f,handleSubmit:m,unregister:y,control:g,register:p,setFocus:b,subscribe:_}),[o,g,d,i,a,m,p,f,c,n,b,l,_,u,y,s]);return t.createElement(P.Provider,{value:v},t.createElement(C.Provider,{value:v.control},r))},e.FormStateSubscribe=({control:e,disabled:t,exact:r,name:s,render:a})=>a(j({control:e,name:s,disabled:t,exact:r})),e.Watch=e=>e.render(B({name:e.names,...e})),e.appendErrors=q,e.createFormControl=Se,e.get=g,e.set=_,e.useController=L,e.useFieldArray=function(e){const r=E(),{control:s=r,name:a,keyName:i="id",shouldUnregister:n,rules:o}=e,[l,u]=t.useState(s._getFieldArray(a)),c=t.useRef(s._getFieldArray(a).map(Ae)),f=t.useRef(!1);s._names.array.add(a),t.useMemo(()=>o&&l.length>=0&&s.register(a,o),[s,a,l.length,o]),T(()=>s._subjects.array.subscribe({next:({values:e,name:t})=>{if(t===a||!t){const t=g(e,a);Array.isArray(t)&&(u(t),c.current=t.map(Ae))}}}).unsubscribe,[s,a]);const m=t.useCallback(e=>{f.current=!0,s._setFieldArray(a,e)},[s,a]);return t.useEffect(()=>{if(s._state.action=!1,pe(a,s._names)&&s._subjects.state.next({...s._formState}),f.current&&(!me(s._options.mode).isOnSubmit||s._formState.isSubmitted)&&!me(s._options.reValidateMode).isOnSubmit)if(s._options.resolver)s._runSchema([a]).then(e=>{s._updateIsValidating([a]);const t=g(e.errors,a),r=g(s._formState.errors,a);(r?!t&&r.type||t&&(r.type!==t.type||r.message!==t.message):t&&t.type)&&(t?_(s._formState.errors,a,t):ee(s._formState.errors,a),s._subjects.state.next({errors:s._formState.errors}))});else{const e=g(s._fields,a);!e||!e._f||me(s._options.reValidateMode).isOnSubmit&&me(s._options.mode).isOnSubmit||Fe(e,s._names.disabled,s._formValues,s._options.criteriaMode===x,s._options.shouldUseNativeValidation,!0).then(e=>!G(e)&&s._subjects.state.next({errors:ve(s._formState.errors,e,a)}))}s._subjects.state.next({name:a,values:d(s._formValues)}),s._names.focus&&be(s._fields,(e,t)=>{if(s._names.focus&&t.startsWith(s._names.focus)&&e.focus)return e.focus(),1}),s._names.focus="",s._setValid(),f.current=!1},[l,a,s]),t.useEffect(()=>(!g(s._formValues,a)&&s._setFieldArray(a),()=>{s._options.shouldUnregister||n?s.unregister(a):(e=>{const t=g(s._fields,e);t&&t._f&&(t._f.mount=!1)})(a)}),[a,s,i,n]),{swap:t.useCallback((e,t)=>{const r=s._getFieldArray(a);je(r,e,t),je(c.current,e,t),m(r),u(r),s._setFieldArray(a,r,je,{argA:e,argB:t},!1)},[m,a,s]),move:t.useCallback((e,t)=>{const r=s._getFieldArray(a);Ee(r,e,t),Ee(c.current,e,t),m(r),u(r),s._setFieldArray(a,r,Ee,{argA:e,argB:t},!1)},[m,a,s]),prepend:t.useCallback((e,t)=>{const r=H(d(e)),i=Oe(s._getFieldArray(a),r);s._names.focus=ke(a,0,t),c.current=Oe(c.current,r.map(Ae)),m(i),u(i),s._setFieldArray(a,i,Oe,{argA:De(e)})},[m,a,s]),append:t.useCallback((e,t)=>{const r=H(d(e)),i=we(s._getFieldArray(a),r);s._names.focus=ke(a,i.length-1,t),c.current=we(c.current,r.map(Ae)),m(i),u(i),s._setFieldArray(a,i,we,{argA:De(e)})},[m,a,s]),remove:t.useCallback(e=>{const t=Te(s._getFieldArray(a),e);c.current=Te(c.current,e),m(t),u(t),!Array.isArray(g(s._fields,a))&&_(s._fields,a,void 0),s._setFieldArray(a,t,Te,{argA:e})},[m,a,s]),insert:t.useCallback((e,t,r)=>{const i=H(d(t)),n=Ce(s._getFieldArray(a),e,i);s._names.focus=ke(a,e,r),c.current=Ce(c.current,e,i.map(Ae)),m(n),u(n),s._setFieldArray(a,n,Ce,{argA:e,argB:De(t)})},[m,a,s]),update:t.useCallback((e,t)=>{const r=d(t),i=Ne(s._getFieldArray(a),e,r);c.current=[...i].map((t,r)=>t&&r!==e?c.current[r]:Ae()),m(i),u([...i]),s._setFieldArray(a,i,Ne,{argA:e,argB:r},!0,!1)},[m,a,s]),replace:t.useCallback(e=>{const t=H(d(e));c.current=t.map(Ae),m([...t]),u([...t]),s._setFieldArray(a,[...t],e=>e,{},!0,!1)},[m,a,s]),fields:t.useMemo(()=>l.map((e,t)=>({...e,[i]:c.current[t]||Ae()})),[l,i])}},e.useForm=function(e={}){const r=t.useRef(void 0),s=t.useRef(void 0),[a,i]=t.useState({isDirty:!1,isValidating:!1,isLoading:b(e.defaultValues),isSubmitted:!1,isSubmitting:!1,isSubmitSuccessful:!1,isValid:!1,submitCount:0,dirtyFields:{},touchedFields:{},validatingFields:{},errors:e.errors||{},disabled:e.disabled||!1,isReady:!1,defaultValues:b(e.defaultValues)?void 0:e.defaultValues});if(!r.current)if(e.formControl)r.current={...e.formControl,formState:a},e.defaultValues&&!b(e.defaultValues)&&e.formControl.reset(e.defaultValues,e.resetOptions);else{const{formControl:t,...s}=Se(e);r.current={...s,formState:a}}const n=r.current.control;return n._options=e,T(()=>{const e=n._subscribe({formState:n._proxyFormState,callback:()=>i({...n._formState}),reRenderRoot:!0});return i(e=>({...e,isReady:!0})),n._formState.isReady=!0,e},[n]),t.useEffect(()=>n._disableForm(e.disabled),[n,e.disabled]),t.useEffect(()=>{e.mode&&(n._options.mode=e.mode),e.reValidateMode&&(n._options.reValidateMode=e.reValidateMode)},[n,e.mode,e.reValidateMode]),t.useEffect(()=>{e.errors&&(n._setErrors(e.errors),n._focusError())},[n,e.errors]),t.useEffect(()=>{e.shouldUnregister&&n._subjects.state.next({values:n._getWatch()})},[n,e.shouldUnregister]),t.useEffect(()=>{if(n._proxyFormState.isDirty){const e=n._getDirty();e!==a.isDirty&&n._subjects.state.next({isDirty:e})}},[n,a.isDirty]),t.useEffect(()=>{var t;e.values&&!U(e.values,s.current)?(n._reset(e.values,{keepFieldsRef:!0,...n._options.resetOptions}),(null===(t=n._options.resetOptions)||void 0===t?void 0:t.keepIsValid)||n._setValid(),s.current=e.values,i(e=>({...e}))):n._resetDefaultValues()},[n,e.values]),t.useEffect(()=>{n._state.mount||(n._setValid(),n._state.mount=!0),n._state.watch&&(n._state.watch=!1,n._subjects.state.next({...n._formState})),n._removeUnmounted()}),r.current.formState=t.useMemo(()=>O(a,n),[n,a]),r.current},e.useFormContext=W,e.useFormState=j,e.useWatch=B});
|
|
2
2
|
//# sourceMappingURL=index.umd.js.map
|