@jcoreio/zod-forms 2.0.0-beta.4 → 2.1.0
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/ConditionalValidator.d.ts.map +1 -1
- package/ConditionalValidator.js +4 -2
- package/ConditionalValidator.js.map +1 -1
- package/ConditionalValidator.mjs +3 -1
- package/ConditionalValidator.mjs.map +1 -1
- package/FieldPath.d.ts.map +1 -1
- package/FieldPath.js +1 -0
- package/FieldPath.js.map +1 -1
- package/FieldPath.mjs.map +1 -1
- package/FormState.d.ts +7 -4
- package/FormState.d.ts.map +1 -1
- package/FormState.js.map +1 -1
- package/FormState.mjs.map +1 -1
- package/actions/arrayActions.js.map +1 -1
- package/actions/arrayActions.mjs.map +1 -1
- package/actions/setSubmitStatus.d.ts +1 -1
- package/createFormMiddleware.js +3 -3
- package/createFormMiddleware.js.map +1 -1
- package/createFormMiddleware.mjs.map +1 -1
- package/createFormProvider.d.ts +9 -3
- package/createFormProvider.d.ts.map +1 -1
- package/createFormProvider.js +10 -3
- package/createFormProvider.js.map +1 -1
- package/createFormProvider.mjs +53 -44
- package/createFormProvider.mjs.map +1 -1
- package/createFormReducer.js +16 -16
- package/createFormReducer.js.map +1 -1
- package/createSelectFieldErrorMap.d.ts +3 -3
- package/createSelectFieldErrorMap.js.map +1 -1
- package/createSelectFieldErrorMap.mjs.map +1 -1
- package/createSelectFormStatus.d.ts +10 -10
- package/createSelectFormStatus.d.ts.map +1 -1
- package/createSelectFormStatus.js +2 -2
- package/createSelectFormStatus.js.map +1 -1
- package/createSelectFormStatus.mjs +1 -1
- package/createSelectFormStatus.mjs.map +1 -1
- package/createSelectFormValues.js.map +1 -1
- package/createZodForm.d.ts +10 -5
- package/createZodForm.d.ts.map +1 -1
- package/package.json +5 -4
- package/reducers/addHandlers.d.ts +2 -2
- package/reducers/addHandlers.d.ts.map +1 -1
- package/reducers/arrayMove.js.map +1 -1
- package/reducers/arrayMove.mjs.map +1 -1
- package/reducers/initialize.d.ts +4 -4
- package/reducers/initialize.d.ts.map +1 -1
- package/reducers/initialize.js.map +1 -1
- package/reducers/initialize.mjs.map +1 -1
- package/reducers/removeHandlers.d.ts +2 -2
- package/reducers/removeHandlers.d.ts.map +1 -1
- package/reducers/setMeta.d.ts.map +1 -1
- package/reducers/setMeta.js +4 -1
- package/reducers/setMeta.js.map +1 -1
- package/reducers/setMeta.mjs +4 -1
- package/reducers/setMeta.mjs.map +1 -1
- package/reducers/setParsedValue.d.ts +2 -2
- package/reducers/setParsedValue.d.ts.map +1 -1
- package/reducers/setParsedValue.js +1 -1
- package/reducers/setParsedValue.js.map +1 -1
- package/reducers/setParsedValue.mjs +1 -1
- package/reducers/setParsedValue.mjs.map +1 -1
- package/reducers/setSubmitStatus.d.ts +2 -2
- package/reducers/setSubmitStatus.d.ts.map +1 -1
- package/reducers/setValue.d.ts +1 -1
- package/reducers/setValue.d.ts.map +1 -1
- package/reducers/submitSucceeded.d.ts +1 -1
- package/reducers/submitSucceeded.d.ts.map +1 -1
- package/reducers/util/updateRawArray.js.map +1 -1
- package/reducers/util/updateRawArray.mjs.map +1 -1
- package/src/ConditionalValidator.ts +11 -12
- package/src/FieldPath.ts +34 -54
- package/src/FormState.ts +5 -4
- package/src/actions/arrayActions.ts +4 -4
- package/src/createFormMiddleware.ts +2 -2
- package/src/createFormProvider.tsx +14 -2
- package/src/createSelectFieldErrorMap.ts +12 -10
- package/src/createSelectFormStatus.ts +3 -1
- package/src/reducers/arrayMove.ts +2 -2
- package/src/reducers/initialize.ts +3 -3
- package/src/reducers/setMeta.ts +4 -1
- package/src/reducers/setParsedValue.ts +10 -9
- package/src/reducers/util/updateRawArray.ts +4 -4
- package/src/useArrayField.ts +39 -28
- package/src/useField.ts +92 -27
- package/src/useFormContext.ts +2 -2
- package/src/useFormDispatch.ts +3 -7
- package/src/useHtmlField.ts +47 -41
- package/src/useInitialize.ts +1 -1
- package/src/util/DeepPartial.ts +2 -3
- package/src/util/PathInType.ts +16 -16
- package/src/util/SchemaAt.ts +38 -49
- package/src/util/bindActionsToField.ts +6 -7
- package/src/util/parsePathstring.ts +47 -41
- package/src/util/pathstring.ts +9 -13
- package/src/util/set.ts +4 -1
- package/useArrayField.d.ts +2 -2
- package/useArrayField.d.ts.map +1 -1
- package/useArrayField.js +22 -8
- package/useArrayField.js.map +1 -1
- package/useArrayField.mjs +12 -2
- package/useArrayField.mjs.map +1 -1
- package/useField.d.ts +6 -3
- package/useField.d.ts.map +1 -1
- package/useField.js +55 -22
- package/useField.js.map +1 -1
- package/useField.mjs +34 -16
- package/useField.mjs.map +1 -1
- package/useFormContext.js.map +1 -1
- package/useFormContext.mjs.map +1 -1
- package/useFormDispatch.d.ts +1 -3
- package/useFormDispatch.d.ts.map +1 -1
- package/useFormDispatch.js.map +1 -1
- package/useFormDispatch.mjs.map +1 -1
- package/useFormStatus.d.ts +1 -1
- package/useHtmlField.d.ts +2 -1
- package/useHtmlField.d.ts.map +1 -1
- package/useHtmlField.js +35 -24
- package/useHtmlField.js.map +1 -1
- package/useHtmlField.mjs +36 -21
- package/useHtmlField.mjs.map +1 -1
- package/useInitialize.js.map +1 -1
- package/useInitialize.mjs.map +1 -1
- package/useSubmit.js.map +1 -1
- package/util/DeepPartial.d.ts.map +1 -1
- package/util/DeepPartial.js.map +1 -1
- package/util/DeepPartial.mjs.map +1 -1
- package/util/PathInType.d.ts +2 -1
- package/util/PathInType.d.ts.map +1 -1
- package/util/PathInType.js.map +1 -1
- package/util/PathInType.mjs.map +1 -1
- package/util/SchemaAt.d.ts +1 -1
- package/util/SchemaAt.d.ts.map +1 -1
- package/util/SchemaAt.js.map +1 -1
- package/util/SchemaAt.mjs.map +1 -1
- package/util/bindActionsToField.d.ts +1 -1
- package/util/bindActionsToField.d.ts.map +1 -1
- package/util/bindActionsToField.js.map +1 -1
- package/util/bindActionsToField.mjs.map +1 -1
- package/util/parsePathstring.d.ts +23 -6
- package/util/parsePathstring.d.ts.map +1 -1
- package/util/parsePathstring.js.map +1 -1
- package/util/parsePathstring.mjs.map +1 -1
- package/util/pathstring.d.ts +2 -8
- package/util/pathstring.d.ts.map +1 -1
- package/util/pathstring.js.map +1 -1
- package/util/pathstring.mjs.map +1 -1
- package/util/set.d.ts.map +1 -1
- package/util/set.js +1 -4
- package/util/set.js.map +1 -1
- package/util/set.mjs +1 -3
- package/util/set.mjs.map +1 -1
package/useField.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useField.js","names":["_FieldPath","require","_get","_react","_interopRequireDefault","_useFormSelector","_useFormContext3","_reselect","_reactRedux","_fastDeepEqual","_maybeParse","_bindActionsToField","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","useFieldBase","field","_useFormContext","useFormContext","setParsedValue","setValue","setMeta","selectFormValues","selectFieldErrorMap","useFormSelector","untypedUseFormSelector","valuesSelector","React","useMemo","createSelector","createStructuredSelector","parsedValue","_ref","parsedValues","get","path","value","_ref2","values","initialParsedValue","_ref3","initialParsedValues","initialValue","_ref4","initialValues","_ref5","_ref5$parsedValue","maybeParse","schema","_ref5$initialParsedVa","dirty","isEqual","pristine","pathstring","shallowEqual","error","state","meta","fieldMeta","submitFailed","boundActions","bindActionsToField","visited","touched","valid","invalid","Boolean","useField","_useFormContext2","root","FieldPath"],"sources":["src/useField.ts"],"sourcesContent":["import z from 'zod'\nimport { BasePath, FieldPath } from './FieldPath'\nimport { FieldMeta } from './FormState'\nimport { get } from './util/get'\nimport React from 'react'\nimport { setParsedValue } from './actions/setParsedValue'\nimport { setValue } from './actions/setValue'\nimport { setMeta } from './actions/setMeta'\nimport {\n useFormSelector as untypedUseFormSelector,\n TypedUseFormSelector,\n} from './useFormSelector'\nimport { useFormContext } from './useFormContext'\nimport { createSelector, createStructuredSelector } from 'reselect'\nimport { shallowEqual } from 'react-redux'\nimport isEqual from 'fast-deep-equal'\nimport { PathInSchema, PathstringInSchema } from './util/PathInSchema'\nimport { parsePathstring } from './util/parsePathstring'\nimport { SchemaAt } from './util/SchemaAt'\nimport { maybeParse } from './util/maybeParse'\nimport { bindActionsToField } from './util/bindActionsToField'\nimport { DeepPartial } from './util/DeepPartial'\n\nexport type UseFieldProps<Field extends FieldPath> = FieldMeta &\n ReturnType<\n typeof bindActionsToField<\n Field,\n {\n setParsedValue: typeof setParsedValue<Field>\n setValue: typeof setValue<Field>\n setMeta: typeof setMeta<Field>\n }\n >\n > & {\n parsedValue?: z.output<Field['schema']>\n value?: DeepPartial<z.input<Field['schema']>>\n initialParsedValue?: z.output<Field['schema']>\n initialValue?: DeepPartial<z.input<Field['schema']>>\n error?: string\n dirty: boolean\n pristine: boolean\n valid: boolean\n invalid: boolean\n }\n\nexport interface TypedUseField<T extends z.ZodTypeAny> {\n <Field extends FieldPath>(field: Field): UseFieldProps<Field>\n <Path extends PathInSchema<T>>(path: Path): UseFieldProps<\n FieldPath<SchemaAt<T, Path>>\n >\n <Pathstring extends PathstringInSchema<T>>(path: Pathstring): UseFieldProps<\n FieldPath<SchemaAt<T, parsePathstring<Pathstring>>>\n >\n}\n\nfunction useFieldBase<T extends z.ZodTypeAny, Field extends FieldPath>(\n field: Field\n): UseFieldProps<Field> {\n type Schema = Field['schema']\n\n const {\n setParsedValue,\n setValue,\n setMeta,\n selectFormValues,\n selectFieldErrorMap,\n } = useFormContext<T>()\n\n const useFormSelector = untypedUseFormSelector as TypedUseFormSelector<T>\n\n const valuesSelector = React.useMemo(\n () =>\n createSelector(\n [selectFormValues],\n createSelector(\n [\n createStructuredSelector({\n parsedValue: ({ parsedValues }) =>\n get(parsedValues, field.path) as z.output<Schema> | undefined,\n value: ({ values }) => get(values, field.path) as unknown,\n initialParsedValue: ({ initialParsedValues }) =>\n get(initialParsedValues, field.path) as\n | z.output<Schema>\n | undefined,\n initialValue: ({ initialValues }) =>\n get(initialValues, field.path) as unknown,\n }),\n ],\n ({\n value,\n parsedValue = maybeParse(field.schema, value),\n initialValue,\n initialParsedValue = maybeParse(field.schema, initialValue),\n }) => {\n const dirty = !isEqual(value, initialValue)\n const pristine = !dirty\n return {\n parsedValue,\n value,\n initialParsedValue,\n initialValue,\n dirty,\n pristine,\n }\n }\n )\n ),\n [field.pathstring]\n )\n\n const parsedValues = useFormSelector(valuesSelector, shallowEqual)\n\n const error = useFormSelector(\n (state) => selectFieldErrorMap(state)[field.pathstring]\n )\n const meta = useFormSelector((state) => state.fieldMeta[field.pathstring])\n const submitFailed = useFormSelector((state) => state.submitFailed)\n\n const boundActions = React.useMemo(\n () => bindActionsToField({ setParsedValue, setValue, setMeta }, field),\n [field.pathstring]\n )\n\n return React.useMemo(\n () => ({\n ...boundActions,\n ...parsedValues,\n visited: meta?.visited || false,\n touched: meta?.touched || submitFailed,\n error,\n valid: !error,\n invalid: Boolean(error),\n }),\n [field.pathstring, parsedValues, meta, error, submitFailed]\n ) as any\n}\n\nexport function useField<Field extends FieldPath>(\n field: Field\n): UseFieldProps<Field>\nexport function useField<\n T extends z.ZodTypeAny = z.ZodBranded<\n z.ZodNever,\n 'cast to TypedUseArray<T> to pass a path array'\n >,\n Path extends PathInSchema<T> = any\n>(field: Path): UseFieldProps<FieldPath<SchemaAt<T, Path>>>\nexport function useField<\n T extends z.ZodTypeAny = z.ZodBranded<\n z.ZodNever,\n 'cast to TypedUseArray<T> to pass a pathstring'\n >,\n Pathstring extends PathstringInSchema<T> = any\n>(\n field: Pathstring\n): UseFieldProps<FieldPath<SchemaAt<T, parsePathstring<Pathstring>>>>\nexport function useField<T extends z.ZodTypeAny>(\n field: FieldPath | BasePath | string\n): UseFieldProps<any> | { ERROR: string } {\n const { root } = useFormContext<T>()\n return useFieldBase(\n field instanceof FieldPath ? field : root.get(field as any)\n )\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"useField.js","names":["_FieldPath","require","_get","_react","_interopRequireDefault","_useFormSelector","_useFormContext3","_reselect","_reactRedux","_fastDeepEqual","_maybeParse","_bindActionsToField","_zodInvertible","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","useFieldBase","field","_ref","undefined","_ref$normalizeOnMount","normalizeOnMount","_useFormContext","useFormContext","setParsedValue","setValue","setMeta","selectFormValues","selectFieldErrorMap","useFormSelector","untypedUseFormSelector","valuesSelector","React","useMemo","createSelector","createStructuredSelector","parsedValue","state","parsedValues","get","path","value","values","initialParsedValue","initialParsedValues","initialValue","initialValues","_ref2","_ref2$parsedValue","maybeParse","schema","_ref2$initialParsedVa","dirty","isEqual","pristine","pathstring","shallowEqual","error","meta","fieldMeta","submitFailed","initialized","boundActions","bindActionsToField","info","useRef","mounted","normalizedValue","current","parsed","safeParse","formatted","success","invert","data","useEffect","visited","touched","customMeta","valid","invalid","Boolean","useField","options","_useFormContext2","root","FieldPath"],"sources":["src/useField.ts"],"sourcesContent":["import z from 'zod'\nimport { BasePath, FieldPath } from './FieldPath'\nimport { FieldMeta } from './FormState'\nimport { get } from './util/get'\nimport React from 'react'\nimport { setParsedValue } from './actions/setParsedValue'\nimport { setValue } from './actions/setValue'\nimport { setMeta } from './actions/setMeta'\nimport {\n useFormSelector as untypedUseFormSelector,\n TypedUseFormSelector,\n} from './useFormSelector'\nimport { useFormContext } from './useFormContext'\nimport { createSelector, createStructuredSelector } from 'reselect'\nimport { shallowEqual } from 'react-redux'\nimport isEqual from 'fast-deep-equal'\nimport { PathInSchema, PathstringInSchema } from './util/PathInSchema'\nimport { parsePathstring } from './util/parsePathstring'\nimport { SchemaAt } from './util/SchemaAt'\nimport { maybeParse } from './util/maybeParse'\nimport { bindActionsToField } from './util/bindActionsToField'\nimport { DeepPartial } from './util/DeepPartial'\nimport { invert } from 'zod-invertible'\nimport { SelectFormValues } from './createSelectFormValues'\n\nexport type UseFieldProps<Field extends FieldPath> = FieldMeta &\n ReturnType<\n typeof bindActionsToField<\n Field,\n {\n setParsedValue: typeof setParsedValue<Field>\n setValue: typeof setValue<Field>\n setMeta: typeof setMeta<Field>\n }\n >\n > & {\n parsedValue?: z.output<Field['schema']>\n value?: DeepPartial<z.input<Field['schema']>>\n initialParsedValue?: z.output<Field['schema']>\n initialValue?: DeepPartial<z.input<Field['schema']>>\n error?: string\n dirty: boolean\n pristine: boolean\n valid: boolean\n invalid: boolean\n }\n\nexport interface TypedUseField<T extends z.ZodTypeAny> {\n <Field extends FieldPath>(field: Field): UseFieldProps<Field>\n <Path extends PathInSchema<T>>(\n path: Path\n ): UseFieldProps<FieldPath<SchemaAt<T, Path>>>\n <Pathstring extends PathstringInSchema<T>>(\n path: Pathstring\n ): UseFieldProps<FieldPath<SchemaAt<T, parsePathstring<Pathstring>>>>\n}\n\nexport type UseFieldOptions = {\n normalizeOnMount?: boolean\n}\n\nfunction useFieldBase<\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-parameters\n T extends z.ZodTypeAny,\n Field extends FieldPath,\n>(\n field: Field,\n { normalizeOnMount = true }: UseFieldOptions = {}\n): UseFieldProps<Field> {\n type Schema = Field['schema']\n\n const {\n setParsedValue,\n setValue,\n setMeta,\n selectFormValues,\n selectFieldErrorMap,\n } = useFormContext<T>()\n\n type FormValues = ReturnType<SelectFormValues<T>>\n\n const useFormSelector = untypedUseFormSelector as TypedUseFormSelector<T>\n\n const valuesSelector = React.useMemo(\n () =>\n createSelector(\n [selectFormValues],\n createSelector(\n [\n createStructuredSelector({\n parsedValue: createSelector(\n (state: FormValues) => state.parsedValues,\n (parsedValues) =>\n get(parsedValues, field.path) as z.output<Schema> | undefined\n ),\n value: createSelector(\n (state: FormValues) => state.values,\n (values) =>\n get(values, field.path) as\n | DeepPartial<z.input<Schema>>\n | undefined\n ),\n initialParsedValue: createSelector(\n (state: FormValues) => state.initialParsedValues,\n (initialParsedValues) =>\n get(initialParsedValues, field.path) as\n | z.output<Schema>\n | undefined\n ),\n initialValue: createSelector(\n (state: FormValues) => state.initialValues,\n (initialValues) =>\n get(initialValues, field.path) as\n | DeepPartial<z.input<Schema>>\n | undefined\n ),\n }),\n ],\n ({\n value,\n parsedValue = maybeParse<Schema>(field.schema, value),\n initialValue,\n initialParsedValue = maybeParse<Schema>(field.schema, initialValue),\n }) => {\n // console.error(new Error('selector'), { value, parsedValue })\n const dirty = !isEqual(parsedValue, initialParsedValue)\n const pristine = !dirty\n return {\n parsedValue,\n value,\n initialParsedValue,\n initialValue,\n dirty,\n pristine,\n }\n }\n )\n ),\n [field.pathstring]\n )\n\n const parsedValues = useFormSelector(valuesSelector, shallowEqual)\n\n const error = useFormSelector(\n (state) => selectFieldErrorMap(state)[field.pathstring]\n )\n const meta = useFormSelector((state) => state.fieldMeta[field.pathstring])\n const submitFailed = useFormSelector((state) => state.submitFailed)\n const initialized = useFormSelector((state) => state.initialized)\n\n const boundActions = React.useMemo(\n () => bindActionsToField({ setParsedValue, setValue, setMeta }, field),\n [field.pathstring]\n )\n\n const info = React.useRef({ mounted: false, initialized })\n\n let normalizedValue = parsedValues.value\n if (\n normalizeOnMount &&\n (!info.current.mounted || (!info.current.initialized && initialized))\n ) {\n const parsed = field.schema.safeParse(parsedValues.value)\n const formatted =\n parsed.success ? invert(field.schema).safeParse(parsed.data) : undefined\n if (formatted?.success && formatted.data !== parsedValues.value) {\n normalizedValue = formatted.data\n }\n }\n info.current.mounted = true\n info.current.initialized = initialized\n\n React.useEffect(() => {\n if (normalizeOnMount && !isEqual(normalizedValue, parsedValues.value)) {\n boundActions.setValue(normalizedValue)\n }\n }, [])\n\n return React.useMemo(\n () => ({\n ...boundActions,\n ...parsedValues,\n value: normalizedValue,\n visited: meta?.visited || false,\n touched: meta?.touched || submitFailed,\n customMeta: meta?.customMeta,\n error,\n valid: !error,\n invalid: Boolean(error),\n }),\n [field.pathstring, parsedValues, meta, error, submitFailed]\n ) as any\n}\n\nexport function useField<Field extends FieldPath>(\n field: Field,\n options?: UseFieldOptions\n): UseFieldProps<Field>\nexport function useField<\n T extends z.ZodTypeAny = z.ZodBranded<\n z.ZodNever,\n 'cast to TypedUseArray<T> to pass a path array'\n >,\n Path extends PathInSchema<T> = any,\n>(\n field: Path,\n options?: UseFieldOptions\n): UseFieldProps<FieldPath<SchemaAt<T, Path>>>\nexport function useField<\n T extends z.ZodTypeAny = z.ZodBranded<\n z.ZodNever,\n 'cast to TypedUseArray<T> to pass a pathstring'\n >,\n Pathstring extends PathstringInSchema<T> = any,\n>(\n field: Pathstring,\n\n options?: UseFieldOptions\n): UseFieldProps<FieldPath<SchemaAt<T, parsePathstring<Pathstring>>>>\nexport function useField<T extends z.ZodTypeAny>(\n field: FieldPath | BasePath | string,\n options?: UseFieldOptions\n): UseFieldProps<any> | { ERROR: string } {\n const { root } = useFormContext<T>()\n return useFieldBase(\n field instanceof FieldPath ? field : root.get(field as any),\n options\n )\n}\n"],"mappings":"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","ignoreList":[]}
|
package/useField.mjs
CHANGED
|
@@ -8,7 +8,10 @@ import { shallowEqual } from 'react-redux';
|
|
|
8
8
|
import isEqual from 'fast-deep-equal';
|
|
9
9
|
import { maybeParse } from "./util/maybeParse.mjs";
|
|
10
10
|
import { bindActionsToField } from "./util/bindActionsToField.mjs";
|
|
11
|
-
|
|
11
|
+
import { invert } from 'zod-invertible';
|
|
12
|
+
function useFieldBase(field, {
|
|
13
|
+
normalizeOnMount = true
|
|
14
|
+
} = {}) {
|
|
12
15
|
const {
|
|
13
16
|
setParsedValue,
|
|
14
17
|
setValue,
|
|
@@ -18,25 +21,18 @@ function useFieldBase(field) {
|
|
|
18
21
|
} = useFormContext();
|
|
19
22
|
const useFormSelector = untypedUseFormSelector;
|
|
20
23
|
const valuesSelector = React.useMemo(() => createSelector([selectFormValues], createSelector([createStructuredSelector({
|
|
21
|
-
parsedValue: (
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
values
|
|
26
|
-
}) => get(values, field.path),
|
|
27
|
-
initialParsedValue: ({
|
|
28
|
-
initialParsedValues
|
|
29
|
-
}) => get(initialParsedValues, field.path),
|
|
30
|
-
initialValue: ({
|
|
31
|
-
initialValues
|
|
32
|
-
}) => get(initialValues, field.path)
|
|
24
|
+
parsedValue: createSelector(state => state.parsedValues, parsedValues => get(parsedValues, field.path)),
|
|
25
|
+
value: createSelector(state => state.values, values => get(values, field.path)),
|
|
26
|
+
initialParsedValue: createSelector(state => state.initialParsedValues, initialParsedValues => get(initialParsedValues, field.path)),
|
|
27
|
+
initialValue: createSelector(state => state.initialValues, initialValues => get(initialValues, field.path))
|
|
33
28
|
})], ({
|
|
34
29
|
value,
|
|
35
30
|
parsedValue = maybeParse(field.schema, value),
|
|
36
31
|
initialValue,
|
|
37
32
|
initialParsedValue = maybeParse(field.schema, initialValue)
|
|
38
33
|
}) => {
|
|
39
|
-
|
|
34
|
+
// console.error(new Error('selector'), { value, parsedValue })
|
|
35
|
+
const dirty = !isEqual(parsedValue, initialParsedValue);
|
|
40
36
|
const pristine = !dirty;
|
|
41
37
|
return {
|
|
42
38
|
parsedValue,
|
|
@@ -51,25 +47,47 @@ function useFieldBase(field) {
|
|
|
51
47
|
const error = useFormSelector(state => selectFieldErrorMap(state)[field.pathstring]);
|
|
52
48
|
const meta = useFormSelector(state => state.fieldMeta[field.pathstring]);
|
|
53
49
|
const submitFailed = useFormSelector(state => state.submitFailed);
|
|
50
|
+
const initialized = useFormSelector(state => state.initialized);
|
|
54
51
|
const boundActions = React.useMemo(() => bindActionsToField({
|
|
55
52
|
setParsedValue,
|
|
56
53
|
setValue,
|
|
57
54
|
setMeta
|
|
58
55
|
}, field), [field.pathstring]);
|
|
56
|
+
const info = React.useRef({
|
|
57
|
+
mounted: false,
|
|
58
|
+
initialized
|
|
59
|
+
});
|
|
60
|
+
let normalizedValue = parsedValues.value;
|
|
61
|
+
if (normalizeOnMount && (!info.current.mounted || !info.current.initialized && initialized)) {
|
|
62
|
+
const parsed = field.schema.safeParse(parsedValues.value);
|
|
63
|
+
const formatted = parsed.success ? invert(field.schema).safeParse(parsed.data) : undefined;
|
|
64
|
+
if (formatted !== null && formatted !== void 0 && formatted.success && formatted.data !== parsedValues.value) {
|
|
65
|
+
normalizedValue = formatted.data;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
info.current.mounted = true;
|
|
69
|
+
info.current.initialized = initialized;
|
|
70
|
+
React.useEffect(() => {
|
|
71
|
+
if (normalizeOnMount && !isEqual(normalizedValue, parsedValues.value)) {
|
|
72
|
+
boundActions.setValue(normalizedValue);
|
|
73
|
+
}
|
|
74
|
+
}, []);
|
|
59
75
|
return React.useMemo(() => ({
|
|
60
76
|
...boundActions,
|
|
61
77
|
...parsedValues,
|
|
78
|
+
value: normalizedValue,
|
|
62
79
|
visited: (meta === null || meta === void 0 ? void 0 : meta.visited) || false,
|
|
63
80
|
touched: (meta === null || meta === void 0 ? void 0 : meta.touched) || submitFailed,
|
|
81
|
+
customMeta: meta === null || meta === void 0 ? void 0 : meta.customMeta,
|
|
64
82
|
error,
|
|
65
83
|
valid: !error,
|
|
66
84
|
invalid: Boolean(error)
|
|
67
85
|
}), [field.pathstring, parsedValues, meta, error, submitFailed]);
|
|
68
86
|
}
|
|
69
|
-
export function useField(field) {
|
|
87
|
+
export function useField(field, options) {
|
|
70
88
|
const {
|
|
71
89
|
root
|
|
72
90
|
} = useFormContext();
|
|
73
|
-
return useFieldBase(field instanceof FieldPath ? field : root.get(field));
|
|
91
|
+
return useFieldBase(field instanceof FieldPath ? field : root.get(field), options);
|
|
74
92
|
}
|
|
75
93
|
//# sourceMappingURL=useField.mjs.map
|
package/useField.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useField.mjs","names":["FieldPath","get","React","useFormSelector","untypedUseFormSelector","useFormContext","createSelector","createStructuredSelector","shallowEqual","isEqual","maybeParse","bindActionsToField","useFieldBase","field","setParsedValue","setValue","setMeta","selectFormValues","selectFieldErrorMap","valuesSelector","useMemo","parsedValue","parsedValues","path","value","values","initialParsedValue","initialParsedValues","initialValue","initialValues","schema","dirty","pristine","pathstring","error","state","meta","fieldMeta","submitFailed","boundActions","visited","touched","valid","invalid","Boolean","useField","root"],"sources":["src/useField.ts"],"sourcesContent":["import z from 'zod'\nimport { BasePath, FieldPath } from './FieldPath'\nimport { FieldMeta } from './FormState'\nimport { get } from './util/get'\nimport React from 'react'\nimport { setParsedValue } from './actions/setParsedValue'\nimport { setValue } from './actions/setValue'\nimport { setMeta } from './actions/setMeta'\nimport {\n useFormSelector as untypedUseFormSelector,\n TypedUseFormSelector,\n} from './useFormSelector'\nimport { useFormContext } from './useFormContext'\nimport { createSelector, createStructuredSelector } from 'reselect'\nimport { shallowEqual } from 'react-redux'\nimport isEqual from 'fast-deep-equal'\nimport { PathInSchema, PathstringInSchema } from './util/PathInSchema'\nimport { parsePathstring } from './util/parsePathstring'\nimport { SchemaAt } from './util/SchemaAt'\nimport { maybeParse } from './util/maybeParse'\nimport { bindActionsToField } from './util/bindActionsToField'\nimport { DeepPartial } from './util/DeepPartial'\n\nexport type UseFieldProps<Field extends FieldPath> = FieldMeta &\n ReturnType<\n typeof bindActionsToField<\n Field,\n {\n setParsedValue: typeof setParsedValue<Field>\n setValue: typeof setValue<Field>\n setMeta: typeof setMeta<Field>\n }\n >\n > & {\n parsedValue?: z.output<Field['schema']>\n value?: DeepPartial<z.input<Field['schema']>>\n initialParsedValue?: z.output<Field['schema']>\n initialValue?: DeepPartial<z.input<Field['schema']>>\n error?: string\n dirty: boolean\n pristine: boolean\n valid: boolean\n invalid: boolean\n }\n\nexport interface TypedUseField<T extends z.ZodTypeAny> {\n <Field extends FieldPath>(field: Field): UseFieldProps<Field>\n <Path extends PathInSchema<T>>(path: Path): UseFieldProps<\n FieldPath<SchemaAt<T, Path>>\n >\n <Pathstring extends PathstringInSchema<T>>(path: Pathstring): UseFieldProps<\n FieldPath<SchemaAt<T, parsePathstring<Pathstring>>>\n >\n}\n\nfunction useFieldBase<T extends z.ZodTypeAny, Field extends FieldPath>(\n field: Field\n): UseFieldProps<Field> {\n type Schema = Field['schema']\n\n const {\n setParsedValue,\n setValue,\n setMeta,\n selectFormValues,\n selectFieldErrorMap,\n } = useFormContext<T>()\n\n const useFormSelector = untypedUseFormSelector as TypedUseFormSelector<T>\n\n const valuesSelector = React.useMemo(\n () =>\n createSelector(\n [selectFormValues],\n createSelector(\n [\n createStructuredSelector({\n parsedValue: ({ parsedValues }) =>\n get(parsedValues, field.path) as z.output<Schema> | undefined,\n value: ({ values }) => get(values, field.path) as unknown,\n initialParsedValue: ({ initialParsedValues }) =>\n get(initialParsedValues, field.path) as\n | z.output<Schema>\n | undefined,\n initialValue: ({ initialValues }) =>\n get(initialValues, field.path) as unknown,\n }),\n ],\n ({\n value,\n parsedValue = maybeParse(field.schema, value),\n initialValue,\n initialParsedValue = maybeParse(field.schema, initialValue),\n }) => {\n const dirty = !isEqual(value, initialValue)\n const pristine = !dirty\n return {\n parsedValue,\n value,\n initialParsedValue,\n initialValue,\n dirty,\n pristine,\n }\n }\n )\n ),\n [field.pathstring]\n )\n\n const parsedValues = useFormSelector(valuesSelector, shallowEqual)\n\n const error = useFormSelector(\n (state) => selectFieldErrorMap(state)[field.pathstring]\n )\n const meta = useFormSelector((state) => state.fieldMeta[field.pathstring])\n const submitFailed = useFormSelector((state) => state.submitFailed)\n\n const boundActions = React.useMemo(\n () => bindActionsToField({ setParsedValue, setValue, setMeta }, field),\n [field.pathstring]\n )\n\n return React.useMemo(\n () => ({\n ...boundActions,\n ...parsedValues,\n visited: meta?.visited || false,\n touched: meta?.touched || submitFailed,\n error,\n valid: !error,\n invalid: Boolean(error),\n }),\n [field.pathstring, parsedValues, meta, error, submitFailed]\n ) as any\n}\n\nexport function useField<Field extends FieldPath>(\n field: Field\n): UseFieldProps<Field>\nexport function useField<\n T extends z.ZodTypeAny = z.ZodBranded<\n z.ZodNever,\n 'cast to TypedUseArray<T> to pass a path array'\n >,\n Path extends PathInSchema<T> = any\n>(field: Path): UseFieldProps<FieldPath<SchemaAt<T, Path>>>\nexport function useField<\n T extends z.ZodTypeAny = z.ZodBranded<\n z.ZodNever,\n 'cast to TypedUseArray<T> to pass a pathstring'\n >,\n Pathstring extends PathstringInSchema<T> = any\n>(\n field: Pathstring\n): UseFieldProps<FieldPath<SchemaAt<T, parsePathstring<Pathstring>>>>\nexport function useField<T extends z.ZodTypeAny>(\n field: FieldPath | BasePath | string\n): UseFieldProps<any> | { ERROR: string } {\n const { root } = useFormContext<T>()\n return useFieldBase(\n field instanceof FieldPath ? field : root.get(field as any)\n )\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"useField.mjs","names":["FieldPath","get","React","useFormSelector","untypedUseFormSelector","useFormContext","createSelector","createStructuredSelector","shallowEqual","isEqual","maybeParse","bindActionsToField","invert","useFieldBase","field","normalizeOnMount","setParsedValue","setValue","setMeta","selectFormValues","selectFieldErrorMap","valuesSelector","useMemo","parsedValue","state","parsedValues","path","value","values","initialParsedValue","initialParsedValues","initialValue","initialValues","schema","dirty","pristine","pathstring","error","meta","fieldMeta","submitFailed","initialized","boundActions","info","useRef","mounted","normalizedValue","current","parsed","safeParse","formatted","success","data","undefined","useEffect","visited","touched","customMeta","valid","invalid","Boolean","useField","options","root"],"sources":["src/useField.ts"],"sourcesContent":["import z from 'zod'\nimport { BasePath, FieldPath } from './FieldPath'\nimport { FieldMeta } from './FormState'\nimport { get } from './util/get'\nimport React from 'react'\nimport { setParsedValue } from './actions/setParsedValue'\nimport { setValue } from './actions/setValue'\nimport { setMeta } from './actions/setMeta'\nimport {\n useFormSelector as untypedUseFormSelector,\n TypedUseFormSelector,\n} from './useFormSelector'\nimport { useFormContext } from './useFormContext'\nimport { createSelector, createStructuredSelector } from 'reselect'\nimport { shallowEqual } from 'react-redux'\nimport isEqual from 'fast-deep-equal'\nimport { PathInSchema, PathstringInSchema } from './util/PathInSchema'\nimport { parsePathstring } from './util/parsePathstring'\nimport { SchemaAt } from './util/SchemaAt'\nimport { maybeParse } from './util/maybeParse'\nimport { bindActionsToField } from './util/bindActionsToField'\nimport { DeepPartial } from './util/DeepPartial'\nimport { invert } from 'zod-invertible'\nimport { SelectFormValues } from './createSelectFormValues'\n\nexport type UseFieldProps<Field extends FieldPath> = FieldMeta &\n ReturnType<\n typeof bindActionsToField<\n Field,\n {\n setParsedValue: typeof setParsedValue<Field>\n setValue: typeof setValue<Field>\n setMeta: typeof setMeta<Field>\n }\n >\n > & {\n parsedValue?: z.output<Field['schema']>\n value?: DeepPartial<z.input<Field['schema']>>\n initialParsedValue?: z.output<Field['schema']>\n initialValue?: DeepPartial<z.input<Field['schema']>>\n error?: string\n dirty: boolean\n pristine: boolean\n valid: boolean\n invalid: boolean\n }\n\nexport interface TypedUseField<T extends z.ZodTypeAny> {\n <Field extends FieldPath>(field: Field): UseFieldProps<Field>\n <Path extends PathInSchema<T>>(\n path: Path\n ): UseFieldProps<FieldPath<SchemaAt<T, Path>>>\n <Pathstring extends PathstringInSchema<T>>(\n path: Pathstring\n ): UseFieldProps<FieldPath<SchemaAt<T, parsePathstring<Pathstring>>>>\n}\n\nexport type UseFieldOptions = {\n normalizeOnMount?: boolean\n}\n\nfunction useFieldBase<\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-parameters\n T extends z.ZodTypeAny,\n Field extends FieldPath,\n>(\n field: Field,\n { normalizeOnMount = true }: UseFieldOptions = {}\n): UseFieldProps<Field> {\n type Schema = Field['schema']\n\n const {\n setParsedValue,\n setValue,\n setMeta,\n selectFormValues,\n selectFieldErrorMap,\n } = useFormContext<T>()\n\n type FormValues = ReturnType<SelectFormValues<T>>\n\n const useFormSelector = untypedUseFormSelector as TypedUseFormSelector<T>\n\n const valuesSelector = React.useMemo(\n () =>\n createSelector(\n [selectFormValues],\n createSelector(\n [\n createStructuredSelector({\n parsedValue: createSelector(\n (state: FormValues) => state.parsedValues,\n (parsedValues) =>\n get(parsedValues, field.path) as z.output<Schema> | undefined\n ),\n value: createSelector(\n (state: FormValues) => state.values,\n (values) =>\n get(values, field.path) as\n | DeepPartial<z.input<Schema>>\n | undefined\n ),\n initialParsedValue: createSelector(\n (state: FormValues) => state.initialParsedValues,\n (initialParsedValues) =>\n get(initialParsedValues, field.path) as\n | z.output<Schema>\n | undefined\n ),\n initialValue: createSelector(\n (state: FormValues) => state.initialValues,\n (initialValues) =>\n get(initialValues, field.path) as\n | DeepPartial<z.input<Schema>>\n | undefined\n ),\n }),\n ],\n ({\n value,\n parsedValue = maybeParse<Schema>(field.schema, value),\n initialValue,\n initialParsedValue = maybeParse<Schema>(field.schema, initialValue),\n }) => {\n // console.error(new Error('selector'), { value, parsedValue })\n const dirty = !isEqual(parsedValue, initialParsedValue)\n const pristine = !dirty\n return {\n parsedValue,\n value,\n initialParsedValue,\n initialValue,\n dirty,\n pristine,\n }\n }\n )\n ),\n [field.pathstring]\n )\n\n const parsedValues = useFormSelector(valuesSelector, shallowEqual)\n\n const error = useFormSelector(\n (state) => selectFieldErrorMap(state)[field.pathstring]\n )\n const meta = useFormSelector((state) => state.fieldMeta[field.pathstring])\n const submitFailed = useFormSelector((state) => state.submitFailed)\n const initialized = useFormSelector((state) => state.initialized)\n\n const boundActions = React.useMemo(\n () => bindActionsToField({ setParsedValue, setValue, setMeta }, field),\n [field.pathstring]\n )\n\n const info = React.useRef({ mounted: false, initialized })\n\n let normalizedValue = parsedValues.value\n if (\n normalizeOnMount &&\n (!info.current.mounted || (!info.current.initialized && initialized))\n ) {\n const parsed = field.schema.safeParse(parsedValues.value)\n const formatted =\n parsed.success ? invert(field.schema).safeParse(parsed.data) : undefined\n if (formatted?.success && formatted.data !== parsedValues.value) {\n normalizedValue = formatted.data\n }\n }\n info.current.mounted = true\n info.current.initialized = initialized\n\n React.useEffect(() => {\n if (normalizeOnMount && !isEqual(normalizedValue, parsedValues.value)) {\n boundActions.setValue(normalizedValue)\n }\n }, [])\n\n return React.useMemo(\n () => ({\n ...boundActions,\n ...parsedValues,\n value: normalizedValue,\n visited: meta?.visited || false,\n touched: meta?.touched || submitFailed,\n customMeta: meta?.customMeta,\n error,\n valid: !error,\n invalid: Boolean(error),\n }),\n [field.pathstring, parsedValues, meta, error, submitFailed]\n ) as any\n}\n\nexport function useField<Field extends FieldPath>(\n field: Field,\n options?: UseFieldOptions\n): UseFieldProps<Field>\nexport function useField<\n T extends z.ZodTypeAny = z.ZodBranded<\n z.ZodNever,\n 'cast to TypedUseArray<T> to pass a path array'\n >,\n Path extends PathInSchema<T> = any,\n>(\n field: Path,\n options?: UseFieldOptions\n): UseFieldProps<FieldPath<SchemaAt<T, Path>>>\nexport function useField<\n T extends z.ZodTypeAny = z.ZodBranded<\n z.ZodNever,\n 'cast to TypedUseArray<T> to pass a pathstring'\n >,\n Pathstring extends PathstringInSchema<T> = any,\n>(\n field: Pathstring,\n\n options?: UseFieldOptions\n): UseFieldProps<FieldPath<SchemaAt<T, parsePathstring<Pathstring>>>>\nexport function useField<T extends z.ZodTypeAny>(\n field: FieldPath | BasePath | string,\n options?: UseFieldOptions\n): UseFieldProps<any> | { ERROR: string } {\n const { root } = useFormContext<T>()\n return useFieldBase(\n field instanceof FieldPath ? field : root.get(field as any),\n options\n )\n}\n"],"mappings":"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","ignoreList":[]}
|
package/useFormContext.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useFormContext.js","names":["_react","_interopRequireDefault","require","_FormContext","useFormContext","props","React","useContext","FormContext","Error"],"sources":["src/useFormContext.ts"],"sourcesContent":["import z from 'zod'\nimport React from 'react'\nimport { FormContext, FormContextProps } from './FormContext'\n\nexport function useFormContext<\n T extends z.ZodTypeAny = z.ZodBranded<\n z.ZodNever,\n 'you must pass a schema type'\n
|
|
1
|
+
{"version":3,"file":"useFormContext.js","names":["_react","_interopRequireDefault","require","_FormContext","useFormContext","props","React","useContext","FormContext","Error"],"sources":["src/useFormContext.ts"],"sourcesContent":["import z from 'zod'\nimport React from 'react'\nimport { FormContext, FormContextProps } from './FormContext'\n\nexport function useFormContext<\n T extends z.ZodTypeAny = z.ZodBranded<\n z.ZodNever,\n 'you must pass a schema type'\n >,\n>(): FormContextProps<T> {\n const props: FormContextProps<T> | null = React.useContext(FormContext) as any\n if (!props) {\n throw new Error(`must be used inside a <FormProvider>`)\n }\n return props\n}\n"],"mappings":";;;;;;;AACA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,YAAA,GAAAD,OAAA;AAEO,SAASE,cAAcA,CAAA,EAKL;EACvB,IAAMC,KAAiC,GAAGC,iBAAK,CAACC,UAAU,CAACC,wBAAW,CAAQ;EAC9E,IAAI,CAACH,KAAK,EAAE;IACV,MAAM,IAAII,KAAK,uCAAuC,CAAC;EACzD;EACA,OAAOJ,KAAK;AACd","ignoreList":[]}
|
package/useFormContext.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useFormContext.mjs","names":["React","FormContext","useFormContext","props","useContext","Error"],"sources":["src/useFormContext.ts"],"sourcesContent":["import z from 'zod'\nimport React from 'react'\nimport { FormContext, FormContextProps } from './FormContext'\n\nexport function useFormContext<\n T extends z.ZodTypeAny = z.ZodBranded<\n z.ZodNever,\n 'you must pass a schema type'\n
|
|
1
|
+
{"version":3,"file":"useFormContext.mjs","names":["React","FormContext","useFormContext","props","useContext","Error"],"sources":["src/useFormContext.ts"],"sourcesContent":["import z from 'zod'\nimport React from 'react'\nimport { FormContext, FormContextProps } from './FormContext'\n\nexport function useFormContext<\n T extends z.ZodTypeAny = z.ZodBranded<\n z.ZodNever,\n 'you must pass a schema type'\n >,\n>(): FormContextProps<T> {\n const props: FormContextProps<T> | null = React.useContext(FormContext) as any\n if (!props) {\n throw new Error(`must be used inside a <FormProvider>`)\n }\n return props\n}\n"],"mappings":"AACA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,WAAW;AAEpB,OAAO,SAASC,cAAcA,CAAA,EAKL;EACvB,MAAMC,KAAiC,GAAGH,KAAK,CAACI,UAAU,CAACH,WAAW,CAAQ;EAC9E,IAAI,CAACE,KAAK,EAAE;IACV,MAAM,IAAIE,KAAK,CAAC,sCAAsC,CAAC;EACzD;EACA,OAAOF,KAAK;AACd","ignoreList":[]}
|
package/useFormDispatch.d.ts
CHANGED
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
import z from 'zod';
|
|
2
2
|
import { FormAction } from './FormAction';
|
|
3
3
|
import { Dispatch } from 'redux';
|
|
4
|
-
export declare const useFormDispatch:
|
|
5
|
-
declare function useFormDispatchType<T extends z.ZodTypeAny = z.ZodBranded<z.ZodNever, 'you must pass a schema type'>>(): Dispatch<FormAction<T>>;
|
|
6
|
-
export {};
|
|
4
|
+
export declare const useFormDispatch: <T extends z.ZodTypeAny = z.ZodBranded<z.ZodNever, "you must pass a schema type">>() => Dispatch<FormAction<T>>;
|
|
7
5
|
//# sourceMappingURL=useFormDispatch.d.ts.map
|
package/useFormDispatch.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useFormDispatch.d.ts","sourceRoot":"","sources":["src/useFormDispatch.ts"],"names":[],"mappings":"AAEA,OAAO,CAAC,MAAM,KAAK,CAAA;AACnB,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAA;AACzC,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEhC,eAAO,MAAM,eAAe,
|
|
1
|
+
{"version":3,"file":"useFormDispatch.d.ts","sourceRoot":"","sources":["src/useFormDispatch.ts"],"names":[],"mappings":"AAEA,OAAO,CAAC,MAAM,KAAK,CAAA;AACnB,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAA;AACzC,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEhC,eAAO,MAAM,eAAe,EAA2C,CACrE,CAAC,SAAS,CAAC,CAAC,UAAU,GAAG,CAAC,CAAC,UAAU,CACnC,CAAC,CAAC,QAAQ,EACV,6BAA6B,CAC9B,OACI,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAA"}
|
package/useFormDispatch.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useFormDispatch.js","names":["_reactRedux","require","_FormStateContext","useFormDispatch","exports","createDispatchHook","FormStateContext"],"sources":["src/useFormDispatch.ts"],"sourcesContent":["import { createDispatchHook } from 'react-redux'\nimport { FormStateContext } from './FormStateContext'\nimport z from 'zod'\nimport { FormAction } from './FormAction'\nimport { Dispatch } from 'redux'\n\nexport const useFormDispatch = createDispatchHook(
|
|
1
|
+
{"version":3,"file":"useFormDispatch.js","names":["_reactRedux","require","_FormStateContext","useFormDispatch","exports","createDispatchHook","FormStateContext"],"sources":["src/useFormDispatch.ts"],"sourcesContent":["import { createDispatchHook } from 'react-redux'\nimport { FormStateContext } from './FormStateContext'\nimport z from 'zod'\nimport { FormAction } from './FormAction'\nimport { Dispatch } from 'redux'\n\nexport const useFormDispatch = createDispatchHook(FormStateContext) as <\n T extends z.ZodTypeAny = z.ZodBranded<\n z.ZodNever,\n 'you must pass a schema type'\n >,\n>() => Dispatch<FormAction<T>>\n"],"mappings":";;;;;;AAAA,IAAAA,WAAA,GAAAC,OAAA;AACA,IAAAC,iBAAA,GAAAD,OAAA;AAKO,IAAME,eAAe,GAAAC,OAAA,CAAAD,eAAA,GAAG,IAAAE,8BAAkB,EAACC,kCAAgB,CAKpC","ignoreList":[]}
|
package/useFormDispatch.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useFormDispatch.mjs","names":["createDispatchHook","FormStateContext","useFormDispatch"],"sources":["src/useFormDispatch.ts"],"sourcesContent":["import { createDispatchHook } from 'react-redux'\nimport { FormStateContext } from './FormStateContext'\nimport z from 'zod'\nimport { FormAction } from './FormAction'\nimport { Dispatch } from 'redux'\n\nexport const useFormDispatch = createDispatchHook(
|
|
1
|
+
{"version":3,"file":"useFormDispatch.mjs","names":["createDispatchHook","FormStateContext","useFormDispatch"],"sources":["src/useFormDispatch.ts"],"sourcesContent":["import { createDispatchHook } from 'react-redux'\nimport { FormStateContext } from './FormStateContext'\nimport z from 'zod'\nimport { FormAction } from './FormAction'\nimport { Dispatch } from 'redux'\n\nexport const useFormDispatch = createDispatchHook(FormStateContext) as <\n T extends z.ZodTypeAny = z.ZodBranded<\n z.ZodNever,\n 'you must pass a schema type'\n >,\n>() => Dispatch<FormAction<T>>\n"],"mappings":"AAAA,SAASA,kBAAkB,QAAQ,aAAa;AAChD,SAASC,gBAAgB;AAKzB,OAAO,MAAMC,eAAe,GAAGF,kBAAkB,CAACC,gBAAgB,CAKpC","ignoreList":[]}
|
package/useFormStatus.d.ts
CHANGED
package/useHtmlField.d.ts
CHANGED
|
@@ -18,7 +18,7 @@ export type ValidUseHtmlFieldProps<Field extends FieldPath> = {
|
|
|
18
18
|
input: HtmlFieldInputProps;
|
|
19
19
|
meta: UseFieldProps<Field>;
|
|
20
20
|
};
|
|
21
|
-
export type UseHtmlFieldProps<Field extends FieldPath> = z.input<Field['schema']> extends string | number | bigint | boolean | null | undefined ? {
|
|
21
|
+
export type UseHtmlFieldProps<Field extends FieldPath> = z.input<Field['schema']> extends (string | number | bigint | boolean | null | undefined) ? {
|
|
22
22
|
input: HtmlFieldInputProps;
|
|
23
23
|
meta: UseFieldProps<Field>;
|
|
24
24
|
} : {
|
|
@@ -27,6 +27,7 @@ export type UseHtmlFieldProps<Field extends FieldPath> = z.input<Field['schema']
|
|
|
27
27
|
export type UseHtmlFieldOptions<Field, Schema extends z.ZodTypeAny = Field extends FieldPath<infer S> ? S : z.ZodTypeAny> = {
|
|
28
28
|
field: Field;
|
|
29
29
|
type: z.input<Schema> extends boolean | null | undefined ? 'checkbox' : Exclude<HTMLInputTypeAttribute, 'checkbox'>;
|
|
30
|
+
normalizeOnMount?: boolean;
|
|
30
31
|
normalizeOnBlur?: boolean;
|
|
31
32
|
};
|
|
32
33
|
export interface TypedUseHtmlField<T extends z.ZodTypeAny> {
|
package/useHtmlField.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useHtmlField.d.ts","sourceRoot":"","sources":["src/useHtmlField.ts"],"names":[],"mappings":"AAAA,OAAO,CAAC,MAAM,KAAK,CAAA;AACnB,OAAO,EAAY,SAAS,EAAE,MAAM,aAAa,CAAA;AACjD,OAAO,EAAY,aAAa,EAAE,MAAM,YAAY,CAAA;AACpD,OAAO,KAAK,EAAE,EAAe,sBAAsB,EAAE,MAAM,OAAO,CAAA;AAKlE,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAA;AACtE,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAA;AACxD,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAA;
|
|
1
|
+
{"version":3,"file":"useHtmlField.d.ts","sourceRoot":"","sources":["src/useHtmlField.ts"],"names":[],"mappings":"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"}
|
package/useHtmlField.js
CHANGED
|
@@ -6,8 +6,8 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
});
|
|
7
7
|
exports.useHtmlField = useHtmlField;
|
|
8
8
|
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
9
|
-
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
10
9
|
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
|
|
10
|
+
var _zod = _interopRequireDefault(require("zod"));
|
|
11
11
|
var _FieldPath = require("./FieldPath.js");
|
|
12
12
|
var _useField = require("./useField.js");
|
|
13
13
|
var _react = _interopRequireDefault(require("react"));
|
|
@@ -15,16 +15,24 @@ var _zodInvertible = require("zod-invertible");
|
|
|
15
15
|
var _useFormContext2 = require("./useFormContext.js");
|
|
16
16
|
var _acceptsNumber = require("./util/acceptsNumber.js");
|
|
17
17
|
var _acceptsBigint = require("./util/acceptsBigint.js");
|
|
18
|
+
var _fastDeepEqual = _interopRequireDefault(require("fast-deep-equal"));
|
|
18
19
|
var _excluded = ["parsedValue", "value", "initialParsedValue", "initialValue", "setParsedValue", "setValue", "setMeta"],
|
|
19
20
|
_excluded2 = ["field"];
|
|
20
21
|
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
21
22
|
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
23
|
+
var customMetaSchema = _zod["default"].object({
|
|
24
|
+
value: _zod["default"].unknown(),
|
|
25
|
+
stringValue: _zod["default"].string()
|
|
26
|
+
});
|
|
22
27
|
function useHtmlFieldBase(options) {
|
|
23
28
|
var field = options.field,
|
|
24
29
|
type = options.type,
|
|
30
|
+
normalizeOnMount = options.normalizeOnMount,
|
|
25
31
|
_options$normalizeOnB = options.normalizeOnBlur,
|
|
26
32
|
normalizeOnBlur = _options$normalizeOnB === void 0 ? true : _options$normalizeOnB;
|
|
27
|
-
var props = (0, _useField.useField)(field
|
|
33
|
+
var props = (0, _useField.useField)(field, {
|
|
34
|
+
normalizeOnMount: normalizeOnMount
|
|
35
|
+
});
|
|
28
36
|
var parsedValue = props.parsedValue,
|
|
29
37
|
value = props.value,
|
|
30
38
|
initialParsedValue = props.initialParsedValue,
|
|
@@ -33,17 +41,16 @@ function useHtmlFieldBase(options) {
|
|
|
33
41
|
setValue = props.setValue,
|
|
34
42
|
setMeta = props.setMeta,
|
|
35
43
|
meta = (0, _objectWithoutProperties2["default"])(props, _excluded);
|
|
36
|
-
var schema = field.schema;
|
|
37
44
|
|
|
38
|
-
//
|
|
39
|
-
//
|
|
40
|
-
// coerced the value to a number or bigint.
|
|
45
|
+
// we've coerced the value to null or undefined, or storing numeric
|
|
46
|
+
// text when we've coerced the value to a number or bigint.
|
|
41
47
|
// This way we can set a value that will parse better in the form
|
|
42
48
|
// state without interfering with the text the user is typing.
|
|
43
|
-
var
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
49
|
+
var customMeta = _react["default"].useMemo(function () {
|
|
50
|
+
var parsedCustomMeta = customMetaSchema.safeParse(meta.customMeta);
|
|
51
|
+
return parsedCustomMeta.success ? parsedCustomMeta.data : undefined;
|
|
52
|
+
}, [meta.customMeta]);
|
|
53
|
+
var schema = field.schema;
|
|
47
54
|
var tryNumber = _react["default"].useMemo(function () {
|
|
48
55
|
return (0, _acceptsNumber.acceptsNumber)(schema);
|
|
49
56
|
}, [schema]);
|
|
@@ -58,7 +65,12 @@ function useHtmlFieldBase(options) {
|
|
|
58
65
|
tryBigint: tryBigint
|
|
59
66
|
});
|
|
60
67
|
if (typeof value === 'string' && typeof normalized !== 'string') {
|
|
61
|
-
|
|
68
|
+
setMeta({
|
|
69
|
+
customMeta: {
|
|
70
|
+
stringValue: value,
|
|
71
|
+
value: normalized
|
|
72
|
+
}
|
|
73
|
+
});
|
|
62
74
|
}
|
|
63
75
|
setValue(normalized);
|
|
64
76
|
}, [getValue, setValue, schema]);
|
|
@@ -68,21 +80,20 @@ function useHtmlFieldBase(options) {
|
|
|
68
80
|
});
|
|
69
81
|
}, []);
|
|
70
82
|
var onBlur = _react["default"].useCallback(function (e) {
|
|
71
|
-
var value = normalizeValue(getValue(e), {
|
|
72
|
-
schema: schema,
|
|
73
|
-
tryNumber: tryNumber,
|
|
74
|
-
tryBigint: tryBigint
|
|
75
|
-
});
|
|
76
83
|
if (normalizeOnBlur) {
|
|
77
|
-
var
|
|
84
|
+
var _value = normalizeValue(getValue(e), {
|
|
85
|
+
schema: schema,
|
|
86
|
+
tryNumber: tryNumber,
|
|
87
|
+
tryBigint: tryBigint
|
|
88
|
+
});
|
|
89
|
+
var parsed = field.schema.safeParse(_value);
|
|
78
90
|
var formatted = parsed.success ? (0, _zodInvertible.invert)(field.schema).safeParse(parsed.data) : undefined;
|
|
79
|
-
|
|
80
|
-
setValue(value);
|
|
91
|
+
setValue(formatted !== null && formatted !== void 0 && formatted.success ? formatted.data : _value);
|
|
81
92
|
}
|
|
82
|
-
setTempValue(undefined);
|
|
83
93
|
setMeta({
|
|
84
94
|
visited: true,
|
|
85
|
-
touched: true
|
|
95
|
+
touched: true,
|
|
96
|
+
customMeta: undefined
|
|
86
97
|
});
|
|
87
98
|
}, [getValue, setValue, schema]);
|
|
88
99
|
return _react["default"].useMemo(function () {
|
|
@@ -90,7 +101,7 @@ function useHtmlFieldBase(options) {
|
|
|
90
101
|
input: _objectSpread(_objectSpread({
|
|
91
102
|
name: field.pathstring,
|
|
92
103
|
type: type,
|
|
93
|
-
value: typeof value === 'boolean' ? String(value) : typeof value === 'string' ? value ||
|
|
104
|
+
value: typeof value === 'boolean' ? String(value) : typeof value === 'string' ? value || (customMeta === null || customMeta === void 0 ? void 0 : customMeta.stringValue) || '' : customMeta && (0, _fastDeepEqual["default"])(customMeta.value, value) ? customMeta.stringValue : value == null ? '' : String(value) || ''
|
|
94
105
|
}, type === 'checkbox' && {
|
|
95
106
|
checked: Boolean(value)
|
|
96
107
|
}), {}, {
|
|
@@ -108,7 +119,7 @@ function useHtmlFieldBase(options) {
|
|
|
108
119
|
setMeta: setMeta
|
|
109
120
|
})
|
|
110
121
|
};
|
|
111
|
-
}, [props,
|
|
122
|
+
}, [props, customMeta, onChange]);
|
|
112
123
|
}
|
|
113
124
|
function getValue(e) {
|
|
114
125
|
var target = e.target;
|
|
@@ -125,7 +136,7 @@ function normalizeBlank(schema) {
|
|
|
125
136
|
function safeBigInt(value) {
|
|
126
137
|
try {
|
|
127
138
|
return BigInt(value);
|
|
128
|
-
} catch (
|
|
139
|
+
} catch (_unused) {
|
|
129
140
|
return undefined;
|
|
130
141
|
}
|
|
131
142
|
}
|
package/useHtmlField.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useHtmlField.js","names":["_FieldPath","require","_useField","_react","_interopRequireDefault","_zodInvertible","_useFormContext2","_acceptsNumber","_acceptsBigint","_excluded","_excluded2","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","useHtmlFieldBase","options","field","type","_options$normalizeOnB","normalizeOnBlur","props","useField","parsedValue","value","initialParsedValue","initialValue","setParsedValue","setValue","setMeta","meta","_objectWithoutProperties2","schema","_React$useState","React","useState","_React$useState2","_slicedToArray2","tempValue","setTempValue","tryNumber","useMemo","acceptsNumber","tryBigint","acceptsBigint","onChange","useCallback","getValue","normalized","normalizeValue","onFocus","visited","onBlur","parsed","safeParse","formatted","success","invert","data","undefined","touched","input","name","pathstring","String","checked","Boolean","target","HTMLInputElement","normalizeBlank","safeBigInt","BigInt","error","_ref","test","num","Number","isNaN","bigint","useHtmlField","_ref2","rest","_useFormContext","useFormContext","root","FieldPath","get"],"sources":["src/useHtmlField.ts"],"sourcesContent":["import z from 'zod'\nimport { BasePath, FieldPath } from './FieldPath'\nimport { useField, UseFieldProps } from './useField'\nimport React, { ChangeEvent, HTMLInputTypeAttribute } from 'react'\nimport { invert } from 'zod-invertible'\nimport { useFormContext } from './useFormContext'\nimport { acceptsNumber } from './util/acceptsNumber'\nimport { acceptsBigint } from './util/acceptsBigint'\nimport { PathInSchema, PathstringInSchema } from './util/PathInSchema'\nimport { parsePathstring } from './util/parsePathstring'\nimport { SchemaAt } from './util/SchemaAt'\nimport { DeepPartial } from './util/DeepPartial'\n\nexport type HtmlFieldInputProps = {\n name: string\n type: HTMLInputTypeAttribute\n value: string\n checked?: boolean\n onChange: React.ChangeEventHandler\n onFocus: React.FocusEventHandler\n onBlur: React.FocusEventHandler\n}\n\nexport type ValidUseHtmlFieldProps<Field extends FieldPath> = {\n input: HtmlFieldInputProps\n meta: UseFieldProps<Field>\n}\n\nexport type UseHtmlFieldProps<Field extends FieldPath> = z.input<\n Field['schema']\n> extends string | number | bigint | boolean | null | undefined\n ? {\n input: HtmlFieldInputProps\n meta: UseFieldProps<Field>\n }\n : {\n ERROR: 'field schema input must be a nullish string, number, boolean or bigint'\n }\n\nexport type UseHtmlFieldOptions<\n Field,\n Schema extends z.ZodTypeAny = Field extends FieldPath<infer S>\n ? S\n : z.ZodTypeAny\n> = {\n field: Field\n type: z.input<Schema> extends boolean | null | undefined\n ? 'checkbox'\n : Exclude<HTMLInputTypeAttribute, 'checkbox'>\n normalizeOnBlur?: boolean\n}\n\nexport interface TypedUseHtmlField<T extends z.ZodTypeAny> {\n <Field extends FieldPath>(\n options: UseHtmlFieldOptions<Field, Field['schema']>\n ): UseHtmlFieldProps<Field>\n <Path extends PathInSchema<T>>(\n options: UseHtmlFieldOptions<Path, SchemaAt<T, Path>>\n ): UseHtmlFieldProps<FieldPath<SchemaAt<T, Path>>>\n <Path extends PathstringInSchema<T>>(\n options: UseHtmlFieldOptions<Path, SchemaAt<T, parsePathstring<Path>>>\n ): UseHtmlFieldProps<FieldPath<SchemaAt<T, parsePathstring<Path>>>>\n}\n\nfunction useHtmlFieldBase<Field extends FieldPath>(\n options: UseHtmlFieldOptions<Field, Field['schema']>\n): UseHtmlFieldProps<Field> {\n const { field, type, normalizeOnBlur = true } = options\n const props = useField(field)\n const {\n parsedValue,\n value,\n initialParsedValue,\n initialValue,\n setParsedValue,\n setValue,\n setMeta,\n ...meta\n } = props\n\n const { schema } = field\n\n // tempValue is used for storing blank text when we've coerced the\n // value to null or undefined, or storing numeric text when we've\n // coerced the value to a number or bigint.\n // This way we can set a value that will parse better in the form\n // state without interfering with the text the user is typing.\n const [tempValue, setTempValue] = React.useState(\n value as string | null | undefined\n )\n\n const tryNumber = React.useMemo(() => acceptsNumber(schema), [schema])\n const tryBigint = React.useMemo(() => acceptsBigint(schema), [schema])\n\n const onChange = React.useCallback(\n (e: React.ChangeEvent) => {\n const value = getValue(e)\n const normalized = normalizeValue(value, {\n schema,\n tryNumber,\n tryBigint,\n })\n if (typeof value === 'string' && typeof normalized !== 'string') {\n setTempValue(value)\n }\n setValue(normalized)\n },\n [getValue, setValue, schema]\n )\n\n const onFocus = React.useCallback(() => {\n setMeta({ visited: true })\n }, [])\n\n const onBlur = React.useCallback(\n (e: React.FocusEvent) => {\n let value = normalizeValue(getValue(e), {\n schema,\n tryNumber,\n tryBigint,\n })\n if (normalizeOnBlur) {\n const parsed = field.schema.safeParse(value)\n const formatted = parsed.success\n ? invert(field.schema).safeParse(parsed.data)\n : undefined\n if (formatted?.success) value = formatted.data\n setValue(value)\n }\n setTempValue(undefined)\n setMeta({ visited: true, touched: true })\n },\n [getValue, setValue, schema]\n )\n\n return React.useMemo(\n (): ValidUseHtmlFieldProps<Field> => ({\n input: {\n name: field.pathstring,\n type,\n value:\n typeof value === 'boolean'\n ? String(value)\n : typeof value === 'string'\n ? value || tempValue || ''\n : tempValue || (value == null ? '' : String(value) || ''),\n ...(type === 'checkbox' && { checked: Boolean(value) }),\n onChange,\n onFocus,\n onBlur,\n },\n meta: {\n ...meta,\n parsedValue,\n value,\n initialParsedValue,\n initialValue,\n setParsedValue,\n setValue,\n setMeta,\n },\n }),\n [props, tempValue, onChange]\n ) as any\n}\n\nfunction getValue(e: ChangeEvent) {\n const { target } = e\n if (target instanceof HTMLInputElement) {\n return target.type === 'checkbox' ? target.checked : target.value\n }\n return (target as any).value\n}\n\nfunction normalizeBlank(schema: z.ZodTypeAny): any {\n if (schema.safeParse(undefined).success) return undefined\n if (schema.safeParse(null).success) return null\n return undefined\n}\n\nfunction safeBigInt(value: string): bigint | undefined {\n try {\n return BigInt(value)\n } catch (error) {\n return undefined\n }\n}\n\nfunction normalizeValue<T extends z.ZodTypeAny>(\n value: string | boolean,\n {\n schema,\n tryNumber,\n tryBigint,\n }: { schema: T; tryNumber: boolean; tryBigint: boolean }\n): DeepPartial<z.input<T>> | undefined {\n if (typeof value === 'boolean') return value as any\n if (typeof value === 'string' && !/\\S/.test(value)) {\n return normalizeBlank(schema)\n }\n if (typeof value === 'string' && !schema.safeParse(value).success) {\n if (tryNumber) {\n const num = Number(value)\n if (!isNaN(num)) return num as any\n }\n if (tryBigint) {\n const bigint = safeBigInt(value)\n if (bigint != null) return bigint as any\n }\n }\n return value as any\n}\n\nexport function useHtmlField<Field extends FieldPath>(\n options: UseHtmlFieldOptions<Field, Field['schema']>\n): UseHtmlFieldProps<Field>\nexport function useHtmlField<\n T extends z.ZodTypeAny = z.ZodBranded<\n z.ZodNever,\n 'cast to TypedUseHtmlField<T> to pass a path array'\n >,\n Path extends PathInSchema<T> = any\n>(\n options: UseHtmlFieldOptions<Path, SchemaAt<T, Path>>\n): UseHtmlFieldProps<FieldPath<SchemaAt<T, Path>>>\nexport function useHtmlField<\n T extends z.ZodTypeAny = z.ZodBranded<\n z.ZodNever,\n 'cast to TypedUseHtmlField<T> to pass a pathstring'\n >,\n Path extends PathstringInSchema<T> = any\n>(\n options: UseHtmlFieldOptions<Path, SchemaAt<T, parsePathstring<Path>>>\n): UseHtmlFieldProps<FieldPath<SchemaAt<T, parsePathstring<Path>>>>\nexport function useHtmlField<T extends z.ZodTypeAny>({\n field,\n ...rest\n}: UseHtmlFieldOptions<FieldPath | BasePath, T>): UseHtmlFieldProps<any> {\n const { root } = useFormContext<T>()\n return useHtmlFieldBase({\n field: field instanceof FieldPath ? field : root.get(field as any),\n ...rest,\n })\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"useHtmlField.js","names":["_zod","_interopRequireDefault","require","_FieldPath","_useField","_react","_zodInvertible","_useFormContext2","_acceptsNumber","_acceptsBigint","_fastDeepEqual","_excluded","_excluded2","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","customMetaSchema","z","object","value","unknown","stringValue","string","useHtmlFieldBase","options","field","type","normalizeOnMount","_options$normalizeOnB","normalizeOnBlur","props","useField","parsedValue","initialParsedValue","initialValue","setParsedValue","setValue","setMeta","meta","_objectWithoutProperties2","customMeta","React","useMemo","parsedCustomMeta","safeParse","success","data","undefined","schema","tryNumber","acceptsNumber","tryBigint","acceptsBigint","onChange","useCallback","getValue","normalized","normalizeValue","onFocus","visited","onBlur","parsed","formatted","invert","touched","input","name","pathstring","String","isEqual","checked","Boolean","target","HTMLInputElement","normalizeBlank","safeBigInt","BigInt","_unused","_ref","test","num","Number","isNaN","bigint","useHtmlField","_ref2","rest","_useFormContext","useFormContext","root","FieldPath","get"],"sources":["src/useHtmlField.ts"],"sourcesContent":["import z from 'zod'\nimport { BasePath, FieldPath } from './FieldPath'\nimport { useField, UseFieldProps } from './useField'\nimport React, { ChangeEvent, HTMLInputTypeAttribute } from 'react'\nimport { invert } from 'zod-invertible'\nimport { useFormContext } from './useFormContext'\nimport { acceptsNumber } from './util/acceptsNumber'\nimport { acceptsBigint } from './util/acceptsBigint'\nimport { PathInSchema, PathstringInSchema } from './util/PathInSchema'\nimport { parsePathstring } from './util/parsePathstring'\nimport { SchemaAt } from './util/SchemaAt'\nimport { DeepPartial } from './util/DeepPartial'\nimport isEqual from 'fast-deep-equal'\n\nexport type HtmlFieldInputProps = {\n name: string\n type: HTMLInputTypeAttribute\n value: string\n checked?: boolean\n onChange: React.ChangeEventHandler\n onFocus: React.FocusEventHandler\n onBlur: React.FocusEventHandler\n}\n\nexport type ValidUseHtmlFieldProps<Field extends FieldPath> = {\n input: HtmlFieldInputProps\n meta: UseFieldProps<Field>\n}\n\nexport type UseHtmlFieldProps<Field extends FieldPath> =\n z.input<Field['schema']> extends (\n string | number | bigint | boolean | null | undefined\n ) ?\n {\n input: HtmlFieldInputProps\n meta: UseFieldProps<Field>\n }\n : {\n ERROR: 'field schema input must be a nullish string, number, boolean or bigint'\n }\n\nexport type UseHtmlFieldOptions<\n Field,\n Schema extends z.ZodTypeAny = Field extends FieldPath<infer S> ? S\n : z.ZodTypeAny,\n> = {\n field: Field\n type: z.input<Schema> extends boolean | null | undefined ? 'checkbox'\n : Exclude<HTMLInputTypeAttribute, 'checkbox'>\n normalizeOnMount?: boolean\n normalizeOnBlur?: boolean\n}\n\nexport interface TypedUseHtmlField<T extends z.ZodTypeAny> {\n <Field extends FieldPath>(\n options: UseHtmlFieldOptions<Field, Field['schema']>\n ): UseHtmlFieldProps<Field>\n <Path extends PathInSchema<T>>(\n options: UseHtmlFieldOptions<Path, SchemaAt<T, Path>>\n ): UseHtmlFieldProps<FieldPath<SchemaAt<T, Path>>>\n <Path extends PathstringInSchema<T>>(\n options: UseHtmlFieldOptions<Path, SchemaAt<T, parsePathstring<Path>>>\n ): UseHtmlFieldProps<FieldPath<SchemaAt<T, parsePathstring<Path>>>>\n}\n\nconst customMetaSchema = z.object({\n value: z.unknown(),\n stringValue: z.string(),\n})\n\nfunction useHtmlFieldBase<Field extends FieldPath>(\n options: UseHtmlFieldOptions<Field, Field['schema']>\n): UseHtmlFieldProps<Field> {\n const { field, type, normalizeOnMount, normalizeOnBlur = true } = options\n const props = useField(field, { normalizeOnMount })\n const {\n parsedValue,\n value,\n initialParsedValue,\n initialValue,\n setParsedValue,\n setValue,\n setMeta,\n ...meta\n } = props\n\n // we've coerced the value to null or undefined, or storing numeric\n // text when we've coerced the value to a number or bigint.\n // This way we can set a value that will parse better in the form\n // state without interfering with the text the user is typing.\n const customMeta = React.useMemo(() => {\n const parsedCustomMeta = customMetaSchema.safeParse(meta.customMeta)\n return parsedCustomMeta.success ? parsedCustomMeta.data : undefined\n }, [meta.customMeta])\n\n const { schema } = field\n\n const tryNumber = React.useMemo(() => acceptsNumber(schema), [schema])\n const tryBigint = React.useMemo(() => acceptsBigint(schema), [schema])\n\n const onChange = React.useCallback(\n (e: React.ChangeEvent) => {\n const value = getValue(e)\n const normalized = normalizeValue(value, {\n schema,\n tryNumber,\n tryBigint,\n })\n if (typeof value === 'string' && typeof normalized !== 'string') {\n setMeta({ customMeta: { stringValue: value, value: normalized } })\n }\n setValue(normalized)\n },\n [getValue, setValue, schema]\n )\n\n const onFocus = React.useCallback(() => {\n setMeta({ visited: true })\n }, [])\n\n const onBlur = React.useCallback(\n (e: React.FocusEvent) => {\n if (normalizeOnBlur) {\n const value = normalizeValue(getValue(e), {\n schema,\n tryNumber,\n tryBigint,\n })\n const parsed = field.schema.safeParse(value)\n const formatted =\n parsed.success ?\n invert(field.schema).safeParse(parsed.data)\n : undefined\n setValue(formatted?.success ? formatted.data : value)\n }\n setMeta({ visited: true, touched: true, customMeta: undefined })\n },\n [getValue, setValue, schema]\n )\n\n return React.useMemo(\n (): ValidUseHtmlFieldProps<Field> => ({\n input: {\n name: field.pathstring,\n type,\n value:\n typeof value === 'boolean' ? String(value)\n : typeof value === 'string' ? value || customMeta?.stringValue || ''\n : customMeta && isEqual(customMeta.value, value) ?\n customMeta.stringValue\n : value == null ? ''\n : String(value) || '',\n ...(type === 'checkbox' && { checked: Boolean(value) }),\n onChange,\n onFocus,\n onBlur,\n },\n meta: {\n ...meta,\n parsedValue,\n value,\n initialParsedValue,\n initialValue,\n setParsedValue,\n setValue,\n setMeta,\n },\n }),\n [props, customMeta, onChange]\n ) as any\n}\n\nfunction getValue(e: ChangeEvent) {\n const { target } = e\n if (target instanceof HTMLInputElement) {\n return target.type === 'checkbox' ? target.checked : target.value\n }\n return (target as any).value\n}\n\nfunction normalizeBlank(schema: z.ZodTypeAny): any {\n if (schema.safeParse(undefined).success) return undefined\n if (schema.safeParse(null).success) return null\n return undefined\n}\n\nfunction safeBigInt(value: string): bigint | undefined {\n try {\n return BigInt(value)\n } catch {\n return undefined\n }\n}\n\nfunction normalizeValue<T extends z.ZodTypeAny>(\n value: string | boolean,\n {\n schema,\n tryNumber,\n tryBigint,\n }: { schema: T; tryNumber: boolean; tryBigint: boolean }\n): DeepPartial<z.input<T>> | undefined {\n if (typeof value === 'boolean') return value as any\n if (typeof value === 'string' && !/\\S/.test(value)) {\n return normalizeBlank(schema)\n }\n if (typeof value === 'string' && !schema.safeParse(value).success) {\n if (tryNumber) {\n const num = Number(value)\n if (!isNaN(num)) return num as any\n }\n if (tryBigint) {\n const bigint = safeBigInt(value)\n if (bigint != null) return bigint as any\n }\n }\n return value as any\n}\n\nexport function useHtmlField<Field extends FieldPath>(\n options: UseHtmlFieldOptions<Field, Field['schema']>\n): UseHtmlFieldProps<Field>\nexport function useHtmlField<\n T extends z.ZodTypeAny = z.ZodBranded<\n z.ZodNever,\n 'cast to TypedUseHtmlField<T> to pass a path array'\n >,\n Path extends PathInSchema<T> = any,\n>(\n options: UseHtmlFieldOptions<Path, SchemaAt<T, Path>>\n): UseHtmlFieldProps<FieldPath<SchemaAt<T, Path>>>\nexport function useHtmlField<\n T extends z.ZodTypeAny = z.ZodBranded<\n z.ZodNever,\n 'cast to TypedUseHtmlField<T> to pass a pathstring'\n >,\n Path extends PathstringInSchema<T> = any,\n>(\n options: UseHtmlFieldOptions<Path, SchemaAt<T, parsePathstring<Path>>>\n): UseHtmlFieldProps<FieldPath<SchemaAt<T, parsePathstring<Path>>>>\nexport function useHtmlField<T extends z.ZodTypeAny>({\n field,\n ...rest\n}: UseHtmlFieldOptions<FieldPath | BasePath, T>): UseHtmlFieldProps<any> {\n const { root } = useFormContext<T>()\n return useHtmlFieldBase({\n field: field instanceof FieldPath ? field : root.get(field as any),\n ...rest,\n })\n}\n"],"mappings":"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","ignoreList":[]}
|