gform-react 2.6.3 → 2.7.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.
Files changed (42) hide show
  1. package/dist/cjs/gform-react.development.js +70 -79
  2. package/dist/cjs/gform-react.development.js.map +1 -1
  3. package/dist/cjs/gform-react.production.js +1 -1
  4. package/dist/cjs/gform-react.production.js.map +1 -1
  5. package/dist/esm/GForm.development.js +14 -44
  6. package/dist/esm/GForm.development.js.map +1 -1
  7. package/dist/esm/GForm.production.js +1 -1
  8. package/dist/esm/GForm.production.js.map +1 -1
  9. package/dist/esm/GInput.development.js +6 -6
  10. package/dist/esm/GInput.development.js.map +1 -1
  11. package/dist/esm/GInput.production.js +1 -1
  12. package/dist/esm/GInput.production.js.map +1 -1
  13. package/dist/esm/GValidator.development.js +0 -6
  14. package/dist/esm/GValidator.development.js.map +1 -1
  15. package/dist/esm/GValidator.production.js +1 -1
  16. package/dist/esm/GValidator.production.js.map +1 -1
  17. package/dist/esm/shared.development.js +48 -7
  18. package/dist/esm/shared.development.js.map +1 -1
  19. package/dist/esm/shared.production.js +1 -1
  20. package/dist/esm/shared.production.js.map +1 -1
  21. package/dist/esm/useFormSelector.development.js +2 -3
  22. package/dist/esm/useFormSelector.development.js.map +1 -1
  23. package/dist/esm/useFormSelector.production.js +1 -1
  24. package/dist/index.d.ts +0 -4
  25. package/native/dist/cjs/gform-react.development.js +85 -104
  26. package/native/dist/cjs/gform-react.development.js.map +1 -1
  27. package/native/dist/cjs/gform-react.production.js +1 -1
  28. package/native/dist/cjs/gform-react.production.js.map +1 -1
  29. package/native/dist/esm/RNGForm.development.js +11 -45
  30. package/native/dist/esm/RNGForm.development.js.map +1 -1
  31. package/native/dist/esm/RNGForm.production.js +1 -1
  32. package/native/dist/esm/RNGForm.production.js.map +1 -1
  33. package/native/dist/esm/RNGInput.development.js +12 -6
  34. package/native/dist/esm/RNGInput.development.js.map +1 -1
  35. package/native/dist/esm/RNGInput.production.js +1 -1
  36. package/native/dist/esm/RNGInput.production.js.map +1 -1
  37. package/native/dist/esm/shared.development.js +45 -22
  38. package/native/dist/esm/shared.development.js.map +1 -1
  39. package/native/dist/esm/shared.production.js +1 -1
  40. package/native/dist/esm/shared.production.js.map +1 -1
  41. package/native/dist/index.d.ts +4 -5
  42. package/package.json +9 -3
