@tanstack/form-core 0.3.0 → 0.3.2
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/build/legacy/FieldApi.cjs +285 -0
- package/build/legacy/FieldApi.cjs.map +1 -0
- package/build/legacy/FieldApi.d.cts +3 -0
- package/build/legacy/FieldApi.d.ts +3 -0
- package/build/legacy/FieldApi.js +252 -0
- package/build/legacy/FieldApi.js.map +1 -0
- package/build/legacy/FormApi.cjs +257 -0
- package/build/legacy/FormApi.cjs.map +1 -0
- package/build/legacy/FormApi.d.cts +3 -0
- package/build/legacy/FormApi.d.ts +3 -0
- package/build/legacy/FormApi.js +234 -0
- package/build/legacy/FormApi.js.map +1 -0
- package/build/legacy/chunk-4QZDOMDG.js +19 -0
- package/build/legacy/chunk-4QZDOMDG.js.map +1 -0
- package/build/legacy/index.cjs +29 -0
- package/build/legacy/index.cjs.map +1 -0
- package/build/legacy/index.d.cts +176 -0
- package/build/legacy/index.d.ts +176 -0
- package/build/legacy/index.js +5 -0
- package/build/legacy/index.js.map +1 -0
- package/build/legacy/utils.cjs +103 -0
- package/build/legacy/utils.cjs.map +1 -0
- package/build/legacy/utils.d.cts +33 -0
- package/build/legacy/utils.d.ts +33 -0
- package/build/legacy/utils.js +77 -0
- package/build/legacy/utils.js.map +1 -0
- package/build/modern/FieldApi.cjs +267 -0
- package/build/modern/FieldApi.cjs.map +1 -0
- package/build/modern/FieldApi.d.cts +3 -0
- package/build/modern/FieldApi.d.ts +3 -0
- package/build/modern/FieldApi.js +242 -0
- package/build/modern/FieldApi.js.map +1 -0
- package/build/modern/FormApi.cjs +251 -0
- package/build/modern/FormApi.cjs.map +1 -0
- package/build/modern/FormApi.d.cts +3 -0
- package/build/modern/FormApi.d.ts +3 -0
- package/build/modern/FormApi.js +226 -0
- package/build/modern/FormApi.js.map +1 -0
- package/build/modern/index.cjs +29 -0
- package/build/modern/index.cjs.map +1 -0
- package/build/modern/index.d.cts +176 -0
- package/build/modern/index.d.ts +176 -0
- package/build/modern/index.js +5 -0
- package/build/modern/index.js.map +1 -0
- package/build/modern/utils.cjs +103 -0
- package/build/modern/utils.cjs.map +1 -0
- package/build/modern/utils.d.cts +33 -0
- package/build/modern/utils.d.ts +33 -0
- package/build/modern/utils.js +75 -0
- package/build/modern/utils.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,285 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var __accessCheck = (obj, member, msg) => {
|
|
20
|
+
if (!member.has(obj))
|
|
21
|
+
throw TypeError("Cannot " + msg);
|
|
22
|
+
};
|
|
23
|
+
var __privateGet = (obj, member, getter) => {
|
|
24
|
+
__accessCheck(obj, member, "read from private field");
|
|
25
|
+
return getter ? getter.call(obj) : member.get(obj);
|
|
26
|
+
};
|
|
27
|
+
var __privateAdd = (obj, member, value) => {
|
|
28
|
+
if (member.has(obj))
|
|
29
|
+
throw TypeError("Cannot add the same private member more than once");
|
|
30
|
+
member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
// src/FieldApi.ts
|
|
34
|
+
var FieldApi_exports = {};
|
|
35
|
+
__export(FieldApi_exports, {
|
|
36
|
+
FieldApi: () => FieldApi
|
|
37
|
+
});
|
|
38
|
+
module.exports = __toCommonJS(FieldApi_exports);
|
|
39
|
+
var import_store = require("@tanstack/store");
|
|
40
|
+
var uid = 0;
|
|
41
|
+
var _leaseValidateAsync;
|
|
42
|
+
var _FieldApi = class _FieldApi {
|
|
43
|
+
constructor(opts) {
|
|
44
|
+
this.options = {};
|
|
45
|
+
this.mount = () => {
|
|
46
|
+
var _a, _b;
|
|
47
|
+
const info = this.getInfo();
|
|
48
|
+
info.instances[this.uid] = this;
|
|
49
|
+
const unsubscribe = this.form.store.subscribe(() => {
|
|
50
|
+
this.store.batch(() => {
|
|
51
|
+
const nextValue = this.getValue();
|
|
52
|
+
const nextMeta = this.getMeta();
|
|
53
|
+
if (nextValue !== this.state.value) {
|
|
54
|
+
this.store.setState((prev) => ({ ...prev, value: nextValue }));
|
|
55
|
+
}
|
|
56
|
+
if (nextMeta !== this.state.meta) {
|
|
57
|
+
this.store.setState((prev) => ({ ...prev, meta: nextMeta }));
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
});
|
|
61
|
+
this.update(this.options);
|
|
62
|
+
(_b = (_a = this.options).onMount) == null ? void 0 : _b.call(_a, this);
|
|
63
|
+
return () => {
|
|
64
|
+
unsubscribe();
|
|
65
|
+
delete info.instances[this.uid];
|
|
66
|
+
if (!Object.keys(info.instances).length) {
|
|
67
|
+
delete this.form.fieldInfo[this.name];
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
};
|
|
71
|
+
this.update = (opts) => {
|
|
72
|
+
var _a;
|
|
73
|
+
if (this.state.value === void 0) {
|
|
74
|
+
const formDefault = (_a = opts.form.options.defaultValues) == null ? void 0 : _a[opts.name];
|
|
75
|
+
if (opts.defaultValue !== void 0) {
|
|
76
|
+
this.setValue(opts.defaultValue);
|
|
77
|
+
} else if (formDefault !== void 0) {
|
|
78
|
+
this.setValue(formDefault);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
if (this._getMeta() === void 0) {
|
|
82
|
+
this.setMeta(this.state.meta);
|
|
83
|
+
}
|
|
84
|
+
this.options = opts;
|
|
85
|
+
};
|
|
86
|
+
this.getValue = () => {
|
|
87
|
+
return this.form.getFieldValue(this.name);
|
|
88
|
+
};
|
|
89
|
+
this.setValue = (updater, options) => {
|
|
90
|
+
this.form.setFieldValue(this.name, updater, options);
|
|
91
|
+
this.validate("change", this.state.value);
|
|
92
|
+
};
|
|
93
|
+
this._getMeta = () => this.form.getFieldMeta(this.name);
|
|
94
|
+
this.getMeta = () => this._getMeta() ?? {
|
|
95
|
+
isValidating: false,
|
|
96
|
+
isTouched: false,
|
|
97
|
+
touchedErrors: [],
|
|
98
|
+
errors: [],
|
|
99
|
+
errorMap: {},
|
|
100
|
+
...this.options.defaultMeta
|
|
101
|
+
};
|
|
102
|
+
this.setMeta = (updater) => this.form.setFieldMeta(this.name, updater);
|
|
103
|
+
this.getInfo = () => this.form.getFieldInfo(this.name);
|
|
104
|
+
this.pushValue = (value) => this.form.pushFieldValue(this.name, value);
|
|
105
|
+
this.insertValue = (index, value) => this.form.insertFieldValue(this.name, index, value);
|
|
106
|
+
this.removeValue = (index) => this.form.removeFieldValue(this.name, index);
|
|
107
|
+
this.swapValues = (aIndex, bIndex) => this.form.swapFieldValues(this.name, aIndex, bIndex);
|
|
108
|
+
this.getSubField = (name) => new _FieldApi({
|
|
109
|
+
name: `${this.name}.${name}`,
|
|
110
|
+
form: this.form
|
|
111
|
+
});
|
|
112
|
+
this.validateSync = (value = this.state.value, cause) => {
|
|
113
|
+
const { onChange, onBlur } = this.options;
|
|
114
|
+
const validate = cause === "submit" ? void 0 : cause === "change" ? onChange : onBlur;
|
|
115
|
+
if (!validate)
|
|
116
|
+
return;
|
|
117
|
+
const validationCount = (this.getInfo().validationCount || 0) + 1;
|
|
118
|
+
this.getInfo().validationCount = validationCount;
|
|
119
|
+
const error = normalizeError(validate(value, this));
|
|
120
|
+
const errorMapKey = getErrorMapKey(cause);
|
|
121
|
+
if (error && this.state.meta.errorMap[errorMapKey] !== error) {
|
|
122
|
+
this.setMeta((prev) => ({
|
|
123
|
+
...prev,
|
|
124
|
+
errors: [...prev.errors, error],
|
|
125
|
+
errorMap: {
|
|
126
|
+
...prev.errorMap,
|
|
127
|
+
[getErrorMapKey(cause)]: error
|
|
128
|
+
}
|
|
129
|
+
}));
|
|
130
|
+
}
|
|
131
|
+
if (this.state.meta.errorMap[errorMapKey]) {
|
|
132
|
+
this.cancelValidateAsync();
|
|
133
|
+
}
|
|
134
|
+
};
|
|
135
|
+
__privateAdd(this, _leaseValidateAsync, () => {
|
|
136
|
+
const count = (this.getInfo().validationAsyncCount || 0) + 1;
|
|
137
|
+
this.getInfo().validationAsyncCount = count;
|
|
138
|
+
return count;
|
|
139
|
+
});
|
|
140
|
+
this.cancelValidateAsync = () => {
|
|
141
|
+
__privateGet(this, _leaseValidateAsync).call(this);
|
|
142
|
+
this.setMeta((prev) => ({
|
|
143
|
+
...prev,
|
|
144
|
+
isValidating: false
|
|
145
|
+
}));
|
|
146
|
+
};
|
|
147
|
+
this.validateAsync = async (value = this.state.value, cause) => {
|
|
148
|
+
var _a, _b, _c, _d;
|
|
149
|
+
const {
|
|
150
|
+
onChangeAsync,
|
|
151
|
+
onBlurAsync,
|
|
152
|
+
onSubmitAsync,
|
|
153
|
+
asyncDebounceMs,
|
|
154
|
+
onBlurAsyncDebounceMs,
|
|
155
|
+
onChangeAsyncDebounceMs
|
|
156
|
+
} = this.options;
|
|
157
|
+
const validate = cause === "change" ? onChangeAsync : cause === "submit" ? onSubmitAsync : onBlurAsync;
|
|
158
|
+
if (!validate)
|
|
159
|
+
return [];
|
|
160
|
+
const debounceMs = cause === "submit" ? 0 : (cause === "change" ? onChangeAsyncDebounceMs : onBlurAsyncDebounceMs) ?? asyncDebounceMs ?? 0;
|
|
161
|
+
if (this.state.meta.isValidating !== true)
|
|
162
|
+
this.setMeta((prev) => ({ ...prev, isValidating: true }));
|
|
163
|
+
const validationAsyncCount = __privateGet(this, _leaseValidateAsync).call(this);
|
|
164
|
+
const checkLatest = () => validationAsyncCount === this.getInfo().validationAsyncCount;
|
|
165
|
+
if (!this.getInfo().validationPromise) {
|
|
166
|
+
this.getInfo().validationPromise = new Promise((resolve, reject) => {
|
|
167
|
+
this.getInfo().validationResolve = resolve;
|
|
168
|
+
this.getInfo().validationReject = reject;
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
if (debounceMs > 0) {
|
|
172
|
+
await new Promise((r) => setTimeout(r, debounceMs));
|
|
173
|
+
}
|
|
174
|
+
if (checkLatest()) {
|
|
175
|
+
const prevErrors = this.getMeta().errors;
|
|
176
|
+
try {
|
|
177
|
+
const rawError = await validate(value, this);
|
|
178
|
+
if (checkLatest()) {
|
|
179
|
+
const error = normalizeError(rawError);
|
|
180
|
+
this.setMeta((prev) => ({
|
|
181
|
+
...prev,
|
|
182
|
+
isValidating: false,
|
|
183
|
+
errors: [...prev.errors, error],
|
|
184
|
+
errorMap: {
|
|
185
|
+
...prev.errorMap,
|
|
186
|
+
[getErrorMapKey(cause)]: error
|
|
187
|
+
}
|
|
188
|
+
}));
|
|
189
|
+
(_b = (_a = this.getInfo()).validationResolve) == null ? void 0 : _b.call(_a, [...prevErrors, error]);
|
|
190
|
+
}
|
|
191
|
+
} catch (error) {
|
|
192
|
+
if (checkLatest()) {
|
|
193
|
+
(_d = (_c = this.getInfo()).validationReject) == null ? void 0 : _d.call(_c, [...prevErrors, error]);
|
|
194
|
+
throw error;
|
|
195
|
+
}
|
|
196
|
+
} finally {
|
|
197
|
+
if (checkLatest()) {
|
|
198
|
+
this.setMeta((prev) => ({ ...prev, isValidating: false }));
|
|
199
|
+
delete this.getInfo().validationPromise;
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
return this.getInfo().validationPromise ?? [];
|
|
204
|
+
};
|
|
205
|
+
this.validate = (cause, value) => {
|
|
206
|
+
if (!this.state.meta.isTouched)
|
|
207
|
+
return [];
|
|
208
|
+
this.validateSync(value, cause);
|
|
209
|
+
const errorMapKey = getErrorMapKey(cause);
|
|
210
|
+
if (this.getMeta().errorMap[errorMapKey]) {
|
|
211
|
+
if (!this.options.asyncAlways) {
|
|
212
|
+
return this.state.meta.errors;
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
return this.validateAsync(value, cause);
|
|
216
|
+
};
|
|
217
|
+
this.handleChange = (updater) => {
|
|
218
|
+
this.setValue(updater, { touch: true });
|
|
219
|
+
};
|
|
220
|
+
this.handleBlur = () => {
|
|
221
|
+
const prevTouched = this.state.meta.isTouched;
|
|
222
|
+
if (!prevTouched) {
|
|
223
|
+
this.setMeta((prev) => ({ ...prev, isTouched: true }));
|
|
224
|
+
this.validate("change");
|
|
225
|
+
}
|
|
226
|
+
this.validate("blur");
|
|
227
|
+
};
|
|
228
|
+
this.form = opts.form;
|
|
229
|
+
this.uid = uid++;
|
|
230
|
+
this.name = opts.name;
|
|
231
|
+
this.store = new import_store.Store(
|
|
232
|
+
{
|
|
233
|
+
value: this.getValue(),
|
|
234
|
+
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
|
|
235
|
+
meta: this._getMeta() ?? {
|
|
236
|
+
isValidating: false,
|
|
237
|
+
isTouched: false,
|
|
238
|
+
touchedErrors: [],
|
|
239
|
+
errors: [],
|
|
240
|
+
errorMap: {},
|
|
241
|
+
...opts.defaultMeta
|
|
242
|
+
}
|
|
243
|
+
},
|
|
244
|
+
{
|
|
245
|
+
onUpdate: () => {
|
|
246
|
+
const state = this.store.state;
|
|
247
|
+
state.meta.touchedErrors = state.meta.isTouched ? state.meta.errors : [];
|
|
248
|
+
this.prevState = state;
|
|
249
|
+
this.state = state;
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
);
|
|
253
|
+
this.state = this.store.state;
|
|
254
|
+
this.prevState = this.state;
|
|
255
|
+
this.options = opts;
|
|
256
|
+
}
|
|
257
|
+
};
|
|
258
|
+
_leaseValidateAsync = new WeakMap();
|
|
259
|
+
var FieldApi = _FieldApi;
|
|
260
|
+
function normalizeError(rawError) {
|
|
261
|
+
if (rawError) {
|
|
262
|
+
if (typeof rawError !== "string") {
|
|
263
|
+
return "Invalid Form Values";
|
|
264
|
+
}
|
|
265
|
+
return rawError;
|
|
266
|
+
}
|
|
267
|
+
return void 0;
|
|
268
|
+
}
|
|
269
|
+
function getErrorMapKey(cause) {
|
|
270
|
+
switch (cause) {
|
|
271
|
+
case "submit":
|
|
272
|
+
return "onSubmit";
|
|
273
|
+
case "change":
|
|
274
|
+
return "onChange";
|
|
275
|
+
case "blur":
|
|
276
|
+
return "onBlur";
|
|
277
|
+
case "mount":
|
|
278
|
+
return "onMount";
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
282
|
+
0 && (module.exports = {
|
|
283
|
+
FieldApi
|
|
284
|
+
});
|
|
285
|
+
//# sourceMappingURL=FieldApi.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/FieldApi.ts"],"sourcesContent":["import { type DeepKeys, type DeepValue, type Updater } from './utils'\nimport type { FormApi, ValidationError, ValidationErrorMap } from './FormApi'\nimport { Store } from '@tanstack/store'\n\nexport type ValidationCause = 'change' | 'blur' | 'submit' | 'mount'\n\ntype ValidateFn<TData, TFormData> = (\n value: TData,\n fieldApi: FieldApi<TData, TFormData>,\n) => ValidationError\n\ntype ValidateAsyncFn<TData, TFormData> = (\n value: TData,\n fieldApi: FieldApi<TData, TFormData>,\n) => ValidationError | Promise<ValidationError>\n\nexport interface FieldOptions<\n _TData,\n TFormData,\n /**\n * This allows us to restrict the name to only be a valid field name while\n * also assigning it to a generic\n */\n TName = unknown extends TFormData ? string : DeepKeys<TFormData>,\n /**\n * If TData is unknown, we can use the TName generic to determine the type\n */\n TData = unknown extends _TData ? DeepValue<TFormData, TName> : _TData,\n> {\n name: TName\n index?: TData extends any[] ? number : never\n defaultValue?: TData\n asyncDebounceMs?: number\n asyncAlways?: boolean\n onMount?: (formApi: FieldApi<TData, TFormData>) => void\n onChange?: ValidateFn<TData, TFormData>\n onChangeAsync?: ValidateAsyncFn<TData, TFormData>\n onChangeAsyncDebounceMs?: number\n onBlur?: ValidateFn<TData, TFormData>\n onBlurAsync?: ValidateAsyncFn<TData, TFormData>\n onBlurAsyncDebounceMs?: number\n onSubmitAsync?: ValidateAsyncFn<TData, TFormData>\n defaultMeta?: Partial<FieldMeta>\n}\n\nexport type FieldApiOptions<TData, TFormData> = FieldOptions<\n TData,\n TFormData\n> & {\n form: FormApi<TFormData>\n}\n\nexport type FieldMeta = {\n isTouched: boolean\n touchedErrors: ValidationError[]\n errors: ValidationError[]\n errorMap: ValidationErrorMap\n isValidating: boolean\n}\n\nlet uid = 0\n\nexport type FieldState<TData> = {\n value: TData\n meta: FieldMeta\n}\n\n/**\n * TData may not be known at the time of FieldApi construction, so we need to\n * use a conditional type to determine if TData is known or not.\n *\n * If TData is not known, we use the TFormData type to determine the type of\n * the field value based on the field name.\n */\ntype GetTData<Name, TData, TFormData> = unknown extends TData\n ? DeepValue<TFormData, Name>\n : TData\n\nexport class FieldApi<TData, TFormData> {\n uid: number\n form: FormApi<TFormData>\n name!: DeepKeys<TFormData>\n /**\n * This is a hack that allows us to use `GetTData` without calling it everywhere\n *\n * Unfortunately this hack appears to be needed alongside the `TName` hack\n * further up in this file. This properly types all of the internal methods,\n * while the `TName` hack types the options properly\n */\n _tdata!: GetTData<typeof this.name, TData, TFormData>\n store!: Store<FieldState<typeof this._tdata>>\n state!: FieldState<typeof this._tdata>\n prevState!: FieldState<typeof this._tdata>\n options: FieldOptions<typeof this._tdata, TFormData> = {} as any\n\n constructor(opts: FieldApiOptions<TData, TFormData>) {\n this.form = opts.form\n this.uid = uid++\n // Support field prefixing from FieldScope\n // let fieldPrefix = ''\n // if (this.form.fieldName) {\n // fieldPrefix = `${this.form.fieldName}.`\n // }\n\n this.name = opts.name as any\n\n this.store = new Store<FieldState<typeof this._tdata>>(\n {\n value: this.getValue(),\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n meta: this._getMeta() ?? {\n isValidating: false,\n isTouched: false,\n touchedErrors: [],\n errors: [],\n errorMap: {},\n ...opts.defaultMeta,\n },\n },\n {\n onUpdate: () => {\n const state = this.store.state\n\n state.meta.touchedErrors = state.meta.isTouched\n ? state.meta.errors\n : []\n\n this.prevState = state\n this.state = state\n },\n },\n )\n\n this.state = this.store.state\n this.prevState = this.state\n this.options = opts as never\n }\n\n mount = () => {\n const info = this.getInfo()\n info.instances[this.uid] = this\n\n const unsubscribe = this.form.store.subscribe(() => {\n this.store.batch(() => {\n const nextValue = this.getValue()\n const nextMeta = this.getMeta()\n\n if (nextValue !== this.state.value) {\n this.store.setState((prev) => ({ ...prev, value: nextValue }))\n }\n\n if (nextMeta !== this.state.meta) {\n this.store.setState((prev) => ({ ...prev, meta: nextMeta }))\n }\n })\n })\n\n this.update(this.options as never)\n this.options.onMount?.(this as never)\n\n return () => {\n unsubscribe()\n delete info.instances[this.uid]\n if (!Object.keys(info.instances).length) {\n delete this.form.fieldInfo[this.name]\n }\n }\n }\n\n update = (opts: FieldApiOptions<typeof this._tdata, TFormData>) => {\n // Default Value\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (this.state.value === undefined) {\n const formDefault =\n opts.form.options.defaultValues?.[opts.name as keyof TFormData]\n\n if (opts.defaultValue !== undefined) {\n this.setValue(opts.defaultValue as never)\n } else if (formDefault !== undefined) {\n this.setValue(formDefault as never)\n }\n }\n\n // Default Meta\n if (this._getMeta() === undefined) {\n this.setMeta(this.state.meta)\n }\n\n this.options = opts as never\n }\n\n getValue = (): typeof this._tdata => {\n return this.form.getFieldValue(this.name)\n }\n\n setValue = (\n updater: Updater<typeof this._tdata>,\n options?: { touch?: boolean; notify?: boolean },\n ) => {\n this.form.setFieldValue(this.name, updater as never, options)\n this.validate('change', this.state.value)\n }\n\n _getMeta = () => this.form.getFieldMeta(this.name)\n getMeta = () =>\n this._getMeta() ??\n ({\n isValidating: false,\n isTouched: false,\n touchedErrors: [],\n errors: [],\n errorMap: {},\n ...this.options.defaultMeta,\n } as FieldMeta)\n\n setMeta = (updater: Updater<FieldMeta>) =>\n this.form.setFieldMeta(this.name, updater)\n\n getInfo = () => this.form.getFieldInfo(this.name)\n\n pushValue = (\n value: typeof this._tdata extends any[]\n ? (typeof this._tdata)[number]\n : never,\n ) => this.form.pushFieldValue(this.name, value as any)\n\n insertValue = (\n index: number,\n value: typeof this._tdata extends any[]\n ? (typeof this._tdata)[number]\n : never,\n ) => this.form.insertFieldValue(this.name, index, value as any)\n\n removeValue = (index: number) => this.form.removeFieldValue(this.name, index)\n\n swapValues = (aIndex: number, bIndex: number) =>\n this.form.swapFieldValues(this.name, aIndex, bIndex)\n\n getSubField = <TName extends DeepKeys<typeof this._tdata>>(name: TName) =>\n new FieldApi<DeepValue<typeof this._tdata, TName>, TFormData>({\n name: `${this.name}.${name}` as never,\n form: this.form,\n })\n\n validateSync = (value = this.state.value, cause: ValidationCause) => {\n const { onChange, onBlur } = this.options\n const validate =\n cause === 'submit' ? undefined : cause === 'change' ? onChange : onBlur\n if (!validate) return\n\n // Use the validationCount for all field instances to\n // track freshness of the validation\n const validationCount = (this.getInfo().validationCount || 0) + 1\n this.getInfo().validationCount = validationCount\n const error = normalizeError(validate(value as never, this as never))\n const errorMapKey = getErrorMapKey(cause)\n if (error && this.state.meta.errorMap[errorMapKey] !== error) {\n this.setMeta((prev) => ({\n ...prev,\n errors: [...prev.errors, error],\n errorMap: {\n ...prev.errorMap,\n [getErrorMapKey(cause)]: error,\n },\n }))\n }\n\n // If a sync error is encountered for the errorMapKey (eg. onChange), cancel any async validation\n if (this.state.meta.errorMap[errorMapKey]) {\n this.cancelValidateAsync()\n }\n }\n\n #leaseValidateAsync = () => {\n const count = (this.getInfo().validationAsyncCount || 0) + 1\n this.getInfo().validationAsyncCount = count\n return count\n }\n\n cancelValidateAsync = () => {\n // Lease a new validation count to ignore any pending validations\n this.#leaseValidateAsync()\n // Cancel any pending validation state\n this.setMeta((prev) => ({\n ...prev,\n isValidating: false,\n }))\n }\n\n validateAsync = async (value = this.state.value, cause: ValidationCause) => {\n const {\n onChangeAsync,\n onBlurAsync,\n onSubmitAsync,\n asyncDebounceMs,\n onBlurAsyncDebounceMs,\n onChangeAsyncDebounceMs,\n } = this.options\n\n const validate =\n cause === 'change'\n ? onChangeAsync\n : cause === 'submit'\n ? onSubmitAsync\n : onBlurAsync\n if (!validate) return []\n const debounceMs =\n cause === 'submit'\n ? 0\n : (cause === 'change'\n ? onChangeAsyncDebounceMs\n : onBlurAsyncDebounceMs) ??\n asyncDebounceMs ??\n 0\n\n if (this.state.meta.isValidating !== true)\n this.setMeta((prev) => ({ ...prev, isValidating: true }))\n\n // Use the validationCount for all field instances to\n // track freshness of the validation\n const validationAsyncCount = this.#leaseValidateAsync()\n\n const checkLatest = () =>\n validationAsyncCount === this.getInfo().validationAsyncCount\n\n if (!this.getInfo().validationPromise) {\n this.getInfo().validationPromise = new Promise((resolve, reject) => {\n this.getInfo().validationResolve = resolve\n this.getInfo().validationReject = reject\n })\n }\n\n if (debounceMs > 0) {\n await new Promise((r) => setTimeout(r, debounceMs))\n }\n\n // Only kick off validation if this validation is the latest attempt\n if (checkLatest()) {\n const prevErrors = this.getMeta().errors\n try {\n const rawError = await validate(value as never, this as never)\n if (checkLatest()) {\n const error = normalizeError(rawError)\n this.setMeta((prev) => ({\n ...prev,\n isValidating: false,\n errors: [...prev.errors, error],\n errorMap: {\n ...prev.errorMap,\n [getErrorMapKey(cause)]: error,\n },\n }))\n this.getInfo().validationResolve?.([...prevErrors, error])\n }\n } catch (error) {\n if (checkLatest()) {\n this.getInfo().validationReject?.([...prevErrors, error])\n throw error\n }\n } finally {\n if (checkLatest()) {\n this.setMeta((prev) => ({ ...prev, isValidating: false }))\n delete this.getInfo().validationPromise\n }\n }\n }\n\n // Always return the latest validation promise to the caller\n return this.getInfo().validationPromise ?? []\n }\n\n validate = (\n cause: ValidationCause,\n value?: typeof this._tdata,\n ): ValidationError[] | Promise<ValidationError[]> => {\n // If the field is pristine and validatePristine is false, do not validate\n if (!this.state.meta.isTouched) return []\n // Attempt to sync validate first\n this.validateSync(value, cause)\n\n const errorMapKey = getErrorMapKey(cause)\n // If there is an error mapped to the errorMapKey (eg. onChange, onBlur, onSubmit), return the errors array, do not attempt async validation\n if (this.getMeta().errorMap[errorMapKey]) {\n if (!this.options.asyncAlways) {\n return this.state.meta.errors\n }\n }\n // No error? Attempt async validation\n return this.validateAsync(value, cause)\n }\n\n handleChange = (updater: Updater<typeof this._tdata>) => {\n this.setValue(updater, { touch: true })\n }\n\n handleBlur = () => {\n const prevTouched = this.state.meta.isTouched\n if (!prevTouched) {\n this.setMeta((prev) => ({ ...prev, isTouched: true }))\n this.validate('change')\n }\n this.validate('blur')\n }\n}\n\nfunction normalizeError(rawError?: ValidationError) {\n if (rawError) {\n if (typeof rawError !== 'string') {\n return 'Invalid Form Values'\n }\n\n return rawError\n }\n\n return undefined\n}\n\nfunction getErrorMapKey(cause: ValidationCause) {\n switch (cause) {\n case 'submit':\n return 'onSubmit'\n case 'change':\n return 'onChange'\n case 'blur':\n return 'onBlur'\n case 'mount':\n return 'onMount'\n }\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,252 @@
|
|
|
1
|
+
import {
|
|
2
|
+
__privateAdd,
|
|
3
|
+
__privateGet
|
|
4
|
+
} from "./chunk-4QZDOMDG.js";
|
|
5
|
+
|
|
6
|
+
// src/FieldApi.ts
|
|
7
|
+
import { Store } from "@tanstack/store";
|
|
8
|
+
var uid = 0;
|
|
9
|
+
var _leaseValidateAsync;
|
|
10
|
+
var _FieldApi = class _FieldApi {
|
|
11
|
+
constructor(opts) {
|
|
12
|
+
this.options = {};
|
|
13
|
+
this.mount = () => {
|
|
14
|
+
var _a, _b;
|
|
15
|
+
const info = this.getInfo();
|
|
16
|
+
info.instances[this.uid] = this;
|
|
17
|
+
const unsubscribe = this.form.store.subscribe(() => {
|
|
18
|
+
this.store.batch(() => {
|
|
19
|
+
const nextValue = this.getValue();
|
|
20
|
+
const nextMeta = this.getMeta();
|
|
21
|
+
if (nextValue !== this.state.value) {
|
|
22
|
+
this.store.setState((prev) => ({ ...prev, value: nextValue }));
|
|
23
|
+
}
|
|
24
|
+
if (nextMeta !== this.state.meta) {
|
|
25
|
+
this.store.setState((prev) => ({ ...prev, meta: nextMeta }));
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
this.update(this.options);
|
|
30
|
+
(_b = (_a = this.options).onMount) == null ? void 0 : _b.call(_a, this);
|
|
31
|
+
return () => {
|
|
32
|
+
unsubscribe();
|
|
33
|
+
delete info.instances[this.uid];
|
|
34
|
+
if (!Object.keys(info.instances).length) {
|
|
35
|
+
delete this.form.fieldInfo[this.name];
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
};
|
|
39
|
+
this.update = (opts) => {
|
|
40
|
+
var _a;
|
|
41
|
+
if (this.state.value === void 0) {
|
|
42
|
+
const formDefault = (_a = opts.form.options.defaultValues) == null ? void 0 : _a[opts.name];
|
|
43
|
+
if (opts.defaultValue !== void 0) {
|
|
44
|
+
this.setValue(opts.defaultValue);
|
|
45
|
+
} else if (formDefault !== void 0) {
|
|
46
|
+
this.setValue(formDefault);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
if (this._getMeta() === void 0) {
|
|
50
|
+
this.setMeta(this.state.meta);
|
|
51
|
+
}
|
|
52
|
+
this.options = opts;
|
|
53
|
+
};
|
|
54
|
+
this.getValue = () => {
|
|
55
|
+
return this.form.getFieldValue(this.name);
|
|
56
|
+
};
|
|
57
|
+
this.setValue = (updater, options) => {
|
|
58
|
+
this.form.setFieldValue(this.name, updater, options);
|
|
59
|
+
this.validate("change", this.state.value);
|
|
60
|
+
};
|
|
61
|
+
this._getMeta = () => this.form.getFieldMeta(this.name);
|
|
62
|
+
this.getMeta = () => this._getMeta() ?? {
|
|
63
|
+
isValidating: false,
|
|
64
|
+
isTouched: false,
|
|
65
|
+
touchedErrors: [],
|
|
66
|
+
errors: [],
|
|
67
|
+
errorMap: {},
|
|
68
|
+
...this.options.defaultMeta
|
|
69
|
+
};
|
|
70
|
+
this.setMeta = (updater) => this.form.setFieldMeta(this.name, updater);
|
|
71
|
+
this.getInfo = () => this.form.getFieldInfo(this.name);
|
|
72
|
+
this.pushValue = (value) => this.form.pushFieldValue(this.name, value);
|
|
73
|
+
this.insertValue = (index, value) => this.form.insertFieldValue(this.name, index, value);
|
|
74
|
+
this.removeValue = (index) => this.form.removeFieldValue(this.name, index);
|
|
75
|
+
this.swapValues = (aIndex, bIndex) => this.form.swapFieldValues(this.name, aIndex, bIndex);
|
|
76
|
+
this.getSubField = (name) => new _FieldApi({
|
|
77
|
+
name: `${this.name}.${name}`,
|
|
78
|
+
form: this.form
|
|
79
|
+
});
|
|
80
|
+
this.validateSync = (value = this.state.value, cause) => {
|
|
81
|
+
const { onChange, onBlur } = this.options;
|
|
82
|
+
const validate = cause === "submit" ? void 0 : cause === "change" ? onChange : onBlur;
|
|
83
|
+
if (!validate)
|
|
84
|
+
return;
|
|
85
|
+
const validationCount = (this.getInfo().validationCount || 0) + 1;
|
|
86
|
+
this.getInfo().validationCount = validationCount;
|
|
87
|
+
const error = normalizeError(validate(value, this));
|
|
88
|
+
const errorMapKey = getErrorMapKey(cause);
|
|
89
|
+
if (error && this.state.meta.errorMap[errorMapKey] !== error) {
|
|
90
|
+
this.setMeta((prev) => ({
|
|
91
|
+
...prev,
|
|
92
|
+
errors: [...prev.errors, error],
|
|
93
|
+
errorMap: {
|
|
94
|
+
...prev.errorMap,
|
|
95
|
+
[getErrorMapKey(cause)]: error
|
|
96
|
+
}
|
|
97
|
+
}));
|
|
98
|
+
}
|
|
99
|
+
if (this.state.meta.errorMap[errorMapKey]) {
|
|
100
|
+
this.cancelValidateAsync();
|
|
101
|
+
}
|
|
102
|
+
};
|
|
103
|
+
__privateAdd(this, _leaseValidateAsync, () => {
|
|
104
|
+
const count = (this.getInfo().validationAsyncCount || 0) + 1;
|
|
105
|
+
this.getInfo().validationAsyncCount = count;
|
|
106
|
+
return count;
|
|
107
|
+
});
|
|
108
|
+
this.cancelValidateAsync = () => {
|
|
109
|
+
__privateGet(this, _leaseValidateAsync).call(this);
|
|
110
|
+
this.setMeta((prev) => ({
|
|
111
|
+
...prev,
|
|
112
|
+
isValidating: false
|
|
113
|
+
}));
|
|
114
|
+
};
|
|
115
|
+
this.validateAsync = async (value = this.state.value, cause) => {
|
|
116
|
+
var _a, _b, _c, _d;
|
|
117
|
+
const {
|
|
118
|
+
onChangeAsync,
|
|
119
|
+
onBlurAsync,
|
|
120
|
+
onSubmitAsync,
|
|
121
|
+
asyncDebounceMs,
|
|
122
|
+
onBlurAsyncDebounceMs,
|
|
123
|
+
onChangeAsyncDebounceMs
|
|
124
|
+
} = this.options;
|
|
125
|
+
const validate = cause === "change" ? onChangeAsync : cause === "submit" ? onSubmitAsync : onBlurAsync;
|
|
126
|
+
if (!validate)
|
|
127
|
+
return [];
|
|
128
|
+
const debounceMs = cause === "submit" ? 0 : (cause === "change" ? onChangeAsyncDebounceMs : onBlurAsyncDebounceMs) ?? asyncDebounceMs ?? 0;
|
|
129
|
+
if (this.state.meta.isValidating !== true)
|
|
130
|
+
this.setMeta((prev) => ({ ...prev, isValidating: true }));
|
|
131
|
+
const validationAsyncCount = __privateGet(this, _leaseValidateAsync).call(this);
|
|
132
|
+
const checkLatest = () => validationAsyncCount === this.getInfo().validationAsyncCount;
|
|
133
|
+
if (!this.getInfo().validationPromise) {
|
|
134
|
+
this.getInfo().validationPromise = new Promise((resolve, reject) => {
|
|
135
|
+
this.getInfo().validationResolve = resolve;
|
|
136
|
+
this.getInfo().validationReject = reject;
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
if (debounceMs > 0) {
|
|
140
|
+
await new Promise((r) => setTimeout(r, debounceMs));
|
|
141
|
+
}
|
|
142
|
+
if (checkLatest()) {
|
|
143
|
+
const prevErrors = this.getMeta().errors;
|
|
144
|
+
try {
|
|
145
|
+
const rawError = await validate(value, this);
|
|
146
|
+
if (checkLatest()) {
|
|
147
|
+
const error = normalizeError(rawError);
|
|
148
|
+
this.setMeta((prev) => ({
|
|
149
|
+
...prev,
|
|
150
|
+
isValidating: false,
|
|
151
|
+
errors: [...prev.errors, error],
|
|
152
|
+
errorMap: {
|
|
153
|
+
...prev.errorMap,
|
|
154
|
+
[getErrorMapKey(cause)]: error
|
|
155
|
+
}
|
|
156
|
+
}));
|
|
157
|
+
(_b = (_a = this.getInfo()).validationResolve) == null ? void 0 : _b.call(_a, [...prevErrors, error]);
|
|
158
|
+
}
|
|
159
|
+
} catch (error) {
|
|
160
|
+
if (checkLatest()) {
|
|
161
|
+
(_d = (_c = this.getInfo()).validationReject) == null ? void 0 : _d.call(_c, [...prevErrors, error]);
|
|
162
|
+
throw error;
|
|
163
|
+
}
|
|
164
|
+
} finally {
|
|
165
|
+
if (checkLatest()) {
|
|
166
|
+
this.setMeta((prev) => ({ ...prev, isValidating: false }));
|
|
167
|
+
delete this.getInfo().validationPromise;
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
return this.getInfo().validationPromise ?? [];
|
|
172
|
+
};
|
|
173
|
+
this.validate = (cause, value) => {
|
|
174
|
+
if (!this.state.meta.isTouched)
|
|
175
|
+
return [];
|
|
176
|
+
this.validateSync(value, cause);
|
|
177
|
+
const errorMapKey = getErrorMapKey(cause);
|
|
178
|
+
if (this.getMeta().errorMap[errorMapKey]) {
|
|
179
|
+
if (!this.options.asyncAlways) {
|
|
180
|
+
return this.state.meta.errors;
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
return this.validateAsync(value, cause);
|
|
184
|
+
};
|
|
185
|
+
this.handleChange = (updater) => {
|
|
186
|
+
this.setValue(updater, { touch: true });
|
|
187
|
+
};
|
|
188
|
+
this.handleBlur = () => {
|
|
189
|
+
const prevTouched = this.state.meta.isTouched;
|
|
190
|
+
if (!prevTouched) {
|
|
191
|
+
this.setMeta((prev) => ({ ...prev, isTouched: true }));
|
|
192
|
+
this.validate("change");
|
|
193
|
+
}
|
|
194
|
+
this.validate("blur");
|
|
195
|
+
};
|
|
196
|
+
this.form = opts.form;
|
|
197
|
+
this.uid = uid++;
|
|
198
|
+
this.name = opts.name;
|
|
199
|
+
this.store = new Store(
|
|
200
|
+
{
|
|
201
|
+
value: this.getValue(),
|
|
202
|
+
// eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
|
|
203
|
+
meta: this._getMeta() ?? {
|
|
204
|
+
isValidating: false,
|
|
205
|
+
isTouched: false,
|
|
206
|
+
touchedErrors: [],
|
|
207
|
+
errors: [],
|
|
208
|
+
errorMap: {},
|
|
209
|
+
...opts.defaultMeta
|
|
210
|
+
}
|
|
211
|
+
},
|
|
212
|
+
{
|
|
213
|
+
onUpdate: () => {
|
|
214
|
+
const state = this.store.state;
|
|
215
|
+
state.meta.touchedErrors = state.meta.isTouched ? state.meta.errors : [];
|
|
216
|
+
this.prevState = state;
|
|
217
|
+
this.state = state;
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
);
|
|
221
|
+
this.state = this.store.state;
|
|
222
|
+
this.prevState = this.state;
|
|
223
|
+
this.options = opts;
|
|
224
|
+
}
|
|
225
|
+
};
|
|
226
|
+
_leaseValidateAsync = new WeakMap();
|
|
227
|
+
var FieldApi = _FieldApi;
|
|
228
|
+
function normalizeError(rawError) {
|
|
229
|
+
if (rawError) {
|
|
230
|
+
if (typeof rawError !== "string") {
|
|
231
|
+
return "Invalid Form Values";
|
|
232
|
+
}
|
|
233
|
+
return rawError;
|
|
234
|
+
}
|
|
235
|
+
return void 0;
|
|
236
|
+
}
|
|
237
|
+
function getErrorMapKey(cause) {
|
|
238
|
+
switch (cause) {
|
|
239
|
+
case "submit":
|
|
240
|
+
return "onSubmit";
|
|
241
|
+
case "change":
|
|
242
|
+
return "onChange";
|
|
243
|
+
case "blur":
|
|
244
|
+
return "onBlur";
|
|
245
|
+
case "mount":
|
|
246
|
+
return "onMount";
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
export {
|
|
250
|
+
FieldApi
|
|
251
|
+
};
|
|
252
|
+
//# sourceMappingURL=FieldApi.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/FieldApi.ts"],"sourcesContent":["import { type DeepKeys, type DeepValue, type Updater } from './utils'\nimport type { FormApi, ValidationError, ValidationErrorMap } from './FormApi'\nimport { Store } from '@tanstack/store'\n\nexport type ValidationCause = 'change' | 'blur' | 'submit' | 'mount'\n\ntype ValidateFn<TData, TFormData> = (\n value: TData,\n fieldApi: FieldApi<TData, TFormData>,\n) => ValidationError\n\ntype ValidateAsyncFn<TData, TFormData> = (\n value: TData,\n fieldApi: FieldApi<TData, TFormData>,\n) => ValidationError | Promise<ValidationError>\n\nexport interface FieldOptions<\n _TData,\n TFormData,\n /**\n * This allows us to restrict the name to only be a valid field name while\n * also assigning it to a generic\n */\n TName = unknown extends TFormData ? string : DeepKeys<TFormData>,\n /**\n * If TData is unknown, we can use the TName generic to determine the type\n */\n TData = unknown extends _TData ? DeepValue<TFormData, TName> : _TData,\n> {\n name: TName\n index?: TData extends any[] ? number : never\n defaultValue?: TData\n asyncDebounceMs?: number\n asyncAlways?: boolean\n onMount?: (formApi: FieldApi<TData, TFormData>) => void\n onChange?: ValidateFn<TData, TFormData>\n onChangeAsync?: ValidateAsyncFn<TData, TFormData>\n onChangeAsyncDebounceMs?: number\n onBlur?: ValidateFn<TData, TFormData>\n onBlurAsync?: ValidateAsyncFn<TData, TFormData>\n onBlurAsyncDebounceMs?: number\n onSubmitAsync?: ValidateAsyncFn<TData, TFormData>\n defaultMeta?: Partial<FieldMeta>\n}\n\nexport type FieldApiOptions<TData, TFormData> = FieldOptions<\n TData,\n TFormData\n> & {\n form: FormApi<TFormData>\n}\n\nexport type FieldMeta = {\n isTouched: boolean\n touchedErrors: ValidationError[]\n errors: ValidationError[]\n errorMap: ValidationErrorMap\n isValidating: boolean\n}\n\nlet uid = 0\n\nexport type FieldState<TData> = {\n value: TData\n meta: FieldMeta\n}\n\n/**\n * TData may not be known at the time of FieldApi construction, so we need to\n * use a conditional type to determine if TData is known or not.\n *\n * If TData is not known, we use the TFormData type to determine the type of\n * the field value based on the field name.\n */\ntype GetTData<Name, TData, TFormData> = unknown extends TData\n ? DeepValue<TFormData, Name>\n : TData\n\nexport class FieldApi<TData, TFormData> {\n uid: number\n form: FormApi<TFormData>\n name!: DeepKeys<TFormData>\n /**\n * This is a hack that allows us to use `GetTData` without calling it everywhere\n *\n * Unfortunately this hack appears to be needed alongside the `TName` hack\n * further up in this file. This properly types all of the internal methods,\n * while the `TName` hack types the options properly\n */\n _tdata!: GetTData<typeof this.name, TData, TFormData>\n store!: Store<FieldState<typeof this._tdata>>\n state!: FieldState<typeof this._tdata>\n prevState!: FieldState<typeof this._tdata>\n options: FieldOptions<typeof this._tdata, TFormData> = {} as any\n\n constructor(opts: FieldApiOptions<TData, TFormData>) {\n this.form = opts.form\n this.uid = uid++\n // Support field prefixing from FieldScope\n // let fieldPrefix = ''\n // if (this.form.fieldName) {\n // fieldPrefix = `${this.form.fieldName}.`\n // }\n\n this.name = opts.name as any\n\n this.store = new Store<FieldState<typeof this._tdata>>(\n {\n value: this.getValue(),\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n meta: this._getMeta() ?? {\n isValidating: false,\n isTouched: false,\n touchedErrors: [],\n errors: [],\n errorMap: {},\n ...opts.defaultMeta,\n },\n },\n {\n onUpdate: () => {\n const state = this.store.state\n\n state.meta.touchedErrors = state.meta.isTouched\n ? state.meta.errors\n : []\n\n this.prevState = state\n this.state = state\n },\n },\n )\n\n this.state = this.store.state\n this.prevState = this.state\n this.options = opts as never\n }\n\n mount = () => {\n const info = this.getInfo()\n info.instances[this.uid] = this\n\n const unsubscribe = this.form.store.subscribe(() => {\n this.store.batch(() => {\n const nextValue = this.getValue()\n const nextMeta = this.getMeta()\n\n if (nextValue !== this.state.value) {\n this.store.setState((prev) => ({ ...prev, value: nextValue }))\n }\n\n if (nextMeta !== this.state.meta) {\n this.store.setState((prev) => ({ ...prev, meta: nextMeta }))\n }\n })\n })\n\n this.update(this.options as never)\n this.options.onMount?.(this as never)\n\n return () => {\n unsubscribe()\n delete info.instances[this.uid]\n if (!Object.keys(info.instances).length) {\n delete this.form.fieldInfo[this.name]\n }\n }\n }\n\n update = (opts: FieldApiOptions<typeof this._tdata, TFormData>) => {\n // Default Value\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (this.state.value === undefined) {\n const formDefault =\n opts.form.options.defaultValues?.[opts.name as keyof TFormData]\n\n if (opts.defaultValue !== undefined) {\n this.setValue(opts.defaultValue as never)\n } else if (formDefault !== undefined) {\n this.setValue(formDefault as never)\n }\n }\n\n // Default Meta\n if (this._getMeta() === undefined) {\n this.setMeta(this.state.meta)\n }\n\n this.options = opts as never\n }\n\n getValue = (): typeof this._tdata => {\n return this.form.getFieldValue(this.name)\n }\n\n setValue = (\n updater: Updater<typeof this._tdata>,\n options?: { touch?: boolean; notify?: boolean },\n ) => {\n this.form.setFieldValue(this.name, updater as never, options)\n this.validate('change', this.state.value)\n }\n\n _getMeta = () => this.form.getFieldMeta(this.name)\n getMeta = () =>\n this._getMeta() ??\n ({\n isValidating: false,\n isTouched: false,\n touchedErrors: [],\n errors: [],\n errorMap: {},\n ...this.options.defaultMeta,\n } as FieldMeta)\n\n setMeta = (updater: Updater<FieldMeta>) =>\n this.form.setFieldMeta(this.name, updater)\n\n getInfo = () => this.form.getFieldInfo(this.name)\n\n pushValue = (\n value: typeof this._tdata extends any[]\n ? (typeof this._tdata)[number]\n : never,\n ) => this.form.pushFieldValue(this.name, value as any)\n\n insertValue = (\n index: number,\n value: typeof this._tdata extends any[]\n ? (typeof this._tdata)[number]\n : never,\n ) => this.form.insertFieldValue(this.name, index, value as any)\n\n removeValue = (index: number) => this.form.removeFieldValue(this.name, index)\n\n swapValues = (aIndex: number, bIndex: number) =>\n this.form.swapFieldValues(this.name, aIndex, bIndex)\n\n getSubField = <TName extends DeepKeys<typeof this._tdata>>(name: TName) =>\n new FieldApi<DeepValue<typeof this._tdata, TName>, TFormData>({\n name: `${this.name}.${name}` as never,\n form: this.form,\n })\n\n validateSync = (value = this.state.value, cause: ValidationCause) => {\n const { onChange, onBlur } = this.options\n const validate =\n cause === 'submit' ? undefined : cause === 'change' ? onChange : onBlur\n if (!validate) return\n\n // Use the validationCount for all field instances to\n // track freshness of the validation\n const validationCount = (this.getInfo().validationCount || 0) + 1\n this.getInfo().validationCount = validationCount\n const error = normalizeError(validate(value as never, this as never))\n const errorMapKey = getErrorMapKey(cause)\n if (error && this.state.meta.errorMap[errorMapKey] !== error) {\n this.setMeta((prev) => ({\n ...prev,\n errors: [...prev.errors, error],\n errorMap: {\n ...prev.errorMap,\n [getErrorMapKey(cause)]: error,\n },\n }))\n }\n\n // If a sync error is encountered for the errorMapKey (eg. onChange), cancel any async validation\n if (this.state.meta.errorMap[errorMapKey]) {\n this.cancelValidateAsync()\n }\n }\n\n #leaseValidateAsync = () => {\n const count = (this.getInfo().validationAsyncCount || 0) + 1\n this.getInfo().validationAsyncCount = count\n return count\n }\n\n cancelValidateAsync = () => {\n // Lease a new validation count to ignore any pending validations\n this.#leaseValidateAsync()\n // Cancel any pending validation state\n this.setMeta((prev) => ({\n ...prev,\n isValidating: false,\n }))\n }\n\n validateAsync = async (value = this.state.value, cause: ValidationCause) => {\n const {\n onChangeAsync,\n onBlurAsync,\n onSubmitAsync,\n asyncDebounceMs,\n onBlurAsyncDebounceMs,\n onChangeAsyncDebounceMs,\n } = this.options\n\n const validate =\n cause === 'change'\n ? onChangeAsync\n : cause === 'submit'\n ? onSubmitAsync\n : onBlurAsync\n if (!validate) return []\n const debounceMs =\n cause === 'submit'\n ? 0\n : (cause === 'change'\n ? onChangeAsyncDebounceMs\n : onBlurAsyncDebounceMs) ??\n asyncDebounceMs ??\n 0\n\n if (this.state.meta.isValidating !== true)\n this.setMeta((prev) => ({ ...prev, isValidating: true }))\n\n // Use the validationCount for all field instances to\n // track freshness of the validation\n const validationAsyncCount = this.#leaseValidateAsync()\n\n const checkLatest = () =>\n validationAsyncCount === this.getInfo().validationAsyncCount\n\n if (!this.getInfo().validationPromise) {\n this.getInfo().validationPromise = new Promise((resolve, reject) => {\n this.getInfo().validationResolve = resolve\n this.getInfo().validationReject = reject\n })\n }\n\n if (debounceMs > 0) {\n await new Promise((r) => setTimeout(r, debounceMs))\n }\n\n // Only kick off validation if this validation is the latest attempt\n if (checkLatest()) {\n const prevErrors = this.getMeta().errors\n try {\n const rawError = await validate(value as never, this as never)\n if (checkLatest()) {\n const error = normalizeError(rawError)\n this.setMeta((prev) => ({\n ...prev,\n isValidating: false,\n errors: [...prev.errors, error],\n errorMap: {\n ...prev.errorMap,\n [getErrorMapKey(cause)]: error,\n },\n }))\n this.getInfo().validationResolve?.([...prevErrors, error])\n }\n } catch (error) {\n if (checkLatest()) {\n this.getInfo().validationReject?.([...prevErrors, error])\n throw error\n }\n } finally {\n if (checkLatest()) {\n this.setMeta((prev) => ({ ...prev, isValidating: false }))\n delete this.getInfo().validationPromise\n }\n }\n }\n\n // Always return the latest validation promise to the caller\n return this.getInfo().validationPromise ?? []\n }\n\n validate = (\n cause: ValidationCause,\n value?: typeof this._tdata,\n ): ValidationError[] | Promise<ValidationError[]> => {\n // If the field is pristine and validatePristine is false, do not validate\n if (!this.state.meta.isTouched) return []\n // Attempt to sync validate first\n this.validateSync(value, cause)\n\n const errorMapKey = getErrorMapKey(cause)\n // If there is an error mapped to the errorMapKey (eg. onChange, onBlur, onSubmit), return the errors array, do not attempt async validation\n if (this.getMeta().errorMap[errorMapKey]) {\n if (!this.options.asyncAlways) {\n return this.state.meta.errors\n }\n }\n // No error? Attempt async validation\n return this.validateAsync(value, cause)\n }\n\n handleChange = (updater: Updater<typeof this._tdata>) => {\n this.setValue(updater, { touch: true })\n }\n\n handleBlur = () => {\n const prevTouched = this.state.meta.isTouched\n if (!prevTouched) {\n this.setMeta((prev) => ({ ...prev, isTouched: true }))\n this.validate('change')\n }\n this.validate('blur')\n }\n}\n\nfunction normalizeError(rawError?: ValidationError) {\n if (rawError) {\n if (typeof rawError !== 'string') {\n return 'Invalid Form Values'\n }\n\n return rawError\n }\n\n return undefined\n}\n\nfunction getErrorMapKey(cause: ValidationCause) {\n switch (cause) {\n case 'submit':\n return 'onSubmit'\n case 'change':\n return 'onChange'\n case 'blur':\n return 'onBlur'\n case 'mount':\n return 'onMount'\n }\n}\n"],"mappings":"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","names":[]}
|