index.umd.js 28 KB

12
  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";function r(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var s=r(t),a=e=>"checkbox"===e.type,n=e=>e instanceof Date,i=e=>null==e;const u=e=>"object"==typeof e;var o=e=>!i(e)&&!Array.isArray(e)&&u(e)&&!n(e),l=e=>o(e)&&e.target?a(e.target)?e.target.checked:e.target.value:e,d=(e,t)=>e.has((e=>e.substring(0,e.search(/\.\d+(\.|$)/))||e)(t)),c=e=>{const t=e.constructor&&e.constructor.prototype;return o(t)&&t.hasOwnProperty("isPrototypeOf")},f="undefined"!=typeof window&&void 0!==window.HTMLElement&&"undefined"!=typeof document;function m(e){let t;const r=Array.isArray(e);if(e instanceof Date)t=new Date(e);else if(e instanceof Set)t=new Set(e);else{if(f&&(e instanceof Blob||e instanceof FileList)||!r&&!o(e))return e;if(t=r?[]:{},r||c(e))for(const r in e)e.hasOwnProperty(r)&&(t[r]=m(e[r]));else t=e}return t}var y=e=>Array.isArray(e)?e.filter(Boolean):[],p=e=>void 0===e,_=(e,t,r)=>{if(!t||!o(e))return r;const s=y(t.split(/[,[\].]+?/)).reduce(((e,t)=>i(e)?e:e[t]),e);return p(s)||s===e?p(e[t])?r:e[t]:s},h=e=>"boolean"==typeof e;const g={BLUR:"blur",FOCUS_OUT:"focusout",CHANGE:"change"},v={onBlur:"onBlur",onChange:"onChange",onSubmit:"onSubmit",onTouched:"onTouched",all:"all"},b="max",x="min",A="maxLength",V="minLength",F="pattern",S="required",w="validate",D=s.default.createContext(null),k=()=>s.default.useContext(D);var C=(e,t,r,s=!0)=>{const a={defaultValues:t._defaultValues};for(const n in e)Object.defineProperty(a,n,{get:()=>{const a=n;return t._proxyFormState[a]!==v.all&&(t._proxyFormState[a]=!s||v.all),r&&(r[a]=!0),e[a]}});return a},E=e=>o(e)&&!Object.keys(e).length,O=(e,t,r,s)=>{r(e);const{name:a,...n}=e;return E(n)||Object.keys(n).length>=Object.keys(t).length||Object.keys(n).find((e=>t[e]===(!s||v.all)))},j=e=>Array.isArray(e)?e:[e],T=(e,t,r)=>!e||!t||e===t||j(e).some((e=>e&&(r?e===t:e.startsWith(t)||t.startsWith(e))));function U(e){const t=s.default.useRef(e);t.current=e,s.default.useEffect((()=>{const r=!e.disabled&&t.current.subject&&t.current.subject.subscribe({next:t.current.next});return()=>{r&&r.unsubscribe()}}),[e.disabled])}function B(e){const t=k(),{control:r=t.control,disabled:a,name:n,exact:i}=e||{},[u,o]=s.default.useState(r._formState),l=s.default.useRef(!0),d=s.default.useRef({isDirty:!1,isLoading:!1,dirtyFields:!1,touchedFields:!1,isValidating:!1,isValid:!1,errors:!1}),c=s.default.useRef(n);return c.current=n,U({disabled:a,next:e=>l.current&&T(c.current,e.name,i)&&O(e,d.current,r._updateFormState)&&o({...r._formState,...e}),subject:r._subjects.state}),s.default.useEffect((()=>(l.current=!0,d.current.isValid&&r._updateValid(!0),()=>{l.current=!1})),[r]),C(u,r,d.current,!1)}var N=e=>"string"==typeof e,L=(e,t,r,s,a)=>N(e)?(s&&t.watch.add(e),_(r,e,a)):Array.isArray(e)?e.map((e=>(s&&t.watch.add(e),_(r,e)))):(s&&(t.watchAll=!0),r);function M(e){const t=k(),{control:r=t.control,name:a,defaultValue:n,disabled:i,exact:u}=e||{},o=s.default.useRef(a);o.current=a,U({disabled:i,subject:r._subjects.values,next:e=>{T(o.current,e.name,u)&&d(m(L(o.current,r._names,e.values||r._formValues,!1,n)))}});const[l,d]=s.default.useState(r._getWatch(a,n));return s.default.useEffect((()=>r._removeUnmounted())),l}var R=e=>/^\w*$/.test(e),P=e=>y(e.replace(/["|']|\]/g,"").split(/\.|\[/)),q=(e,t,r)=>{let s=-1;const a=R(t)?[t]:P(t),n=a.length,i=n-1;for(;++s<n;){const t=a[s];let n=r;if(s!==i){const r=e[t];n=o(r)||Array.isArray(r)?r:isNaN(+a[s+1])?{}:[]}e[t]=n,e=e[t]}return e};function W(e){const t=k(),{name:r,disabled:a,control:n=t.control,shouldUnregister:i}=e,u=d(n._names.array,r),o=M({control:n,name:r,defaultValue:_(n._formValues,r,_(n._defaultValues,r,e.defaultValue)),exact:!0}),c=B({control:n,name:r}),f=s.default.useRef(n.register(r,{...e.rules,value:o,...h(e.disabled)?{disabled:e.disabled}:{}}));return s.default.useEffect((()=>{const e=n._options.shouldUnregister||i,t=(e,t)=>{const r=_(n._fields,e);r&&(r._f.mount=t)};if(t(r,!0),e){const e=m(_(n._options.defaultValues,r));q(n._defaultValues,r,e),p(_(n._formValues,r))&&q(n._formValues,r,e)}return()=>{(u?e&&!n._state.action:e)?n.unregister(r):t(r,!1)}}),[r,n,u,i]),s.default.useEffect((()=>{_(n._fields,r)&&n._updateDisabledField({disabled:a,fields:n._fields,name:r,value:_(n._fields,r)._f.value})}),[a,r,n]),{field:{name:r,value:o,...h(a)||c.disabled?{disabled:c.disabled||a}:{},onChange:s.default.useCallback((e=>f.current.onChange({target:{value:l(e),name:r},type:g.CHANGE})),[r]),onBlur:s.default.useCallback((()=>f.current.onBlur({target:{value:_(n._formValues,r),name:r},type:g.BLUR})),[r,n]),ref:e=>{const t=_(n._fields,r);t&&e&&(t._f.ref={focus:()=>e.focus(),select:()=>e.select(),setCustomValidity:t=>e.setCustomValidity(t),reportValidity:()=>e.reportValidity()})}},formState:c,fieldState:Object.defineProperties({},{invalid:{enumerable:!0,get:()=>!!_(c.errors,r)},isDirty:{enumerable:!0,get:()=>!!_(c.dirtyFields,r)},isTouched:{enumerable:!0,get:()=>!!_(c.touchedFields,r)},error:{enumerable:!0,get:()=>_(c.errors,r)}})}}const H="post";var I=(e,t,r,s,a)=>t?{...r[e],types:{...r[e]&&r[e].types?r[e].types:{},[s]:a||!0}}:{},$=()=>{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)}))},G=(e,t,r={})=>r.shouldFocus||p(r.shouldFocus)?r.focusName||`${e}.${p(r.focusIndex)?t:r.focusIndex}.`:"",J=e=>({isOnSubmit:!e||e===v.onSubmit,isOnBlur:e===v.onBlur,isOnChange:e===v.onChange,isOnAll:e===v.all,isOnTouch:e===v.onTouched}),z=(e,t,r)=>!r&&(t.watchAll||t.watch.has(e)||[...t.watch].some((t=>e.startsWith(t)&&/^\.\w+/.test(e.slice(t.length)))));const K=(e,t,r,s)=>{for(const a of r||Object.keys(e)){const r=_(e,a);if(r){const{_f:e,...n}=r;if(e){if(e.refs&&e.refs[0]&&t(e.refs[0],a)&&!s)break;if(e.ref&&t(e.ref,e.name)&&!s)break;K(n,t)}else o(n)&&K(n,t)}}};var Q=(e,t,r)=>{const s=y(_(e,r));return q(s,"root",t[r]),q(e,r,s),e},X=e=>"file"===e.type,Y=e=>"function"==typeof e,Z=e=>{if(!f)return!1;const t=e?e.ownerDocument:0;return e instanceof(t&&t.defaultView?t.defaultView.HTMLElement:HTMLElement)},ee=e=>N(e),te=e=>"radio"===e.type,re=e=>e instanceof RegExp;const se={value:!1,isValid:!1},ae={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&&!p(e[0].attributes.value)?p(e[0].value)||""===e[0].value?ae:{value:e[0].value,isValid:!0}:ae:se}return se};const ie={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),ie):ie;function oe(e,t,r="validate"){if(ee(e)||Array.isArray(e)&&e.every(ee)||h(e)&&!e)return{type:r,message:ee(e)?e:"",ref:t}}var le=e=>o(e)&&!re(e)?e:{value:e,message:""},de=async(e,t,r,s,n)=>{const{ref:u,refs:l,required:d,maxLength:c,minLength:f,min:m,max:y,pattern:g,validate:v,name:D,valueAsNumber:k,mount:C,disabled:O}=e._f,j=_(t,D);if(!C||O)return{};const T=l?l[0]:u,U=e=>{s&&T.reportValidity&&(T.setCustomValidity(h(e)?"":e||""),T.reportValidity())},B={},L=te(u),M=a(u),R=L||M,P=(k||X(u))&&p(u.value)&&p(j)||Z(u)&&""===u.value||""===j||Array.isArray(j)&&!j.length,q=I.bind(null,D,r,B),W=(e,t,r,s=A,a=V)=>{const n=e?t:r;B[D]={type:e?s:a,message:n,ref:u,...q(e?s:a,n)}};if(n?!Array.isArray(j)||!j.length:d&&(!R&&(P||i(j))||h(j)&&!j||M&&!ne(l).isValid||L&&!ue(l).isValid)){const{value:e,message:t}=ee(d)?{value:!!d,message:d}:le(d);if(e&&(B[D]={type:S,message:t,ref:T,...q(S,t)},!r))return U(t),B}if(!(P||i(m)&&i(y))){let e,t;const s=le(y),a=le(m);if(i(j)||isNaN(j)){const r=u.valueAsDate||new Date(j),n=e=>new Date((new Date).toDateString()+" "+e),i="time"==u.type,o="week"==u.type;N(s.value)&&j&&(e=i?n(j)>n(s.value):o?j>s.value:r>new Date(s.value)),N(a.value)&&j&&(t=i?n(j)<n(a.value):o?j<a.value:r<new Date(a.value))}else{const r=u.valueAsNumber||(j?+j:j);i(s.value)||(e=r>s.value),i(a.value)||(t=r<a.value)}if((e||t)&&(W(!!e,s.message,a.message,b,x),!r))return U(B[D].message),B}if((c||f)&&!P&&(N(j)||n&&Array.isArray(j))){const e=le(c),t=le(f),s=!i(e.value)&&j.length>+e.value,a=!i(t.value)&&j.length<+t.value;if((s||a)&&(W(s,e.message,t.message),!r))return U(B[D].message),B}if(g&&!P&&N(j)){const{value:e,message:t}=le(g);if(re(e)&&!j.match(e)&&(B[D]={type:F,message:t,ref:u,...q(F,t)},!r))return U(t),B}if(v)if(Y(v)){const e=oe(await v(j,t),T);if(e&&(B[D]={...e,...q(w,e.message)},!r))return U(e.message),B}else if(o(v)){let e={};for(const s in v){if(!E(e)&&!r)break;const a=oe(await v[s](j,t),T,s);a&&(e={...a,...q(s,a.message)},U(a.message),r&&(B[D]=e))}if(!E(e)&&(B[D]={ref:T,...e},!r))return B}return U(!0),B},ce=(e,t)=>[...e,...j(t)],fe=e=>Array.isArray(e)?e.map((()=>{})):void 0;function me(e,t,r){return[...e.slice(0,t),...j(r),...e.slice(t)]}var ye=(e,t,r)=>Array.isArray(e)?(p(e[r])&&(e[r]=void 0),e.splice(r,0,e.splice(t,1)[0]),e):[],pe=(e,t)=>[...j(t),...j(e)];var _e=(e,t)=>p(t)?[]:function(e,t){let r=0;const s=[...e];for(const e of t)s.splice(e-r,1),r++;return y(s).length?s:[]}(e,j(t).sort(((e,t)=>e-t))),he=(e,t,r)=>{[e[t],e[r]]=[e[r],e[t]]};function ge(e,t){const r=Array.isArray(t)?t:R(t)?[t]:P(t),s=1===r.length?e:function(e,t){const r=t.slice(0,-1).length;let s=0;for(;s<r;)e=p(e)?s++:e[t[s++]];return e}(e,r),a=r.length-1,n=r[a];return s&&delete s[n],0!==a&&(o(s)&&E(s)||Array.isArray(s)&&function(e){for(const t in e)if(e.hasOwnProperty(t)&&!p(e[t]))return!1;return!0}(s))&&ge(e,r.slice(0,-1)),e}var ve=(e,t,r)=>(e[t]=r,e);var be=()=>{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=[]}}},xe=e=>i(e)||!u(e);function Ae(e,t){if(xe(e)||xe(t))return e===t;if(n(e)&&n(t))return e.getTime()===t.getTime();const r=Object.keys(e),s=Object.keys(t);if(r.length!==s.length)return!1;for(const a of r){const r=e[a];if(!s.includes(a))return!1;if("ref"!==a){const e=t[a];if(n(r)&&n(e)||o(r)&&o(e)||Array.isArray(r)&&Array.isArray(e)?!Ae(r,e):r!==e)return!1}}return!0}var Ve=e=>"select-multiple"===e.type,Fe=e=>te(e)||a(e),Se=e=>Z(e)&&e.isConnected,we=e=>{for(const t in e)if(Y(e[t]))return!0;return!1};function De(e,t={}){const r=Array.isArray(e);if(o(e)||r)for(const r in e)Array.isArray(e[r])||o(e[r])&&!we(e[r])?(t[r]=Array.isArray(e[r])?[]:{},De(e[r],t[r])):i(e[r])||(t[r]=!0);return t}function ke(e,t,r){const s=Array.isArray(e);if(o(e)||s)for(const s in e)Array.isArray(e[s])||o(e[s])&&!we(e[s])?p(t)||xe(r[s])?r[s]=Array.isArray(e[s])?De(e[s],[]):{...De(e[s])}:ke(e[s],i(t)?{}:t[s],r[s]):r[s]=!Ae(e[s],t[s]);return r}var Ce=(e,t)=>ke(e,t,De(t)),Ee=(e,{valueAsNumber:t,valueAsDate:r,setValueAs:s})=>p(e)?e:t?""===e?NaN:e?+e:e:r&&N(e)?new Date(e):s?s(e):e;function Oe(e){const t=e.ref;if(!(e.refs?e.refs.every((e=>e.disabled)):t.disabled))return X(t)?t.files:te(t)?ue(e.refs).value:Ve(t)?[...t.selectedOptions].map((({value:e})=>e)):a(t)?ne(e.refs).value:Ee(p(t.value)?e.ref.value:t.value,e)}var je=(e,t,r,s)=>{const a={};for(const r of e){const e=_(t,r);e&&q(a,r,e._f)}return{criteriaMode:r,names:[...e],fields:a,shouldUseNativeValidation:s}},Te=e=>p(e)?e:re(e)?e.source:o(e)?re(e.value)?e.value.source:e.value:e,Ue=e=>e.mount&&(e.required||e.min||e.max||e.maxLength||e.minLength||e.pattern||e.validate);function Be(e,t,r){const s=_(e,r);if(s||R(r))return{error:s,name:r};const a=r.split(".");for(;a.length;){const s=a.join("."),n=_(t,s),i=_(e,s);if(n&&!Array.isArray(n)&&r!==s)return{name:r};if(i&&i.type)return{name:s,error:i};a.pop()}return{name:r}}var Ne=(e,t,r,s,a)=>!a.isOnAll&&(!r&&a.isOnTouch?!(t||e):(r?s.isOnBlur:a.isOnBlur)?!e:!(r?s.isOnChange:a.isOnChange)||e),Le=(e,t)=>!y(_(e,t)).length&&ge(e,t);const Me={mode:v.onSubmit,reValidateMode:v.onChange,shouldFocusError:!0};function Re(e={},t){let r,s={...Me,...e},u={submitCount:0,isDirty:!1,isLoading:Y(s.defaultValues),isValidating:!1,isSubmitted:!1,isSubmitting:!1,isSubmitSuccessful:!1,isValid:!1,touchedFields:{},dirtyFields:{},errors:s.errors||{},disabled:s.disabled||!1},c={},b=(o(s.values)||o(s.defaultValues))&&m(s.values||s.defaultValues)||{},x=s.shouldUnregister?{}:m(b),A={action:!1,mount:!1,watch:!1},V={mount:new Set,unMount:new Set,array:new Set,watch:new Set},F=0;const S={isDirty:!1,dirtyFields:!1,touchedFields:!1,isValidating:!1,isValid:!1,errors:!1},w={values:be(),array:be(),state:be()},D=J(s.mode),k=J(s.reValidateMode),C=s.criteriaMode===v.all,O=async e=>{if(S.isValid||e){const e=s.resolver?E((await R()).errors):await P(c,!0);e!==u.isValid&&w.state.next({isValid:e})}},T=e=>S.isValidating&&w.state.next({isValidating:e}),U=(e,t,r,s)=>{const a=_(c,e);if(a){const n=_(x,e,p(r)?_(b,e):r);p(n)||s&&s.defaultChecked||t?q(x,e,t?n:Oe(a._f)):I(e,n),A.mount&&O()}},B=(e,t,r,s,a)=>{let n=!1,i=!1;const o={name:e},l=!(!_(c,e)||!_(c,e)._f.disabled);if(!r||s){S.isDirty&&(i=u.isDirty,u.isDirty=o.isDirty=W(),n=i!==o.isDirty);const r=l||Ae(_(b,e),t);i=!(l||!_(u.dirtyFields,e)),r||l?ge(u.dirtyFields,e):q(u.dirtyFields,e,!0),o.dirtyFields=u.dirtyFields,n=n||S.dirtyFields&&i!==!r}if(r){const t=_(u.touchedFields,e);t||(q(u.touchedFields,e,r),o.touchedFields=u.touchedFields,n=n||S.touchedFields&&t!==r)}return n&&a&&w.state.next(o),n?o:{}},M=(t,s,a,n)=>{const i=_(u.errors,t),o=S.isValid&&h(s)&&u.isValid!==s;var l;if(e.delayError&&a?(l=()=>((e,t)=>{q(u.errors,e,t),w.state.next({errors:u.errors})})(t,a),r=e=>{clearTimeout(F),F=setTimeout(l,e)},r(e.delayError)):(clearTimeout(F),r=null,a?q(u.errors,t,a):ge(u.errors,t)),(a?!Ae(i,a):i)||!E(n)||o){const e={...n,...o&&h(s)?{isValid:s}:{},errors:u.errors,name:t};u={...u,...e},w.state.next(e)}T(!1)},R=async e=>s.resolver(x,s.context,je(e||V.mount,c,s.criteriaMode,s.shouldUseNativeValidation)),P=async(e,t,r={valid:!0})=>{for(const a in e){const n=e[a];if(n){const{_f:e,...a}=n;if(e){const a=V.array.has(e.name),i=await de(n,x,C,s.shouldUseNativeValidation&&!t,a);if(i[e.name]&&(r.valid=!1,t))break;!t&&(_(i,e.name)?a?Q(u.errors,i,e.name):q(u.errors,e.name,i[e.name]):ge(u.errors,e.name))}a&&await P(a,t,r)}}return r.valid},W=(e,t)=>(e&&t&&q(x,e,t),!Ae(se(),b)),H=(e,t,r)=>L(e,V,{...A.mount?x:p(t)?b:N(e)?{[e]:t}:t},r,t),I=(e,t,r={})=>{const s=_(c,e);let n=t;if(s){const r=s._f;r&&(!r.disabled&&q(x,e,Ee(t,r)),n=Z(r.ref)&&i(t)?"":t,Ve(r.ref)?[...r.ref.options].forEach((e=>e.selected=n.includes(e.value))):r.refs?a(r.ref)?r.refs.length>1?r.refs.forEach((e=>(!e.defaultChecked||!e.disabled)&&(e.checked=Array.isArray(n)?!!n.find((t=>t===e.value)):n===e.value))):r.refs[0]&&(r.refs[0].checked=!!n):r.refs.forEach((e=>e.checked=e.value===n)):X(r.ref)?r.ref.value="":(r.ref.value=n,r.ref.type||w.values.next({name:e,values:{...x}})))}(r.shouldDirty||r.shouldTouch)&&B(e,n,r.shouldTouch,r.shouldDirty,!0),r.shouldValidate&&re(e)},$=(e,t,r)=>{for(const s in t){const a=t[s],i=`${e}.${s}`,u=_(c,i);!V.array.has(e)&&xe(a)&&(!u||u._f)||n(a)?I(i,a,r):$(i,a,r)}},G=(e,r,s={})=>{const a=_(c,e),n=V.array.has(e),o=m(r);q(x,e,o),n?(w.array.next({name:e,values:{...x}}),(S.isDirty||S.dirtyFields)&&s.shouldDirty&&w.state.next({name:e,dirtyFields:Ce(b,x),isDirty:W(e,o)})):!a||a._f||i(o)?I(e,o,s):$(e,o,s),z(e,V)&&w.state.next({...u}),w.values.next({name:e,values:{...x}}),!A.mount&&t()},ee=async e=>{const t=e.target;let a=t.name,n=!0;const i=_(c,a),o=e=>{n=Number.isNaN(e)||e===_(x,a,e)};if(i){let d,f;const m=t.type?Oe(i._f):l(e),y=e.type===g.BLUR||e.type===g.FOCUS_OUT,p=!Ue(i._f)&&!s.resolver&&!_(u.errors,a)&&!i._f.deps||Ne(y,_(u.touchedFields,a),u.isSubmitted,k,D),h=z(a,V,y);q(x,a,m),y?(i._f.onBlur&&i._f.onBlur(e),r&&r(0)):i._f.onChange&&i._f.onChange(e);const v=B(a,m,y,!1),b=!E(v)||h;if(!y&&w.values.next({name:a,type:e.type,values:{...x}}),p)return S.isValid&&O(),b&&w.state.next({name:a,...h?{}:v});if(!y&&h&&w.state.next({...u}),T(!0),s.resolver){const{errors:e}=await R([a]);if(o(m),n){const t=Be(u.errors,c,a),r=Be(e,c,t.name||a);d=r.error,a=r.name,f=E(e)}}else d=(await de(i,x,C,s.shouldUseNativeValidation))[a],o(m),n&&(d?f=!1:S.isValid&&(f=await P(c,!0)));n&&(i._f.deps&&re(i._f.deps),M(a,f,d,v))}},te=(e,t)=>{if(_(u.errors,t)&&e.focus)return e.focus(),1},re=async(e,t={})=>{let r,a;const n=j(e);if(T(!0),s.resolver){const t=await(async e=>{const{errors:t}=await R(e);if(e)for(const r of e){const e=_(t,r);e?q(u.errors,r,e):ge(u.errors,r)}else u.errors=t;return t})(p(e)?e:n);r=E(t),a=e?!n.some((e=>_(t,e))):r}else e?(a=(await Promise.all(n.map((async e=>{const t=_(c,e);return await P(t&&t._f?{[e]:t}:t)})))).every(Boolean),(a||u.isValid)&&O()):a=r=await P(c);return w.state.next({...!N(e)||S.isValid&&r!==u.isValid?{}:{name:e},...s.resolver||!e?{isValid:r}:{},errors:u.errors,isValidating:!1}),t.shouldFocus&&!a&&K(c,te,e?n:V.mount),a},se=e=>{const t={...b,...A.mount?x:{}};return p(e)?t:N(e)?_(t,e):e.map((e=>_(t,e)))},ae=(e,t)=>({invalid:!!_((t||u).errors,e),isDirty:!!_((t||u).dirtyFields,e),isTouched:!!_((t||u).touchedFields,e),error:_((t||u).errors,e)}),ne=(e,t,r)=>{const s=(_(c,e,{_f:{}})._f||{}).ref;q(u.errors,e,{...t,ref:s}),w.state.next({name:e,errors:u.errors,isValid:!1}),r&&r.shouldFocus&&s&&s.focus&&s.focus()},ie=(e,t={})=>{for(const r of e?j(e):V.mount)V.mount.delete(r),V.array.delete(r),t.keepValue||(ge(c,r),ge(x,r)),!t.keepError&&ge(u.errors,r),!t.keepDirty&&ge(u.dirtyFields,r),!t.keepTouched&&ge(u.touchedFields,r),!s.shouldUnregister&&!t.keepDefaultValue&&ge(b,r);w.values.next({values:{...x}}),w.state.next({...u,...t.keepDirty?{isDirty:W()}:{}}),!t.keepIsValid&&O()},ue=({disabled:e,name:t,field:r,fields:s,value:a})=>{if(h(e)){const n=e?void 0:p(a)?Oe(r?r._f:_(s,t)._f):a;q(x,t,n),B(t,n,!1,!1,!0)}},oe=(e,t={})=>{let r=_(c,e);const a=h(t.disabled);return q(c,e,{...r||{},_f:{...r&&r._f?r._f:{ref:{name:e}},name:e,mount:!0,...t}}),V.mount.add(e),r?ue({field:r,disabled:t.disabled,name:e,value:t.value}):U(e,!0,t.value),{...a?{disabled:t.disabled}:{},...s.progressive?{required:!!t.required,min:Te(t.min),max:Te(t.max),minLength:Te(t.minLength),maxLength:Te(t.maxLength),pattern:Te(t.pattern)}:{},name:e,onChange:ee,onBlur:ee,ref:a=>{if(a){oe(e,t),r=_(c,e);const s=p(a.value)&&a.querySelectorAll&&a.querySelectorAll("input,select,textarea")[0]||a,n=Fe(s),i=r._f.refs||[];if(n?i.find((e=>e===s)):s===r._f.ref)return;q(c,e,{_f:{...r._f,...n?{refs:[...i.filter(Se),s,...Array.isArray(_(b,e))?[{}]:[]],ref:{type:s.type,name:e}}:{ref:s}}}),U(e,!1,void 0,s)}else r=_(c,e,{}),r._f&&(r._f.mount=!1),(s.shouldUnregister||t.shouldUnregister)&&(!d(V.array,e)||!A.action)&&V.unMount.add(e)}}},le=()=>s.shouldFocusError&&K(c,te,V.mount),ce=(e,t)=>async r=>{let a;r&&(r.preventDefault&&r.preventDefault(),r.persist&&r.persist());let n=m(x);if(w.state.next({isSubmitting:!0}),s.resolver){const{errors:e,values:t}=await R();u.errors=e,n=t}else await P(c);if(ge(u.errors,"root"),E(u.errors)){w.state.next({errors:{}});try{await e(n,r)}catch(e){a=e}}else t&&await t({...u.errors},r),le(),setTimeout(le);if(w.state.next({isSubmitted:!0,isSubmitting:!1,isSubmitSuccessful:E(u.errors)&&!a,submitCount:u.submitCount+1,errors:u.errors}),a)throw a},fe=(r,s={})=>{const a=r?m(r):b,n=m(a),i=r&&!E(r)?n:b;if(s.keepDefaultValues||(b=a),!s.keepValues){if(s.keepDirtyValues)for(const e of V.mount)_(u.dirtyFields,e)?q(i,e,_(x,e)):G(e,_(i,e));else{if(f&&p(r))for(const e of V.mount){const t=_(c,e);if(t&&t._f){const e=Array.isArray(t._f.refs)?t._f.refs[0]:t._f.ref;if(Z(e)){const t=e.closest("form");if(t){t.reset();break}}}}c={}}x=e.shouldUnregister?s.keepDefaultValues?m(b):{}:m(i),w.array.next({values:{...i}}),w.values.next({values:{...i}})}V={mount:new Set,unMount:new Set,array:new Set,watch:new Set,watchAll:!1,focus:""},!A.mount&&t(),A.mount=!S.isValid||!!s.keepIsValid||!!s.keepDirtyValues,A.watch=!!e.shouldUnregister,w.state.next({submitCount:s.keepSubmitCount?u.submitCount:0,isDirty:s.keepDirty?u.isDirty:!(!s.keepDefaultValues||Ae(r,b)),isSubmitted:!!s.keepIsSubmitted&&u.isSubmitted,dirtyFields:s.keepDirtyValues?s.keepDefaultValues&&x?Ce(b,x):u.dirtyFields:s.keepDefaultValues&&r?Ce(b,r):{},touchedFields:s.keepTouched?u.touchedFields:{},errors:s.keepErrors?u.errors:{},isSubmitSuccessful:!!s.keepIsSubmitSuccessful&&u.isSubmitSuccessful,isSubmitting:!1})},me=(e,t)=>fe(Y(e)?e(x):e,t);return{control:{register:oe,unregister:ie,getFieldState:ae,handleSubmit:ce,setError:ne,_executeSchema:R,_getWatch:H,_getDirty:W,_updateValid:O,_removeUnmounted:()=>{for(const e of V.unMount){const t=_(c,e);t&&(t._f.refs?t._f.refs.every((e=>!Se(e))):!Se(t._f.ref))&&ie(e)}V.unMount=new Set},_updateFieldArray:(e,t=[],r,s,a=!0,n=!0)=>{if(s&&r){if(A.action=!0,n&&Array.isArray(_(c,e))){const t=r(_(c,e),s.argA,s.argB);a&&q(c,e,t)}if(n&&Array.isArray(_(u.errors,e))){const t=r(_(u.errors,e),s.argA,s.argB);a&&q(u.errors,e,t),Le(u.errors,e)}if(S.touchedFields&&n&&Array.isArray(_(u.touchedFields,e))){const t=r(_(u.touchedFields,e),s.argA,s.argB);a&&q(u.touchedFields,e,t)}S.dirtyFields&&(u.dirtyFields=Ce(b,x)),w.state.next({name:e,isDirty:W(e,t),dirtyFields:u.dirtyFields,errors:u.errors,isValid:u.isValid})}else q(x,e,t)},_updateDisabledField:ue,_getFieldArray:t=>y(_(A.mount?x:b,t,e.shouldUnregister?_(b,t,[]):[])),_reset:fe,_resetDefaultValues:()=>Y(s.defaultValues)&&s.defaultValues().then((e=>{me(e,s.resetOptions),w.state.next({isLoading:!1})})),_updateFormState:e=>{u={...u,...e}},_disableForm:e=>{h(e)&&(w.state.next({disabled:e}),K(c,((t,r)=>{let s=e;const a=_(c,r);a&&h(a._f.disabled)&&(s||(s=a._f.disabled)),t.disabled=s}),0,!1))},_subjects:w,_proxyFormState:S,_setErrors:e=>{u.errors=e,w.state.next({errors:u.errors,isValid:!1})},get _fields(){return c},get _formValues(){return x},get _state(){return A},set _state(e){A=e},get _defaultValues(){return b},get _names(){return V},set _names(e){V=e},get _formState(){return u},set _formState(e){u=e},get _options(){return s},set _options(e){s={...s,...e}}},trigger:re,register:oe,handleSubmit:ce,watch:(e,t)=>Y(e)?w.values.subscribe({next:r=>e(H(void 0,t),r)}):H(e,t,!0),setValue:G,getValues:se,reset:me,resetField:(e,t={})=>{_(c,e)&&(p(t.defaultValue)?G(e,m(_(b,e))):(G(e,t.defaultValue),q(b,e,m(t.defaultValue))),t.keepTouched||ge(u.touchedFields,e),t.keepDirty||(ge(u.dirtyFields,e),u.isDirty=t.defaultValue?W(e,m(_(b,e))):W()),t.keepError||(ge(u.errors,e),S.isValid&&O()),w.state.next({...u}))},clearErrors:e=>{e&&j(e).forEach((e=>ge(u.errors,e))),w.state.next({errors:e?u.errors:{}})},unregister:ie,setError:ne,setFocus:(e,t={})=>{const r=_(c,e),s=r&&r._f;if(s){const e=s.refs?s.refs[0]:s.ref;e.focus&&(e.focus(),t.shouldSelect&&e.select())}},getFieldState:ae}}e.Controller=e=>e.render(W(e)),e.Form=function(e){const t=k(),[r,a]=s.default.useState(!1),{control:n=t.control,onSubmit:i,children:u,action:o,method:l=H,headers:d,encType:c,onError:f,render:m,onSuccess:y,validateStatus:p,...h}=e,g=async t=>{let r=!1,s="";await n.handleSubmit((async e=>{const a=new FormData;let u="";try{u=JSON.stringify(e)}catch(e){}for(const t of n._names.mount)a.append(t,_(e,t));if(i&&await i({data:e,event:t,method:l,formData:a,formDataJson:u}),o)try{const e=[d&&d["Content-Type"],c].some((e=>e&&e.includes("json"))),t=await fetch(o,{method:l,headers:{...d,...c?{"Content-Type":c}:{}},body:e?u:a});t&&(p?!p(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 s.default.useEffect((()=>{a(!0)}),[]),m?s.default.createElement(s.default.Fragment,null,m({submit:g})):s.default.createElement("form",{noValidate:r,action:o,method:l,encType:c,onSubmit:g,...h},u)},e.FormProvider=e=>{const{children:t,...r}=e;return s.default.createElement(D.Provider,{value:r},t)},e.appendErrors=I,e.get=_,e.set=q,e.useController=W,e.useFieldArray=function(e){const t=k(),{control:r=t.control,name:a,keyName:n="id",shouldUnregister:i}=e,[u,o]=s.default.useState(r._getFieldArray(a)),l=s.default.useRef(r._getFieldArray(a).map($)),d=s.default.useRef(u),c=s.default.useRef(a),f=s.default.useRef(!1);c.current=a,d.current=u,r._names.array.add(a),e.rules&&r.register(a,e.rules),U({next:({values:e,name:t})=>{if(t===c.current||!t){const t=_(e,c.current);Array.isArray(t)&&(o(t),l.current=t.map($))}},subject:r._subjects.array});const y=s.default.useCallback((e=>{f.current=!0,r._updateFieldArray(a,e)}),[r,a]);return s.default.useEffect((()=>{if(r._state.action=!1,z(a,r._names)&&r._subjects.state.next({...r._formState}),f.current&&(!J(r._options.mode).isOnSubmit||r._formState.isSubmitted))if(r._options.resolver)r._executeSchema([a]).then((e=>{const t=_(e.errors,a),s=_(r._formState.errors,a);(s?!t&&s.type||t&&(s.type!==t.type||s.message!==t.message):t&&t.type)&&(t?q(r._formState.errors,a,t):ge(r._formState.errors,a),r._subjects.state.next({errors:r._formState.errors}))}));else{const e=_(r._fields,a);!e||!e._f||J(r._options.reValidateMode).isOnSubmit&&J(r._options.mode).isOnSubmit||de(e,r._formValues,r._options.criteriaMode===v.all,r._options.shouldUseNativeValidation,!0).then((e=>!E(e)&&r._subjects.state.next({errors:Q(r._formState.errors,e,a)})))}r._subjects.values.next({name:a,values:{...r._formValues}}),r._names.focus&&K(r._fields,((e,t)=>{if(r._names.focus&&t.startsWith(r._names.focus)&&e.focus)return e.focus(),1})),r._names.focus="",r._updateValid(),f.current=!1}),[u,a,r]),s.default.useEffect((()=>(!_(r._formValues,a)&&r._updateFieldArray(a),()=>{(r._options.shouldUnregister||i)&&r.unregister(a)})),[a,r,n,i]),{swap:s.default.useCallback(((e,t)=>{const s=r._getFieldArray(a);he(s,e,t),he(l.current,e,t),y(s),o(s),r._updateFieldArray(a,s,he,{argA:e,argB:t},!1)}),[y,a,r]),move:s.default.useCallback(((e,t)=>{const s=r._getFieldArray(a);ye(s,e,t),ye(l.current,e,t),y(s),o(s),r._updateFieldArray(a,s,ye,{argA:e,argB:t},!1)}),[y,a,r]),prepend:s.default.useCallback(((e,t)=>{const s=j(m(e)),n=pe(r._getFieldArray(a),s);r._names.focus=G(a,0,t),l.current=pe(l.current,s.map($)),y(n),o(n),r._updateFieldArray(a,n,pe,{argA:fe(e)})}),[y,a,r]),append:s.default.useCallback(((e,t)=>{const s=j(m(e)),n=ce(r._getFieldArray(a),s);r._names.focus=G(a,n.length-1,t),l.current=ce(l.current,s.map($)),y(n),o(n),r._updateFieldArray(a,n,ce,{argA:fe(e)})}),[y,a,r]),remove:s.default.useCallback((e=>{const t=_e(r._getFieldArray(a),e);l.current=_e(l.current,e),y(t),o(t),r._updateFieldArray(a,t,_e,{argA:e})}),[y,a,r]),insert:s.default.useCallback(((e,t,s)=>{const n=j(m(t)),i=me(r._getFieldArray(a),e,n);r._names.focus=G(a,e,s),l.current=me(l.current,e,n.map($)),y(i),o(i),r._updateFieldArray(a,i,me,{argA:e,argB:fe(t)})}),[y,a,r]),update:s.default.useCallback(((e,t)=>{const s=m(t),n=ve(r._getFieldArray(a),e,s);l.current=[...n].map(((t,r)=>t&&r!==e?l.current[r]:$())),y(n),o([...n]),r._updateFieldArray(a,n,ve,{argA:e,argB:s},!0,!1)}),[y,a,r]),replace:s.default.useCallback((e=>{const t=j(m(e));l.current=t.map($),y([...t]),o([...t]),r._updateFieldArray(a,[...t],(e=>e),{},!0,!1)}),[y,a,r]),fields:s.default.useMemo((()=>u.map(((e,t)=>({...e,[n]:l.current[t]||$()})))),[u,n])}},e.useForm=function(e={}){const t=s.default.useRef(),r=s.default.useRef(),[a,n]=s.default.useState({isDirty:!1,isValidating:!1,isLoading:Y(e.defaultValues),isSubmitted:!1,isSubmitting:!1,isSubmitSuccessful:!1,isValid:!1,submitCount:0,dirtyFields:{},touchedFields:{},errors:e.errors||{},disabled:e.disabled||!1,defaultValues:Y(e.defaultValues)?void 0:e.defaultValues});t.current||(t.current={...Re(e,(()=>n((e=>({...e}))))),formState:a});const i=t.current.control;return i._options=e,U({subject:i._subjects.state,next:e=>{O(e,i._proxyFormState,i._updateFormState,!0)&&n({...i._formState})}}),s.default.useEffect((()=>i._disableForm(e.disabled)),[i,e.disabled]),s.default.useEffect((()=>{if(i._proxyFormState.isDirty){const e=i._getDirty();e!==a.isDirty&&i._subjects.state.next({isDirty:e})}}),[i,a.isDirty]),s.default.useEffect((()=>{e.values&&!Ae(e.values,r.current)?(i._reset(e.values,i._options.resetOptions),r.current=e.values,n((e=>({...e})))):i._resetDefaultValues()}),[e.values,i]),s.default.useEffect((()=>{e.errors&&i._setErrors(e.errors)}),[e.errors,i]),s.default.useEffect((()=>{i._state.mount||(i._updateValid(),i._state.mount=!0),i._state.watch&&(i._state.watch=!1,i._subjects.state.next({...i._formState})),i._removeUnmounted()})),s.default.useEffect((()=>{e.shouldUnregister&&i._subjects.values.next({values:i._getWatch()})}),[e.shouldUnregister,i]),t.current.formState=C(a,i),t.current},e.useFormContext=k,e.useFormState=B,e.useWatch=M,Object.defineProperty(e,"__esModule",{value:!0})}));
  2. //# sourceMappingURL=index.umd.js.map