solid-hook-form 1.3.3 → 1.3.4

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/main.js CHANGED
@@ -1,347 +1,124 @@
1
- const Y = (t, e) => t === e, d = {
2
- equals: Y
3
- };
4
- let Z = H;
5
- const g = 1, y = 2, $ = {};
6
- var a = null;
7
- let C = null, tt = null, l = null, f = null, h = null, S = 0;
8
- function F(t, e) {
9
- e = e ? Object.assign({}, d, e) : d;
10
- const r = {
11
- value: t,
12
- observers: null,
13
- observerSlots: null,
14
- comparator: e.equals || void 0
15
- }, n = (s) => (typeof s == "function" && (s = s(r.value)), R(r, s));
16
- return [P.bind(r), n];
17
- }
18
- function et(t, e, r) {
19
- const n = U(t, e, !1, g);
20
- A(n);
21
- }
22
- function T(t, e, r) {
23
- r = r ? Object.assign({}, d, r) : d;
24
- const n = U(t, e, !0, 0);
25
- return n.observers = null, n.observerSlots = null, n.comparator = r.equals || void 0, A(n), P.bind(n);
26
- }
27
- function M(t) {
28
- if (l === null) return t();
29
- const e = l;
30
- l = null;
31
- try {
32
- return t();
33
- } finally {
34
- l = e;
35
- }
36
- }
37
- function rt(t, e) {
38
- const r = Symbol("context");
39
- return {
40
- id: r,
41
- Provider: ct(r),
42
- defaultValue: t
43
- };
44
- }
45
- function nt(t) {
46
- let e;
47
- return a && a.context && (e = a.context[t.id]) !== void 0 ? e : t.defaultValue;
48
- }
49
- function st(t) {
50
- const e = T(t), r = T(() => V(e()));
51
- return r.toArray = () => {
52
- const n = r();
53
- return Array.isArray(n) ? n : n != null ? [n] : [];
54
- }, r;
55
- }
56
- function P() {
57
- if (this.sources && this.state)
58
- if (this.state === g) A(this);
59
- else {
60
- const t = f;
61
- f = null, L(() => w(this)), f = t;
62
- }
63
- if (l) {
64
- const t = this.observers ? this.observers.length : 0;
65
- l.sources ? (l.sources.push(this), l.sourceSlots.push(t)) : (l.sources = [this], l.sourceSlots = [t]), this.observers ? (this.observers.push(l), this.observerSlots.push(l.sources.length - 1)) : (this.observers = [l], this.observerSlots = [l.sources.length - 1]);
66
- }
67
- return this.value;
68
- }
69
- function R(t, e, r) {
70
- let n = t.value;
71
- return (!t.comparator || !t.comparator(n, e)) && (t.value = e, t.observers && t.observers.length && L(() => {
72
- for (let s = 0; s < t.observers.length; s += 1) {
73
- const i = t.observers[s], p = C && C.running;
74
- p && C.disposed.has(i), (p ? !i.tState : !i.state) && (i.pure ? f.push(i) : h.push(i), i.observers && _(i)), p || (i.state = g);
75
- }
76
- if (f.length > 1e6)
77
- throw f = [], new Error();
78
- })), e;
79
- }
80
- function A(t) {
81
- if (!t.fn) return;
82
- x(t);
83
- const e = S;
84
- ot(
85
- t,
86
- t.value,
87
- e
88
- );
89
- }
90
- function ot(t, e, r) {
91
- let n;
92
- const s = a, i = l;
93
- l = a = t;
94
- try {
95
- n = t.fn(e);
96
- } catch (p) {
97
- return t.pure && (t.state = g, t.owned && t.owned.forEach(x), t.owned = null), t.updatedAt = r + 1, G(p);
98
- } finally {
99
- l = i, a = s;
100
- }
101
- (!t.updatedAt || t.updatedAt <= r) && (t.updatedAt != null && "observers" in t ? R(t, n) : t.value = n, t.updatedAt = r);
102
- }
103
- function U(t, e, r, n = g, s) {
104
- const i = {
105
- fn: t,
106
- state: n,
107
- updatedAt: null,
108
- owned: null,
109
- sources: null,
110
- sourceSlots: null,
111
- cleanups: null,
112
- value: e,
113
- owner: a,
114
- context: a ? a.context : null,
115
- pure: r
116
- };
117
- return a === null || a !== $ && (a.owned ? a.owned.push(i) : a.owned = [i]), i;
118
- }
119
- function j(t) {
120
- if (t.state === 0) return;
121
- if (t.state === y) return w(t);
122
- if (t.suspense && M(t.suspense.inFallback)) return t.suspense.effects.push(t);
123
- const e = [t];
124
- for (; (t = t.owner) && (!t.updatedAt || t.updatedAt < S); )
125
- t.state && e.push(t);
126
- for (let r = e.length - 1; r >= 0; r--)
127
- if (t = e[r], t.state === g)
128
- A(t);
129
- else if (t.state === y) {
130
- const n = f;
131
- f = null, L(() => w(t, e[0])), f = n;
132
- }
133
- }
134
- function L(t, e) {
135
- if (f) return t();
136
- let r = !1;
137
- f = [], h ? r = !0 : h = [], S++;
138
- try {
139
- const n = t();
140
- return it(r), n;
141
- } catch (n) {
142
- r || (h = null), f = null, G(n);
143
- }
144
- }
145
- function it(t) {
146
- if (f && (H(f), f = null), t) return;
147
- const e = h;
148
- h = null, e.length && L(() => Z(e));
149
- }
150
- function H(t) {
151
- for (let e = 0; e < t.length; e++) j(t[e]);
152
- }
153
- function w(t, e) {
154
- t.state = 0;
155
- for (let r = 0; r < t.sources.length; r += 1) {
156
- const n = t.sources[r];
157
- if (n.sources) {
158
- const s = n.state;
159
- s === g ? n !== e && (!n.updatedAt || n.updatedAt < S) && j(n) : s === y && w(n, e);
160
- }
161
- }
162
- }
163
- function _(t) {
164
- for (let e = 0; e < t.observers.length; e += 1) {
165
- const r = t.observers[e];
166
- r.state || (r.state = y, r.pure ? f.push(r) : h.push(r), r.observers && _(r));
167
- }
168
- }
169
- function x(t) {
170
- let e;
171
- if (t.sources)
172
- for (; t.sources.length; ) {
173
- const r = t.sources.pop(), n = t.sourceSlots.pop(), s = r.observers;
174
- if (s && s.length) {
175
- const i = s.pop(), p = r.observerSlots.pop();
176
- n < s.length && (i.sourceSlots[p] = n, s[n] = i, r.observerSlots[n] = p);
177
- }
178
- }
179
- if (t.tOwned) {
180
- for (e = t.tOwned.length - 1; e >= 0; e--) x(t.tOwned[e]);
181
- delete t.tOwned;
182
- }
183
- if (t.owned) {
184
- for (e = t.owned.length - 1; e >= 0; e--) x(t.owned[e]);
185
- t.owned = null;
186
- }
187
- if (t.cleanups) {
188
- for (e = t.cleanups.length - 1; e >= 0; e--) t.cleanups[e]();
189
- t.cleanups = null;
190
- }
191
- t.state = 0;
192
- }
193
- function ut(t) {
194
- return t instanceof Error ? t : new Error(typeof t == "string" ? t : "Unknown error", {
195
- cause: t
196
- });
197
- }
198
- function G(t, e = a) {
199
- throw ut(t);
200
- }
201
- function V(t) {
202
- if (typeof t == "function" && !t.length) return V(t());
203
- if (Array.isArray(t)) {
204
- const e = [];
205
- for (let r = 0; r < t.length; r++) {
206
- const n = V(t[r]);
207
- Array.isArray(n) ? e.push.apply(e, n) : e.push(n);
208
- }
209
- return e;
210
- }
211
- return t;
212
- }
213
- function ct(t, e) {
214
- return function(n) {
215
- let s;
216
- return et(
217
- () => s = M(() => (a.context = {
218
- ...a.context,
219
- [t]: n.value
220
- }, st(() => n.children))),
221
- void 0
222
- ), s;
223
- };
224
- }
225
- const lt = (t) => {
226
- const e = t.target;
227
- return e instanceof HTMLSelectElement ? e.value : e instanceof HTMLInputElement && e.type === "checkbox" ? e.checked : e.value;
228
- }, D = (t, e) => {
229
- if (t instanceof HTMLSelectElement) {
230
- t.value = e;
1
+ import { createSignal as p, createContext as q, useContext as M } from "solid-js";
2
+ const S = (e) => {
3
+ const n = e.target;
4
+ return n instanceof HTMLSelectElement ? n.value : n instanceof HTMLInputElement && n.type === "checkbox" ? n.checked : n.value;
5
+ }, y = (e, n) => {
6
+ if (e instanceof HTMLSelectElement) {
7
+ e.value = n;
231
8
  return;
232
9
  }
233
- if (t instanceof HTMLInputElement && t.type === "checkbox") {
234
- t.checked = e;
10
+ if (e instanceof HTMLInputElement && e.type === "checkbox") {
11
+ e.checked = n;
235
12
  return;
236
13
  }
237
- t.value = e;
238
- }, b = (t) => t instanceof RegExp || typeof t == "string" || typeof t == "number" ? t : t.value, v = (t) => typeof t == "string" ? t : typeof t.message == "string" ? t.message : "", at = (t, e, r = {}) => {
239
- const n = t[e];
240
- if (r.required && !n)
241
- return { type: "required", message: v(r.required) };
242
- if (r.min && Number(n) < Number(b(r.min)))
243
- return { type: "min", message: v(r.min) };
244
- if (r.max && Number(n) > Number(b(r.max)))
245
- return { type: "max", message: v(r.max) };
246
- if (r.minLength && n.length < b(r.minLength))
247
- return { type: "minLength", message: v(r.minLength) };
248
- if (r.maxLength && n.length > b(r.maxLength))
249
- return { type: "maxLength", message: v(r.maxLength) };
250
- if (r.pattern && !b(r.pattern).test(n))
251
- return { type: "pattern", message: v(r.pattern) };
14
+ e.value = n;
15
+ }, g = (e) => e instanceof RegExp || typeof e == "string" || typeof e == "number" ? e : e.value, m = (e) => typeof e == "string" ? e : typeof e.message == "string" ? e.message : "", H = (e, n, r = {}) => {
16
+ const i = e[n];
17
+ if (r.required && !i)
18
+ return { type: "required", message: m(r.required) };
19
+ if (r.min && Number(i) < Number(g(r.min)))
20
+ return { type: "min", message: m(r.min) };
21
+ if (r.max && Number(i) > Number(g(r.max)))
22
+ return { type: "max", message: m(r.max) };
23
+ if (r.minLength && i.length < g(r.minLength))
24
+ return { type: "minLength", message: m(r.minLength) };
25
+ if (r.maxLength && i.length > g(r.maxLength))
26
+ return { type: "maxLength", message: m(r.maxLength) };
27
+ if (r.pattern && !g(r.pattern).test(i))
28
+ return { type: "pattern", message: m(r.pattern) };
252
29
  if (r.validate) {
253
- const s = r.validate(n, t);
254
- if (s === !1)
30
+ const a = r.validate(i, e);
31
+ if (a === !1)
255
32
  return { type: "validate" };
256
- if (typeof s == "string")
257
- return { type: "validate", message: s };
33
+ if (typeof a == "string")
34
+ return { type: "validate", message: a };
258
35
  }
259
- }, ft = () => {
260
- const [t, e] = F({});
36
+ }, N = () => {
37
+ const [e, n] = p({});
261
38
  return {
262
- errors: t,
263
- appendError: (i, p) => {
264
- e((m) => ({ ...m, [i]: p }));
39
+ errors: e,
40
+ appendError: (c, f) => {
41
+ n((u) => ({ ...u, [c]: f }));
265
42
  },
266
- removeError: (i) => {
267
- e((p) => {
268
- const m = { ...p };
269
- return delete m[i], m;
43
+ removeError: (c) => {
44
+ n((f) => {
45
+ const u = { ...f };
46
+ return delete u[c], u;
270
47
  });
271
48
  },
272
49
  resetErrors: () => {
273
- e({});
50
+ n({});
274
51
  }
275
52
  };
276
- }, mt = ({
277
- defaultValues: t,
278
- mode: e = "onInput"
53
+ }, w = ({
54
+ defaultValues: e,
55
+ mode: n = "onInput"
279
56
  }) => {
280
- const r = {}, n = {}, [s, i] = F(t), { errors: p, appendError: m, removeError: W, resetErrors: z } = ft(), [k, O] = F(!0), B = (o, u) => {
281
- const c = r[o];
282
- c && (u.ref = c), m(o, u);
283
- }, J = (o) => {
284
- W(o);
285
- }, I = (o) => {
286
- const u = n[o], c = at(s(), o, u);
287
- c ? B(o, c) : J(o), O(!Object.keys(p()).length);
288
- }, K = () => {
289
- Object.keys(s()).forEach((o) => {
290
- I(o);
57
+ const r = {}, i = {}, [a, c] = p(e), { errors: f, appendError: u, removeError: F, resetErrors: b } = N(), [h, l] = p(!0), C = (t, o) => {
58
+ const s = r[t];
59
+ s && (o.ref = s), u(t, o);
60
+ }, V = (t) => {
61
+ F(t);
62
+ }, v = (t) => {
63
+ const o = i[t], s = H(a(), t, o);
64
+ s ? C(t, s) : V(t), l(!Object.keys(f()).length);
65
+ }, I = () => {
66
+ Object.keys(a()).forEach((t) => {
67
+ v(t);
291
68
  });
292
- }, N = (o, u) => {
293
- const c = lt(o);
294
- i((E) => ({ ...E, [u]: c })), I(u);
295
- }, X = (o, u = {}) => (n[o] = {
296
- required: u.required,
297
- min: u.min,
298
- max: u.max,
299
- minLength: u.minLength,
300
- maxLength: u.maxLength,
301
- pattern: u.pattern,
302
- validate: u.validate
69
+ }, x = (t, o) => {
70
+ const s = S(t);
71
+ c((d) => ({ ...d, [o]: s })), v(o);
72
+ }, k = (t, o = {}) => (i[t] = {
73
+ required: o.required,
74
+ min: o.min,
75
+ max: o.max,
76
+ minLength: o.minLength,
77
+ maxLength: o.maxLength,
78
+ pattern: o.pattern,
79
+ validate: o.validate
303
80
  }, {
304
- name: o,
81
+ name: t,
305
82
  // value: values()[name],
306
- onInput(c) {
307
- e === "onInput" && N(c, o);
83
+ onInput(s) {
84
+ n === "onInput" && x(s, t);
308
85
  },
309
- onChange(c) {
310
- (e === "onChange" || e === "onInput") && N(c, o);
86
+ onChange(s) {
87
+ (n === "onChange" || n === "onInput") && x(s, t);
311
88
  },
312
- ref(c) {
313
- r[o] || (r[o] = c, c && D(c, s()[o]));
89
+ ref(s) {
90
+ r[t] || (r[t] = s, s && y(s, a()[t]));
314
91
  }
315
- }), q = (o) => o ? s()[o] : s();
92
+ }), E = (t) => t ? a()[t] : a();
316
93
  return {
317
- values: s,
318
- errors: p,
319
- isValid: k,
320
- register: X,
321
- getValues: q,
322
- setValue: (o, u) => {
323
- i((E) => ({ ...E, [o]: u }));
324
- const c = r[o];
325
- c && D(c, u);
94
+ values: a,
95
+ errors: f,
96
+ isValid: h,
97
+ register: k,
98
+ getValues: E,
99
+ setValue: (t, o) => {
100
+ c((d) => ({ ...d, [t]: o }));
101
+ const s = r[t];
102
+ s && y(s, o);
326
103
  },
327
- onSubmit: (o) => (u) => {
328
- u.preventDefault(), K(), k() && o(q());
104
+ onSubmit: (t) => (o) => {
105
+ o.preventDefault(), I(), h() && t(E());
329
106
  },
330
- reset: (o = {}) => {
331
- i(() => ({
332
- ...t,
333
- ...o
334
- })), z(), O(!0);
107
+ reset: (t = {}) => {
108
+ c(() => ({
109
+ ...e,
110
+ ...t
111
+ })), b(), l(!0);
335
112
  }
336
113
  };
337
- }, Q = rt({}), vt = (t) => /* @__PURE__ */ React.createElement(Q.Provider, { value: t.form }, t.children), bt = () => {
338
- const t = nt(Q);
339
- if (!t)
114
+ }, L = q({}), O = (e) => /* @__PURE__ */ React.createElement(L.Provider, { value: e.form }, e.children), A = () => {
115
+ const e = M(L);
116
+ if (!e)
340
117
  throw new Error("useFormContext: cannot find a FormProvider");
341
- return t;
118
+ return e;
342
119
  };
343
120
  export {
344
- vt as FormProvider,
345
- mt as useForm,
346
- bt as useFormContext
121
+ O as FormProvider,
122
+ w as useForm,
123
+ A as useFormContext
347
124
  };
package/dist/main.umd.cjs CHANGED
@@ -1 +1 @@
1
- (function(h,y){typeof exports=="object"&&typeof module<"u"?y(exports):typeof define=="function"&&define.amd?define(["exports"],y):(h=typeof globalThis<"u"?globalThis:h||self,y(h["solid-hook-form"]={}))})(this,function(h){"use strict";const E={equals:(t,e)=>t===e};let B=j;const g=1,w=2,J={};var c=null;let k=null,K=null,a=null,f=null,m=null,x=0;function O(t,e){e=e?Object.assign({},E,e):E;const r={value:t,observers:null,observerSlots:null,comparator:e.equals||void 0},n=s=>(typeof s=="function"&&(s=s(r.value)),N(r,s));return[q.bind(r),n]}function X(t,e,r){const n=P(t,e,!1,g);S(n)}function T(t,e,r){r=r?Object.assign({},E,r):E;const n=P(t,e,!0,0);return n.observers=null,n.observerSlots=null,n.comparator=r.equals||void 0,S(n),q.bind(n)}function I(t){if(a===null)return t();const e=a;a=null;try{return t()}finally{a=e}}function Y(t,e){const r=Symbol("context");return{id:r,Provider:nt(r),defaultValue:t}}function Z(t){let e;return c&&c.context&&(e=c.context[t.id])!==void 0?e:t.defaultValue}function $(t){const e=T(t),r=T(()=>V(e()));return r.toArray=()=>{const n=r();return Array.isArray(n)?n:n!=null?[n]:[]},r}function q(){if(this.sources&&this.state)if(this.state===g)S(this);else{const t=f;f=null,A(()=>F(this)),f=t}if(a){const t=this.observers?this.observers.length:0;a.sources?(a.sources.push(this),a.sourceSlots.push(t)):(a.sources=[this],a.sourceSlots=[t]),this.observers?(this.observers.push(a),this.observerSlots.push(a.sources.length-1)):(this.observers=[a],this.observerSlots=[a.sources.length-1])}return this.value}function N(t,e,r){let n=t.value;return(!t.comparator||!t.comparator(n,e))&&(t.value=e,t.observers&&t.observers.length&&A(()=>{for(let s=0;s<t.observers.length;s+=1){const i=t.observers[s],p=k&&k.running;p&&k.disposed.has(i),(p?!i.tState:!i.state)&&(i.pure?f.push(i):m.push(i),i.observers&&D(i)),p||(i.state=g)}if(f.length>1e6)throw f=[],new Error})),e}function S(t){if(!t.fn)return;L(t);const e=x;tt(t,t.value,e)}function tt(t,e,r){let n;const s=c,i=a;a=c=t;try{n=t.fn(e)}catch(p){return t.pure&&(t.state=g,t.owned&&t.owned.forEach(L),t.owned=null),t.updatedAt=r+1,R(p)}finally{a=i,c=s}(!t.updatedAt||t.updatedAt<=r)&&(t.updatedAt!=null&&"observers"in t?N(t,n):t.value=n,t.updatedAt=r)}function P(t,e,r,n=g,s){const i={fn:t,state:n,updatedAt:null,owned:null,sources:null,sourceSlots:null,cleanups:null,value:e,owner:c,context:c?c.context:null,pure:r};return c===null||c!==J&&(c.owned?c.owned.push(i):c.owned=[i]),i}function M(t){if(t.state===0)return;if(t.state===w)return F(t);if(t.suspense&&I(t.suspense.inFallback))return t.suspense.effects.push(t);const e=[t];for(;(t=t.owner)&&(!t.updatedAt||t.updatedAt<x);)t.state&&e.push(t);for(let r=e.length-1;r>=0;r--)if(t=e[r],t.state===g)S(t);else if(t.state===w){const n=f;f=null,A(()=>F(t,e[0])),f=n}}function A(t,e){if(f)return t();let r=!1;f=[],m?r=!0:m=[],x++;try{const n=t();return et(r),n}catch(n){r||(m=null),f=null,R(n)}}function et(t){if(f&&(j(f),f=null),t)return;const e=m;m=null,e.length&&A(()=>B(e))}function j(t){for(let e=0;e<t.length;e++)M(t[e])}function F(t,e){t.state=0;for(let r=0;r<t.sources.length;r+=1){const n=t.sources[r];if(n.sources){const s=n.state;s===g?n!==e&&(!n.updatedAt||n.updatedAt<x)&&M(n):s===w&&F(n,e)}}}function D(t){for(let e=0;e<t.observers.length;e+=1){const r=t.observers[e];r.state||(r.state=w,r.pure?f.push(r):m.push(r),r.observers&&D(r))}}function L(t){let e;if(t.sources)for(;t.sources.length;){const r=t.sources.pop(),n=t.sourceSlots.pop(),s=r.observers;if(s&&s.length){const i=s.pop(),p=r.observerSlots.pop();n<s.length&&(i.sourceSlots[p]=n,s[n]=i,r.observerSlots[n]=p)}}if(t.tOwned){for(e=t.tOwned.length-1;e>=0;e--)L(t.tOwned[e]);delete t.tOwned}if(t.owned){for(e=t.owned.length-1;e>=0;e--)L(t.owned[e]);t.owned=null}if(t.cleanups){for(e=t.cleanups.length-1;e>=0;e--)t.cleanups[e]();t.cleanups=null}t.state=0}function rt(t){return t instanceof Error?t:new Error(typeof t=="string"?t:"Unknown error",{cause:t})}function R(t,e=c){throw rt(t)}function V(t){if(typeof t=="function"&&!t.length)return V(t());if(Array.isArray(t)){const e=[];for(let r=0;r<t.length;r++){const n=V(t[r]);Array.isArray(n)?e.push.apply(e,n):e.push(n)}return e}return t}function nt(t,e){return function(n){let s;return X(()=>s=I(()=>(c.context={...c.context,[t]:n.value},$(()=>n.children))),void 0),s}}const st=t=>{const e=t.target;return e instanceof HTMLSelectElement?e.value:e instanceof HTMLInputElement&&e.type==="checkbox"?e.checked:e.value},U=(t,e)=>{if(t instanceof HTMLSelectElement){t.value=e;return}if(t instanceof HTMLInputElement&&t.type==="checkbox"){t.checked=e;return}t.value=e},b=t=>t instanceof RegExp||typeof t=="string"||typeof t=="number"?t:t.value,v=t=>typeof t=="string"?t:typeof t.message=="string"?t.message:"",ot=(t,e,r={})=>{const n=t[e];if(r.required&&!n)return{type:"required",message:v(r.required)};if(r.min&&Number(n)<Number(b(r.min)))return{type:"min",message:v(r.min)};if(r.max&&Number(n)>Number(b(r.max)))return{type:"max",message:v(r.max)};if(r.minLength&&n.length<b(r.minLength))return{type:"minLength",message:v(r.minLength)};if(r.maxLength&&n.length>b(r.maxLength))return{type:"maxLength",message:v(r.maxLength)};if(r.pattern&&!b(r.pattern).test(n))return{type:"pattern",message:v(r.pattern)};if(r.validate){const s=r.validate(n,t);if(s===!1)return{type:"validate"};if(typeof s=="string")return{type:"validate",message:s}}},it=()=>{const[t,e]=O({});return{errors:t,appendError:(i,p)=>{e(d=>({...d,[i]:p}))},removeError:i=>{e(p=>{const d={...p};return delete d[i],d})},resetErrors:()=>{e({})}}},ut=({defaultValues:t,mode:e="onInput"})=>{const r={},n={},[s,i]=O(t),{errors:p,appendError:d,removeError:at,resetErrors:ft}=it(),[_,G]=O(!0),pt=(o,u)=>{const l=r[o];l&&(u.ref=l),d(o,u)},ht=o=>{at(o)},Q=o=>{const u=n[o],l=ot(s(),o,u);l?pt(o,l):ht(o),G(!Object.keys(p()).length)},gt=()=>{Object.keys(s()).forEach(o=>{Q(o)})},W=(o,u)=>{const l=st(o);i(C=>({...C,[u]:l})),Q(u)},mt=(o,u={})=>(n[o]={required:u.required,min:u.min,max:u.max,minLength:u.minLength,maxLength:u.maxLength,pattern:u.pattern,validate:u.validate},{name:o,onInput(l){e==="onInput"&&W(l,o)},onChange(l){(e==="onChange"||e==="onInput")&&W(l,o)},ref(l){r[o]||(r[o]=l,l&&U(l,s()[o]))}}),z=o=>o?s()[o]:s();return{values:s,errors:p,isValid:_,register:mt,getValues:z,setValue:(o,u)=>{i(C=>({...C,[o]:u}));const l=r[o];l&&U(l,u)},onSubmit:o=>u=>{u.preventDefault(),gt(),_()&&o(z())},reset:(o={})=>{i(()=>({...t,...o})),ft(),G(!0)}}},H=Y({}),lt=t=>React.createElement(H.Provider,{value:t.form},t.children),ct=()=>{const t=Z(H);if(!t)throw new Error("useFormContext: cannot find a FormProvider");return t};h.FormProvider=lt,h.useForm=ut,h.useFormContext=ct,Object.defineProperty(h,Symbol.toStringTag,{value:"Module"})});
1
+ (function(c,f){typeof exports=="object"&&typeof module<"u"?f(exports,require("solid-js")):typeof define=="function"&&define.amd?define(["exports","solid-js"],f):(c=typeof globalThis<"u"?globalThis:c||self,f(c["solid-hook-form"]={},c.solid))})(this,function(c,f){"use strict";const b=e=>{const n=e.target;return n instanceof HTMLSelectElement?n.value:n instanceof HTMLInputElement&&n.type==="checkbox"?n.checked:n.value},l=(e,n)=>{if(e instanceof HTMLSelectElement){e.value=n;return}if(e instanceof HTMLInputElement&&e.type==="checkbox"){e.checked=n;return}e.value=n},p=e=>e instanceof RegExp||typeof e=="string"||typeof e=="number"?e:e.value,m=e=>typeof e=="string"?e:typeof e.message=="string"?e.message:"",C=(e,n,r={})=>{const s=e[n];if(r.required&&!s)return{type:"required",message:m(r.required)};if(r.min&&Number(s)<Number(p(r.min)))return{type:"min",message:m(r.min)};if(r.max&&Number(s)>Number(p(r.max)))return{type:"max",message:m(r.max)};if(r.minLength&&s.length<p(r.minLength))return{type:"minLength",message:m(r.minLength)};if(r.maxLength&&s.length>p(r.maxLength))return{type:"maxLength",message:m(r.maxLength)};if(r.pattern&&!p(r.pattern).test(s))return{type:"pattern",message:m(r.pattern)};if(r.validate){const a=r.validate(s,e);if(a===!1)return{type:"validate"};if(typeof a=="string")return{type:"validate",message:a}}},S=()=>{const[e,n]=f.createSignal({});return{errors:e,appendError:(u,d)=>{n(g=>({...g,[u]:d}))},removeError:u=>{n(d=>{const g={...d};return delete g[u],g})},resetErrors:()=>{n({})}}},V=({defaultValues:e,mode:n="onInput"})=>{const r={},s={},[a,u]=f.createSignal(e),{errors:d,appendError:g,removeError:T,resetErrors:j}=S(),[x,y]=f.createSignal(!0),q=(t,o)=>{const i=r[t];i&&(o.ref=i),g(t,o)},M=t=>{T(t)},E=t=>{const o=s[t],i=C(a(),t,o);i?q(t,i):M(t),y(!Object.keys(d()).length)},P=()=>{Object.keys(a()).forEach(t=>{E(t)})},F=(t,o)=>{const i=b(t);u(h=>({...h,[o]:i})),E(o)},H=(t,o={})=>(s[t]={required:o.required,min:o.min,max:o.max,minLength:o.minLength,maxLength:o.maxLength,pattern:o.pattern,validate:o.validate},{name:t,onInput(i){n==="onInput"&&F(i,t)},onChange(i){(n==="onChange"||n==="onInput")&&F(i,t)},ref(i){r[t]||(r[t]=i,i&&l(i,a()[t]))}}),L=t=>t?a()[t]:a();return{values:a,errors:d,isValid:x,register:H,getValues:L,setValue:(t,o)=>{u(h=>({...h,[t]:o}));const i=r[t];i&&l(i,o)},onSubmit:t=>o=>{o.preventDefault(),P(),x()&&t(L())},reset:(t={})=>{u(()=>({...e,...t})),j(),y(!0)}}},v=f.createContext({}),k=e=>React.createElement(v.Provider,{value:e.form},e.children),I=()=>{const e=f.useContext(v);if(!e)throw new Error("useFormContext: cannot find a FormProvider");return e};c.FormProvider=k,c.useForm=V,c.useFormContext=I,Object.defineProperty(c,Symbol.toStringTag,{value:"Module"})});
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "solid-hook-form",
3
- "version": "1.3.3",
3
+ "version": "1.3.4",
4
4
  "type": "module",
5
5
  "main": "./dist/main.umd.cjs",
6
6
  "module": "./dist/main.js",