@@ -1 +1 @@
1
- {"version":3,"file":"shared.development.js","sources":["../../src/helpers.ts","../../src/useFormHandlers.ts","../../src/form-context.tsx"],"sourcesContent":["import {Children, isValidElement} from 'react';\r\nimport type {PropsWithChildren, ReactElement, ReactNode} from 'react';\r\nimport type {GInputInitialState, GInputProps, GInputState, GInputStateMutable} from './fields';\r\nimport type {FormNode, FormTreeResult, GChangeEvent, GDOMElement, IForm} from './form';\r\nimport type {GFormState, InitialState, RawData, ToFormDataOptions, ToRawDataOptions, ToURLSearchParamsOptions} from './state';\r\n\r\nexport const isObject = (o: any): o is object => (o && typeof o === 'object' && !Array.isArray(o));\r\n\r\nconst defaultFieldProps: { [key: string]: { value: string | number | boolean } } = {\r\n text: {value: ''},\r\n checkbox: {value: false},\r\n number: {value: 0}\r\n};\r\n\r\nconst typeValueDict: { [key: string]: keyof HTMLFormElement | GDOMElement } = {\r\n checkbox: 'checked',\r\n number: 'valueAsNumber',\r\n};\r\n\r\nconst _generateIdUnsafe = () => (+new Date()).toString(36) + (1 - Math.random()).toString(36).substring(2, 16);\r\n\r\nexport const _copyStateFields = (source: InitialState, destination: InitialState) => {\r\n for (const key in destination.fields) {\r\n const sourceField = source.fields[key];\r\n const destField = destination.fields[key];\r\n\r\n if (!sourceField || sourceField.type !== destField.type) continue;\r\n\r\n destination.fields[key] = {...destField, ...sourceField};\r\n }\r\n};\r\n\r\nexport const _buildFormInitialValues = <T>(rows: ReactNode = []): InitialState<T> => {\r\n const fields: { [key: string]: GInputInitialState } = {};\r\n\r\n if (__DEBUG__) {\r\n console.log('[buildFormInitialValues] -', 'building initial values for ', rows);\r\n }\r\n\r\n const inputs = _findInputs(rows);\r\n\r\n inputs.forEach(config => {\r\n if (__DEBUG__) {\r\n console.log('[buildFormInitialValues] -', 'building input', `(${config.formKey})`, config);\r\n }\r\n\r\n if (__DEV__ && fields[config.formKey]) {\r\n console.warn(`DEV ONLY - [Duplicate Keys] - field with key '${config.formKey}' already defined.`);\r\n }\r\n\r\n const {\r\n required = false,\r\n max,\r\n maxLength,\r\n min,\r\n minLength,\r\n step,\r\n pattern,\r\n type = \"text\",\r\n defaultValue,\r\n value,\r\n checked,\r\n defaultChecked,\r\n formKey,\r\n debounce,\r\n validatorKey\r\n } = config;\r\n const defaultProps = defaultFieldProps[type] || defaultFieldProps.text;\r\n const inputValue = value || defaultValue || checked || defaultChecked || defaultProps.value;\r\n\r\n fields[formKey] = {\r\n formKey,\r\n type,\r\n required,\r\n max,\r\n maxLength,\r\n min,\r\n minLength,\r\n step,\r\n pattern,\r\n value: inputValue,\r\n validatorKey,\r\n debounce,\r\n dirty: false,\r\n touched: false,\r\n gid: _generateIdUnsafe(),\r\n };\r\n });\r\n\r\n return {fields: fields as IForm<T>};\r\n};\r\n\r\n\r\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\r\nconst _buildFormTree = (\r\n root?: ReactElement<any> | ReactElement<any>[] | undefined\r\n): FormNode[] => {\r\n if (!root) return [];\r\n\r\n if (Array.isArray(root)) {\r\n return root.flatMap(element => _buildFormTree(element));\r\n }\r\n\r\n if (root.props?.formKey) {\r\n if (__DEBUG__) {\r\n console.log(\"[findInputs] - input config found\", `(${root.props.formKey})`);\r\n }\r\n return [\r\n {\r\n type: \"input\",\r\n formKey: root.props.formKey,\r\n },\r\n ];\r\n }\r\n\r\n // Group node\r\n const childrenTree = _buildFormTree(root.props?.children);\r\n return [\r\n {\r\n type: \"group\",\r\n children: childrenTree,\r\n },\r\n ];\r\n};\r\n\r\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\r\nconst buildFormTreeWithFlatAndSignature = (\r\n root?: ReactElement<any> | ReactElement<any>[] | undefined\r\n): FormTreeResult => {\r\n const flat: (GInputProps & GInputStateMutable)[] = [];\r\n let signature = '';\r\n\r\n const walk = (node?: ReactElement<any> | ReactElement<any>[] | undefined): FormNode[] => {\r\n if (!node) return [];\r\n\r\n if (Array.isArray(node)) {\r\n return node.flatMap(child => walk(child));\r\n }\r\n\r\n if (node.props?.formKey) {\r\n flat.push(node.props);\r\n signature = `${signature}I(${node.props.formKey})`;\r\n return [\r\n {\r\n type: \"input\",\r\n formKey: node.props.formKey,\r\n props: node.props,\r\n },\r\n ];\r\n }\r\n\r\n signature = `${signature}G(`;\r\n const childrenTree = walk(node.props?.children);\r\n signature = `${signature})`;\r\n\r\n return [\r\n {\r\n type: \"group\",\r\n children: childrenTree,\r\n },\r\n ];\r\n };\r\n\r\n const tree = walk(root);\r\n\r\n return {tree, flat, signature};\r\n};\r\n\r\nconst _findInputs = (root?: ReactNode, total: (GInputProps & GInputStateMutable)[] = []): (GInputProps & GInputStateMutable)[] => {\r\n if (!root) return total;\r\n\r\n Children.forEach(root, child => {\r\n if (!isValidElement(child)) return;\r\n\r\n if (child.props) {\r\n const {formKey, children} = child.props as PropsWithChildren<GInputProps & GInputStateMutable>;\r\n\r\n if (formKey) {\r\n if (__DEBUG__) {\r\n console.log(\"[findInputs] - input config found\", `(${formKey})`);\r\n }\r\n total.push(child.props as GInputProps & GInputStateMutable);\r\n }\r\n\r\n if (children) {\r\n _findInputs(children, total);\r\n }\r\n }\r\n });\r\n\r\n return total;\r\n};\r\n\r\nexport const _findValidityKey = (validity: Partial<ValidityState>, exclude: (keyof ValidityState)[] = []): keyof ValidityState | undefined => {\r\n for (const key in validity) {\r\n if (exclude.includes(key as keyof ValidityState)) continue;\r\n if (key !== 'valid' && validity[key as keyof ValidityState]) {\r\n if (__DEBUG__) {\r\n console.log('[findValidityKey] -', 'found validity key:', key);\r\n }\r\n return key as keyof ValidityState;\r\n }\r\n }\r\n};\r\n\r\nexport const _checkTypeMismatch = (input: GInputState<any>) => {\r\n const value = input.value?.toString().trim();\r\n if (!value) return false;\r\n\r\n switch (input.type) {\r\n case 'email':\r\n return !/^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/.test(value); // basic email pattern\r\n case 'url':\r\n try {\r\n new URL(value);\r\n return false;\r\n } catch {\r\n return true;\r\n }\r\n case 'tel':\r\n return !/^\\+?[0-9\\s\\-().]{7,}$/.test(value); // basic phone pattern\r\n default:\r\n return false;\r\n }\r\n};\r\n\r\n\r\nexport const _hasSubmitter = (form?: HTMLFormElement | null): boolean => {\r\n if (!form) return false;\r\n\r\n for (const element of form) {\r\n if ((element as HTMLInputElement).type === 'submit') return true;\r\n }\r\n\r\n return false;\r\n};\r\n\r\nexport const _checkIfFormIsValid = <T>(fields: IForm<T>): boolean => {\r\n for (const f in fields) {\r\n if (fields[f].error) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n};\r\n\r\nexport const _toRawData = <T>(fields: IForm<T> & {\r\n [key: string]: GInputState<any>\r\n}, options: ToRawDataOptions<T> = {}): RawData<T> => {\r\n const data: { [key: string]: unknown } = {};\r\n\r\n const {include, exclude, transform} = options;\r\n\r\n if (include) {\r\n include.forEach(key => data[key as string] = fields[key]?.value);\r\n } else for (const f in fields) {\r\n data[f] = fields[f].value;\r\n }\r\n\r\n exclude?.forEach(key => delete data[key as string]);\r\n\r\n if (transform) {\r\n for (const key in transform) {\r\n const set = transform[key] as (value: GFormState<T>[typeof key]['value']) => any;\r\n data[key] = set(fields[key]?.value || fields[key]);\r\n }\r\n }\r\n\r\n return data as RawData<T>;\r\n};\r\n\r\nexport const _toFormData = <T>(form: HTMLFormElement | null, options?: ToFormDataOptions<T>): FormData => {\r\n if (!form) return new FormData();\r\n\r\n if (options) {\r\n const {exclude, include, transform} = options;\r\n let formData: FormData;\r\n\r\n if (include) {\r\n formData = new FormData();\r\n include.forEach(key => formData.set(key as string, form[key as string]?.value));\r\n } else {\r\n formData = new FormData(form);\r\n exclude?.forEach(key => formData.delete(key as string));\r\n }\r\n\r\n if (transform) {\r\n for (const key in transform) {\r\n const set = transform[key] as (value: GFormState<T>[typeof key]['value']) => any;\r\n formData.set(key, set(form[key]?.value));\r\n }\r\n }\r\n return formData;\r\n\r\n }\r\n\r\n return new FormData(form);\r\n};\r\n\r\nexport function _toURLSearchParams<T>(this: GFormState<T>, options?: ToURLSearchParamsOptions<T>): URLSearchParams {\r\n let data: Record<keyof T, any>;\r\n if (options) {\r\n const {exclude, include, transform} = options;\r\n if (include) {\r\n data = {} as Record<keyof T, any>;\r\n include.forEach(key => (data[key] = this[key]?.value));\r\n } else {\r\n data = this.toRawData();\r\n exclude?.forEach(key => delete data[key]);\r\n }\r\n\r\n if (transform) {\r\n for (const key in transform) {\r\n const set = transform[key] as (value: GFormState<T>[typeof key]['value']) => any;\r\n (data[key] = set(this[key]?.value));\r\n }\r\n }\r\n } else data = this.toRawData();\r\n\r\n return new URLSearchParams(data); // this is ok because URLSearchParams will stringify the values (boolean/number)\r\n}\r\n\r\nfunction __debounce(this: { [key: string]: { timerId: NodeJS.Timeout } }, timeout: number, id: string): Promise<void> {\r\n return new Promise(resolve => {\r\n if (this[id]?.timerId)\r\n clearTimeout(this[id].timerId);\r\n\r\n const timerId = setTimeout(() => resolve(), timeout);\r\n\r\n if (this[id]) {\r\n this[id].timerId = timerId;\r\n } else this[id] = {timerId};\r\n });\r\n}\r\n\r\nexport const _debounce = __debounce.bind({});\r\n\r\nexport const _extractValue = <T>(e?: GChangeEvent<GDOMElement | HTMLFormElement>, unknown?: {\r\n value: T\r\n} | string | number): undefined | string | number | boolean | T => {\r\n if (e?.target) {\r\n if (Object.hasOwn(typeValueDict, e.target.type)) return e.target[typeValueDict[e.target.type] as 'value'];\r\n return e.target.value;\r\n }\r\n return (e?.value as T) || (isObject(unknown) ? unknown.value : unknown);\r\n};\r\n\r\nexport const _checkResult = (handlerResult: boolean | RegExp | string, value: string | number | boolean): boolean => typeof handlerResult === 'boolean' ? handlerResult : typeof value === 'string' ? typeof handlerResult === 'string' ? !new RegExp(handlerResult).test(value) : !handlerResult.test(value) : false;\r\n\r\nexport const _merge = <T extends object>(target: { [key: string]: any } = {}, ...nodes: ({\r\n [key: string]: any\r\n} | undefined | void)[]): T => {\r\n if (!nodes.length) return target as T;\r\n\r\n const next = nodes.shift();\r\n if (isObject(next)) {\r\n for (const key in next) {\r\n target[key] = target[key] ? {...target[key], ...next[key]} : next[key];\r\n }\r\n }\r\n\r\n return _merge(target, ...nodes);\r\n};\r\n","import {_checkResult, _checkTypeMismatch, _debounce, _extractValue, _findValidityKey} from \"./helpers\";\r\nimport {type GInputValidator, type GValidators} from \"./validations\";\r\nimport type {GInputState} from \"./fields\";\r\nimport type {GChangeEvent, GDOMElement, GFocusEvent, GFormEvent, GInvalidEvent} from \"./form\";\r\nimport type {InitialState, Store} from \"./state\";\r\nimport {handlersMap, validityMap} from \"./validations/GValidator\";\r\n\r\nexport const useFormHandlers = (getState: Store['getState'], setState: Store['setState'], validators: GValidators = {}, optimized = false) => {\r\n /**\r\n * handler for validating a form input\r\n * @param input the input to be validated\r\n * @param e the event object\r\n */\r\n const _viHandler = (input: GInputState, e?: GFocusEvent<GDOMElement | HTMLFormElement> | GInvalidEvent<GDOMElement | HTMLFormElement> | GFormEvent<GDOMElement | HTMLFormElement> | GFormEvent): void => {\r\n if (!input) return;\r\n\r\n const element = e && e.target;\r\n const hasInitialValue = !input.dirty && input.value && !input.touched;\r\n\r\n if (!element && !hasInitialValue) return;\r\n\r\n if (typeof document !== 'undefined' && (element instanceof HTMLInputElement || element instanceof HTMLTextAreaElement || element instanceof HTMLSelectElement)) {\r\n if (!input.checkValidity) input.checkValidity = () => element.checkValidity();\r\n\r\n if (hasInitialValue) { //if the field has initial value\r\n /**\r\n * for inputs with initial value we have to manually check for validations.\r\n * validity.tooShort is false even though initial value is smaller than minLength, because its required to be filled in by user (native dirty flag is true).\r\n * it only works for validity.valueMissing.\r\n * If an element has a minimum allowed value length, its dirty value flag is true, its value was last changed by a user edit (as opposed to a change made by a script), its value is not the empty string, and the length of the element's API value is less than the element's minimum allowed value length, then the element is suffering from being too short.\r\n * @see https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#setting-minimum-input-length-requirements:-the-minlength-attribute\r\n */\r\n _checkInputManually(input);\r\n _dispatchChanges(input, input.formKey);\r\n return;\r\n }\r\n element.setCustomValidity(''); //reset any previous error (custom)\r\n\r\n const exclude: (keyof ValidityState)[] = input.type && (input.pattern || hasCustomValidation(input)) ? ['typeMismatch'] : [];\r\n const validityKey = _findValidityKey(element.validity, exclude);\r\n _validateInput(input, validityKey, (v: string) => element.setCustomValidity(v));\r\n\r\n if (!validityKey && input.error) {\r\n element.setCustomValidity(input.errorText || 'error');\r\n }\r\n\r\n _dispatchChanges(input, input.formKey);\r\n } else {\r\n if (__DEBUG__) {\r\n console.log('[validateInputHandler] -', `the input '${input.formKey}' is not a native web element\\nevent:`, e);\r\n }\r\n\r\n //fallback - validate the input for validations manually\r\n input.checkValidity = () => _checkInputManually(input);\r\n input.checkValidity();\r\n\r\n _dispatchChanges(input, input.formKey);\r\n }\r\n };\r\n\r\n const _checkInputManually = (input: GInputState) => {\r\n const exclude: (keyof ValidityState)[] = input.type && (input.pattern || hasCustomValidation(input)) ? ['typeMismatch'] : [];\r\n\r\n let validityKey = _findValidityKey({\r\n valueMissing: input.required && !input.value || false,\r\n typeMismatch: _checkTypeMismatch(input),\r\n tooShort: input.minLength && input.value.toString().length < input.minLength || false,\r\n tooLong: input.maxLength && input.value.toString().length > input.maxLength || false,\r\n patternMismatch: input.pattern && _checkResult(input.pattern, input.value) || false,\r\n rangeUnderflow: input.min && Number(input.value) < Number(input.min) || false,\r\n rangeOverflow: input.max && Number(input.value) > Number(input.max) || false\r\n }, exclude);\r\n\r\n if (!validityKey && input.error) {\r\n validityKey = 'customError';\r\n }\r\n _validateInput(input, validityKey);\r\n return !input.error;\r\n };\r\n\r\n /**\r\n * handler for updating and validating a form input\r\n * @param input\r\n * @param e the event object\r\n * @param unknown\r\n */\r\n const _updateInputHandler = (input: GInputState, e?: GChangeEvent<GDOMElement | HTMLFormElement>, unknown?: {\r\n value: unknown\r\n } | string | number): void => {\r\n input.value = _extractValue(e, unknown) as GInputState['value'];\r\n _viHandler(input, e);\r\n };\r\n\r\n /**\r\n * Validates the input and updates the state with the result\r\n * @param input the input to be validated\r\n * @param validityKey the `Constraint Validation` key\r\n * @param setValidity\r\n */\r\n const _validateInput = (input: GInputState, validityKey?: keyof ValidityState, setValidity?: (e: string) => void): void => {\r\n const inputValidator = validators[input.validatorKey || input.formKey] || validators['*'];\r\n if (__DEBUG__) {\r\n console.log('[validateInput] -', 'validating input:', input.formKey, `(${validityKey ? validityKey : 'custom'})`);\r\n }\r\n\r\n if (__DEV__) {\r\n if (validityKey && !inputValidator?.hasConstraint(validityKey)) {\r\n if (validityKey === 'typeMismatch') console.warn(`DEV ONLY - [Missing Validator] - the input '${input.formKey}' has described the constraint '${validityMap[validityKey]}' however, a correspond validator/custom validation/pattern validator is missing.\\nadd '${handlersMap[validityMap[validityKey]]}' or 'withCustomValidation' or '${handlersMap[validityMap.patternMismatch]}' to the input validator.\\nexample:\\nconst validators: GValidators = {\\n\\temail: new GValidator().withPatternMismatchMessage('pattern mismatch'),\\n\\t...\\n}\\n\\nor either remove the constraint '${validityMap[validityKey]}' from the input props`);\r\n else console.warn(`DEV ONLY - [Missing Validator] - the input '${input.formKey}' has described the constraint '${validityMap[validityKey]}' however, a correspond validator is missing.\\nadd '${handlersMap[validityMap[validityKey]]}' to the input validator.\\nexample:\\nconst validators: GValidators = {\\n\\temail: new GValidator().withPatternMismatchMessage('pattern mismatch'),\\n\\t...\\n}\\n\\nor either remove the constraint '${validityMap[validityKey]}' from the input props`);\r\n }\r\n }\r\n\r\n if (inputValidator) {\r\n __validateInput(input, inputValidator, validityKey, setValidity);\r\n }\r\n input.touched = true;\r\n };\r\n\r\n const _dispatchChanges = (changes: Partial<InitialState> | Partial<GInputState>, key?: string) => setState(prev => {\r\n if (key) {\r\n return {...prev, fields: {...prev.fields, [key]: {...prev.fields[key], ...changes}}};\r\n }\r\n return {...prev, ...changes};\r\n });\r\n\r\n /**\r\n * @internal\r\n */\r\n const __validateInput = (input: GInputState, inputValidator: GInputValidator<any>, validityKey?: keyof ValidityState, setValidity?: (e: string) => void): void => {\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validating input (${input.formKey}) with handlers:`, inputValidator.handlers);\r\n }\r\n const fields = getState().fields;\r\n\r\n for (const index in inputValidator.constraintHandlers) {\r\n const result = inputValidator.constraintHandlers[index](input, validityKey);\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validation results for constraint handler (${index}):\\n`, inputValidator.constraintHandlers[index], '\\n\\nvalidator result:', result, '\\nviolation:', input.error, `(${input.error ? 'failed' : 'passed'})`);\r\n }\r\n\r\n input.error = _checkResult(result, input.value);\r\n if (input.error) return;\r\n }\r\n\r\n for (const index in inputValidator.handlers) {\r\n const result = inputValidator.handlers[index](input, fields);\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validation results for custom handler (${index}):\\n`, inputValidator.handlers[index], '\\n\\nvalidator result:', result, '\\nviolation:', input.error, `(${input.error ? 'failed' : 'passed'})`);\r\n }\r\n\r\n input.error = _checkResult(result, input.value);\r\n if (input.error) return;\r\n }\r\n\r\n input.errorText = '';\r\n\r\n if (inputValidator.asyncHandlers.length) {\r\n input.error = true;\r\n _debounce(input.debounce || 300, `${input.gid}-async`).then(() => {\r\n const validateAsync = async () => {\r\n for (const index in inputValidator.asyncHandlers) {\r\n const result = await inputValidator.asyncHandlers[index](input, fields);\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validation results for custom async handler (${index}):\\n`, inputValidator.asyncHandlers[index], '\\n\\nvalidator result:', result, '\\nviolation:', input.error, `(${input.error ? 'failed' : 'passed'})`);\r\n }\r\n\r\n input.error = _checkResult(result, input.value);\r\n if (input.error) break;\r\n }\r\n if (!input.error) input.errorText = '';\r\n\r\n _dispatchChanges({error: input.error, errorText: input.errorText}, input.formKey);\r\n if (setValidity) {\r\n setValidity(input.errorText);\r\n }\r\n };\r\n\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validating input (${input.formKey}) with async handlers:`, inputValidator.asyncHandlers);\r\n }\r\n validateAsync();\r\n });\r\n }\r\n };\r\n\r\n const hasCustomValidation = (input: GInputState) => {\r\n const validator = validators[input.validatorKey || input.formKey] || validators['*'];\r\n return validator && (validator.asyncHandlers.length > 0 || validator.handlers.length > 0);\r\n };\r\n\r\n return {_updateInputHandler, _viHandler, _dispatchChanges, optimized, _createInputChecker: _checkInputManually};\r\n};","import React, {createContext, useCallback, useContext, useMemo, useRef, useSyncExternalStore} from 'react';\r\nimport type {FC, PropsWithChildren} from 'react';\r\n\r\nimport {useFormHandlers} from \"./useFormHandlers\";\r\nimport type {InitialState, Store} from \"./state\";\r\nimport type {GValidators} from \"./validations\";\r\nimport type {GInputState} from './fields';\r\nimport {_copyStateFields} from \"./helpers\";\r\n\r\nconst GFormContext = createContext<Store>({} as Store);\r\n\r\ntype GFormContextProviderProps = PropsWithChildren & {\r\n initialState: InitialState;\r\n validators?: GValidators;\r\n optimized?: boolean;\r\n};\r\n\r\nexport const GFormContextProvider: FC<GFormContextProviderProps> = ({ children, initialState, validators, optimized }) => {\r\n const stateRef = useRef(initialState);\r\n const listeners = useRef<Set<() => void>>(null);\r\n\r\n const setState = useCallback((updater: InitialState | ((state: InitialState) => InitialState)) => {\r\n stateRef.current = typeof updater === 'function' ? updater(stateRef.current) : updater;\r\n listeners.current!.forEach((l) => l());\r\n }, []);\r\n\r\n const handlers = useFormHandlers(() => stateRef.current, setState, validators, optimized);\r\n\r\n const store = useMemo<Store>(() => {\r\n if (!listeners.current) {\r\n listeners.current = new Set();\r\n } else {\r\n if (__DEBUG__) {\r\n console.log(`[form-context] - form changed stated from`, stateRef.current, '\\nto\\n', initialState);\r\n }\r\n listeners.current.clear();\r\n _copyStateFields(stateRef.current, initialState);\r\n }\r\n\r\n stateRef.current = initialState;\r\n\r\n for (const fieldKey in initialState.fields) {\r\n initialState.fields[fieldKey].dispatchChanges = (changes: Partial<GInputState>) => handlers._dispatchChanges(changes, fieldKey);\r\n }\r\n\r\n return {\r\n getState: () => stateRef.current,\r\n setState,\r\n subscribe: (listener: () => void) => {\r\n listeners.current!.add(listener);\r\n return () => listeners.current!.delete(listener);\r\n },\r\n handlers\r\n };\r\n }, [initialState]);\r\n\r\n return <GFormContext.Provider value={store}>{children}</GFormContext.Provider>;\r\n};\r\n\r\nexport const useFormStore = () => {\r\n const store = useContext(GFormContext);\r\n if (!store.getState) throw new Error('useGFormStore must be used within `GForm` component');\r\n\r\n return store;\r\n};\r\n\r\nexport const useFormSelector = <T extends any>(selector: (state: InitialState) => T): T => {\r\n const store = useFormStore();\r\n\r\n return useSyncExternalStore(\r\n store.subscribe,\r\n () => selector(store.getState()),\r\n () => selector(store.getState()) // for SSR\r\n );\r\n};\r\n\r\nexport function createSelector<\r\n State=InitialState,\r\n Selectors extends Array<(state: State) => any> = [],\r\n Result = any\r\n>(\r\n selectors: Selectors,\r\n combiner: (...args: {\r\n [K in keyof Selectors]: Selectors[K] extends (state: State) => infer R ? R : never;\r\n }) => Result\r\n): (state: State) => Result {\r\n let lastArgs: any[] = [];\r\n let lastResult: Result;\r\n\r\n return (state: State): Result => {\r\n const args = selectors.map(fn => fn(state));\r\n if (\r\n lastArgs.length === args.length &&\r\n args.every((val, i) => val === lastArgs[i])\r\n ) {\r\n return lastResult;\r\n }\r\n lastArgs = args;\r\n lastResult = combiner(...args as any);\r\n return lastResult;\r\n };\r\n}"],"names":["isObject","o","Array","isArray","defaultFieldProps","text","value","checkbox","number","typeValueDict","_generateIdUnsafe","Date","toString","Math","random","substring","_copyStateFields","source","destination","key","fields","sourceField","destField","type","_objectSpread","_buildFormInitialValues","rows","inputs","_findInputs","forEach","config","formKey","console","warn","required","max","maxLength","min","minLength","step","pattern","defaultValue","checked","defaultChecked","debounce","validatorKey","defaultProps","inputValue","dirty","touched","gid","root","total","Children","child","isValidElement","props","children","push","_findValidityKey","validity","exclude","includes","_checkTypeMismatch","input","_input$value","trim","test","URL","_unused","_hasSubmitter","form","element","_checkIfFormIsValid","f","error","_toRawData","options","data","include","transform","_fields$key","_fields$key2","set","_toFormData","FormData","_toURLSearchParams","_this$key","toRawData","_this$key2","URLSearchParams","__debounce","timeout","id","Promise","resolve","_this$id","timerId","clearTimeout","setTimeout","_debounce","bind","_extractValue","e","unknown","target","Object","hasOwn","_checkResult","handlerResult","RegExp","_merge","nodes","length","next","shift","useFormHandlers","getState","setState","validators","optimized","_viHandler","hasInitialValue","document","HTMLInputElement","HTMLTextAreaElement","HTMLSelectElement","checkValidity","_checkInputManually","_dispatchChanges","setCustomValidity","hasCustomValidation","validityKey","_validateInput","v","errorText","valueMissing","typeMismatch","tooShort","tooLong","patternMismatch","rangeUnderflow","Number","rangeOverflow","_updateInputHandler","setValidity","inputValidator","hasConstraint","validityMap","handlersMap","__validateInput","changes","prev","index","constraintHandlers","result","handlers","asyncHandlers","then","validateAsync","validator","_createInputChecker","GFormContext","createContext","GFormContextProvider","initialState","stateRef","useRef","listeners","useCallback","updater","current","l","store","useMemo","Set","clear","fieldKey","dispatchChanges","subscribe","listener","add","delete","React","createElement","Provider","useFormStore","useContext","Error","useFormSelector","selector","useSyncExternalStore","createSelector","selectors","combiner","lastArgs","lastResult","state","args","map","fn","every","val","i"],"mappings":";;;;AAMO,MAAMA,QAAQ,GAAIC,CAAM,IAAmBA,CAAC,IAAI,OAAOA,CAAC,KAAK,QAAQ,IAAI,CAACC,KAAK,CAACC,OAAO,CAACF,CAAC,CAAE;AAElG,MAAMG,iBAA0E,GAAG;AAC/EC,EAAAA,IAAI,EAAE;AAACC,IAAAA,KAAK,EAAE;GAAG;AACjBC,EAAAA,QAAQ,EAAE;AAACD,IAAAA,KAAK,EAAE;GAAM;AACxBE,EAAAA,MAAM,EAAE;AAACF,IAAAA,KAAK,EAAE;AAAC;AACrB,CAAC;AAED,MAAMG,aAAqE,GAAG;AAC1EF,EAAAA,QAAQ,EAAE,SAAS;AACnBC,EAAAA,MAAM,EAAE;AACZ,CAAC;AAED,MAAME,iBAAiB,GAAGA,MAAM,CAAC,CAAC,IAAIC,IAAI,EAAE,EAAEC,QAAQ,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,GAAGC,IAAI,CAACC,MAAM,EAAE,EAAEF,QAAQ,CAAC,EAAE,CAAC,CAACG,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC;AAEvG,MAAMC,gBAAgB,GAAGA,CAACC,MAAoB,EAAEC,WAAyB,KAAK;AACjF,EAAA,KAAK,MAAMC,GAAG,IAAID,WAAW,CAACE,MAAM,EAAE;AAClC,IAAA,MAAMC,WAAW,GAAGJ,MAAM,CAACG,MAAM,CAACD,GAAG,CAAC;AACtC,IAAA,MAAMG,SAAS,GAAGJ,WAAW,CAACE,MAAM,CAACD,GAAG,CAAC;IAEzC,IAAI,CAACE,WAAW,IAAIA,WAAW,CAACE,IAAI,KAAKD,SAAS,CAACC,IAAI,EAAE;AAEzDL,IAAAA,WAAW,CAACE,MAAM,CAACD,GAAG,CAAC,GAAAK,aAAA,CAAAA,aAAA,CAAA,EAAA,EAAOF,SAAS,CAAA,EAAKD,WAAW,CAAC;AAC5D,EAAA;AACJ,CAAC;MAEYI,uBAAuB,GAAGA,CAAIC,IAAe,GAAG,EAAE,KAAsB;EACjF,MAAMN,MAA6C,GAAG,EAAE;AAMxD,EAAA,MAAMO,MAAM,GAAGC,WAAW,CAACF,IAAI,CAAC;AAEhCC,EAAAA,MAAM,CAACE,OAAO,CAACC,MAAM,IAAI;IAKrB,IAAeV,MAAM,CAACU,MAAM,CAACC,OAAO,CAAC,EAAE;MACnCC,OAAO,CAACC,IAAI,CAAC,CAAA,8CAAA,EAAiDH,MAAM,CAACC,OAAO,oBAAoB,CAAC;AACrG,IAAA;IAEA,MAAM;AACFG,MAAAA,QAAQ,GAAG,KAAK;MAChBC,GAAG;MACHC,SAAS;MACTC,GAAG;MACHC,SAAS;MACTC,IAAI;MACJC,OAAO;AACPjB,MAAAA,IAAI,GAAG,MAAM;MACbkB,YAAY;MACZnC,KAAK;MACLoC,OAAO;MACPC,cAAc;MACdZ,OAAO;MACPa,QAAQ;AACRC,MAAAA;AACJ,KAAC,GAAGf,MAAM;IACV,MAAMgB,YAAY,GAAG1C,iBAAiB,CAACmB,IAAI,CAAC,IAAInB,iBAAiB,CAACC,IAAI;AACtE,IAAA,MAAM0C,UAAU,GAAGzC,KAAK,IAAImC,YAAY,IAAIC,OAAO,IAAIC,cAAc,IAAIG,YAAY,CAACxC,KAAK;IAE3Fc,MAAM,CAACW,OAAO,CAAC,GAAG;MACdA,OAAO;MACPR,IAAI;MACJW,QAAQ;MACRC,GAAG;MACHC,SAAS;MACTC,GAAG;MACHC,SAAS;MACTC,IAAI;MACJC,OAAO;AACPlC,MAAAA,KAAK,EAAEyC,UAAU;MACjBF,YAAY;MACZD,QAAQ;AACRI,MAAAA,KAAK,EAAE,KAAK;AACZC,MAAAA,OAAO,EAAE,KAAK;MACdC,GAAG,EAAExC,iBAAiB;KACzB;AACL,EAAA,CAAC,CAAC;EAEF,OAAO;AAACU,IAAAA,MAAM,EAAEA;GAAmB;AACvC;AA8EA,MAAMQ,WAAW,GAAGA,CAACuB,IAAgB,EAAEC,KAA2C,GAAG,EAAE,KAA2C;AAC9H,EAAA,IAAI,CAACD,IAAI,EAAE,OAAOC,KAAK;AAEvBC,EAAAA,QAAQ,CAACxB,OAAO,CAACsB,IAAI,EAAEG,KAAK,IAAI;AAC5B,IAAA,IAAI,CAACC,cAAc,CAACD,KAAK,CAAC,EAAE;IAE5B,IAAIA,KAAK,CAACE,KAAK,EAAE;MACb,MAAM;QAACzB,OAAO;AAAE0B,QAAAA;OAAS,GAAGH,KAAK,CAACE,KAA4D;AAE9F,MAAA,IAAIzB,OAAO,EAAE;AAITqB,QAAAA,KAAK,CAACM,IAAI,CAACJ,KAAK,CAACE,KAAyC,CAAC;AAC/D,MAAA;AAEA,MAAA,IAAIC,QAAQ,EAAE;AACV7B,QAAAA,WAAW,CAAC6B,QAAQ,EAAEL,KAAK,CAAC;AAChC,MAAA;AACJ,IAAA;AACJ,EAAA,CAAC,CAAC;AAEF,EAAA,OAAOA,KAAK;AAChB,CAAC;AAEM,MAAMO,gBAAgB,GAAGA,CAACC,QAAgC,EAAEC,OAAgC,GAAG,EAAE,KAAsC;AAC1I,EAAA,KAAK,MAAM1C,GAAG,IAAIyC,QAAQ,EAAE;AACxB,IAAA,IAAIC,OAAO,CAACC,QAAQ,CAAC3C,GAA0B,CAAC,EAAE;IAClD,IAAIA,GAAG,KAAK,OAAO,IAAIyC,QAAQ,CAACzC,GAAG,CAAwB,EAAE;AAIzD,MAAA,OAAOA,GAAG;AACd,IAAA;AACJ,EAAA;AACJ,CAAC;AAEM,MAAM4C,kBAAkB,GAAIC,KAAuB,IAAK;AAAA,EAAA,IAAAC,YAAA;AAC3D,EAAA,MAAM3D,KAAK,GAAA,CAAA2D,YAAA,GAAGD,KAAK,CAAC1D,KAAK,MAAA,IAAA,IAAA2D,YAAA,KAAA,MAAA,GAAA,MAAA,GAAXA,YAAA,CAAarD,QAAQ,EAAE,CAACsD,IAAI,EAAE;AAC5C,EAAA,IAAI,CAAC5D,KAAK,EAAE,OAAO,KAAK;EAExB,QAAQ0D,KAAK,CAACzC,IAAI;AACd,IAAA,KAAK,OAAO;AACR,MAAA,OAAO,CAAC,4BAA4B,CAAC4C,IAAI,CAAC7D,KAAK,CAAC;AACpD,IAAA,KAAK,KAAK;MACN,IAAI;QACA,IAAI8D,GAAG,CAAC9D,KAAK,CAAC;AACd,QAAA,OAAO,KAAK;MAChB,CAAC,CAAC,OAAA+D,OAAA,EAAM;AACJ,QAAA,OAAO,IAAI;AACf,MAAA;AACJ,IAAA,KAAK,KAAK;AACN,MAAA,OAAO,CAAC,uBAAuB,CAACF,IAAI,CAAC7D,KAAK,CAAC;AAC/C,IAAA;AACI,MAAA,OAAO,KAAK;AACpB;AACJ,CAAC;AAGM,MAAMgE,aAAa,GAAIC,IAA6B,IAAc;AACrE,EAAA,IAAI,CAACA,IAAI,EAAE,OAAO,KAAK;AAEvB,EAAA,KAAK,MAAMC,OAAO,IAAID,IAAI,EAAE;AACxB,IAAA,IAAKC,OAAO,CAAsBjD,IAAI,KAAK,QAAQ,EAAE,OAAO,IAAI;AACpE,EAAA;AAEA,EAAA,OAAO,KAAK;AAChB;AAEO,MAAMkD,mBAAmB,GAAOrD,MAAgB,IAAc;AACjE,EAAA,KAAK,MAAMsD,CAAC,IAAItD,MAAM,EAAE;AACpB,IAAA,IAAIA,MAAM,CAACsD,CAAC,CAAC,CAACC,KAAK,EAAE;AACjB,MAAA,OAAO,KAAK;AAChB,IAAA;AACJ,EAAA;AACA,EAAA,OAAO,IAAI;AACf;AAEO,MAAMC,UAAU,GAAGA,CAAIxD,MAE7B,EAAEyD,OAA4B,GAAG,EAAE,KAAiB;EACjD,MAAMC,IAAgC,GAAG,EAAE;EAE3C,MAAM;IAACC,OAAO;IAAElB,OAAO;AAAEmB,IAAAA;AAAS,GAAC,GAAGH,OAAO;AAE7C,EAAA,IAAIE,OAAO,EAAE;IACTA,OAAO,CAAClD,OAAO,CAACV,GAAG,IAAA;AAAA,MAAA,IAAA8D,WAAA;AAAA,MAAA,OAAIH,IAAI,CAAC3D,GAAG,CAAW,GAAA,CAAA8D,WAAA,GAAG7D,MAAM,CAACD,GAAG,CAAC,MAAA,IAAA,IAAA8D,WAAA,KAAA,MAAA,GAAA,MAAA,GAAXA,WAAA,CAAa3E,KAAK;IAAA,CAAA,CAAC;AACpE,EAAA,CAAC,MAAM,KAAK,MAAMoE,CAAC,IAAItD,MAAM,EAAE;IAC3B0D,IAAI,CAACJ,CAAC,CAAC,GAAGtD,MAAM,CAACsD,CAAC,CAAC,CAACpE,KAAK;AAC7B,EAAA;AAEAuD,EAAAA,OAAO,KAAA,IAAA,IAAPA,OAAO,KAAA,MAAA,IAAPA,OAAO,CAAEhC,OAAO,CAACV,GAAG,IAAI,OAAO2D,IAAI,CAAC3D,GAAG,CAAW,CAAC;AAEnD,EAAA,IAAI6D,SAAS,EAAE;AACX,IAAA,KAAK,MAAM7D,GAAG,IAAI6D,SAAS,EAAE;AAAA,MAAA,IAAAE,YAAA;AACzB,MAAA,MAAMC,GAAG,GAAGH,SAAS,CAAC7D,GAAG,CAAuD;MAChF2D,IAAI,CAAC3D,GAAG,CAAC,GAAGgE,GAAG,CAAC,CAAA,CAAAD,YAAA,GAAA9D,MAAM,CAACD,GAAG,CAAC,MAAA,IAAA,IAAA+D,YAAA,KAAA,MAAA,GAAA,MAAA,GAAXA,YAAA,CAAa5E,KAAK,KAAIc,MAAM,CAACD,GAAG,CAAC,CAAC;AACtD,IAAA;AACJ,EAAA;AAEA,EAAA,OAAO2D,IAAI;AACf;MAEaM,WAAW,GAAGA,CAAIb,IAA4B,EAAEM,OAA8B,KAAe;AACtG,EAAA,IAAI,CAACN,IAAI,EAAE,OAAO,IAAIc,QAAQ,EAAE;AAwBhC,EAAA,OAAO,IAAIA,QAAQ,CAACd,IAAI,CAAC;AAC7B;AAEO,SAASe,kBAAkBA,CAAyBT,OAAqC,EAAmB;AAC/G,EAAA,IAAIC,IAA0B;AAC9B,EAAA,IAAID,OAAO,EAAE;IACT,MAAM;MAAChB,OAAO;MAAEkB,OAAO;AAAEC,MAAAA;AAAS,KAAC,GAAGH,OAAO;AAC7C,IAAA,IAAIE,OAAO,EAAE;MACTD,IAAI,GAAG,EAA0B;MACjCC,OAAO,CAAClD,OAAO,CAACV,GAAG,IAAA;AAAA,QAAA,IAAAoE,SAAA;AAAA,QAAA,OAAKT,IAAI,CAAC3D,GAAG,CAAC,GAAA,CAAAoE,SAAA,GAAG,IAAI,CAACpE,GAAG,CAAC,MAAA,IAAA,IAAAoE,SAAA,KAAA,MAAA,GAAA,MAAA,GAATA,SAAA,CAAWjF,KAAK;AAAA,MAAA,CAAC,CAAC;AAC1D,IAAA,CAAC,MAAM;AACHwE,MAAAA,IAAI,GAAG,IAAI,CAACU,SAAS,EAAE;AACvB3B,MAAAA,OAAO,KAAA,IAAA,IAAPA,OAAO,KAAA,MAAA,IAAPA,OAAO,CAAEhC,OAAO,CAACV,GAAG,IAAI,OAAO2D,IAAI,CAAC3D,GAAG,CAAC,CAAC;AAC7C,IAAA;AAEA,IAAA,IAAI6D,SAAS,EAAE;AACX,MAAA,KAAK,MAAM7D,GAAG,IAAI6D,SAAS,EAAE;AAAA,QAAA,IAAAS,UAAA;AACzB,QAAA,MAAMN,GAAG,GAAGH,SAAS,CAAC7D,GAAG,CAAuD;AAC/E2D,QAAAA,IAAI,CAAC3D,GAAG,CAAC,GAAGgE,GAAG,CAAA,CAAAM,UAAA,GAAC,IAAI,CAACtE,GAAG,CAAC,MAAA,IAAA,IAAAsE,UAAA,uBAATA,UAAA,CAAWnF,KAAK,CAAC;AACtC,MAAA;AACJ,IAAA;AACJ,EAAA,CAAC,MAAMwE,IAAI,GAAG,IAAI,CAACU,SAAS,EAAE;AAE9B,EAAA,OAAO,IAAIE,eAAe,CAACZ,IAAI,CAAC;AACpC;AAEA,SAASa,UAAUA,CAAuDC,OAAe,EAAEC,EAAU,EAAiB;AAClH,EAAA,OAAO,IAAIC,OAAO,CAACC,OAAO,IAAI;AAAA,IAAA,IAAAC,QAAA;IAC1B,IAAA,CAAAA,QAAA,GAAI,IAAI,CAACH,EAAE,CAAC,MAAA,IAAA,IAAAG,QAAA,KAAA,MAAA,IAARA,QAAA,CAAUC,OAAO,EACjBC,YAAY,CAAC,IAAI,CAACL,EAAE,CAAC,CAACI,OAAO,CAAC;IAElC,MAAMA,OAAO,GAAGE,UAAU,CAAC,MAAMJ,OAAO,EAAE,EAAEH,OAAO,CAAC;AAEpD,IAAA,IAAI,IAAI,CAACC,EAAE,CAAC,EAAE;AACV,MAAA,IAAI,CAACA,EAAE,CAAC,CAACI,OAAO,GAAGA,OAAO;AAC9B,IAAA,CAAC,MAAM,IAAI,CAACJ,EAAE,CAAC,GAAG;AAACI,MAAAA;KAAQ;AAC/B,EAAA,CAAC,CAAC;AACN;AAEO,MAAMG,SAAS,GAAGT,UAAU,CAACU,IAAI,CAAC,EAAE;AAEpC,MAAMC,aAAa,GAAGA,CAAIC,CAA+C,EAAEC,OAE/D,KAAgD;AAC/D,EAAA,IAAID,CAAC,KAAA,IAAA,IAADA,CAAC,eAADA,CAAC,CAAEE,MAAM,EAAE;IACX,IAAIC,MAAM,CAACC,MAAM,CAAClG,aAAa,EAAE8F,CAAC,CAACE,MAAM,CAAClF,IAAI,CAAC,EAAE,OAAOgF,CAAC,CAACE,MAAM,CAAChG,aAAa,CAAC8F,CAAC,CAACE,MAAM,CAAClF,IAAI,CAAC,CAAY;AACzG,IAAA,OAAOgF,CAAC,CAACE,MAAM,CAACnG,KAAK;AACzB,EAAA;AACA,EAAA,OAAO,CAACiG,CAAC,KAAA,IAAA,IAADA,CAAC,KAAA,MAAA,GAAA,MAAA,GAADA,CAAC,CAAEjG,KAAK,MAAWN,QAAQ,CAACwG,OAAO,CAAC,GAAGA,OAAO,CAAClG,KAAK,GAAGkG,OAAO,CAAC;AAC3E,CAAC;AAEM,MAAMI,YAAY,GAAGA,CAACC,aAAwC,EAAEvG,KAAgC,KAAc,OAAOuG,aAAa,KAAK,SAAS,GAAGA,aAAa,GAAG,OAAOvG,KAAK,KAAK,QAAQ,GAAG,OAAOuG,aAAa,KAAK,QAAQ,GAAG,CAAC,IAAIC,MAAM,CAACD,aAAa,CAAC,CAAC1C,IAAI,CAAC7D,KAAK,CAAC,GAAG,CAACuG,aAAa,CAAC1C,IAAI,CAAC7D,KAAK,CAAC,GAAG,KAAK;AAE9S,MAAMyG,MAAM,GAAGA,CAAmBN,MAA8B,GAAG,EAAE,EAAE,GAAGO,KAE1D,KAAQ;AAC3B,EAAA,IAAI,CAACA,KAAK,CAACC,MAAM,EAAE,OAAOR,MAAM;AAEhC,EAAA,MAAMS,IAAI,GAAGF,KAAK,CAACG,KAAK,EAAE;AAC1B,EAAA,IAAInH,QAAQ,CAACkH,IAAI,CAAC,EAAE;AAChB,IAAA,KAAK,MAAM/F,GAAG,IAAI+F,IAAI,EAAE;MACpBT,MAAM,CAACtF,GAAG,CAAC,GAAGsF,MAAM,CAACtF,GAAG,CAAC,GAAAK,aAAA,CAAAA,aAAA,CAAA,EAAA,EAAOiF,MAAM,CAACtF,GAAG,CAAC,CAAA,EAAK+F,IAAI,CAAC/F,GAAG,CAAC,CAAA,GAAI+F,IAAI,CAAC/F,GAAG,CAAC;AAC1E,IAAA;AACJ,EAAA;AAEA,EAAA,OAAO4F,MAAM,CAACN,MAAM,EAAE,GAAGO,KAAK,CAAC;AACnC;;ACnWO,MAAMI,eAAe,GAAGA,CAACC,QAA2B,EAAEC,QAA2B,EAAEC,UAAuB,GAAG,EAAE,EAAEC,SAAS,GAAG,KAAK,KAAK;AAM1I,EAAA,MAAMC,UAAU,GAAGA,CAACzD,KAAkB,EAAEuC,CAAsJ,KAAW;IACrM,IAAI,CAACvC,KAAK,EAAE;AAEZ,IAAA,MAAMQ,OAAO,GAAG+B,CAAC,IAAIA,CAAC,CAACE,MAAM;AAC7B,IAAA,MAAMiB,eAAe,GAAG,CAAC1D,KAAK,CAAChB,KAAK,IAAIgB,KAAK,CAAC1D,KAAK,IAAI,CAAC0D,KAAK,CAACf,OAAO;AAErE,IAAA,IAAI,CAACuB,OAAO,IAAI,CAACkD,eAAe,EAAE;AAElC,IAAA,IAAI,OAAOC,QAAQ,KAAK,WAAW,KAAKnD,OAAO,YAAYoD,gBAAgB,IAAIpD,OAAO,YAAYqD,mBAAmB,IAAIrD,OAAO,YAAYsD,iBAAiB,CAAC,EAAE;AAC5J,MAAA,IAAI,CAAC9D,KAAK,CAAC+D,aAAa,EAAE/D,KAAK,CAAC+D,aAAa,GAAG,MAAMvD,OAAO,CAACuD,aAAa,EAAE;AAE7E,MAAA,IAAIL,eAAe,EAAE;QAQjBM,mBAAmB,CAAChE,KAAK,CAAC;AAC1BiE,QAAAA,gBAAgB,CAACjE,KAAK,EAAEA,KAAK,CAACjC,OAAO,CAAC;AACtC,QAAA;AACJ,MAAA;AACAyC,MAAAA,OAAO,CAAC0D,iBAAiB,CAAC,EAAE,CAAC;MAE7B,MAAMrE,OAAgC,GAAGG,KAAK,CAACzC,IAAI,KAAKyC,KAAK,CAACxB,OAAO,IAAI2F,mBAAmB,CAACnE,KAAK,CAAC,CAAC,GAAI,CAAC,cAAc,CAAC,GAAG,EAAE;MAC7H,MAAMoE,WAAW,GAAGzE,gBAAgB,CAACa,OAAO,CAACZ,QAAQ,EAAEC,OAAO,CAAC;AAC/DwE,MAAAA,cAAc,CAACrE,KAAK,EAAEoE,WAAW,EAAGE,CAAS,IAAK9D,OAAO,CAAC0D,iBAAiB,CAACI,CAAC,CAAC,CAAC;AAE/E,MAAA,IAAI,CAACF,WAAW,IAAIpE,KAAK,CAACW,KAAK,EAAE;QAC7BH,OAAO,CAAC0D,iBAAiB,CAAClE,KAAK,CAACuE,SAAS,IAAI,OAAO,CAAC;AACzD,MAAA;AAEAN,MAAAA,gBAAgB,CAACjE,KAAK,EAAEA,KAAK,CAACjC,OAAO,CAAC;AAC1C,IAAA,CAAC,MAAM;AAMHiC,MAAAA,KAAK,CAAC+D,aAAa,GAAG,MAAMC,mBAAmB,CAAChE,KAAK,CAAC;MACtDA,KAAK,CAAC+D,aAAa,EAAE;AAErBE,MAAAA,gBAAgB,CAACjE,KAAK,EAAEA,KAAK,CAACjC,OAAO,CAAC;AAC1C,IAAA;EACJ,CAAC;EAED,MAAMiG,mBAAmB,GAAIhE,KAAkB,IAAK;IAChD,MAAMH,OAAgC,GAAGG,KAAK,CAACzC,IAAI,KAAKyC,KAAK,CAACxB,OAAO,IAAI2F,mBAAmB,CAACnE,KAAK,CAAC,CAAC,GAAI,CAAC,cAAc,CAAC,GAAG,EAAE;IAE7H,IAAIoE,WAAW,GAAGzE,gBAAgB,CAAC;MAC/B6E,YAAY,EAAExE,KAAK,CAAC9B,QAAQ,IAAI,CAAC8B,KAAK,CAAC1D,KAAK,IAAI,KAAK;AACrDmI,MAAAA,YAAY,EAAE1E,kBAAkB,CAACC,KAAK,CAAC;AACvC0E,MAAAA,QAAQ,EAAE1E,KAAK,CAAC1B,SAAS,IAAI0B,KAAK,CAAC1D,KAAK,CAACM,QAAQ,EAAE,CAACqG,MAAM,GAAGjD,KAAK,CAAC1B,SAAS,IAAI,KAAK;AACrFqG,MAAAA,OAAO,EAAE3E,KAAK,CAAC5B,SAAS,IAAI4B,KAAK,CAAC1D,KAAK,CAACM,QAAQ,EAAE,CAACqG,MAAM,GAAGjD,KAAK,CAAC5B,SAAS,IAAI,KAAK;AACpFwG,MAAAA,eAAe,EAAE5E,KAAK,CAACxB,OAAO,IAAIoE,YAAY,CAAC5C,KAAK,CAACxB,OAAO,EAAEwB,KAAK,CAAC1D,KAAK,CAAC,IAAI,KAAK;AACnFuI,MAAAA,cAAc,EAAE7E,KAAK,CAAC3B,GAAG,IAAIyG,MAAM,CAAC9E,KAAK,CAAC1D,KAAK,CAAC,GAAGwI,MAAM,CAAC9E,KAAK,CAAC3B,GAAG,CAAC,IAAI,KAAK;AAC7E0G,MAAAA,aAAa,EAAE/E,KAAK,CAAC7B,GAAG,IAAI2G,MAAM,CAAC9E,KAAK,CAAC1D,KAAK,CAAC,GAAGwI,MAAM,CAAC9E,KAAK,CAAC7B,GAAG,CAAC,IAAI;KAC1E,EAAE0B,OAAO,CAAC;AAEX,IAAA,IAAI,CAACuE,WAAW,IAAIpE,KAAK,CAACW,KAAK,EAAE;AAC7ByD,MAAAA,WAAW,GAAG,aAAa;AAC/B,IAAA;AACAC,IAAAA,cAAc,CAACrE,KAAK,EAAEoE,WAAW,CAAC;IAClC,OAAO,CAACpE,KAAK,CAACW,KAAK;EACvB,CAAC;EAQD,MAAMqE,mBAAmB,GAAGA,CAAChF,KAAkB,EAAEuC,CAA+C,EAAEC,OAE/E,KAAW;IAC1BxC,KAAK,CAAC1D,KAAK,GAAGgG,aAAa,CAACC,CAAC,EAAEC,OAAO,CAAyB;AAC/DiB,IAAAA,UAAU,CAACzD,KAAK,EAAEuC,CAAC,CAAC;EACxB,CAAC;EAQD,MAAM8B,cAAc,GAAGA,CAACrE,KAAkB,EAAEoE,WAAiC,EAAEa,WAAiC,KAAW;AACvH,IAAA,MAAMC,cAAc,GAAG3B,UAAU,CAACvD,KAAK,CAACnB,YAAY,IAAImB,KAAK,CAACjC,OAAO,CAAC,IAAIwF,UAAU,CAAC,GAAG,CAAC;AAKzF,IAAa;AACT,MAAA,IAAIa,WAAW,IAAI,EAACc,cAAc,KAAA,IAAA,IAAdA,cAAc,KAAA,MAAA,IAAdA,cAAc,CAAEC,aAAa,CAACf,WAAW,CAAC,CAAA,EAAE;AAC5D,QAAA,IAAIA,WAAW,KAAK,cAAc,EAAEpG,OAAO,CAACC,IAAI,CAAC,CAAA,4CAAA,EAA+C+B,KAAK,CAACjC,OAAO,CAAA,gCAAA,EAAmCqH,WAAW,CAAChB,WAAW,CAAC,CAAA,wFAAA,EAA2FiB,WAAW,CAACD,WAAW,CAAChB,WAAW,CAAC,CAAC,CAAA,gCAAA,EAAmCiB,WAAW,CAACD,WAAW,CAACR,eAAe,CAAC,CAAA,gMAAA,EAAmMQ,WAAW,CAAChB,WAAW,CAAC,CAAA,sBAAA,CAAwB,CAAC,CAAC,KACnmBpG,OAAO,CAACC,IAAI,CAAC,CAAA,4CAAA,EAA+C+B,KAAK,CAACjC,OAAO,mCAAmCqH,WAAW,CAAChB,WAAW,CAAC,CAAA,oDAAA,EAAuDiB,WAAW,CAACD,WAAW,CAAChB,WAAW,CAAC,CAAC,CAAA,gMAAA,EAAmMgB,WAAW,CAAChB,WAAW,CAAC,wBAAwB,CAAC;AAC7d,MAAA;AACJ,IAAA;AAEA,IAAA,IAAIc,cAAc,EAAE;MAChBI,eAAe,CAACtF,KAAK,EAAEkF,cAAc,EAAEd,WAAW,EAAEa,WAAW,CAAC;AACpE,IAAA;IACAjF,KAAK,CAACf,OAAO,GAAG,IAAI;EACxB,CAAC;EAED,MAAMgF,gBAAgB,GAAGA,CAACsB,OAAqD,EAAEpI,GAAY,KAAKmG,QAAQ,CAACkC,IAAI,IAAI;AAC/G,IAAA,IAAIrI,GAAG,EAAE;AACL,MAAA,OAAAK,aAAA,CAAAA,aAAA,CAAA,EAAA,EAAWgI,IAAI,CAAA,EAAA,EAAA,EAAA;AAAEpI,QAAAA,MAAM,EAAAI,aAAA,CAAAA,aAAA,CAAA,EAAA,EAAMgI,IAAI,CAACpI,MAAM,CAAA,EAAA,EAAA,EAAA;AAAE,UAAA,CAACD,GAAG,GAAAK,aAAA,CAAAA,aAAA,CAAA,EAAA,EAAOgI,IAAI,CAACpI,MAAM,CAACD,GAAG,CAAC,GAAKoI,OAAO;AAAC,SAAA;AAAC,OAAA,CAAA;AACvF,IAAA;AACA,IAAA,OAAA/H,aAAA,CAAAA,aAAA,CAAA,EAAA,EAAWgI,IAAI,GAAKD,OAAO,CAAA;AAC/B,EAAA,CAAC,CAAC;EAKF,MAAMD,eAAe,GAAGA,CAACtF,KAAkB,EAAEkF,cAAoC,EAAEd,WAAiC,EAAEa,WAAiC,KAAW;AAI9J,IAAA,MAAM7H,MAAM,GAAGiG,QAAQ,EAAE,CAACjG,MAAM;AAEhC,IAAA,KAAK,MAAMqI,KAAK,IAAIP,cAAc,CAACQ,kBAAkB,EAAE;AACnD,MAAA,MAAMC,MAAM,GAAGT,cAAc,CAACQ,kBAAkB,CAACD,KAAK,CAAC,CAACzF,KAAK,EAAEoE,WAAW,CAAC;MAK3EpE,KAAK,CAACW,KAAK,GAAGiC,YAAY,CAAC+C,MAAM,EAAE3F,KAAK,CAAC1D,KAAK,CAAC;MAC/C,IAAI0D,KAAK,CAACW,KAAK,EAAE;AACrB,IAAA;AAEA,IAAA,KAAK,MAAM8E,KAAK,IAAIP,cAAc,CAACU,QAAQ,EAAE;AACzC,MAAA,MAAMD,MAAM,GAAGT,cAAc,CAACU,QAAQ,CAACH,KAAK,CAAC,CAACzF,KAAK,EAAE5C,MAAM,CAAC;MAK5D4C,KAAK,CAACW,KAAK,GAAGiC,YAAY,CAAC+C,MAAM,EAAE3F,KAAK,CAAC1D,KAAK,CAAC;MAC/C,IAAI0D,KAAK,CAACW,KAAK,EAAE;AACrB,IAAA;IAEAX,KAAK,CAACuE,SAAS,GAAG,EAAE;AAEpB,IAAA,IAAIW,cAAc,CAACW,aAAa,CAAC5C,MAAM,EAAE;MACrCjD,KAAK,CAACW,KAAK,GAAG,IAAI;AAClByB,MAAAA,SAAS,CAACpC,KAAK,CAACpB,QAAQ,IAAI,GAAG,EAAE,CAAA,EAAGoB,KAAK,CAACd,GAAG,CAAA,MAAA,CAAQ,CAAC,CAAC4G,IAAI,CAAC,MAAM;AAC9D,QAAA,MAAMC,aAAa,GAAG,YAAY;AAC9B,UAAA,KAAK,MAAMN,KAAK,IAAIP,cAAc,CAACW,aAAa,EAAE;AAC9C,YAAA,MAAMF,MAAM,GAAG,MAAMT,cAAc,CAACW,aAAa,CAACJ,KAAK,CAAC,CAACzF,KAAK,EAAE5C,MAAM,CAAC;YAKvE4C,KAAK,CAACW,KAAK,GAAGiC,YAAY,CAAC+C,MAAM,EAAE3F,KAAK,CAAC1D,KAAK,CAAC;YAC/C,IAAI0D,KAAK,CAACW,KAAK,EAAE;AACrB,UAAA;UACA,IAAI,CAACX,KAAK,CAACW,KAAK,EAAEX,KAAK,CAACuE,SAAS,GAAG,EAAE;AAEtCN,UAAAA,gBAAgB,CAAC;YAACtD,KAAK,EAAEX,KAAK,CAACW,KAAK;YAAE4D,SAAS,EAAEvE,KAAK,CAACuE;AAAS,WAAC,EAAEvE,KAAK,CAACjC,OAAO,CAAC;AACjF,UAAA,IAAIkH,WAAW,EAAE;AACbA,YAAAA,WAAW,CAACjF,KAAK,CAACuE,SAAS,CAAC;AAChC,UAAA;QACJ,CAAC;AAKDwB,QAAAA,aAAa,EAAE;AACnB,MAAA,CAAC,CAAC;AACN,IAAA;EACJ,CAAC;EAED,MAAM5B,mBAAmB,GAAInE,KAAkB,IAAK;AAChD,IAAA,MAAMgG,SAAS,GAAGzC,UAAU,CAACvD,KAAK,CAACnB,YAAY,IAAImB,KAAK,CAACjC,OAAO,CAAC,IAAIwF,UAAU,CAAC,GAAG,CAAC;AACpF,IAAA,OAAOyC,SAAS,KAAKA,SAAS,CAACH,aAAa,CAAC5C,MAAM,GAAG,CAAC,IAAI+C,SAAS,CAACJ,QAAQ,CAAC3C,MAAM,GAAG,CAAC,CAAC;EAC7F,CAAC;EAED,OAAO;IAAC+B,mBAAmB;IAAEvB,UAAU;IAAEQ,gBAAgB;IAAET,SAAS;AAAEyC,IAAAA,mBAAmB,EAAEjC;GAAoB;AACnH,CAAC;;ACtLD,MAAMkC,YAAY,GAAGC,aAAa,CAAQ,EAAW,CAAC;AAQ/C,MAAMC,oBAAmD,GAAGA,CAAC;EAAE3G,QAAQ;EAAE4G,YAAY;EAAE9C,UAAU;AAAEC,EAAAA;AAAU,CAAC,KAAK;AACtH,EAAA,MAAM8C,QAAQ,GAAGC,MAAM,CAACF,YAAY,CAAC;AACrC,EAAA,MAAMG,SAAS,GAAGD,MAAM,CAAkB,IAAI,CAAC;AAE/C,EAAA,MAAMjD,QAAQ,GAAGmD,WAAW,CAAEC,OAA+D,IAAK;AAC9FJ,IAAAA,QAAQ,CAACK,OAAO,GAAG,OAAOD,OAAO,KAAK,UAAU,GAAGA,OAAO,CAACJ,QAAQ,CAACK,OAAO,CAAC,GAAGD,OAAO;IACtFF,SAAS,CAACG,OAAO,CAAE9I,OAAO,CAAE+I,CAAC,IAAKA,CAAC,EAAE,CAAC;EAC1C,CAAC,EAAE,EAAE,CAAC;AAEN,EAAA,MAAMhB,QAAQ,GAAGxC,eAAe,CAAC,MAAMkD,QAAQ,CAACK,OAAO,EAAErD,QAAQ,EAAEC,UAAU,EAAEC,SAAS,CAAC;AAEzF,EAAA,MAAMqD,KAAK,GAAGC,OAAO,CAAQ,MAAM;AAC/B,IAAA,IAAI,CAACN,SAAS,CAACG,OAAO,EAAE;AACpBH,MAAAA,SAAS,CAACG,OAAO,GAAG,IAAII,GAAG,EAAE;AACjC,IAAA,CAAC,MAAM;AAIHP,MAAAA,SAAS,CAACG,OAAO,CAACK,KAAK,EAAE;AACzBhK,MAAAA,gBAAgB,CAACsJ,QAAQ,CAACK,OAAO,EAAEN,YAAY,CAAC;AACpD,IAAA;IAEAC,QAAQ,CAACK,OAAO,GAAGN,YAAY;AAE/B,IAAA,KAAK,MAAMY,QAAQ,IAAIZ,YAAY,CAACjJ,MAAM,EAAE;AACxCiJ,MAAAA,YAAY,CAACjJ,MAAM,CAAC6J,QAAQ,CAAC,CAACC,eAAe,GAAI3B,OAA6B,IAAKK,QAAQ,CAAC3B,gBAAgB,CAACsB,OAAO,EAAE0B,QAAQ,CAAC;AACnI,IAAA;IAEA,OAAO;AACH5D,MAAAA,QAAQ,EAAEA,MAAMiD,QAAQ,CAACK,OAAO;MAChCrD,QAAQ;MACR6D,SAAS,EAAGC,QAAoB,IAAK;AACjCZ,QAAAA,SAAS,CAACG,OAAO,CAAEU,GAAG,CAACD,QAAQ,CAAC;QAChC,OAAO,MAAMZ,SAAS,CAACG,OAAO,CAAEW,MAAM,CAACF,QAAQ,CAAC;MACpD,CAAC;AACDxB,MAAAA;KACH;AACL,EAAA,CAAC,EAAE,CAACS,YAAY,CAAC,CAAC;AAElB,EAAA,OAAOkB,KAAA,CAAAC,aAAA,CAACtB,YAAY,CAACuB,QAAQ,EAAA;AAACnL,IAAAA,KAAK,EAAEuK;AAAM,GAAA,EAAEpH,QAAgC,CAAC;AAClF;AAEO,MAAMiI,YAAY,GAAGA,MAAM;AAC9B,EAAA,MAAMb,KAAK,GAAGc,UAAU,CAACzB,YAAY,CAAC;EACtC,IAAI,CAACW,KAAK,CAACxD,QAAQ,EAAE,MAAM,IAAIuE,KAAK,CAAC,qDAAqD,CAAC;AAE3F,EAAA,OAAOf,KAAK;AAChB;AAEO,MAAMgB,eAAe,GAAmBC,QAAoC,IAAQ;AACvF,EAAA,MAAMjB,KAAK,GAAGa,YAAY,EAAE;EAE5B,OAAOK,oBAAoB,CACvBlB,KAAK,CAACM,SAAS,EACf,MAAMW,QAAQ,CAACjB,KAAK,CAACxD,QAAQ,EAAE,CAAC,EAChC,MAAMyE,QAAQ,CAACjB,KAAK,CAACxD,QAAQ,EAAE,CACnC,CAAC;AACL;AAEO,SAAS2E,cAAcA,CAK1BC,SAAoB,EACpBC,QAEY,EACY;EACxB,IAAIC,QAAe,GAAG,EAAE;AACxB,EAAA,IAAIC,UAAkB;AAEtB,EAAA,OAAQC,KAAY,IAAa;AAC7B,IAAA,MAAMC,IAAI,GAAGL,SAAS,CAACM,GAAG,CAACC,EAAE,IAAIA,EAAE,CAACH,KAAK,CAAC,CAAC;IAC3C,IACIF,QAAQ,CAAClF,MAAM,KAAKqF,IAAI,CAACrF,MAAM,IAC/BqF,IAAI,CAACG,KAAK,CAAC,CAACC,GAAG,EAAEC,CAAC,KAAKD,GAAG,KAAKP,QAAQ,CAACQ,CAAC,CAAC,CAAC,EAC7C;AACE,MAAA,OAAOP,UAAU;AACrB,IAAA;AACAD,IAAAA,QAAQ,GAAGG,IAAI;AACfF,IAAAA,UAAU,GAAGF,QAAQ,CAAC,GAAGI,IAAW,CAAC;AACrC,IAAA,OAAOF,UAAU;EACrB,CAAC;AACL;;;;"}
1
+ {"version":3,"file":"shared.development.js","sources":["../../src/helpers.ts","../../src/useFormHandlers.ts","../../src/form-context.tsx"],"sourcesContent":["import {Children, isValidElement} from 'react';\r\nimport type {PropsWithChildren, ReactElement, ReactNode} from 'react';\r\nimport type {GInputInitialState, GInputProps, GInputState, GInputStateMutable} from './fields';\r\nimport type {FormNode, FormTreeResult, GChangeEvent, GDOMElement, IForm, PartialForm} from './form';\r\nimport type {GFormState, InitialState, RawData, RNGFormState, ToFormDataOptions, ToRawDataOptions, ToURLSearchParamsOptions} from './state';\r\n\r\nexport const isObject = (o: any): o is object => (o && typeof o === 'object' && !Array.isArray(o));\r\n\r\nconst defaultFieldProps: { [key: string]: { value: string | number | boolean } } = {\r\n text: {value: ''},\r\n checkbox: {value: false},\r\n number: {value: 0}\r\n};\r\n\r\nconst typeValueDict: { [key: string]: keyof HTMLFormElement | GDOMElement } = {\r\n checkbox: 'checked',\r\n number: 'valueAsNumber',\r\n};\r\n\r\nconst _generateIdUnsafe = () => (+new Date()).toString(36) + (1 - Math.random()).toString(36).substring(2, 16);\r\n\r\nexport const _copyStateFields = (source: InitialState, destination: InitialState) => {\r\n for (const key in destination.fields) {\r\n const sourceField = source.fields[key];\r\n const destField = destination.fields[key];\r\n\r\n if (!sourceField || sourceField.type !== destField.type) continue;\r\n\r\n destination.fields[key] = {...destField, ...sourceField};\r\n }\r\n};\r\n\r\nexport const _buildFormInitialValues = <T>(rows: ReactNode = []): InitialState<T> => {\r\n const fields: { [key: string]: GInputInitialState } = {};\r\n\r\n if (__DEBUG__) {\r\n console.log('[buildFormInitialValues] -', 'building initial values for ', rows);\r\n }\r\n\r\n const inputs = _findInputs(rows);\r\n\r\n inputs.forEach(config => {\r\n if (__DEBUG__) {\r\n console.log('[buildFormInitialValues] -', 'building input', `(${config.formKey})`, config);\r\n }\r\n\r\n if (__DEV__ && fields[config.formKey]) {\r\n console.warn(`DEV ONLY - [Duplicate Keys] - field with key '${config.formKey}' already defined.`);\r\n }\r\n\r\n const {\r\n required = false,\r\n max,\r\n maxLength,\r\n min,\r\n minLength,\r\n step,\r\n pattern,\r\n type = \"text\",\r\n defaultValue,\r\n value,\r\n checked,\r\n defaultChecked,\r\n formKey,\r\n debounce,\r\n validatorKey\r\n } = config;\r\n const defaultProps = defaultFieldProps[type] || defaultFieldProps.text;\r\n const inputValue = value || defaultValue || checked || defaultChecked || defaultProps.value;\r\n\r\n fields[formKey] = {\r\n formKey,\r\n type,\r\n required,\r\n max,\r\n maxLength,\r\n min,\r\n minLength,\r\n step,\r\n pattern,\r\n value: inputValue,\r\n validatorKey,\r\n debounce,\r\n dirty: false,\r\n touched: false,\r\n gid: _generateIdUnsafe(),\r\n };\r\n });\r\n\r\n return {fields: fields as IForm<T>};\r\n};\r\n\r\n\r\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\r\nconst _buildFormTree = (\r\n root?: ReactElement<any> | ReactElement<any>[] | undefined\r\n): FormNode[] => {\r\n if (!root) return [];\r\n\r\n if (Array.isArray(root)) {\r\n return root.flatMap(element => _buildFormTree(element));\r\n }\r\n\r\n if (root.props?.formKey) {\r\n if (__DEBUG__) {\r\n console.log(\"[findInputs] - input config found\", `(${root.props.formKey})`);\r\n }\r\n return [\r\n {\r\n type: \"input\",\r\n formKey: root.props.formKey,\r\n },\r\n ];\r\n }\r\n\r\n // Group node\r\n const childrenTree = _buildFormTree(root.props?.children);\r\n return [\r\n {\r\n type: \"group\",\r\n children: childrenTree,\r\n },\r\n ];\r\n};\r\n\r\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\r\nconst buildFormTreeWithFlatAndSignature = (\r\n root?: ReactElement<any> | ReactElement<any>[] | undefined\r\n): FormTreeResult => {\r\n const flat: (GInputProps & GInputStateMutable)[] = [];\r\n let signature = '';\r\n\r\n const walk = (node?: ReactElement<any> | ReactElement<any>[] | undefined): FormNode[] => {\r\n if (!node) return [];\r\n\r\n if (Array.isArray(node)) {\r\n return node.flatMap(child => walk(child));\r\n }\r\n\r\n if (node.props?.formKey) {\r\n flat.push(node.props);\r\n signature = `${signature}I(${node.props.formKey})`;\r\n return [\r\n {\r\n type: \"input\",\r\n formKey: node.props.formKey,\r\n props: node.props,\r\n },\r\n ];\r\n }\r\n\r\n signature = `${signature}G(`;\r\n const childrenTree = walk(node.props?.children);\r\n signature = `${signature})`;\r\n\r\n return [\r\n {\r\n type: \"group\",\r\n children: childrenTree,\r\n },\r\n ];\r\n };\r\n\r\n const tree = walk(root);\r\n\r\n return {tree, flat, signature};\r\n};\r\n\r\nconst _findInputs = (root?: ReactNode, total: (GInputProps & GInputStateMutable)[] = []): (GInputProps & GInputStateMutable)[] => {\r\n if (!root) return total;\r\n\r\n Children.forEach(root, child => {\r\n if (!isValidElement(child)) return;\r\n\r\n if (child.props) {\r\n const {formKey, children} = child.props as PropsWithChildren<GInputProps & GInputStateMutable>;\r\n\r\n if (formKey) {\r\n if (__DEBUG__) {\r\n console.log(\"[findInputs] - input config found\", `(${formKey})`);\r\n }\r\n total.push(child.props as GInputProps & GInputStateMutable);\r\n }\r\n\r\n if (children) {\r\n _findInputs(children, total);\r\n }\r\n }\r\n });\r\n\r\n return total;\r\n};\r\n\r\nexport const _findValidityKey = (validity: Partial<ValidityState>, exclude: (keyof ValidityState)[] = []): keyof ValidityState | undefined => {\r\n for (const key in validity) {\r\n if (exclude.includes(key as keyof ValidityState)) continue;\r\n if (key !== 'valid' && validity[key as keyof ValidityState]) {\r\n if (__DEBUG__) {\r\n console.log('[findValidityKey] -', 'found validity key:', key);\r\n }\r\n return key as keyof ValidityState;\r\n }\r\n }\r\n};\r\n\r\nexport const _checkTypeMismatch = (input: GInputState<any>) => {\r\n const value = input.value?.toString().trim();\r\n if (!value) return false;\r\n\r\n switch (input.type) {\r\n case 'email':\r\n return !/^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/.test(value); // basic email pattern\r\n case 'url':\r\n try {\r\n new URL(value);\r\n return false;\r\n } catch {\r\n return true;\r\n }\r\n case 'tel':\r\n return !/^\\+?[0-9\\s\\-().]{7,}$/.test(value); // basic phone pattern\r\n default:\r\n return false;\r\n }\r\n};\r\n\r\n\r\nexport const _hasSubmitter = (form?: HTMLFormElement | null): boolean => {\r\n if (!form) return false;\r\n\r\n for (const element of form) {\r\n if ((element as HTMLInputElement).type === 'submit') return true;\r\n }\r\n\r\n return false;\r\n};\r\n\r\nexport const _checkIfFormIsValid = <T>(fields: IForm<T>): boolean => {\r\n for (const f in fields) {\r\n if (fields[f].error) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n};\r\n\r\nexport const _toRawData = <T>(fields: IForm<T> & {\r\n [key: string]: GInputState<any>\r\n}, options: ToRawDataOptions<T> = {}): RawData<T> => {\r\n const data: { [key: string]: unknown } = {};\r\n\r\n const {include, exclude, transform} = options;\r\n\r\n if (include) {\r\n include.forEach(key => data[key as string] = fields[key]?.value);\r\n } else for (const f in fields) {\r\n data[f] = fields[f].value;\r\n }\r\n\r\n exclude?.forEach(key => delete data[key as string]);\r\n\r\n if (transform) {\r\n for (const key in transform) {\r\n const set = transform[key] as (value: GFormState<T>[typeof key]['value']) => any;\r\n data[key] = set(fields[key]?.value || fields[key]);\r\n }\r\n }\r\n\r\n return data as RawData<T>;\r\n};\r\n\r\nexport const _toFormData = <T>(form: HTMLFormElement | null, options?: ToFormDataOptions<T>): FormData => {\r\n if (!form) return new FormData();\r\n\r\n if (options) {\r\n const {exclude, include, transform} = options;\r\n let formData: FormData;\r\n\r\n if (include) {\r\n formData = new FormData();\r\n include.forEach(key => formData.set(key as string, form[key as string]?.value));\r\n } else {\r\n formData = new FormData(form);\r\n exclude?.forEach(key => formData.delete(key as string));\r\n }\r\n\r\n if (transform) {\r\n for (const key in transform) {\r\n const set = transform[key] as (value: GFormState<T>[typeof key]['value']) => any;\r\n formData.set(key, set(form[key]?.value));\r\n }\r\n }\r\n return formData;\r\n\r\n }\r\n\r\n return new FormData(form);\r\n};\r\n\r\nexport function _toURLSearchParams<T>(this: GFormState<T>, options?: ToURLSearchParamsOptions<T>): URLSearchParams {\r\n let data: Record<keyof T, any>;\r\n if (options) {\r\n const {exclude, include, transform} = options;\r\n if (include) {\r\n data = {} as Record<keyof T, any>;\r\n include.forEach(key => (data[key] = this[key]?.value));\r\n } else {\r\n data = this.toRawData();\r\n exclude?.forEach(key => delete data[key]);\r\n }\r\n\r\n if (transform) {\r\n for (const key in transform) {\r\n const set = transform[key] as (value: GFormState<T>[typeof key]['value']) => any;\r\n (data[key] = set(this[key]?.value));\r\n }\r\n }\r\n } else data = this.toRawData();\r\n\r\n return new URLSearchParams(data); // this is ok because URLSearchParams will stringify the values (boolean/number)\r\n}\r\n\r\nfunction __debounce(this: { [key: string]: { timerId: number } }, timeout: number, id: string): Promise<void> {\r\n return new Promise(resolve => {\r\n if (this[id]?.timerId)\r\n clearTimeout(this[id].timerId);\r\n\r\n const timerId = setTimeout(() => resolve(), timeout);\r\n\r\n if (this[id]) {\r\n this[id].timerId = timerId;\r\n } else this[id] = {timerId};\r\n });\r\n}\r\n\r\nexport const _debounce = __debounce.bind({});\r\n\r\nexport const _extractValue = <T>(e?: GChangeEvent<GDOMElement | HTMLFormElement>, unknown?: {\r\n value: T\r\n} | string | number): undefined | string | number | boolean | T => {\r\n if (e?.target) {\r\n if (Object.hasOwn(typeValueDict, e.target.type)) return e.target[typeValueDict[e.target.type] as 'value'];\r\n return e.target.value;\r\n }\r\n return (e?.value as T) || (isObject(unknown) ? unknown.value : unknown);\r\n};\r\n\r\nexport const _checkResult = (handlerResult: boolean | RegExp | string, value: string | number | boolean): boolean => typeof handlerResult === 'boolean' ? handlerResult : typeof value === 'string' ? typeof handlerResult === 'string' ? !new RegExp(handlerResult).test(value) : !handlerResult.test(value) : false;\r\n\r\nexport const _merge = <T extends object>(target: { [key: string]: any } = {}, ...nodes: ({\r\n [key: string]: any\r\n} | undefined | void)[]): T => {\r\n if (!nodes.length) return target as T;\r\n\r\n const next = nodes.shift();\r\n if (isObject(next)) {\r\n for (const key in next) {\r\n target[key] = target[key] ? {...target[key], ...next[key]} : next[key];\r\n }\r\n }\r\n\r\n return _merge(target, ...nodes);\r\n};\r\n\r\nexport const _mergeRefs = <T>(\r\n refA: React.Ref<T> | undefined,\r\n refB: React.Ref<T> | undefined\r\n) => {\r\n return (value: T | null) => {\r\n if (typeof refA === 'function') {\r\n refA(value);\r\n } else if (refA) {\r\n refA.current = value;\r\n }\r\n\r\n if (typeof refB === 'function') {\r\n refB(value);\r\n } else if (refB) {\r\n refB.current = value;\r\n }\r\n };\r\n};\r\n\r\nexport const _buildFormState = <T>(fields: InitialState<T>['fields'], formElement: HTMLFormElement, dispatchChanges: (changes: Partial<InitialState> | Partial<GInputState>, key?: string) => void) => {\r\n const isFormValid = _checkIfFormIsValid(fields);\r\n\r\n const formState: GFormState<T> = {\r\n ...fields,\r\n isValid: isFormValid,\r\n isInvalid: !isFormValid,\r\n toRawData: (options?: ToRawDataOptions<T>) => _toRawData(fields, options),\r\n toFormData: () => _toFormData(formElement),\r\n toURLSearchParams: _toURLSearchParams,\r\n checkValidity: function () { // it has to be a function in order to refer to 'this'\r\n this.isValid = formElement && formElement.checkValidity() || false;\r\n this.isInvalid = !this.isValid;\r\n return this.isValid;\r\n },\r\n dispatchChanges: (changes: PartialForm<T> & {\r\n [key: string]: Partial<GInputState<any>>\r\n }) => dispatchChanges({\r\n fields: _merge<IForm<T> & {\r\n [key: string]: GInputState;\r\n }>({}, fields, changes)\r\n })\r\n };\r\n\r\n return formState;\r\n};\r\n\r\nexport const _buildRNFormState = <T>(fields: InitialState<T>['fields'], dispatchChanges: (changes: Partial<InitialState> | Partial<GInputState>, key?: string) => void) => {\r\n const isFormValid = _checkIfFormIsValid(fields);\r\n\r\n const formState: RNGFormState<T> = {\r\n ...fields,\r\n isValid: isFormValid,\r\n isInvalid: !isFormValid,\r\n toRawData: (options?: ToRawDataOptions<T>) => _toRawData(fields, options),\r\n toURLSearchParams: _toURLSearchParams,\r\n checkValidity: () => {\r\n for (const i in fields) {\r\n const valid = fields[i].checkValidity();\r\n if (!valid) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n },\r\n dispatchChanges: (changes: PartialForm<T> & {\r\n [key: string]: Partial<GInputState<any>>\r\n }) => dispatchChanges({\r\n fields: _merge<IForm<T> & {\r\n [key: string]: GInputState;\r\n }>({}, fields, changes)\r\n })\r\n };\r\n\r\n return formState;\r\n};","import {_checkResult, _checkTypeMismatch, _debounce, _extractValue, _findValidityKey} from \"./helpers\";\r\nimport {type GInputValidator, type GValidators} from \"./validations\";\r\nimport type {GInputState} from \"./fields\";\r\nimport type {GChangeEvent, GDOMElement, GFocusEvent, GFormEvent, GInvalidEvent} from \"./form\";\r\nimport type {InitialState, Store} from \"./state\";\r\nimport {handlersMap, validityMap} from \"./validations/GValidator\";\r\n\r\nexport const useFormHandlers = (getState: Store['getState'], setState: Store['setState'], validators: GValidators = {}, optimized = false) => {\r\n /**\r\n * handler for validating a form input\r\n * @param input the input to be validated\r\n * @param e the event object\r\n */\r\n const _viHandler = (input: GInputState<any>, e?: GFocusEvent<GDOMElement | HTMLFormElement> | GInvalidEvent<GDOMElement | HTMLFormElement> | GFormEvent<GDOMElement | HTMLFormElement> | GFormEvent): void => {\r\n if (!input) return;\r\n\r\n const element = e && e.target;\r\n\r\n if (typeof document !== 'undefined' && (element instanceof HTMLInputElement || element instanceof HTMLTextAreaElement || element instanceof HTMLSelectElement)) {\r\n if (!input.checkValidity) input.checkValidity = () => element.checkValidity();\r\n\r\n const hasInitialValue = !input.dirty && input.value && !input.touched;\r\n\r\n if (hasInitialValue) { //if the field has initial value\r\n /**\r\n * for inputs with initial value we have to manually check for validations.\r\n * validity.tooShort is false even though initial value is smaller than minLength, because its required to be filled in by user (native dirty flag is true).\r\n * it only works for validity.valueMissing.\r\n * If an element has a minimum allowed value length, its dirty value flag is true, its value was last changed by a user edit (as opposed to a change made by a script), its value is not the empty string, and the length of the element's API value is less than the element's minimum allowed value length, then the element is suffering from being too short.\r\n * @see https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#setting-minimum-input-length-requirements:-the-minlength-attribute\r\n */\r\n _checkInputManually(input);\r\n _dispatchChanges(input, input.formKey);\r\n return;\r\n }\r\n element.setCustomValidity(''); //reset any previous error (custom)\r\n\r\n const exclude: (keyof ValidityState)[] = input.type && (input.pattern || hasCustomValidation(input)) ? ['typeMismatch'] : [];\r\n const validityKey = _findValidityKey(element.validity, exclude);\r\n _validateInput(input, validityKey, (v: string) => element.setCustomValidity(v));\r\n\r\n if (!validityKey && input.error) {\r\n element.setCustomValidity(input.errorText || 'error');\r\n }\r\n\r\n _dispatchChanges(input, input.formKey);\r\n } else {\r\n if (__DEBUG__) {\r\n console.log('[validateInputHandler] -', `the input '${input.formKey}' is not a native web element\\nevent:`, e);\r\n }\r\n\r\n // fallback - validate the input for validations manually\r\n input.checkValidity = () => _checkInputManually(input);\r\n input.checkValidity();\r\n\r\n _dispatchChanges(input, input.formKey);\r\n }\r\n };\r\n\r\n const _checkInputManually = (input: GInputState<any>) => {\r\n const exclude: (keyof ValidityState)[] = input.type && (input.pattern || hasCustomValidation(input)) ? ['typeMismatch'] : [];\r\n\r\n let validityKey = _findValidityKey({\r\n valueMissing: input.required && !input.value || false,\r\n typeMismatch: _checkTypeMismatch(input),\r\n tooShort: input.minLength && input.value.toString().length < input.minLength || false,\r\n tooLong: input.maxLength && input.value.toString().length > input.maxLength || false,\r\n patternMismatch: input.pattern && _checkResult(input.pattern, input.value) || false,\r\n rangeUnderflow: input.min && Number(input.value) < Number(input.min) || false,\r\n rangeOverflow: input.max && Number(input.value) > Number(input.max) || false\r\n }, exclude);\r\n\r\n if (!validityKey && input.error) {\r\n validityKey = 'customError';\r\n }\r\n _validateInput(input, validityKey);\r\n return !input.error;\r\n };\r\n\r\n /**\r\n * handler for updating and validating a form input\r\n * @param input\r\n * @param e the event object\r\n * @param unknown\r\n */\r\n const _updateInputHandler = (input: GInputState<any>, e?: GChangeEvent<GDOMElement | HTMLFormElement>, unknown?: {\r\n value: unknown\r\n } | string | number): void => {\r\n input.value = _extractValue(e, unknown) as GInputState['value'];\r\n _viHandler(input, e);\r\n };\r\n\r\n /**\r\n * Validates the input and updates the state with the result\r\n * @param input the input to be validated\r\n * @param validityKey the `Constraint Validation` key\r\n * @param setValidity\r\n */\r\n const _validateInput = (input: GInputState, validityKey?: keyof ValidityState, setValidity?: (e: string) => void): void => {\r\n const inputValidator = validators[input.validatorKey || input.formKey] || validators['*'];\r\n if (__DEBUG__) {\r\n console.log('[validateInput] -', 'validating input:', input.formKey, `(${validityKey ? validityKey : 'custom'})`);\r\n }\r\n\r\n if (__DEV__) {\r\n if (validityKey && !inputValidator?.hasConstraint(validityKey)) {\r\n if (validityKey === 'typeMismatch') console.warn(`DEV ONLY - [Missing Validator] - the input '${input.formKey}' has described the constraint '${validityMap[validityKey]}' however, a correspond validator/custom validation/pattern validator is missing.\\nadd '${handlersMap[validityMap[validityKey]]}' or 'withCustomValidation' or '${handlersMap[validityMap.patternMismatch]}' to the input validator.\\nexample:\\nconst validators: GValidators = {\\n\\temail: new GValidator().withPatternMismatchMessage('pattern mismatch'),\\n\\t...\\n}\\n\\nor either remove the constraint '${validityMap[validityKey]}' from the input props`);\r\n else console.warn(`DEV ONLY - [Missing Validator] - the input '${input.formKey}' has described the constraint '${validityMap[validityKey]}' however, a correspond validator is missing.\\nadd '${handlersMap[validityMap[validityKey]]}' to the input validator.\\nexample:\\nconst validators: GValidators = {\\n\\temail: new GValidator().withPatternMismatchMessage('pattern mismatch'),\\n\\t...\\n}\\n\\nor either remove the constraint '${validityMap[validityKey]}' from the input props`);\r\n }\r\n }\r\n\r\n if (inputValidator) {\r\n __validateInput(input, inputValidator, validityKey, setValidity);\r\n }\r\n input.touched = true;\r\n };\r\n\r\n const _dispatchChanges = (changes: Partial<InitialState> | Partial<GInputState<any>>, key?: string) => setState(prev => {\r\n if (key) {\r\n return {...prev, fields: {...prev.fields, [key]: {...prev.fields[key], ...changes}}};\r\n }\r\n return {...prev, ...changes};\r\n });\r\n\r\n /**\r\n * @internal\r\n */\r\n const __validateInput = (input: GInputState, inputValidator: GInputValidator<any>, validityKey?: keyof ValidityState, setValidity?: (e: string) => void): void => {\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validating input (${input.formKey}) with handlers:`, inputValidator.handlers);\r\n }\r\n const fields = getState().fields;\r\n\r\n for (const index in inputValidator.constraintHandlers) {\r\n const result = inputValidator.constraintHandlers[index](input, validityKey);\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validation results for constraint handler (${index}):\\n`, inputValidator.constraintHandlers[index], '\\n\\nvalidator result:', result, '\\nviolation:', input.error, `(${input.error ? 'failed' : 'passed'})`);\r\n }\r\n\r\n input.error = _checkResult(result, input.value);\r\n if (input.error) return;\r\n }\r\n\r\n for (const index in inputValidator.handlers) {\r\n const result = inputValidator.handlers[index](input, fields);\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validation results for custom handler (${index}):\\n`, inputValidator.handlers[index], '\\n\\nvalidator result:', result, '\\nviolation:', input.error, `(${input.error ? 'failed' : 'passed'})`);\r\n }\r\n\r\n input.error = _checkResult(result, input.value);\r\n if (input.error) return;\r\n }\r\n\r\n input.errorText = '';\r\n\r\n if (inputValidator.asyncHandlers.length) {\r\n input.error = true;\r\n _debounce(input.debounce || 300, `${input.gid}-async`).then(() => {\r\n const validateAsync = async () => {\r\n for (const index in inputValidator.asyncHandlers) {\r\n const result = await inputValidator.asyncHandlers[index](input, fields);\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validation results for custom async handler (${index}):\\n`, inputValidator.asyncHandlers[index], '\\n\\nvalidator result:', result, '\\nviolation:', input.error, `(${input.error ? 'failed' : 'passed'})`);\r\n }\r\n\r\n input.error = _checkResult(result, input.value);\r\n if (input.error) break;\r\n }\r\n if (!input.error) input.errorText = '';\r\n\r\n _dispatchChanges({error: input.error, errorText: input.errorText}, input.formKey);\r\n if (setValidity) {\r\n setValidity(input.errorText);\r\n }\r\n };\r\n\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validating input (${input.formKey}) with async handlers:`, inputValidator.asyncHandlers);\r\n }\r\n validateAsync();\r\n });\r\n }\r\n };\r\n\r\n const hasCustomValidation = (input: GInputState) => {\r\n const validator = validators[input.validatorKey || input.formKey] || validators['*'];\r\n return validator && (validator.asyncHandlers.length > 0 || validator.handlers.length > 0);\r\n };\r\n\r\n return {_updateInputHandler, _viHandler, _dispatchChanges, optimized, _createInputChecker: _checkInputManually};\r\n};","import React, {createContext, useCallback, useContext, useMemo, useRef, useSyncExternalStore} from 'react';\r\nimport type {FC, PropsWithChildren} from 'react';\r\n\r\nimport {useFormHandlers} from \"./useFormHandlers\";\r\nimport type {InitialState, Store} from \"./state\";\r\nimport type {GValidators} from \"./validations\";\r\nimport type {GInputState} from './fields';\r\nimport {_copyStateFields} from \"./helpers\";\r\n\r\nconst GFormContext = createContext<Store>({} as Store);\r\n\r\ntype GFormContextProviderProps = PropsWithChildren & {\r\n initialState: InitialState;\r\n validators?: GValidators;\r\n optimized?: boolean;\r\n};\r\n\r\nexport const GFormContextProvider: FC<GFormContextProviderProps> = ({ children, initialState, validators, optimized }) => {\r\n const stateRef = useRef(initialState);\r\n const listeners = useRef<Set<() => void>>(null);\r\n\r\n const setState = useCallback((updater: InitialState | ((state: InitialState) => InitialState)) => {\r\n const prevState = stateRef.current;\r\n const nextState =\r\n typeof updater === \"function\" ? (updater as (s: InitialState) => InitialState)(prevState) : updater;\r\n\r\n if (Object.is(prevState, nextState)) {\r\n return;\r\n }\r\n\r\n stateRef.current = nextState;\r\n listeners.current!.forEach((l) => l());\r\n }, []);\r\n\r\n const handlers = useFormHandlers(() => stateRef.current, setState, validators, optimized);\r\n\r\n const store = useMemo<Store>(() => {\r\n if (!listeners.current) {\r\n listeners.current = new Set();\r\n } else {\r\n if (__DEBUG__) {\r\n console.log(`[form-context] - form changed stated from`, stateRef.current, '\\nto\\n', initialState);\r\n }\r\n listeners.current.clear();\r\n _copyStateFields(stateRef.current, initialState);\r\n }\r\n\r\n stateRef.current = initialState;\r\n\r\n for (const fieldKey in initialState.fields) {\r\n initialState.fields[fieldKey].dispatchChanges = (changes: Partial<GInputState>) => handlers._dispatchChanges(changes, fieldKey);\r\n }\r\n\r\n return {\r\n getState: () => stateRef.current,\r\n setState,\r\n subscribe: (listener: () => void) => {\r\n listeners.current!.add(listener);\r\n return () => listeners.current!.delete(listener);\r\n },\r\n handlers\r\n };\r\n }, [initialState]);\r\n\r\n return <GFormContext.Provider value={store}>{children}</GFormContext.Provider>;\r\n};\r\n\r\nexport const useFormStore = () => {\r\n const store = useContext(GFormContext);\r\n if (!store.getState) throw new Error('useGFormStore must be used within `GForm` component');\r\n\r\n return store;\r\n};\r\n\r\nexport const useFormSelector = <T extends any>(selector: (state: InitialState) => T): T => {\r\n const store = useFormStore();\r\n\r\n return useSyncExternalStore(\r\n store.subscribe,\r\n () => selector(store.getState()),\r\n () => selector(store.getState()) // for SSR\r\n );\r\n};\r\n\r\nexport function createSelector<\r\n State=InitialState,\r\n Selectors extends Array<(state: State) => any> = [],\r\n Result = any\r\n>(\r\n selectors: Selectors,\r\n combiner: (...args: {\r\n [K in keyof Selectors]: Selectors[K] extends (state: State) => infer R ? R : never;\r\n }) => Result\r\n): (state: State) => Result {\r\n let lastArgs: any[] = [];\r\n let lastResult: Result;\r\n\r\n return (state: State): Result => {\r\n const args = selectors.map(fn => fn(state));\r\n if (\r\n lastArgs.length === args.length &&\r\n args.every((val, i) => val === lastArgs[i])\r\n ) {\r\n return lastResult;\r\n }\r\n lastArgs = args;\r\n lastResult = combiner(...args as any);\r\n return lastResult;\r\n };\r\n}"],"names":["isObject","o","Array","isArray","defaultFieldProps","text","value","checkbox","number","typeValueDict","_generateIdUnsafe","Date","toString","Math","random","substring","_copyStateFields","source","destination","key","fields","sourceField","destField","type","_objectSpread","_buildFormInitialValues","rows","inputs","_findInputs","forEach","config","formKey","console","warn","required","max","maxLength","min","minLength","step","pattern","defaultValue","checked","defaultChecked","debounce","validatorKey","defaultProps","inputValue","dirty","touched","gid","root","total","Children","child","isValidElement","props","children","push","_findValidityKey","validity","exclude","includes","_checkTypeMismatch","input","_input$value","trim","test","URL","_unused","_hasSubmitter","form","element","_checkIfFormIsValid","f","error","_toRawData","options","data","include","transform","_fields$key","_fields$key2","set","_toFormData","FormData","_toURLSearchParams","_this$key","toRawData","_this$key2","URLSearchParams","__debounce","timeout","id","Promise","resolve","_this$id","timerId","clearTimeout","setTimeout","_debounce","bind","_extractValue","e","unknown","target","Object","hasOwn","_checkResult","handlerResult","RegExp","_merge","nodes","length","next","shift","_mergeRefs","refA","refB","current","_buildFormState","formElement","dispatchChanges","isFormValid","formState","isValid","isInvalid","toFormData","toURLSearchParams","checkValidity","changes","useFormHandlers","getState","setState","validators","optimized","_viHandler","document","HTMLInputElement","HTMLTextAreaElement","HTMLSelectElement","hasInitialValue","_checkInputManually","_dispatchChanges","setCustomValidity","hasCustomValidation","validityKey","_validateInput","v","errorText","valueMissing","typeMismatch","tooShort","tooLong","patternMismatch","rangeUnderflow","Number","rangeOverflow","_updateInputHandler","setValidity","inputValidator","hasConstraint","validityMap","handlersMap","__validateInput","prev","index","constraintHandlers","result","handlers","asyncHandlers","then","validateAsync","validator","_createInputChecker","GFormContext","createContext","GFormContextProvider","initialState","stateRef","useRef","listeners","useCallback","updater","prevState","nextState","is","l","store","useMemo","Set","clear","fieldKey","subscribe","listener","add","delete","React","createElement","Provider","useFormStore","useContext","Error","useFormSelector","selector","useSyncExternalStore","createSelector","selectors","combiner","lastArgs","lastResult","state","args","map","fn","every","val","i"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import e,{Children as t,isValidElement as r,createContext as n,useContext as a,useSyncExternalStore as o,useRef as i,useCallback as s,useMemo as c}from"react";import l from"@babel/runtime/helpers/esm/objectSpread2";const u=e=>e&&"object"==typeof e&&!Array.isArray(e),d={text:{value:""},checkbox:{value:!1},number:{value:0}},f={checkbox:"checked",number:"valueAsNumber"},h=(e=[])=>{const t={};return m(e).forEach((e=>{const{required:r=!1,max:n,maxLength:a,min:o,minLength:i,step:s,pattern:c,type:l="text",defaultValue:u,value:f,checked:h,defaultChecked:m,formKey:v,debounce:y,validatorKey:p}=e,g=f||u||h||m||(d[l]||d.text).value;t[v]={formKey:v,type:l,required:r,max:n,maxLength:a,min:o,minLength:i,step:s,pattern:c,value:g,validatorKey:p,debounce:y,dirty:!1,touched:!1,gid:(+new Date).toString(36)+(1-Math.random()).toString(36).substring(2,16)}})),{fields:t}},m=(e,n=[])=>e?(t.forEach(e,(e=>{if(r(e)&&e.props){const{formKey:t,children:r}=e.props;t&&n.push(e.props),r&&m(r,n)}})),n):n,v=(e,t=[])=>{for(const r in e)if(!t.includes(r)&&"valid"!==r&&e[r])return r},y=e=>{var t;const r=null===(t=e.value)||void 0===t?void 0:t.toString().trim();if(!r)return!1;switch(e.type){case"email":return!/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(r);case"url":try{return new URL(r),!1}catch(e){return!0}case"tel":return!/^\+?[0-9\s\-().]{7,}$/.test(r);default:return!1}},p=e=>{for(const t in e)if(e[t].error)return!1;return!0},g=(e,t={})=>{const r={},{include:n,exclude:a,transform:o}=t;if(n)n.forEach((t=>{var n;return r[t]=null===(n=e[t])||void 0===n?void 0:n.value}));else for(const t in e)r[t]=e[t].value;if(null==a||a.forEach((e=>delete r[e])),o)for(const t in o){var i;const n=o[t];r[t]=n((null===(i=e[t])||void 0===i?void 0:i.value)||e[t])}return r},b=(e,t)=>e?new FormData(e):new FormData;function x(e){let t;if(e){const{exclude:n,include:a,transform:o}=e;if(a?(t={},a.forEach((e=>{var r;return t[e]=null===(r=this[e])||void 0===r?void 0:r.value}))):(t=this.toRawData(),null==n||n.forEach((e=>delete t[e]))),o)for(const e in o){var r;const n=o[e];t[e]=n(null===(r=this[e])||void 0===r?void 0:r.value)}}else t=this.toRawData();return new URLSearchParams(t)}const w=function(e,t){return new Promise((r=>{var n;null!==(n=this[t])&&void 0!==n&&n.timerId&&clearTimeout(this[t].timerId);const a=setTimeout((()=>r()),e);this[t]?this[t].timerId=a:this[t]={timerId:a}}))}.bind({}),S=(e,t)=>"boolean"==typeof e?e:"string"==typeof t&&("string"==typeof e?!new RegExp(e).test(t):!e.test(t)),E=(e={},...t)=>{if(!t.length)return e;const r=t.shift();if(u(r))for(const t in r)e[t]=e[t]?l(l({},e[t]),r[t]):r[t];return E(e,...t)},L=(e,t,r={},n=!1)=>{const a=(e,t)=>{if(!e)return;const r=t&&t.target,n=!e.dirty&&e.value&&!e.touched;if(r||n)if("undefined"!=typeof document&&(r instanceof HTMLInputElement||r instanceof HTMLTextAreaElement||r instanceof HTMLSelectElement)){if(e.checkValidity||(e.checkValidity=()=>r.checkValidity()),n)return o(e),void s(e,e.formKey);r.setCustomValidity("");const t=e.type&&(e.pattern||d(e))?["typeMismatch"]:[],a=v(r.validity,t);i(e,a,(e=>r.setCustomValidity(e))),!a&&e.error&&r.setCustomValidity(e.errorText||"error"),s(e,e.formKey)}else e.checkValidity=()=>o(e),e.checkValidity(),s(e,e.formKey)},o=e=>{const t=e.type&&(e.pattern||d(e))?["typeMismatch"]:[];let r=v({valueMissing:e.required&&!e.value||!1,typeMismatch:y(e),tooShort:e.minLength&&e.value.toString().length<e.minLength||!1,tooLong:e.maxLength&&e.value.toString().length>e.maxLength||!1,patternMismatch:e.pattern&&S(e.pattern,e.value)||!1,rangeUnderflow:e.min&&Number(e.value)<Number(e.min)||!1,rangeOverflow:e.max&&Number(e.value)>Number(e.max)||!1},t);return!r&&e.error&&(r="customError"),i(e,r),!e.error},i=(e,t,n)=>{const a=r[e.validatorKey||e.formKey]||r["*"];a&&c(e,a,t,n),e.touched=!0},s=(e,r)=>t((t=>r?l(l({},t),{},{fields:l(l({},t.fields),{},{[r]:l(l({},t.fields[r]),e)})}):l(l({},t),e))),c=(t,r,n,a)=>{const o=e().fields;for(const e in r.constraintHandlers){const a=r.constraintHandlers[e](t,n);if(t.error=S(a,t.value),t.error)return}for(const e in r.handlers){const n=r.handlers[e](t,o);if(t.error=S(n,t.value),t.error)return}t.errorText="",r.asyncHandlers.length&&(t.error=!0,w(t.debounce||300,`${t.gid}-async`).then((()=>{(async()=>{for(const e in r.asyncHandlers){const n=await r.asyncHandlers[e](t,o);if(t.error=S(n,t.value),t.error)break}t.error||(t.errorText=""),s({error:t.error,errorText:t.errorText},t.formKey),a&&a(t.errorText)})()})))},d=e=>{const t=r[e.validatorKey||e.formKey]||r["*"];return t&&(t.asyncHandlers.length>0||t.handlers.length>0)};return{_updateInputHandler:(e,t,r)=>{e.value=((e,t)=>null!=e&&e.target?Object.hasOwn(f,e.target.type)?e.target[f[e.target.type]]:e.target.value:(null==e?void 0:e.value)||(u(t)?t.value:t))(t,r),a(e,t)},_viHandler:a,_dispatchChanges:s,optimized:n,_createInputChecker:o}},K=n({}),k=({children:t,initialState:r,validators:n,optimized:a})=>{const o=i(r),u=i(null),d=s((e=>{o.current="function"==typeof e?e(o.current):e,u.current.forEach((e=>e()))}),[]),f=L((()=>o.current),d,n,a),h=c((()=>{u.current?(u.current.clear(),((e,t)=>{for(const r in t.fields){const n=e.fields[r],a=t.fields[r];n&&n.type===a.type&&(t.fields[r]=l(l({},a),n))}})(o.current,r)):u.current=new Set,o.current=r;for(const e in r.fields)r.fields[e].dispatchChanges=t=>f._dispatchChanges(t,e);return{getState:()=>o.current,setState:d,subscribe:e=>(u.current.add(e),()=>u.current.delete(e)),handlers:f}}),[r]);return e.createElement(K.Provider,{value:h},t)},T=()=>{const e=a(K);if(!e.getState)throw new Error("useGFormStore must be used within `GForm` component");return e},H=e=>{const t=T();return o(t.subscribe,(()=>e(t.getState())),(()=>e(t.getState())))};function M(e,t){let r,n=[];return a=>{const o=e.map((e=>e(a)));return n.length===o.length&&o.every(((e,t)=>e===n[t]))||(n=o,r=t(...o)),r}}export{k as G,p as _,H as a,x as b,b as c,g as d,E as e,h as f,M as g,w as h,T as u};
1
+ import e,{Children as t,isValidElement as r,createContext as n,useContext as o,useSyncExternalStore as i,useRef as a,useCallback as s,useMemo as c}from"react";import u from"@babel/runtime/helpers/esm/defineProperty";function l(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function d(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?arguments[t]:{};t%2?l(Object(r),!0).forEach((function(t){u(e,t,r[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(r)):l(Object(r)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(r,t))}))}return e}const f=e=>e&&"object"==typeof e&&!Array.isArray(e),h={text:{value:""},checkbox:{value:!1},number:{value:0}},p={checkbox:"checked",number:"valueAsNumber"},m=(e=[])=>{const t={};return y(e).forEach((e=>{const{required:r=!1,max:n,maxLength:o,min:i,minLength:a,step:s,pattern:c,type:u="text",defaultValue:l,value:d,checked:f,defaultChecked:p,formKey:m,debounce:y,validatorKey:v}=e,g=d||l||f||p||(h[u]||h.text).value;t[m]={formKey:m,type:u,required:r,max:n,maxLength:o,min:i,minLength:a,step:s,pattern:c,value:g,validatorKey:v,debounce:y,dirty:!1,touched:!1,gid:(+new Date).toString(36)+(1-Math.random()).toString(36).substring(2,16)}})),{fields:t}},y=(e,n=[])=>e?(t.forEach(e,(e=>{if(r(e)&&e.props){const{formKey:t,children:r}=e.props;t&&n.push(e.props),r&&y(r,n)}})),n):n,v=(e,t=[])=>{for(const r in e)if(!t.includes(r)&&"valid"!==r&&e[r])return r},g=e=>{var t;const r=null===(t=e.value)||void 0===t?void 0:t.toString().trim();if(!r)return!1;switch(e.type){case"email":return!/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(r);case"url":try{return new URL(r),!1}catch(e){return!0}case"tel":return!/^\+?[0-9\s\-().]{7,}$/.test(r);default:return!1}};function b(e){let t;if(e){const{exclude:n,include:o,transform:i}=e;if(o?(t={},o.forEach((e=>{var r;return t[e]=null===(r=this[e])||void 0===r?void 0:r.value}))):(t=this.toRawData(),null==n||n.forEach((e=>delete t[e]))),i)for(const e in i){var r;const n=i[e];t[e]=n(null===(r=this[e])||void 0===r?void 0:r.value)}}else t=this.toRawData();return new URLSearchParams(t)}const O=function(e,t){return new Promise((r=>{var n;null!==(n=this[t])&&void 0!==n&&n.timerId&&clearTimeout(this[t].timerId);const o=setTimeout((()=>r()),e);this[t]?this[t].timerId=o:this[t]={timerId:o}}))}.bind({}),w=(e,t)=>"boolean"==typeof e?e:"string"==typeof t&&("string"==typeof e?!new RegExp(e).test(t):!e.test(t)),j=(e={},...t)=>{if(!t.length)return e;const r=t.shift();if(f(r))for(const t in r)e[t]=e[t]?d(d({},e[t]),r[t]):r[t];return j(e,...t)},x=(e,t)=>r=>{"function"==typeof e?e(r):e&&(e.current=r),"function"==typeof t?t(r):t&&(t.current=r)},P=(e,t,r)=>{const n=(e=>{for(const t in e)if(e[t].error)return!1;return!0})(e);return d(d({},e),{},{isValid:n,isInvalid:!n,toRawData:t=>((e,t={})=>{const r={},{include:n,exclude:o,transform:i}=t;if(n)n.forEach((t=>{var n;return r[t]=null===(n=e[t])||void 0===n?void 0:n.value}));else for(const t in e)r[t]=e[t].value;if(null==o||o.forEach((e=>delete r[e])),i)for(const t in i){var a;const n=i[t];r[t]=n((null===(a=e[t])||void 0===a?void 0:a.value)||e[t])}return r})(e,t),toFormData:()=>{return(e=t)?new FormData(e):new FormData;var e},toURLSearchParams:b,checkValidity:function(){return this.isValid=t&&t.checkValidity()||!1,this.isInvalid=!this.isValid,this.isValid},dispatchChanges:t=>r({fields:j({},e,t)})})};function S(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function E(e){for(var t=1;t<arguments.length;t++){var r=null!=arguments[t]?arguments[t]:{};t%2?S(Object(r),!0).forEach((function(t){u(e,t,r[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(r)):S(Object(r)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(r,t))}))}return e}const k=(e,t,r={},n=!1)=>{const o=(e,t)=>{if(!e)return;const r=t&&t.target;if("undefined"!=typeof document&&(r instanceof HTMLInputElement||r instanceof HTMLTextAreaElement||r instanceof HTMLSelectElement)){e.checkValidity||(e.checkValidity=()=>r.checkValidity());if(!e.dirty&&e.value&&!e.touched)return i(e),void s(e,e.formKey);r.setCustomValidity("");const t=e.type&&(e.pattern||u(e))?["typeMismatch"]:[],n=v(r.validity,t);a(e,n,(e=>r.setCustomValidity(e))),!n&&e.error&&r.setCustomValidity(e.errorText||"error"),s(e,e.formKey)}else e.checkValidity=()=>i(e),e.checkValidity(),s(e,e.formKey)},i=e=>{const t=e.type&&(e.pattern||u(e))?["typeMismatch"]:[];let r=v({valueMissing:e.required&&!e.value||!1,typeMismatch:g(e),tooShort:e.minLength&&e.value.toString().length<e.minLength||!1,tooLong:e.maxLength&&e.value.toString().length>e.maxLength||!1,patternMismatch:e.pattern&&w(e.pattern,e.value)||!1,rangeUnderflow:e.min&&Number(e.value)<Number(e.min)||!1,rangeOverflow:e.max&&Number(e.value)>Number(e.max)||!1},t);return!r&&e.error&&(r="customError"),a(e,r),!e.error},a=(e,t,n)=>{const o=r[e.validatorKey||e.formKey]||r["*"];o&&c(e,o,t,n),e.touched=!0},s=(e,r)=>t((t=>r?E(E({},t),{},{fields:E(E({},t.fields),{},{[r]:E(E({},t.fields[r]),e)})}):E(E({},t),e))),c=(t,r,n,o)=>{const i=e().fields;for(const e in r.constraintHandlers){const o=r.constraintHandlers[e](t,n);if(t.error=w(o,t.value),t.error)return}for(const e in r.handlers){const n=r.handlers[e](t,i);if(t.error=w(n,t.value),t.error)return}t.errorText="",r.asyncHandlers.length&&(t.error=!0,O(t.debounce||300,`${t.gid}-async`).then((()=>{(async()=>{for(const e in r.asyncHandlers){const n=await r.asyncHandlers[e](t,i);if(t.error=w(n,t.value),t.error)break}t.error||(t.errorText=""),s({error:t.error,errorText:t.errorText},t.formKey),o&&o(t.errorText)})()})))},u=e=>{const t=r[e.validatorKey||e.formKey]||r["*"];return t&&(t.asyncHandlers.length>0||t.handlers.length>0)};return{_updateInputHandler:(e,t,r)=>{e.value=((e,t)=>null!=e&&e.target?Object.hasOwn(p,e.target.type)?e.target[p[e.target.type]]:e.target.value:(null==e?void 0:e.value)||(f(t)?t.value:t))(t,r),o(e,t)},_viHandler:o,_dispatchChanges:s,optimized:n,_createInputChecker:i}},D=n({}),L=({children:t,initialState:r,validators:n,optimized:o})=>{const i=a(r),u=a(null),l=s((e=>{const t=i.current,r="function"==typeof e?e(t):e;Object.is(t,r)||(i.current=r,u.current.forEach((e=>e())))}),[]),f=k((()=>i.current),l,n,o),h=c((()=>{u.current?(u.current.clear(),((e,t)=>{for(const r in t.fields){const n=e.fields[r],o=t.fields[r];n&&n.type===o.type&&(t.fields[r]=d(d({},o),n))}})(i.current,r)):u.current=new Set,i.current=r;for(const e in r.fields)r.fields[e].dispatchChanges=t=>f._dispatchChanges(t,e);return{getState:()=>i.current,setState:l,subscribe:e=>(u.current.add(e),()=>u.current.delete(e)),handlers:f}}),[r]);return e.createElement(D.Provider,{value:h},t)},V=()=>{const e=o(D);if(!e.getState)throw new Error("useGFormStore must be used within `GForm` component");return e},K=e=>{const t=V();return i(t.subscribe,(()=>e(t.getState())),(()=>e(t.getState())))};function T(e,t){let r,n=[];return o=>{const i=e.map((e=>e(o)));return n.length===i.length&&i.every(((e,t)=>e===n[t]))||(n=i,r=t(...i)),r}}export{L as G,P as _,K as a,x as b,m as c,j as d,T as e,O as f,V as u};
2
2
  //# sourceMappingURL=shared.production.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"shared.production.js","sources":["../../src/helpers.ts","../../src/useFormHandlers.ts","../../src/form-context.tsx"],"sourcesContent":["import {Children, isValidElement} from 'react';\r\nimport type {PropsWithChildren, ReactElement, ReactNode} from 'react';\r\nimport type {GInputInitialState, GInputProps, GInputState, GInputStateMutable} from './fields';\r\nimport type {FormNode, FormTreeResult, GChangeEvent, GDOMElement, IForm} from './form';\r\nimport type {GFormState, InitialState, RawData, ToFormDataOptions, ToRawDataOptions, ToURLSearchParamsOptions} from './state';\r\n\r\nexport const isObject = (o: any): o is object => (o && typeof o === 'object' && !Array.isArray(o));\r\n\r\nconst defaultFieldProps: { [key: string]: { value: string | number | boolean } } = {\r\n text: {value: ''},\r\n checkbox: {value: false},\r\n number: {value: 0}\r\n};\r\n\r\nconst typeValueDict: { [key: string]: keyof HTMLFormElement | GDOMElement } = {\r\n checkbox: 'checked',\r\n number: 'valueAsNumber',\r\n};\r\n\r\nconst _generateIdUnsafe = () => (+new Date()).toString(36) + (1 - Math.random()).toString(36).substring(2, 16);\r\n\r\nexport const _copyStateFields = (source: InitialState, destination: InitialState) => {\r\n for (const key in destination.fields) {\r\n const sourceField = source.fields[key];\r\n const destField = destination.fields[key];\r\n\r\n if (!sourceField || sourceField.type !== destField.type) continue;\r\n\r\n destination.fields[key] = {...destField, ...sourceField};\r\n }\r\n};\r\n\r\nexport const _buildFormInitialValues = <T>(rows: ReactNode = []): InitialState<T> => {\r\n const fields: { [key: string]: GInputInitialState } = {};\r\n\r\n if (__DEBUG__) {\r\n console.log('[buildFormInitialValues] -', 'building initial values for ', rows);\r\n }\r\n\r\n const inputs = _findInputs(rows);\r\n\r\n inputs.forEach(config => {\r\n if (__DEBUG__) {\r\n console.log('[buildFormInitialValues] -', 'building input', `(${config.formKey})`, config);\r\n }\r\n\r\n if (__DEV__ && fields[config.formKey]) {\r\n console.warn(`DEV ONLY - [Duplicate Keys] - field with key '${config.formKey}' already defined.`);\r\n }\r\n\r\n const {\r\n required = false,\r\n max,\r\n maxLength,\r\n min,\r\n minLength,\r\n step,\r\n pattern,\r\n type = \"text\",\r\n defaultValue,\r\n value,\r\n checked,\r\n defaultChecked,\r\n formKey,\r\n debounce,\r\n validatorKey\r\n } = config;\r\n const defaultProps = defaultFieldProps[type] || defaultFieldProps.text;\r\n const inputValue = value || defaultValue || checked || defaultChecked || defaultProps.value;\r\n\r\n fields[formKey] = {\r\n formKey,\r\n type,\r\n required,\r\n max,\r\n maxLength,\r\n min,\r\n minLength,\r\n step,\r\n pattern,\r\n value: inputValue,\r\n validatorKey,\r\n debounce,\r\n dirty: false,\r\n touched: false,\r\n gid: _generateIdUnsafe(),\r\n };\r\n });\r\n\r\n return {fields: fields as IForm<T>};\r\n};\r\n\r\n\r\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\r\nconst _buildFormTree = (\r\n root?: ReactElement<any> | ReactElement<any>[] | undefined\r\n): FormNode[] => {\r\n if (!root) return [];\r\n\r\n if (Array.isArray(root)) {\r\n return root.flatMap(element => _buildFormTree(element));\r\n }\r\n\r\n if (root.props?.formKey) {\r\n if (__DEBUG__) {\r\n console.log(\"[findInputs] - input config found\", `(${root.props.formKey})`);\r\n }\r\n return [\r\n {\r\n type: \"input\",\r\n formKey: root.props.formKey,\r\n },\r\n ];\r\n }\r\n\r\n // Group node\r\n const childrenTree = _buildFormTree(root.props?.children);\r\n return [\r\n {\r\n type: \"group\",\r\n children: childrenTree,\r\n },\r\n ];\r\n};\r\n\r\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\r\nconst buildFormTreeWithFlatAndSignature = (\r\n root?: ReactElement<any> | ReactElement<any>[] | undefined\r\n): FormTreeResult => {\r\n const flat: (GInputProps & GInputStateMutable)[] = [];\r\n let signature = '';\r\n\r\n const walk = (node?: ReactElement<any> | ReactElement<any>[] | undefined): FormNode[] => {\r\n if (!node) return [];\r\n\r\n if (Array.isArray(node)) {\r\n return node.flatMap(child => walk(child));\r\n }\r\n\r\n if (node.props?.formKey) {\r\n flat.push(node.props);\r\n signature = `${signature}I(${node.props.formKey})`;\r\n return [\r\n {\r\n type: \"input\",\r\n formKey: node.props.formKey,\r\n props: node.props,\r\n },\r\n ];\r\n }\r\n\r\n signature = `${signature}G(`;\r\n const childrenTree = walk(node.props?.children);\r\n signature = `${signature})`;\r\n\r\n return [\r\n {\r\n type: \"group\",\r\n children: childrenTree,\r\n },\r\n ];\r\n };\r\n\r\n const tree = walk(root);\r\n\r\n return {tree, flat, signature};\r\n};\r\n\r\nconst _findInputs = (root?: ReactNode, total: (GInputProps & GInputStateMutable)[] = []): (GInputProps & GInputStateMutable)[] => {\r\n if (!root) return total;\r\n\r\n Children.forEach(root, child => {\r\n if (!isValidElement(child)) return;\r\n\r\n if (child.props) {\r\n const {formKey, children} = child.props as PropsWithChildren<GInputProps & GInputStateMutable>;\r\n\r\n if (formKey) {\r\n if (__DEBUG__) {\r\n console.log(\"[findInputs] - input config found\", `(${formKey})`);\r\n }\r\n total.push(child.props as GInputProps & GInputStateMutable);\r\n }\r\n\r\n if (children) {\r\n _findInputs(children, total);\r\n }\r\n }\r\n });\r\n\r\n return total;\r\n};\r\n\r\nexport const _findValidityKey = (validity: Partial<ValidityState>, exclude: (keyof ValidityState)[] = []): keyof ValidityState | undefined => {\r\n for (const key in validity) {\r\n if (exclude.includes(key as keyof ValidityState)) continue;\r\n if (key !== 'valid' && validity[key as keyof ValidityState]) {\r\n if (__DEBUG__) {\r\n console.log('[findValidityKey] -', 'found validity key:', key);\r\n }\r\n return key as keyof ValidityState;\r\n }\r\n }\r\n};\r\n\r\nexport const _checkTypeMismatch = (input: GInputState<any>) => {\r\n const value = input.value?.toString().trim();\r\n if (!value) return false;\r\n\r\n switch (input.type) {\r\n case 'email':\r\n return !/^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/.test(value); // basic email pattern\r\n case 'url':\r\n try {\r\n new URL(value);\r\n return false;\r\n } catch {\r\n return true;\r\n }\r\n case 'tel':\r\n return !/^\\+?[0-9\\s\\-().]{7,}$/.test(value); // basic phone pattern\r\n default:\r\n return false;\r\n }\r\n};\r\n\r\n\r\nexport const _hasSubmitter = (form?: HTMLFormElement | null): boolean => {\r\n if (!form) return false;\r\n\r\n for (const element of form) {\r\n if ((element as HTMLInputElement).type === 'submit') return true;\r\n }\r\n\r\n return false;\r\n};\r\n\r\nexport const _checkIfFormIsValid = <T>(fields: IForm<T>): boolean => {\r\n for (const f in fields) {\r\n if (fields[f].error) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n};\r\n\r\nexport const _toRawData = <T>(fields: IForm<T> & {\r\n [key: string]: GInputState<any>\r\n}, options: ToRawDataOptions<T> = {}): RawData<T> => {\r\n const data: { [key: string]: unknown } = {};\r\n\r\n const {include, exclude, transform} = options;\r\n\r\n if (include) {\r\n include.forEach(key => data[key as string] = fields[key]?.value);\r\n } else for (const f in fields) {\r\n data[f] = fields[f].value;\r\n }\r\n\r\n exclude?.forEach(key => delete data[key as string]);\r\n\r\n if (transform) {\r\n for (const key in transform) {\r\n const set = transform[key] as (value: GFormState<T>[typeof key]['value']) => any;\r\n data[key] = set(fields[key]?.value || fields[key]);\r\n }\r\n }\r\n\r\n return data as RawData<T>;\r\n};\r\n\r\nexport const _toFormData = <T>(form: HTMLFormElement | null, options?: ToFormDataOptions<T>): FormData => {\r\n if (!form) return new FormData();\r\n\r\n if (options) {\r\n const {exclude, include, transform} = options;\r\n let formData: FormData;\r\n\r\n if (include) {\r\n formData = new FormData();\r\n include.forEach(key => formData.set(key as string, form[key as string]?.value));\r\n } else {\r\n formData = new FormData(form);\r\n exclude?.forEach(key => formData.delete(key as string));\r\n }\r\n\r\n if (transform) {\r\n for (const key in transform) {\r\n const set = transform[key] as (value: GFormState<T>[typeof key]['value']) => any;\r\n formData.set(key, set(form[key]?.value));\r\n }\r\n }\r\n return formData;\r\n\r\n }\r\n\r\n return new FormData(form);\r\n};\r\n\r\nexport function _toURLSearchParams<T>(this: GFormState<T>, options?: ToURLSearchParamsOptions<T>): URLSearchParams {\r\n let data: Record<keyof T, any>;\r\n if (options) {\r\n const {exclude, include, transform} = options;\r\n if (include) {\r\n data = {} as Record<keyof T, any>;\r\n include.forEach(key => (data[key] = this[key]?.value));\r\n } else {\r\n data = this.toRawData();\r\n exclude?.forEach(key => delete data[key]);\r\n }\r\n\r\n if (transform) {\r\n for (const key in transform) {\r\n const set = transform[key] as (value: GFormState<T>[typeof key]['value']) => any;\r\n (data[key] = set(this[key]?.value));\r\n }\r\n }\r\n } else data = this.toRawData();\r\n\r\n return new URLSearchParams(data); // this is ok because URLSearchParams will stringify the values (boolean/number)\r\n}\r\n\r\nfunction __debounce(this: { [key: string]: { timerId: NodeJS.Timeout } }, timeout: number, id: string): Promise<void> {\r\n return new Promise(resolve => {\r\n if (this[id]?.timerId)\r\n clearTimeout(this[id].timerId);\r\n\r\n const timerId = setTimeout(() => resolve(), timeout);\r\n\r\n if (this[id]) {\r\n this[id].timerId = timerId;\r\n } else this[id] = {timerId};\r\n });\r\n}\r\n\r\nexport const _debounce = __debounce.bind({});\r\n\r\nexport const _extractValue = <T>(e?: GChangeEvent<GDOMElement | HTMLFormElement>, unknown?: {\r\n value: T\r\n} | string | number): undefined | string | number | boolean | T => {\r\n if (e?.target) {\r\n if (Object.hasOwn(typeValueDict, e.target.type)) return e.target[typeValueDict[e.target.type] as 'value'];\r\n return e.target.value;\r\n }\r\n return (e?.value as T) || (isObject(unknown) ? unknown.value : unknown);\r\n};\r\n\r\nexport const _checkResult = (handlerResult: boolean | RegExp | string, value: string | number | boolean): boolean => typeof handlerResult === 'boolean' ? handlerResult : typeof value === 'string' ? typeof handlerResult === 'string' ? !new RegExp(handlerResult).test(value) : !handlerResult.test(value) : false;\r\n\r\nexport const _merge = <T extends object>(target: { [key: string]: any } = {}, ...nodes: ({\r\n [key: string]: any\r\n} | undefined | void)[]): T => {\r\n if (!nodes.length) return target as T;\r\n\r\n const next = nodes.shift();\r\n if (isObject(next)) {\r\n for (const key in next) {\r\n target[key] = target[key] ? {...target[key], ...next[key]} : next[key];\r\n }\r\n }\r\n\r\n return _merge(target, ...nodes);\r\n};\r\n","import {_checkResult, _checkTypeMismatch, _debounce, _extractValue, _findValidityKey} from \"./helpers\";\r\nimport {type GInputValidator, type GValidators} from \"./validations\";\r\nimport type {GInputState} from \"./fields\";\r\nimport type {GChangeEvent, GDOMElement, GFocusEvent, GFormEvent, GInvalidEvent} from \"./form\";\r\nimport type {InitialState, Store} from \"./state\";\r\nimport {handlersMap, validityMap} from \"./validations/GValidator\";\r\n\r\nexport const useFormHandlers = (getState: Store['getState'], setState: Store['setState'], validators: GValidators = {}, optimized = false) => {\r\n /**\r\n * handler for validating a form input\r\n * @param input the input to be validated\r\n * @param e the event object\r\n */\r\n const _viHandler = (input: GInputState, e?: GFocusEvent<GDOMElement | HTMLFormElement> | GInvalidEvent<GDOMElement | HTMLFormElement> | GFormEvent<GDOMElement | HTMLFormElement> | GFormEvent): void => {\r\n if (!input) return;\r\n\r\n const element = e && e.target;\r\n const hasInitialValue = !input.dirty && input.value && !input.touched;\r\n\r\n if (!element && !hasInitialValue) return;\r\n\r\n if (typeof document !== 'undefined' && (element instanceof HTMLInputElement || element instanceof HTMLTextAreaElement || element instanceof HTMLSelectElement)) {\r\n if (!input.checkValidity) input.checkValidity = () => element.checkValidity();\r\n\r\n if (hasInitialValue) { //if the field has initial value\r\n /**\r\n * for inputs with initial value we have to manually check for validations.\r\n * validity.tooShort is false even though initial value is smaller than minLength, because its required to be filled in by user (native dirty flag is true).\r\n * it only works for validity.valueMissing.\r\n * If an element has a minimum allowed value length, its dirty value flag is true, its value was last changed by a user edit (as opposed to a change made by a script), its value is not the empty string, and the length of the element's API value is less than the element's minimum allowed value length, then the element is suffering from being too short.\r\n * @see https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#setting-minimum-input-length-requirements:-the-minlength-attribute\r\n */\r\n _checkInputManually(input);\r\n _dispatchChanges(input, input.formKey);\r\n return;\r\n }\r\n element.setCustomValidity(''); //reset any previous error (custom)\r\n\r\n const exclude: (keyof ValidityState)[] = input.type && (input.pattern || hasCustomValidation(input)) ? ['typeMismatch'] : [];\r\n const validityKey = _findValidityKey(element.validity, exclude);\r\n _validateInput(input, validityKey, (v: string) => element.setCustomValidity(v));\r\n\r\n if (!validityKey && input.error) {\r\n element.setCustomValidity(input.errorText || 'error');\r\n }\r\n\r\n _dispatchChanges(input, input.formKey);\r\n } else {\r\n if (__DEBUG__) {\r\n console.log('[validateInputHandler] -', `the input '${input.formKey}' is not a native web element\\nevent:`, e);\r\n }\r\n\r\n //fallback - validate the input for validations manually\r\n input.checkValidity = () => _checkInputManually(input);\r\n input.checkValidity();\r\n\r\n _dispatchChanges(input, input.formKey);\r\n }\r\n };\r\n\r\n const _checkInputManually = (input: GInputState) => {\r\n const exclude: (keyof ValidityState)[] = input.type && (input.pattern || hasCustomValidation(input)) ? ['typeMismatch'] : [];\r\n\r\n let validityKey = _findValidityKey({\r\n valueMissing: input.required && !input.value || false,\r\n typeMismatch: _checkTypeMismatch(input),\r\n tooShort: input.minLength && input.value.toString().length < input.minLength || false,\r\n tooLong: input.maxLength && input.value.toString().length > input.maxLength || false,\r\n patternMismatch: input.pattern && _checkResult(input.pattern, input.value) || false,\r\n rangeUnderflow: input.min && Number(input.value) < Number(input.min) || false,\r\n rangeOverflow: input.max && Number(input.value) > Number(input.max) || false\r\n }, exclude);\r\n\r\n if (!validityKey && input.error) {\r\n validityKey = 'customError';\r\n }\r\n _validateInput(input, validityKey);\r\n return !input.error;\r\n };\r\n\r\n /**\r\n * handler for updating and validating a form input\r\n * @param input\r\n * @param e the event object\r\n * @param unknown\r\n */\r\n const _updateInputHandler = (input: GInputState, e?: GChangeEvent<GDOMElement | HTMLFormElement>, unknown?: {\r\n value: unknown\r\n } | string | number): void => {\r\n input.value = _extractValue(e, unknown) as GInputState['value'];\r\n _viHandler(input, e);\r\n };\r\n\r\n /**\r\n * Validates the input and updates the state with the result\r\n * @param input the input to be validated\r\n * @param validityKey the `Constraint Validation` key\r\n * @param setValidity\r\n */\r\n const _validateInput = (input: GInputState, validityKey?: keyof ValidityState, setValidity?: (e: string) => void): void => {\r\n const inputValidator = validators[input.validatorKey || input.formKey] || validators['*'];\r\n if (__DEBUG__) {\r\n console.log('[validateInput] -', 'validating input:', input.formKey, `(${validityKey ? validityKey : 'custom'})`);\r\n }\r\n\r\n if (__DEV__) {\r\n if (validityKey && !inputValidator?.hasConstraint(validityKey)) {\r\n if (validityKey === 'typeMismatch') console.warn(`DEV ONLY - [Missing Validator] - the input '${input.formKey}' has described the constraint '${validityMap[validityKey]}' however, a correspond validator/custom validation/pattern validator is missing.\\nadd '${handlersMap[validityMap[validityKey]]}' or 'withCustomValidation' or '${handlersMap[validityMap.patternMismatch]}' to the input validator.\\nexample:\\nconst validators: GValidators = {\\n\\temail: new GValidator().withPatternMismatchMessage('pattern mismatch'),\\n\\t...\\n}\\n\\nor either remove the constraint '${validityMap[validityKey]}' from the input props`);\r\n else console.warn(`DEV ONLY - [Missing Validator] - the input '${input.formKey}' has described the constraint '${validityMap[validityKey]}' however, a correspond validator is missing.\\nadd '${handlersMap[validityMap[validityKey]]}' to the input validator.\\nexample:\\nconst validators: GValidators = {\\n\\temail: new GValidator().withPatternMismatchMessage('pattern mismatch'),\\n\\t...\\n}\\n\\nor either remove the constraint '${validityMap[validityKey]}' from the input props`);\r\n }\r\n }\r\n\r\n if (inputValidator) {\r\n __validateInput(input, inputValidator, validityKey, setValidity);\r\n }\r\n input.touched = true;\r\n };\r\n\r\n const _dispatchChanges = (changes: Partial<InitialState> | Partial<GInputState>, key?: string) => setState(prev => {\r\n if (key) {\r\n return {...prev, fields: {...prev.fields, [key]: {...prev.fields[key], ...changes}}};\r\n }\r\n return {...prev, ...changes};\r\n });\r\n\r\n /**\r\n * @internal\r\n */\r\n const __validateInput = (input: GInputState, inputValidator: GInputValidator<any>, validityKey?: keyof ValidityState, setValidity?: (e: string) => void): void => {\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validating input (${input.formKey}) with handlers:`, inputValidator.handlers);\r\n }\r\n const fields = getState().fields;\r\n\r\n for (const index in inputValidator.constraintHandlers) {\r\n const result = inputValidator.constraintHandlers[index](input, validityKey);\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validation results for constraint handler (${index}):\\n`, inputValidator.constraintHandlers[index], '\\n\\nvalidator result:', result, '\\nviolation:', input.error, `(${input.error ? 'failed' : 'passed'})`);\r\n }\r\n\r\n input.error = _checkResult(result, input.value);\r\n if (input.error) return;\r\n }\r\n\r\n for (const index in inputValidator.handlers) {\r\n const result = inputValidator.handlers[index](input, fields);\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validation results for custom handler (${index}):\\n`, inputValidator.handlers[index], '\\n\\nvalidator result:', result, '\\nviolation:', input.error, `(${input.error ? 'failed' : 'passed'})`);\r\n }\r\n\r\n input.error = _checkResult(result, input.value);\r\n if (input.error) return;\r\n }\r\n\r\n input.errorText = '';\r\n\r\n if (inputValidator.asyncHandlers.length) {\r\n input.error = true;\r\n _debounce(input.debounce || 300, `${input.gid}-async`).then(() => {\r\n const validateAsync = async () => {\r\n for (const index in inputValidator.asyncHandlers) {\r\n const result = await inputValidator.asyncHandlers[index](input, fields);\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validation results for custom async handler (${index}):\\n`, inputValidator.asyncHandlers[index], '\\n\\nvalidator result:', result, '\\nviolation:', input.error, `(${input.error ? 'failed' : 'passed'})`);\r\n }\r\n\r\n input.error = _checkResult(result, input.value);\r\n if (input.error) break;\r\n }\r\n if (!input.error) input.errorText = '';\r\n\r\n _dispatchChanges({error: input.error, errorText: input.errorText}, input.formKey);\r\n if (setValidity) {\r\n setValidity(input.errorText);\r\n }\r\n };\r\n\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validating input (${input.formKey}) with async handlers:`, inputValidator.asyncHandlers);\r\n }\r\n validateAsync();\r\n });\r\n }\r\n };\r\n\r\n const hasCustomValidation = (input: GInputState) => {\r\n const validator = validators[input.validatorKey || input.formKey] || validators['*'];\r\n return validator && (validator.asyncHandlers.length > 0 || validator.handlers.length > 0);\r\n };\r\n\r\n return {_updateInputHandler, _viHandler, _dispatchChanges, optimized, _createInputChecker: _checkInputManually};\r\n};","import React, {createContext, useCallback, useContext, useMemo, useRef, useSyncExternalStore} from 'react';\r\nimport type {FC, PropsWithChildren} from 'react';\r\n\r\nimport {useFormHandlers} from \"./useFormHandlers\";\r\nimport type {InitialState, Store} from \"./state\";\r\nimport type {GValidators} from \"./validations\";\r\nimport type {GInputState} from './fields';\r\nimport {_copyStateFields} from \"./helpers\";\r\n\r\nconst GFormContext = createContext<Store>({} as Store);\r\n\r\ntype GFormContextProviderProps = PropsWithChildren & {\r\n initialState: InitialState;\r\n validators?: GValidators;\r\n optimized?: boolean;\r\n};\r\n\r\nexport const GFormContextProvider: FC<GFormContextProviderProps> = ({ children, initialState, validators, optimized }) => {\r\n const stateRef = useRef(initialState);\r\n const listeners = useRef<Set<() => void>>(null);\r\n\r\n const setState = useCallback((updater: InitialState | ((state: InitialState) => InitialState)) => {\r\n stateRef.current = typeof updater === 'function' ? updater(stateRef.current) : updater;\r\n listeners.current!.forEach((l) => l());\r\n }, []);\r\n\r\n const handlers = useFormHandlers(() => stateRef.current, setState, validators, optimized);\r\n\r\n const store = useMemo<Store>(() => {\r\n if (!listeners.current) {\r\n listeners.current = new Set();\r\n } else {\r\n if (__DEBUG__) {\r\n console.log(`[form-context] - form changed stated from`, stateRef.current, '\\nto\\n', initialState);\r\n }\r\n listeners.current.clear();\r\n _copyStateFields(stateRef.current, initialState);\r\n }\r\n\r\n stateRef.current = initialState;\r\n\r\n for (const fieldKey in initialState.fields) {\r\n initialState.fields[fieldKey].dispatchChanges = (changes: Partial<GInputState>) => handlers._dispatchChanges(changes, fieldKey);\r\n }\r\n\r\n return {\r\n getState: () => stateRef.current,\r\n setState,\r\n subscribe: (listener: () => void) => {\r\n listeners.current!.add(listener);\r\n return () => listeners.current!.delete(listener);\r\n },\r\n handlers\r\n };\r\n }, [initialState]);\r\n\r\n return <GFormContext.Provider value={store}>{children}</GFormContext.Provider>;\r\n};\r\n\r\nexport const useFormStore = () => {\r\n const store = useContext(GFormContext);\r\n if (!store.getState) throw new Error('useGFormStore must be used within `GForm` component');\r\n\r\n return store;\r\n};\r\n\r\nexport const useFormSelector = <T extends any>(selector: (state: InitialState) => T): T => {\r\n const store = useFormStore();\r\n\r\n return useSyncExternalStore(\r\n store.subscribe,\r\n () => selector(store.getState()),\r\n () => selector(store.getState()) // for SSR\r\n );\r\n};\r\n\r\nexport function createSelector<\r\n State=InitialState,\r\n Selectors extends Array<(state: State) => any> = [],\r\n Result = any\r\n>(\r\n selectors: Selectors,\r\n combiner: (...args: {\r\n [K in keyof Selectors]: Selectors[K] extends (state: State) => infer R ? R : never;\r\n }) => Result\r\n): (state: State) => Result {\r\n let lastArgs: any[] = [];\r\n let lastResult: Result;\r\n\r\n return (state: State): Result => {\r\n const args = selectors.map(fn => fn(state));\r\n if (\r\n lastArgs.length === args.length &&\r\n args.every((val, i) => val === lastArgs[i])\r\n ) {\r\n return lastResult;\r\n }\r\n lastArgs = args;\r\n lastResult = combiner(...args as any);\r\n return lastResult;\r\n };\r\n}"],"names":["isObject","o","Array","isArray","defaultFieldProps","text","value","checkbox","number","typeValueDict","_buildFormInitialValues","rows","fields","_findInputs","forEach","config","required","max","maxLength","min","minLength","step","pattern","type","defaultValue","checked","defaultChecked","formKey","debounce","validatorKey","inputValue","dirty","touched","gid","Date","toString","Math","random","substring","root","total","Children","child","isValidElement","props","children","push","_findValidityKey","validity","exclude","key","includes","_checkTypeMismatch","input","_input$value","trim","test","URL","_unused","_checkIfFormIsValid","f","error","_toRawData","options","data","include","transform","_fields$key","_fields$key2","set","_toFormData","form","FormData","_toURLSearchParams","_this$key","this","toRawData","_this$key2","URLSearchParams","_debounce","timeout","id","Promise","resolve","_this$id","timerId","clearTimeout","setTimeout","bind","_checkResult","handlerResult","RegExp","_merge","target","nodes","length","next","shift","_objectSpread","useFormHandlers","getState","setState","validators","optimized","_viHandler","e","element","hasInitialValue","document","HTMLInputElement","HTMLTextAreaElement","HTMLSelectElement","checkValidity","_checkInputManually","_dispatchChanges","setCustomValidity","hasCustomValidation","validityKey","_validateInput","v","errorText","valueMissing","typeMismatch","tooShort","tooLong","patternMismatch","rangeUnderflow","Number","rangeOverflow","setValidity","inputValidator","__validateInput","changes","prev","index","constraintHandlers","result","handlers","asyncHandlers","then","async","validateAsync","validator","_updateInputHandler","unknown","_extractValue","Object","hasOwn","_createInputChecker","GFormContext","createContext","GFormContextProvider","initialState","stateRef","useRef","listeners","useCallback","updater","current","l","store","useMemo","clear","_copyStateFields","source","destination","sourceField","destField","Set","fieldKey","dispatchChanges","subscribe","listener","add","delete","React","createElement","Provider","useFormStore","useContext","Error","useFormSelector","selector","useSyncExternalStore","createSelector","selectors","combiner","lastResult","lastArgs","state","args","map","fn","every","val","i"],"mappings":"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"}
1
+ {"version":3,"file":"shared.production.js","sources":["../../src/helpers.ts","../../src/useFormHandlers.ts","../../src/form-context.tsx"],"sourcesContent":["import {Children, isValidElement} from 'react';\r\nimport type {PropsWithChildren, ReactElement, ReactNode} from 'react';\r\nimport type {GInputInitialState, GInputProps, GInputState, GInputStateMutable} from './fields';\r\nimport type {FormNode, FormTreeResult, GChangeEvent, GDOMElement, IForm, PartialForm} from './form';\r\nimport type {GFormState, InitialState, RawData, RNGFormState, ToFormDataOptions, ToRawDataOptions, ToURLSearchParamsOptions} from './state';\r\n\r\nexport const isObject = (o: any): o is object => (o && typeof o === 'object' && !Array.isArray(o));\r\n\r\nconst defaultFieldProps: { [key: string]: { value: string | number | boolean } } = {\r\n text: {value: ''},\r\n checkbox: {value: false},\r\n number: {value: 0}\r\n};\r\n\r\nconst typeValueDict: { [key: string]: keyof HTMLFormElement | GDOMElement } = {\r\n checkbox: 'checked',\r\n number: 'valueAsNumber',\r\n};\r\n\r\nconst _generateIdUnsafe = () => (+new Date()).toString(36) + (1 - Math.random()).toString(36).substring(2, 16);\r\n\r\nexport const _copyStateFields = (source: InitialState, destination: InitialState) => {\r\n for (const key in destination.fields) {\r\n const sourceField = source.fields[key];\r\n const destField = destination.fields[key];\r\n\r\n if (!sourceField || sourceField.type !== destField.type) continue;\r\n\r\n destination.fields[key] = {...destField, ...sourceField};\r\n }\r\n};\r\n\r\nexport const _buildFormInitialValues = <T>(rows: ReactNode = []): InitialState<T> => {\r\n const fields: { [key: string]: GInputInitialState } = {};\r\n\r\n if (__DEBUG__) {\r\n console.log('[buildFormInitialValues] -', 'building initial values for ', rows);\r\n }\r\n\r\n const inputs = _findInputs(rows);\r\n\r\n inputs.forEach(config => {\r\n if (__DEBUG__) {\r\n console.log('[buildFormInitialValues] -', 'building input', `(${config.formKey})`, config);\r\n }\r\n\r\n if (__DEV__ && fields[config.formKey]) {\r\n console.warn(`DEV ONLY - [Duplicate Keys] - field with key '${config.formKey}' already defined.`);\r\n }\r\n\r\n const {\r\n required = false,\r\n max,\r\n maxLength,\r\n min,\r\n minLength,\r\n step,\r\n pattern,\r\n type = \"text\",\r\n defaultValue,\r\n value,\r\n checked,\r\n defaultChecked,\r\n formKey,\r\n debounce,\r\n validatorKey\r\n } = config;\r\n const defaultProps = defaultFieldProps[type] || defaultFieldProps.text;\r\n const inputValue = value || defaultValue || checked || defaultChecked || defaultProps.value;\r\n\r\n fields[formKey] = {\r\n formKey,\r\n type,\r\n required,\r\n max,\r\n maxLength,\r\n min,\r\n minLength,\r\n step,\r\n pattern,\r\n value: inputValue,\r\n validatorKey,\r\n debounce,\r\n dirty: false,\r\n touched: false,\r\n gid: _generateIdUnsafe(),\r\n };\r\n });\r\n\r\n return {fields: fields as IForm<T>};\r\n};\r\n\r\n\r\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\r\nconst _buildFormTree = (\r\n root?: ReactElement<any> | ReactElement<any>[] | undefined\r\n): FormNode[] => {\r\n if (!root) return [];\r\n\r\n if (Array.isArray(root)) {\r\n return root.flatMap(element => _buildFormTree(element));\r\n }\r\n\r\n if (root.props?.formKey) {\r\n if (__DEBUG__) {\r\n console.log(\"[findInputs] - input config found\", `(${root.props.formKey})`);\r\n }\r\n return [\r\n {\r\n type: \"input\",\r\n formKey: root.props.formKey,\r\n },\r\n ];\r\n }\r\n\r\n // Group node\r\n const childrenTree = _buildFormTree(root.props?.children);\r\n return [\r\n {\r\n type: \"group\",\r\n children: childrenTree,\r\n },\r\n ];\r\n};\r\n\r\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\r\nconst buildFormTreeWithFlatAndSignature = (\r\n root?: ReactElement<any> | ReactElement<any>[] | undefined\r\n): FormTreeResult => {\r\n const flat: (GInputProps & GInputStateMutable)[] = [];\r\n let signature = '';\r\n\r\n const walk = (node?: ReactElement<any> | ReactElement<any>[] | undefined): FormNode[] => {\r\n if (!node) return [];\r\n\r\n if (Array.isArray(node)) {\r\n return node.flatMap(child => walk(child));\r\n }\r\n\r\n if (node.props?.formKey) {\r\n flat.push(node.props);\r\n signature = `${signature}I(${node.props.formKey})`;\r\n return [\r\n {\r\n type: \"input\",\r\n formKey: node.props.formKey,\r\n props: node.props,\r\n },\r\n ];\r\n }\r\n\r\n signature = `${signature}G(`;\r\n const childrenTree = walk(node.props?.children);\r\n signature = `${signature})`;\r\n\r\n return [\r\n {\r\n type: \"group\",\r\n children: childrenTree,\r\n },\r\n ];\r\n };\r\n\r\n const tree = walk(root);\r\n\r\n return {tree, flat, signature};\r\n};\r\n\r\nconst _findInputs = (root?: ReactNode, total: (GInputProps & GInputStateMutable)[] = []): (GInputProps & GInputStateMutable)[] => {\r\n if (!root) return total;\r\n\r\n Children.forEach(root, child => {\r\n if (!isValidElement(child)) return;\r\n\r\n if (child.props) {\r\n const {formKey, children} = child.props as PropsWithChildren<GInputProps & GInputStateMutable>;\r\n\r\n if (formKey) {\r\n if (__DEBUG__) {\r\n console.log(\"[findInputs] - input config found\", `(${formKey})`);\r\n }\r\n total.push(child.props as GInputProps & GInputStateMutable);\r\n }\r\n\r\n if (children) {\r\n _findInputs(children, total);\r\n }\r\n }\r\n });\r\n\r\n return total;\r\n};\r\n\r\nexport const _findValidityKey = (validity: Partial<ValidityState>, exclude: (keyof ValidityState)[] = []): keyof ValidityState | undefined => {\r\n for (const key in validity) {\r\n if (exclude.includes(key as keyof ValidityState)) continue;\r\n if (key !== 'valid' && validity[key as keyof ValidityState]) {\r\n if (__DEBUG__) {\r\n console.log('[findValidityKey] -', 'found validity key:', key);\r\n }\r\n return key as keyof ValidityState;\r\n }\r\n }\r\n};\r\n\r\nexport const _checkTypeMismatch = (input: GInputState<any>) => {\r\n const value = input.value?.toString().trim();\r\n if (!value) return false;\r\n\r\n switch (input.type) {\r\n case 'email':\r\n return !/^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/.test(value); // basic email pattern\r\n case 'url':\r\n try {\r\n new URL(value);\r\n return false;\r\n } catch {\r\n return true;\r\n }\r\n case 'tel':\r\n return !/^\\+?[0-9\\s\\-().]{7,}$/.test(value); // basic phone pattern\r\n default:\r\n return false;\r\n }\r\n};\r\n\r\n\r\nexport const _hasSubmitter = (form?: HTMLFormElement | null): boolean => {\r\n if (!form) return false;\r\n\r\n for (const element of form) {\r\n if ((element as HTMLInputElement).type === 'submit') return true;\r\n }\r\n\r\n return false;\r\n};\r\n\r\nexport const _checkIfFormIsValid = <T>(fields: IForm<T>): boolean => {\r\n for (const f in fields) {\r\n if (fields[f].error) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n};\r\n\r\nexport const _toRawData = <T>(fields: IForm<T> & {\r\n [key: string]: GInputState<any>\r\n}, options: ToRawDataOptions<T> = {}): RawData<T> => {\r\n const data: { [key: string]: unknown } = {};\r\n\r\n const {include, exclude, transform} = options;\r\n\r\n if (include) {\r\n include.forEach(key => data[key as string] = fields[key]?.value);\r\n } else for (const f in fields) {\r\n data[f] = fields[f].value;\r\n }\r\n\r\n exclude?.forEach(key => delete data[key as string]);\r\n\r\n if (transform) {\r\n for (const key in transform) {\r\n const set = transform[key] as (value: GFormState<T>[typeof key]['value']) => any;\r\n data[key] = set(fields[key]?.value || fields[key]);\r\n }\r\n }\r\n\r\n return data as RawData<T>;\r\n};\r\n\r\nexport const _toFormData = <T>(form: HTMLFormElement | null, options?: ToFormDataOptions<T>): FormData => {\r\n if (!form) return new FormData();\r\n\r\n if (options) {\r\n const {exclude, include, transform} = options;\r\n let formData: FormData;\r\n\r\n if (include) {\r\n formData = new FormData();\r\n include.forEach(key => formData.set(key as string, form[key as string]?.value));\r\n } else {\r\n formData = new FormData(form);\r\n exclude?.forEach(key => formData.delete(key as string));\r\n }\r\n\r\n if (transform) {\r\n for (const key in transform) {\r\n const set = transform[key] as (value: GFormState<T>[typeof key]['value']) => any;\r\n formData.set(key, set(form[key]?.value));\r\n }\r\n }\r\n return formData;\r\n\r\n }\r\n\r\n return new FormData(form);\r\n};\r\n\r\nexport function _toURLSearchParams<T>(this: GFormState<T>, options?: ToURLSearchParamsOptions<T>): URLSearchParams {\r\n let data: Record<keyof T, any>;\r\n if (options) {\r\n const {exclude, include, transform} = options;\r\n if (include) {\r\n data = {} as Record<keyof T, any>;\r\n include.forEach(key => (data[key] = this[key]?.value));\r\n } else {\r\n data = this.toRawData();\r\n exclude?.forEach(key => delete data[key]);\r\n }\r\n\r\n if (transform) {\r\n for (const key in transform) {\r\n const set = transform[key] as (value: GFormState<T>[typeof key]['value']) => any;\r\n (data[key] = set(this[key]?.value));\r\n }\r\n }\r\n } else data = this.toRawData();\r\n\r\n return new URLSearchParams(data); // this is ok because URLSearchParams will stringify the values (boolean/number)\r\n}\r\n\r\nfunction __debounce(this: { [key: string]: { timerId: number } }, timeout: number, id: string): Promise<void> {\r\n return new Promise(resolve => {\r\n if (this[id]?.timerId)\r\n clearTimeout(this[id].timerId);\r\n\r\n const timerId = setTimeout(() => resolve(), timeout);\r\n\r\n if (this[id]) {\r\n this[id].timerId = timerId;\r\n } else this[id] = {timerId};\r\n });\r\n}\r\n\r\nexport const _debounce = __debounce.bind({});\r\n\r\nexport const _extractValue = <T>(e?: GChangeEvent<GDOMElement | HTMLFormElement>, unknown?: {\r\n value: T\r\n} | string | number): undefined | string | number | boolean | T => {\r\n if (e?.target) {\r\n if (Object.hasOwn(typeValueDict, e.target.type)) return e.target[typeValueDict[e.target.type] as 'value'];\r\n return e.target.value;\r\n }\r\n return (e?.value as T) || (isObject(unknown) ? unknown.value : unknown);\r\n};\r\n\r\nexport const _checkResult = (handlerResult: boolean | RegExp | string, value: string | number | boolean): boolean => typeof handlerResult === 'boolean' ? handlerResult : typeof value === 'string' ? typeof handlerResult === 'string' ? !new RegExp(handlerResult).test(value) : !handlerResult.test(value) : false;\r\n\r\nexport const _merge = <T extends object>(target: { [key: string]: any } = {}, ...nodes: ({\r\n [key: string]: any\r\n} | undefined | void)[]): T => {\r\n if (!nodes.length) return target as T;\r\n\r\n const next = nodes.shift();\r\n if (isObject(next)) {\r\n for (const key in next) {\r\n target[key] = target[key] ? {...target[key], ...next[key]} : next[key];\r\n }\r\n }\r\n\r\n return _merge(target, ...nodes);\r\n};\r\n\r\nexport const _mergeRefs = <T>(\r\n refA: React.Ref<T> | undefined,\r\n refB: React.Ref<T> | undefined\r\n) => {\r\n return (value: T | null) => {\r\n if (typeof refA === 'function') {\r\n refA(value);\r\n } else if (refA) {\r\n refA.current = value;\r\n }\r\n\r\n if (typeof refB === 'function') {\r\n refB(value);\r\n } else if (refB) {\r\n refB.current = value;\r\n }\r\n };\r\n};\r\n\r\nexport const _buildFormState = <T>(fields: InitialState<T>['fields'], formElement: HTMLFormElement, dispatchChanges: (changes: Partial<InitialState> | Partial<GInputState>, key?: string) => void) => {\r\n const isFormValid = _checkIfFormIsValid(fields);\r\n\r\n const formState: GFormState<T> = {\r\n ...fields,\r\n isValid: isFormValid,\r\n isInvalid: !isFormValid,\r\n toRawData: (options?: ToRawDataOptions<T>) => _toRawData(fields, options),\r\n toFormData: () => _toFormData(formElement),\r\n toURLSearchParams: _toURLSearchParams,\r\n checkValidity: function () { // it has to be a function in order to refer to 'this'\r\n this.isValid = formElement && formElement.checkValidity() || false;\r\n this.isInvalid = !this.isValid;\r\n return this.isValid;\r\n },\r\n dispatchChanges: (changes: PartialForm<T> & {\r\n [key: string]: Partial<GInputState<any>>\r\n }) => dispatchChanges({\r\n fields: _merge<IForm<T> & {\r\n [key: string]: GInputState;\r\n }>({}, fields, changes)\r\n })\r\n };\r\n\r\n return formState;\r\n};\r\n\r\nexport const _buildRNFormState = <T>(fields: InitialState<T>['fields'], dispatchChanges: (changes: Partial<InitialState> | Partial<GInputState>, key?: string) => void) => {\r\n const isFormValid = _checkIfFormIsValid(fields);\r\n\r\n const formState: RNGFormState<T> = {\r\n ...fields,\r\n isValid: isFormValid,\r\n isInvalid: !isFormValid,\r\n toRawData: (options?: ToRawDataOptions<T>) => _toRawData(fields, options),\r\n toURLSearchParams: _toURLSearchParams,\r\n checkValidity: () => {\r\n for (const i in fields) {\r\n const valid = fields[i].checkValidity();\r\n if (!valid) {\r\n return false;\r\n }\r\n }\r\n return true;\r\n },\r\n dispatchChanges: (changes: PartialForm<T> & {\r\n [key: string]: Partial<GInputState<any>>\r\n }) => dispatchChanges({\r\n fields: _merge<IForm<T> & {\r\n [key: string]: GInputState;\r\n }>({}, fields, changes)\r\n })\r\n };\r\n\r\n return formState;\r\n};","import {_checkResult, _checkTypeMismatch, _debounce, _extractValue, _findValidityKey} from \"./helpers\";\r\nimport {type GInputValidator, type GValidators} from \"./validations\";\r\nimport type {GInputState} from \"./fields\";\r\nimport type {GChangeEvent, GDOMElement, GFocusEvent, GFormEvent, GInvalidEvent} from \"./form\";\r\nimport type {InitialState, Store} from \"./state\";\r\nimport {handlersMap, validityMap} from \"./validations/GValidator\";\r\n\r\nexport const useFormHandlers = (getState: Store['getState'], setState: Store['setState'], validators: GValidators = {}, optimized = false) => {\r\n /**\r\n * handler for validating a form input\r\n * @param input the input to be validated\r\n * @param e the event object\r\n */\r\n const _viHandler = (input: GInputState<any>, e?: GFocusEvent<GDOMElement | HTMLFormElement> | GInvalidEvent<GDOMElement | HTMLFormElement> | GFormEvent<GDOMElement | HTMLFormElement> | GFormEvent): void => {\r\n if (!input) return;\r\n\r\n const element = e && e.target;\r\n\r\n if (typeof document !== 'undefined' && (element instanceof HTMLInputElement || element instanceof HTMLTextAreaElement || element instanceof HTMLSelectElement)) {\r\n if (!input.checkValidity) input.checkValidity = () => element.checkValidity();\r\n\r\n const hasInitialValue = !input.dirty && input.value && !input.touched;\r\n\r\n if (hasInitialValue) { //if the field has initial value\r\n /**\r\n * for inputs with initial value we have to manually check for validations.\r\n * validity.tooShort is false even though initial value is smaller than minLength, because its required to be filled in by user (native dirty flag is true).\r\n * it only works for validity.valueMissing.\r\n * If an element has a minimum allowed value length, its dirty value flag is true, its value was last changed by a user edit (as opposed to a change made by a script), its value is not the empty string, and the length of the element's API value is less than the element's minimum allowed value length, then the element is suffering from being too short.\r\n * @see https://html.spec.whatwg.org/multipage/form-control-infrastructure.html#setting-minimum-input-length-requirements:-the-minlength-attribute\r\n */\r\n _checkInputManually(input);\r\n _dispatchChanges(input, input.formKey);\r\n return;\r\n }\r\n element.setCustomValidity(''); //reset any previous error (custom)\r\n\r\n const exclude: (keyof ValidityState)[] = input.type && (input.pattern || hasCustomValidation(input)) ? ['typeMismatch'] : [];\r\n const validityKey = _findValidityKey(element.validity, exclude);\r\n _validateInput(input, validityKey, (v: string) => element.setCustomValidity(v));\r\n\r\n if (!validityKey && input.error) {\r\n element.setCustomValidity(input.errorText || 'error');\r\n }\r\n\r\n _dispatchChanges(input, input.formKey);\r\n } else {\r\n if (__DEBUG__) {\r\n console.log('[validateInputHandler] -', `the input '${input.formKey}' is not a native web element\\nevent:`, e);\r\n }\r\n\r\n // fallback - validate the input for validations manually\r\n input.checkValidity = () => _checkInputManually(input);\r\n input.checkValidity();\r\n\r\n _dispatchChanges(input, input.formKey);\r\n }\r\n };\r\n\r\n const _checkInputManually = (input: GInputState<any>) => {\r\n const exclude: (keyof ValidityState)[] = input.type && (input.pattern || hasCustomValidation(input)) ? ['typeMismatch'] : [];\r\n\r\n let validityKey = _findValidityKey({\r\n valueMissing: input.required && !input.value || false,\r\n typeMismatch: _checkTypeMismatch(input),\r\n tooShort: input.minLength && input.value.toString().length < input.minLength || false,\r\n tooLong: input.maxLength && input.value.toString().length > input.maxLength || false,\r\n patternMismatch: input.pattern && _checkResult(input.pattern, input.value) || false,\r\n rangeUnderflow: input.min && Number(input.value) < Number(input.min) || false,\r\n rangeOverflow: input.max && Number(input.value) > Number(input.max) || false\r\n }, exclude);\r\n\r\n if (!validityKey && input.error) {\r\n validityKey = 'customError';\r\n }\r\n _validateInput(input, validityKey);\r\n return !input.error;\r\n };\r\n\r\n /**\r\n * handler for updating and validating a form input\r\n * @param input\r\n * @param e the event object\r\n * @param unknown\r\n */\r\n const _updateInputHandler = (input: GInputState<any>, e?: GChangeEvent<GDOMElement | HTMLFormElement>, unknown?: {\r\n value: unknown\r\n } | string | number): void => {\r\n input.value = _extractValue(e, unknown) as GInputState['value'];\r\n _viHandler(input, e);\r\n };\r\n\r\n /**\r\n * Validates the input and updates the state with the result\r\n * @param input the input to be validated\r\n * @param validityKey the `Constraint Validation` key\r\n * @param setValidity\r\n */\r\n const _validateInput = (input: GInputState, validityKey?: keyof ValidityState, setValidity?: (e: string) => void): void => {\r\n const inputValidator = validators[input.validatorKey || input.formKey] || validators['*'];\r\n if (__DEBUG__) {\r\n console.log('[validateInput] -', 'validating input:', input.formKey, `(${validityKey ? validityKey : 'custom'})`);\r\n }\r\n\r\n if (__DEV__) {\r\n if (validityKey && !inputValidator?.hasConstraint(validityKey)) {\r\n if (validityKey === 'typeMismatch') console.warn(`DEV ONLY - [Missing Validator] - the input '${input.formKey}' has described the constraint '${validityMap[validityKey]}' however, a correspond validator/custom validation/pattern validator is missing.\\nadd '${handlersMap[validityMap[validityKey]]}' or 'withCustomValidation' or '${handlersMap[validityMap.patternMismatch]}' to the input validator.\\nexample:\\nconst validators: GValidators = {\\n\\temail: new GValidator().withPatternMismatchMessage('pattern mismatch'),\\n\\t...\\n}\\n\\nor either remove the constraint '${validityMap[validityKey]}' from the input props`);\r\n else console.warn(`DEV ONLY - [Missing Validator] - the input '${input.formKey}' has described the constraint '${validityMap[validityKey]}' however, a correspond validator is missing.\\nadd '${handlersMap[validityMap[validityKey]]}' to the input validator.\\nexample:\\nconst validators: GValidators = {\\n\\temail: new GValidator().withPatternMismatchMessage('pattern mismatch'),\\n\\t...\\n}\\n\\nor either remove the constraint '${validityMap[validityKey]}' from the input props`);\r\n }\r\n }\r\n\r\n if (inputValidator) {\r\n __validateInput(input, inputValidator, validityKey, setValidity);\r\n }\r\n input.touched = true;\r\n };\r\n\r\n const _dispatchChanges = (changes: Partial<InitialState> | Partial<GInputState<any>>, key?: string) => setState(prev => {\r\n if (key) {\r\n return {...prev, fields: {...prev.fields, [key]: {...prev.fields[key], ...changes}}};\r\n }\r\n return {...prev, ...changes};\r\n });\r\n\r\n /**\r\n * @internal\r\n */\r\n const __validateInput = (input: GInputState, inputValidator: GInputValidator<any>, validityKey?: keyof ValidityState, setValidity?: (e: string) => void): void => {\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validating input (${input.formKey}) with handlers:`, inputValidator.handlers);\r\n }\r\n const fields = getState().fields;\r\n\r\n for (const index in inputValidator.constraintHandlers) {\r\n const result = inputValidator.constraintHandlers[index](input, validityKey);\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validation results for constraint handler (${index}):\\n`, inputValidator.constraintHandlers[index], '\\n\\nvalidator result:', result, '\\nviolation:', input.error, `(${input.error ? 'failed' : 'passed'})`);\r\n }\r\n\r\n input.error = _checkResult(result, input.value);\r\n if (input.error) return;\r\n }\r\n\r\n for (const index in inputValidator.handlers) {\r\n const result = inputValidator.handlers[index](input, fields);\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validation results for custom handler (${index}):\\n`, inputValidator.handlers[index], '\\n\\nvalidator result:', result, '\\nviolation:', input.error, `(${input.error ? 'failed' : 'passed'})`);\r\n }\r\n\r\n input.error = _checkResult(result, input.value);\r\n if (input.error) return;\r\n }\r\n\r\n input.errorText = '';\r\n\r\n if (inputValidator.asyncHandlers.length) {\r\n input.error = true;\r\n _debounce(input.debounce || 300, `${input.gid}-async`).then(() => {\r\n const validateAsync = async () => {\r\n for (const index in inputValidator.asyncHandlers) {\r\n const result = await inputValidator.asyncHandlers[index](input, fields);\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validation results for custom async handler (${index}):\\n`, inputValidator.asyncHandlers[index], '\\n\\nvalidator result:', result, '\\nviolation:', input.error, `(${input.error ? 'failed' : 'passed'})`);\r\n }\r\n\r\n input.error = _checkResult(result, input.value);\r\n if (input.error) break;\r\n }\r\n if (!input.error) input.errorText = '';\r\n\r\n _dispatchChanges({error: input.error, errorText: input.errorText}, input.formKey);\r\n if (setValidity) {\r\n setValidity(input.errorText);\r\n }\r\n };\r\n\r\n if (__DEBUG__) {\r\n console.log('[_validateInput] -', `validating input (${input.formKey}) with async handlers:`, inputValidator.asyncHandlers);\r\n }\r\n validateAsync();\r\n });\r\n }\r\n };\r\n\r\n const hasCustomValidation = (input: GInputState) => {\r\n const validator = validators[input.validatorKey || input.formKey] || validators['*'];\r\n return validator && (validator.asyncHandlers.length > 0 || validator.handlers.length > 0);\r\n };\r\n\r\n return {_updateInputHandler, _viHandler, _dispatchChanges, optimized, _createInputChecker: _checkInputManually};\r\n};","import React, {createContext, useCallback, useContext, useMemo, useRef, useSyncExternalStore} from 'react';\r\nimport type {FC, PropsWithChildren} from 'react';\r\n\r\nimport {useFormHandlers} from \"./useFormHandlers\";\r\nimport type {InitialState, Store} from \"./state\";\r\nimport type {GValidators} from \"./validations\";\r\nimport type {GInputState} from './fields';\r\nimport {_copyStateFields} from \"./helpers\";\r\n\r\nconst GFormContext = createContext<Store>({} as Store);\r\n\r\ntype GFormContextProviderProps = PropsWithChildren & {\r\n initialState: InitialState;\r\n validators?: GValidators;\r\n optimized?: boolean;\r\n};\r\n\r\nexport const GFormContextProvider: FC<GFormContextProviderProps> = ({ children, initialState, validators, optimized }) => {\r\n const stateRef = useRef(initialState);\r\n const listeners = useRef<Set<() => void>>(null);\r\n\r\n const setState = useCallback((updater: InitialState | ((state: InitialState) => InitialState)) => {\r\n const prevState = stateRef.current;\r\n const nextState =\r\n typeof updater === \"function\" ? (updater as (s: InitialState) => InitialState)(prevState) : updater;\r\n\r\n if (Object.is(prevState, nextState)) {\r\n return;\r\n }\r\n\r\n stateRef.current = nextState;\r\n listeners.current!.forEach((l) => l());\r\n }, []);\r\n\r\n const handlers = useFormHandlers(() => stateRef.current, setState, validators, optimized);\r\n\r\n const store = useMemo<Store>(() => {\r\n if (!listeners.current) {\r\n listeners.current = new Set();\r\n } else {\r\n if (__DEBUG__) {\r\n console.log(`[form-context] - form changed stated from`, stateRef.current, '\\nto\\n', initialState);\r\n }\r\n listeners.current.clear();\r\n _copyStateFields(stateRef.current, initialState);\r\n }\r\n\r\n stateRef.current = initialState;\r\n\r\n for (const fieldKey in initialState.fields) {\r\n initialState.fields[fieldKey].dispatchChanges = (changes: Partial<GInputState>) => handlers._dispatchChanges(changes, fieldKey);\r\n }\r\n\r\n return {\r\n getState: () => stateRef.current,\r\n setState,\r\n subscribe: (listener: () => void) => {\r\n listeners.current!.add(listener);\r\n return () => listeners.current!.delete(listener);\r\n },\r\n handlers\r\n };\r\n }, [initialState]);\r\n\r\n return <GFormContext.Provider value={store}>{children}</GFormContext.Provider>;\r\n};\r\n\r\nexport const useFormStore = () => {\r\n const store = useContext(GFormContext);\r\n if (!store.getState) throw new Error('useGFormStore must be used within `GForm` component');\r\n\r\n return store;\r\n};\r\n\r\nexport const useFormSelector = <T extends any>(selector: (state: InitialState) => T): T => {\r\n const store = useFormStore();\r\n\r\n return useSyncExternalStore(\r\n store.subscribe,\r\n () => selector(store.getState()),\r\n () => selector(store.getState()) // for SSR\r\n );\r\n};\r\n\r\nexport function createSelector<\r\n State=InitialState,\r\n Selectors extends Array<(state: State) => any> = [],\r\n Result = any\r\n>(\r\n selectors: Selectors,\r\n combiner: (...args: {\r\n [K in keyof Selectors]: Selectors[K] extends (state: State) => infer R ? R : never;\r\n }) => Result\r\n): (state: State) => Result {\r\n let lastArgs: any[] = [];\r\n let lastResult: Result;\r\n\r\n return (state: State): Result => {\r\n const args = selectors.map(fn => fn(state));\r\n if (\r\n lastArgs.length === args.length &&\r\n args.every((val, i) => val === lastArgs[i])\r\n ) {\r\n return lastResult;\r\n }\r\n lastArgs = args;\r\n lastResult = combiner(...args as any);\r\n return lastResult;\r\n };\r\n}"],"names":["isObject","o","Array","isArray","defaultFieldProps","text","value","checkbox","number","typeValueDict","_buildFormInitialValues","rows","fields","_findInputs","forEach","config","required","max","maxLength","min","minLength","step","pattern","type","defaultValue","checked","defaultChecked","formKey","debounce","validatorKey","inputValue","dirty","touched","gid","Date","toString","Math","random","substring","root","total","Children","child","isValidElement","props","children","push","_findValidityKey","validity","exclude","key","includes","_checkTypeMismatch","input","_input$value","trim","test","URL","_unused","_toURLSearchParams","options","data","include","transform","_this$key","this","toRawData","_this$key2","set","URLSearchParams","_debounce","timeout","id","Promise","resolve","_this$id","timerId","clearTimeout","setTimeout","bind","_checkResult","handlerResult","RegExp","_merge","target","nodes","length","next","shift","_objectSpread","_mergeRefs","refA","refB","current","_buildFormState","formElement","dispatchChanges","isFormValid","f","error","_checkIfFormIsValid","isValid","isInvalid","_toRawData","_fields$key","_fields$key2","toFormData","_toFormData","form","FormData","toURLSearchParams","checkValidity","changes","useFormHandlers","getState","setState","validators","optimized","_viHandler","e","element","document","HTMLInputElement","HTMLTextAreaElement","HTMLSelectElement","_checkInputManually","_dispatchChanges","setCustomValidity","hasCustomValidation","validityKey","_validateInput","v","errorText","valueMissing","typeMismatch","tooShort","tooLong","patternMismatch","rangeUnderflow","Number","rangeOverflow","setValidity","inputValidator","__validateInput","prev","index","constraintHandlers","result","handlers","asyncHandlers","then","async","validateAsync","validator","_updateInputHandler","unknown","_extractValue","Object","hasOwn","_createInputChecker","GFormContext","createContext","GFormContextProvider","initialState","stateRef","useRef","listeners","useCallback","updater","prevState","nextState","is","l","store","useMemo","clear","_copyStateFields","source","destination","sourceField","destField","Set","fieldKey","subscribe","listener","add","delete","React","createElement","Provider","useFormStore","useContext","Error","useFormSelector","selector","useSyncExternalStore","createSelector","selectors","combiner","lastResult","lastArgs","state","args","map","fn","every","val","i"],"mappings":"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"}
@@ -1,6 +1,5 @@
1
1
  import 'react';
2
- export { G as GFormContextProvider, h as createSelector, a as useFormSelector, u as useFormStore } from './shared.development.js';
3
- import '@babel/runtime/helpers/esm/objectSpread2';
4
- import './GValidator.development.js';
2
+ export { G as GFormContextProvider, f as createSelector, a as useFormSelector, u as useFormStore } from './shared.development.js';
5
3
  import '@babel/runtime/helpers/esm/defineProperty';
4
+ import './GValidator.development.js';
6
5
  //# sourceMappingURL=useFormSelector.development.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useFormSelector.development.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
1
+ {"version":3,"file":"useFormSelector.development.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;"}
@@ -1,2 +1,2 @@
1
- import"react";export{G as GFormContextProvider,g as createSelector,a as useFormSelector,u as useFormStore}from"./shared.production.js";import"@babel/runtime/helpers/esm/objectSpread2";
1
+ import"react";export{G as GFormContextProvider,e as createSelector,a as useFormSelector,u as useFormStore}from"./shared.production.js";import"@babel/runtime/helpers/esm/defineProperty";
2
2
  //# sourceMappingURL=useFormSelector.production.js.map
package/dist/index.d.ts CHANGED
@@ -108,8 +108,6 @@ type GInputProps = BaseGenericFieldProps & Omit<InputHTMLAttributes<HTMLInputEle
108
108
 
109
109
  type IForm<T = any> = {
110
110
  [key in keyof T]: GInputState<T[key]>;
111
- } & {
112
- [key: string]: GInputState<any>;
113
111
  };
114
112
  type PartialForm<T> = Partial<{
115
113
  [key in keyof T]: Partial<GInputStateMutable<T[key]>>;
@@ -222,8 +220,6 @@ type GFormState<T> = RNGFormState<T> & {
222
220
 
223
221
  type GFormProps<T> = Omit<DetailedHTMLProps<FormHTMLAttributes<HTMLFormElement>, HTMLFormElement>, 'onSubmit' | 'onPaste' | 'onChange' | 'onKeyUp' | 'onKeyDown' | 'children'> & {
224
222
  children?: ReactNode | ReactNode[] | ((state: GFormState<T>) => ReactNode | ReactNode[]);
225
- /** @param loader - a component to display while loading (optional). */
226
- loader?: ReactNode;
227
223
  /** @param stateRef - pass a ref which will points to the current state of the form (optional). */
228
224
  stateRef?: RefObject<GFormState<T> | undefined>;
229
225
  /** @param onSubmit - a handler for the form submission (optional). */