@digigov/form 2.0.0-85c27c19 → 2.0.0-8e254888
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/Field/ErrorGroup/index.js +48 -0
- package/{Form.stories → Field/ErrorGroup}/package.json +1 -1
- package/Field/ErrorGroup.d.ts +15 -0
- package/Field/ErrorGroup.js.map +7 -0
- package/Field/FieldBase/index.js +31 -22
- package/Field/FieldBase.js.map +2 -2
- package/Field/FieldBaseContainer/index.js +5 -4
- package/Field/FieldBaseContainer.js.map +2 -2
- package/Field/FieldConditional/index.js +7 -3
- package/Field/FieldConditional.js.map +2 -2
- package/Field/index.js +10 -2
- package/Field/index.js.map +2 -2
- package/Field/types.d.ts +15 -9
- package/Field/utils/index.d.ts +1 -0
- package/Field/utils/index.js +24 -1
- package/Field/utils/index.js.map +2 -2
- package/Field/utils/useField/index.js +7 -1
- package/Field/utils/useField.js.map +2 -2
- package/FieldArray/FieldArray.stories.d.ts +1 -0
- package/FieldArray/FormDialog/index.js +279 -0
- package/{Questions/Questions.stories → FieldArray/FormDialog}/package.json +1 -1
- package/FieldArray/FormDialog.d.ts +53 -0
- package/FieldArray/FormDialog.js.map +7 -0
- package/FieldArray/__stories__/WithModal.d.ts +2 -0
- package/FieldArray/index.d.ts +6 -0
- package/FieldArray/index.js +59 -23
- package/FieldArray/index.js.map +2 -2
- package/FieldObject/index.d.ts +4 -0
- package/FieldObject/index.js +16 -8
- package/FieldObject/index.js.map +2 -2
- package/Fieldset/index.d.ts +1 -1
- package/Fieldset/index.js +5 -5
- package/Fieldset/index.js.map +2 -2
- package/Fieldset/types.d.ts +2 -3
- package/FormBuilder/FormBuilder.stories.d.ts +2 -0
- package/FormBuilder/__stories__/AutoErrorGrouping.d.ts +3 -0
- package/FormBuilder/__stories__/ErrorGrouping.d.ts +3 -0
- package/FormBuilder/index.d.ts +8 -2
- package/FormBuilder/index.js +229 -6
- package/FormBuilder/index.js.map +3 -3
- package/FormBuilder/interaction.test.d.ts +1 -0
- package/FormContext.js.map +2 -2
- package/MultiplicityField/add-objects/index.js +11 -7
- package/MultiplicityField/add-objects.js.map +2 -2
- package/MultiplicityField/index.js +17 -12
- package/MultiplicityField/index.js.map +2 -2
- package/MultiplicityField/types.d.ts +1 -2
- package/Questions/Questions/index.js +5 -4
- package/Questions/Questions.js.map +2 -2
- package/Questions/QuestionsContext.d.ts +0 -1
- package/Questions/Step/StepArrayReview.js.map +2 -2
- package/Questions/Step/StepContext.d.ts +0 -1
- package/Questions/Step/StepTitle/index.js +4 -3
- package/Questions/Step/StepTitle.d.ts +1 -1
- package/Questions/Step/StepTitle.js.map +2 -2
- package/Questions/Step/types.d.ts +0 -1
- package/Questions/types.d.ts +0 -1
- package/cjs/Field/ErrorGroup/index.js +82 -0
- package/cjs/Field/ErrorGroup.js.map +7 -0
- package/cjs/Field/FieldBase/index.js +30 -21
- package/cjs/Field/FieldBase.js.map +2 -2
- package/cjs/Field/FieldBaseContainer/index.js +5 -4
- package/cjs/Field/FieldBaseContainer.js.map +3 -3
- package/cjs/Field/FieldConditional/index.js +7 -3
- package/cjs/Field/FieldConditional.js.map +2 -2
- package/cjs/Field/index.js +10 -2
- package/cjs/Field/index.js.map +2 -2
- package/cjs/Field/types.js.map +1 -1
- package/cjs/Field/utils/index.js +24 -0
- package/cjs/Field/utils/index.js.map +3 -3
- package/cjs/Field/utils/useField/index.js +7 -1
- package/cjs/Field/utils/useField.js.map +2 -2
- package/cjs/FieldArray/FormDialog/index.js +301 -0
- package/cjs/FieldArray/FormDialog.js.map +7 -0
- package/cjs/FieldArray/index.js +58 -22
- package/cjs/FieldArray/index.js.map +3 -3
- package/cjs/FieldObject/index.js +17 -9
- package/cjs/FieldObject/index.js.map +3 -3
- package/cjs/Fieldset/index.js +10 -10
- package/cjs/Fieldset/index.js.map +3 -3
- package/cjs/Fieldset/types.js.map +1 -1
- package/cjs/FormBuilder/index.js +244 -5
- package/cjs/FormBuilder/index.js.map +3 -3
- package/cjs/FormContext/index.js +2 -2
- package/cjs/FormContext.js.map +3 -3
- package/cjs/MultiplicityField/add-objects/index.js +15 -11
- package/cjs/MultiplicityField/add-objects.js.map +3 -3
- package/cjs/MultiplicityField/index.js +16 -16
- package/cjs/MultiplicityField/index.js.map +3 -3
- package/cjs/MultiplicityField/types.js.map +1 -1
- package/cjs/Questions/Questions/index.js +5 -4
- package/cjs/Questions/Questions.js.map +2 -2
- package/cjs/Questions/Step/StepArrayReview.js.map +2 -2
- package/cjs/Questions/Step/StepTitle/index.js +5 -5
- package/cjs/Questions/Step/StepTitle.js.map +3 -3
- package/cjs/index.js +11 -155
- package/cjs/index.js.map +4 -4
- package/cjs/inputs/AutoCompleteInput/index.js +12 -9
- package/cjs/inputs/AutoCompleteInput/index.js.map +3 -3
- package/cjs/inputs/Checkboxes/index.js +9 -9
- package/cjs/inputs/Checkboxes/index.js.map +3 -3
- package/cjs/inputs/DateInput/index.js +10 -8
- package/cjs/inputs/DateInput/index.js.map +3 -3
- package/cjs/inputs/DateTimeInput/index.js +211 -0
- package/cjs/inputs/DateTimeInput/index.js.map +7 -0
- package/cjs/inputs/FileInput/index.js +41 -27
- package/cjs/inputs/FileInput/index.js.map +3 -3
- package/cjs/inputs/ImageInput/index.js +16 -10
- package/cjs/inputs/ImageInput/index.js.map +3 -3
- package/cjs/inputs/Input/index.js +29 -8
- package/cjs/inputs/Input/index.js.map +3 -3
- package/cjs/inputs/Input/inputsInputScenarios.js.map +2 -2
- package/cjs/inputs/Label/index.js +3 -3
- package/cjs/inputs/Label/index.js.map +3 -3
- package/cjs/inputs/OtpInput/index.js +1 -0
- package/cjs/inputs/OtpInput/index.js.map +2 -2
- package/cjs/inputs/Radio/index.js +57 -10
- package/cjs/inputs/Radio/index.js.map +3 -3
- package/cjs/inputs/Select/index.js +10 -5
- package/cjs/inputs/Select/index.js.map +3 -3
- package/cjs/inputs/inputsScenarios/index.js +4 -11
- package/cjs/inputs/inputsScenarios.js.map +2 -2
- package/cjs/lazy/index.js +49 -34
- package/cjs/lazy.js.map +3 -3
- package/cjs/locales/el.js.map +1 -1
- package/cjs/registry/index.js +72 -62
- package/cjs/registry.js.map +3 -3
- package/cjs/types.js.map +1 -1
- package/cjs/utils/index.js +2 -1
- package/cjs/utils.js.map +2 -2
- package/cjs/validators/index.js +44 -79
- package/cjs/validators/index.js.map +3 -3
- package/cjs/validators/utils/date/index.js +138 -0
- package/cjs/validators/utils/date.js.map +7 -0
- package/cjs/validators/utils/datetime/index.js +151 -0
- package/cjs/validators/utils/datetime.js.map +7 -0
- package/cjs/validators/utils/file/index.js +2 -2
- package/cjs/validators/utils/file.js.map +2 -2
- package/cjs/validators/utils/index.js +5 -1
- package/cjs/validators/utils/index.js.map +2 -2
- package/cjs/validators/utils/int/index.js +1 -1
- package/cjs/validators/utils/int.js.map +2 -2
- package/cjs/validators/utils/number/index.js +1 -1
- package/cjs/validators/utils/number.js.map +2 -2
- package/cjs/validators/utils/phone.js.map +2 -2
- package/cjs/validators/utils/postal_code.js.map +1 -1
- package/cjs/validators/utils/uuid4.js.map +2 -2
- package/index.d.ts +5 -8
- package/index.js +9 -152
- package/index.js.map +4 -4
- package/inputs/AutoCompleteInput/index.d.ts +1 -1
- package/inputs/AutoCompleteInput/index.js +14 -9
- package/inputs/AutoCompleteInput/index.js.map +2 -2
- package/inputs/Checkboxes/index.d.ts +1 -1
- package/inputs/Checkboxes/index.js +10 -6
- package/inputs/Checkboxes/index.js.map +2 -2
- package/inputs/DateInput/index.d.ts +1 -2
- package/inputs/DateInput/index.js +12 -7
- package/inputs/DateInput/index.js.map +2 -2
- package/inputs/DateTimeInput/DateTimeInput.stories.d.ts +7 -0
- package/inputs/DateTimeInput/__stories__/Default.d.ts +3 -0
- package/inputs/DateTimeInput/index.d.ts +13 -0
- package/inputs/DateTimeInput/index.js +181 -0
- package/inputs/DateTimeInput/index.js.map +7 -0
- package/inputs/DateTimeInput/index.test.d.ts +1 -0
- package/inputs/{Input/Input.stories → DateTimeInput}/package.json +1 -1
- package/inputs/FileInput/index.d.ts +9 -0
- package/inputs/FileInput/index.js +41 -27
- package/inputs/FileInput/index.js.map +2 -2
- package/inputs/ImageInput/ImageInput.stories.d.ts +1 -1
- package/inputs/ImageInput/__stories__/MaxSize.d.ts +3 -0
- package/inputs/ImageInput/index.js +15 -9
- package/inputs/ImageInput/index.js.map +2 -2
- package/inputs/Input/Input.stories.d.ts +1 -0
- package/inputs/Input/__stories__/StringWithTrimValidation.d.ts +3 -0
- package/inputs/Input/index.js +27 -6
- package/inputs/Input/index.js.map +3 -3
- package/inputs/Input/inputsInputScenarios.js.map +2 -2
- package/inputs/Label/index.d.ts +0 -2
- package/inputs/Label/index.js +2 -2
- package/inputs/Label/index.js.map +2 -2
- package/inputs/OtpInput/index.js +1 -0
- package/inputs/OtpInput/index.js.map +2 -2
- package/inputs/Radio/index.d.ts +5 -1
- package/inputs/Radio/index.js +58 -8
- package/inputs/Radio/index.js.map +2 -2
- package/inputs/Select/index.d.ts +1 -1
- package/inputs/Select/index.js +11 -3
- package/inputs/Select/index.js.map +2 -2
- package/inputs/inputsScenarios/index.js +4 -11
- package/inputs/inputsScenarios.d.ts +0 -42
- package/inputs/inputsScenarios.js.map +2 -2
- package/lazy/index.js +76 -65
- package/locales/el.js.map +1 -1
- package/package.json +4 -4
- package/registry/index.js +116 -107
- package/src/Field/ErrorGroup.tsx +84 -0
- package/src/Field/FieldBase.tsx +34 -22
- package/src/Field/FieldBaseContainer.tsx +7 -4
- package/src/Field/FieldConditional.tsx +4 -0
- package/src/Field/index.tsx +9 -1
- package/src/Field/types.tsx +15 -8
- package/src/Field/utils/index.ts +24 -1
- package/src/Field/utils/useField.ts +7 -3
- package/src/FieldArray/FieldArray.stories.js +1 -0
- package/src/FieldArray/FormDialog.tsx +378 -0
- package/src/FieldArray/__stories__/Default.tsx +1 -0
- package/src/FieldArray/__stories__/WithExactLength.tsx +1 -0
- package/src/FieldArray/__stories__/WithModal.tsx +159 -0
- package/src/FieldArray/index.test.tsx +4 -0
- package/src/FieldArray/index.tsx +88 -43
- package/src/FieldObject/index.tsx +17 -5
- package/src/Fieldset/index.tsx +5 -5
- package/src/Fieldset/types.tsx +2 -2
- package/src/FormBuilder/FormBuilder.stories.js +2 -0
- package/src/FormBuilder/__stories__/AutoErrorGrouping.tsx +63 -0
- package/src/FormBuilder/__stories__/ErrorGrouping.tsx +43 -0
- package/src/FormBuilder/{FormBuilder.mdx → doc.mdx} +20 -33
- package/src/FormBuilder/index.test.tsx +8 -0
- package/src/FormBuilder/index.tsx +264 -7
- package/src/FormBuilder/interaction.test.tsx +32 -0
- package/src/FormBuilder/scenarios.test.tsx +121 -7
- package/src/FormContext.tsx +1 -2
- package/src/MultiplicityField/add-objects.tsx +10 -8
- package/src/MultiplicityField/{MultiplicityField.mdx → doc.mdx} +12 -16
- package/src/MultiplicityField/index.tsx +16 -12
- package/src/MultiplicityField/types.ts +1 -2
- package/src/Questions/Questions.tsx +4 -4
- package/src/Questions/Step/StepArrayReview.tsx +1 -1
- package/src/Questions/Step/StepTitle.tsx +4 -3
- package/src/Questions/__snapshots__/index.spec.tsx.snap +10 -5
- package/src/Questions/{index.mdx → doc.mdx} +9 -12
- package/src/Questions/index.spec.tsx +14 -2
- package/src/create-simple-form.mdx +2 -6
- package/src/{index.mdx → doc.mdx} +4 -8
- package/src/index.ts +6 -0
- package/src/inputs/AutoCompleteInput/__stories__/Default.tsx +2 -10
- package/src/inputs/AutoCompleteInput/__stories__/Multiple.tsx +1 -8
- package/src/inputs/AutoCompleteInput/{index.mdx → doc.mdx} +2 -13
- package/src/inputs/AutoCompleteInput/index.tsx +37 -31
- package/src/inputs/Checkboxes/{index.mdx → doc.mdx} +5 -15
- package/src/inputs/Checkboxes/index.tsx +12 -8
- package/src/inputs/DateInput/__stories__/Default.tsx +7 -12
- package/src/inputs/DateInput/{index.mdx → doc.mdx} +1 -8
- package/src/inputs/DateInput/index.tsx +12 -7
- package/src/inputs/DateTimeInput/DateTimeInput.stories.js +8 -0
- package/src/inputs/DateTimeInput/__stories__/Default.tsx +25 -0
- package/src/inputs/DateTimeInput/doc.mdx +16 -0
- package/src/inputs/DateTimeInput/index.test.tsx +20 -0
- package/src/inputs/DateTimeInput/index.tsx +194 -0
- package/src/inputs/FileInput/{index.mdx → doc.mdx} +1 -5
- package/src/inputs/FileInput/index.tsx +33 -10
- package/src/inputs/ImageInput/ImageInput.stories.js +1 -1
- package/src/inputs/ImageInput/__stories__/MaxSize.tsx +37 -0
- package/src/inputs/ImageInput/__stories__/WithInvalidImageDimension.tsx +2 -0
- package/src/inputs/ImageInput/doc.mdx +23 -0
- package/src/inputs/ImageInput/index.test.tsx +4 -0
- package/src/inputs/ImageInput/index.tsx +17 -16
- package/src/inputs/Input/Input.stories.js +1 -0
- package/src/inputs/Input/__stories__/LandlineNumber.tsx +2 -1
- package/src/inputs/Input/__stories__/MobilePhone.tsx +1 -0
- package/src/inputs/Input/__stories__/PhoneNumber.tsx +1 -0
- package/src/inputs/Input/__stories__/PostalCode.tsx +1 -0
- package/src/inputs/Input/__stories__/StringWithTrimValidation.tsx +26 -0
- package/src/inputs/Input/__stories__/TextWithLimit.tsx +1 -0
- package/src/inputs/Input/doc.mdx +56 -0
- package/src/inputs/Input/index.test.tsx +4 -0
- package/src/inputs/Input/index.tsx +41 -30
- package/src/inputs/Input/inputsInputScenarios.ts +244 -245
- package/src/inputs/Label/doc.mdx +14 -0
- package/src/inputs/Label/index.tsx +2 -6
- package/src/inputs/OtpInput/{index.mdx → doc.mdx} +1 -8
- package/src/inputs/OtpInput/index.tsx +3 -1
- package/src/inputs/Radio/__stories__/Conditional.tsx +2 -1
- package/src/inputs/Radio/{index.mdx → doc.mdx} +5 -15
- package/src/inputs/Radio/index.tsx +77 -10
- package/src/inputs/Select/{index.mdx → doc.mdx} +1 -5
- package/src/inputs/Select/index.tsx +12 -4
- package/src/inputs/inputsScenarios.ts +174 -181
- package/src/installation.mdx +2 -5
- package/src/lazy.js +76 -62
- package/src/locales/el.ts +1 -1
- package/src/registry.js +108 -100
- package/src/types.tsx +3 -2
- package/src/utils.ts +2 -2
- package/src/validators/index.ts +86 -85
- package/src/validators/utils/date.ts +107 -0
- package/src/validators/utils/datetime.ts +130 -0
- package/src/validators/utils/file.ts +5 -3
- package/src/validators/utils/index.ts +2 -0
- package/src/validators/utils/int.ts +1 -1
- package/src/validators/utils/number.ts +1 -1
- package/src/validators/utils/phone.ts +1 -1
- package/src/validators/utils/postal_code.ts +1 -1
- package/src/validators/utils/uuid4.ts +2 -1
- package/src/validators/validators.spec.ts +3 -3
- package/types.d.ts +3 -3
- package/types.js.map +1 -1
- package/utils/index.js +2 -1
- package/utils.js.map +2 -2
- package/validators/index.js +51 -80
- package/validators/index.js.map +2 -2
- package/validators/utils/date/index.js +103 -0
- package/{FieldArray/FieldArray.stories → validators/utils/date}/package.json +1 -1
- package/validators/utils/date.d.ts +9 -0
- package/validators/utils/date.js.map +7 -0
- package/validators/utils/datetime/index.js +116 -0
- package/validators/utils/datetime/package.json +6 -0
- package/validators/utils/datetime.d.ts +9 -0
- package/validators/utils/datetime.js.map +7 -0
- package/validators/utils/file/index.js +2 -2
- package/validators/utils/file.js.map +2 -2
- package/validators/utils/index.d.ts +2 -0
- package/validators/utils/index.js +2 -0
- package/validators/utils/index.js.map +2 -2
- package/validators/utils/int/index.js +1 -1
- package/validators/utils/int.js.map +2 -2
- package/validators/utils/number/index.js +1 -1
- package/validators/utils/number.js.map +2 -2
- package/validators/utils/phone.d.ts +1 -1
- package/validators/utils/phone.js.map +2 -2
- package/validators/utils/postal_code.d.ts +1 -1
- package/validators/utils/postal_code.js.map +1 -1
- package/validators/utils/uuid4.js.map +2 -2
- package/FieldArray/FieldArray.stories/index.js +0 -14
- package/FieldArray/FieldArray.stories.js.map +0 -7
- package/FieldArray/__stories__/Default/index.js +0 -95
- package/FieldArray/__stories__/Default/package.json +0 -6
- package/FieldArray/__stories__/Default.js.map +0 -7
- package/FieldArray/__stories__/WithExactLength/index.js +0 -95
- package/FieldArray/__stories__/WithExactLength/package.json +0 -6
- package/FieldArray/__stories__/WithExactLength.js.map +0 -7
- package/Form.stories/index.js +0 -7
- package/Form.stories.js.map +0 -7
- package/FormBuilder/FormBuilder.stories/index.js +0 -12
- package/FormBuilder/FormBuilder.stories/package.json +0 -6
- package/FormBuilder/FormBuilder.stories.js.map +0 -7
- package/FormBuilder/__stories__/Default/index.js +0 -32
- package/FormBuilder/__stories__/Default/package.json +0 -6
- package/FormBuilder/__stories__/Default.js.map +0 -7
- package/MultiplicityField/MultiplicityField.stories/index.js +0 -22
- package/MultiplicityField/MultiplicityField.stories/package.json +0 -6
- package/MultiplicityField/MultiplicityField.stories.js.map +0 -7
- package/MultiplicityField/__stories__/Default/index.js +0 -100
- package/MultiplicityField/__stories__/Default/package.json +0 -6
- package/MultiplicityField/__stories__/Default.js.map +0 -7
- package/MultiplicityField/__stories__/PreviewDisplay/index.js +0 -70
- package/MultiplicityField/__stories__/PreviewDisplay/package.json +0 -6
- package/MultiplicityField/__stories__/PreviewDisplay.js.map +0 -7
- package/MultiplicityField/__stories__/WithExactLength/index.js +0 -97
- package/MultiplicityField/__stories__/WithExactLength/package.json +0 -6
- package/MultiplicityField/__stories__/WithExactLength.js.map +0 -7
- package/MultiplicityField/__stories__/WithMaxLength/index.js +0 -100
- package/MultiplicityField/__stories__/WithMaxLength/package.json +0 -6
- package/MultiplicityField/__stories__/WithMaxLength.js.map +0 -7
- package/MultiplicityField/__stories__/WithMinAndMaxLength/index.js +0 -101
- package/MultiplicityField/__stories__/WithMinAndMaxLength/package.json +0 -6
- package/MultiplicityField/__stories__/WithMinAndMaxLength.js.map +0 -7
- package/MultiplicityField/__stories__/WithMinLength/index.js +0 -100
- package/MultiplicityField/__stories__/WithMinLength/package.json +0 -6
- package/MultiplicityField/__stories__/WithMinLength.js.map +0 -7
- package/Questions/Questions.stories/index.js +0 -12
- package/Questions/Questions.stories.js.map +0 -7
- package/Questions/__stories__/Default/index.js +0 -108
- package/Questions/__stories__/Default/package.json +0 -6
- package/Questions/__stories__/Default.js.map +0 -7
- package/cjs/FieldArray/FieldArray.stories/index.js +0 -48
- package/cjs/FieldArray/FieldArray.stories.js.map +0 -7
- package/cjs/FieldArray/__stories__/Default/index.js +0 -128
- package/cjs/FieldArray/__stories__/Default.js.map +0 -7
- package/cjs/FieldArray/__stories__/WithExactLength/index.js +0 -128
- package/cjs/FieldArray/__stories__/WithExactLength.js.map +0 -7
- package/cjs/Form.stories/index.js +0 -26
- package/cjs/Form.stories.js.map +0 -7
- package/cjs/FormBuilder/FormBuilder.stories/index.js +0 -45
- package/cjs/FormBuilder/FormBuilder.stories.js.map +0 -7
- package/cjs/FormBuilder/__stories__/Default/index.js +0 -65
- package/cjs/FormBuilder/__stories__/Default.js.map +0 -7
- package/cjs/MultiplicityField/MultiplicityField.stories/index.js +0 -60
- package/cjs/MultiplicityField/MultiplicityField.stories.js.map +0 -7
- package/cjs/MultiplicityField/__stories__/Default/index.js +0 -133
- package/cjs/MultiplicityField/__stories__/Default.js.map +0 -7
- package/cjs/MultiplicityField/__stories__/PreviewDisplay/index.js +0 -86
- package/cjs/MultiplicityField/__stories__/PreviewDisplay.js.map +0 -7
- package/cjs/MultiplicityField/__stories__/WithExactLength/index.js +0 -130
- package/cjs/MultiplicityField/__stories__/WithExactLength.js.map +0 -7
- package/cjs/MultiplicityField/__stories__/WithMaxLength/index.js +0 -133
- package/cjs/MultiplicityField/__stories__/WithMaxLength.js.map +0 -7
- package/cjs/MultiplicityField/__stories__/WithMinAndMaxLength/index.js +0 -134
- package/cjs/MultiplicityField/__stories__/WithMinAndMaxLength.js.map +0 -7
- package/cjs/MultiplicityField/__stories__/WithMinLength/index.js +0 -133
- package/cjs/MultiplicityField/__stories__/WithMinLength.js.map +0 -7
- package/cjs/Questions/Questions.stories/index.js +0 -45
- package/cjs/Questions/Questions.stories.js.map +0 -7
- package/cjs/Questions/__stories__/Default/index.js +0 -136
- package/cjs/Questions/__stories__/Default.js.map +0 -7
- package/cjs/inputs/AutoCompleteInput/AutoComplete.stories/index.js +0 -48
- package/cjs/inputs/AutoCompleteInput/AutoComplete.stories.js.map +0 -7
- package/cjs/inputs/AutoCompleteInput/__stories__/Default/index.js +0 -83
- package/cjs/inputs/AutoCompleteInput/__stories__/Default.js.map +0 -7
- package/cjs/inputs/AutoCompleteInput/__stories__/Multiple/index.js +0 -84
- package/cjs/inputs/AutoCompleteInput/__stories__/Multiple.js.map +0 -7
- package/cjs/inputs/Checkboxes/Checkboxes.stories/index.js +0 -51
- package/cjs/inputs/Checkboxes/Checkboxes.stories.js.map +0 -7
- package/cjs/inputs/Checkboxes/__stories__/Conditional/index.js +0 -133
- package/cjs/inputs/Checkboxes/__stories__/Conditional.js.map +0 -7
- package/cjs/inputs/Checkboxes/__stories__/Default/index.js +0 -77
- package/cjs/inputs/Checkboxes/__stories__/Default.js.map +0 -7
- package/cjs/inputs/Checkboxes/__stories__/WithDivider/index.js +0 -78
- package/cjs/inputs/Checkboxes/__stories__/WithDivider.js.map +0 -7
- package/cjs/inputs/DateInput/DateInput.stories/index.js +0 -45
- package/cjs/inputs/DateInput/DateInput.stories.js.map +0 -7
- package/cjs/inputs/DateInput/__stories__/Default/index.js +0 -61
- package/cjs/inputs/DateInput/__stories__/Default.js.map +0 -7
- package/cjs/inputs/FileInput/FileInput.stories/index.js +0 -45
- package/cjs/inputs/FileInput/FileInput.stories.js.map +0 -7
- package/cjs/inputs/FileInput/__stories__/Default/index.js +0 -61
- package/cjs/inputs/FileInput/__stories__/Default.js.map +0 -7
- package/cjs/inputs/ImageInput/ImageInput.stories/index.js +0 -51
- package/cjs/inputs/ImageInput/ImageInput.stories.js.map +0 -7
- package/cjs/inputs/ImageInput/__stories__/Default/index.js +0 -63
- package/cjs/inputs/ImageInput/__stories__/Default.js.map +0 -7
- package/cjs/inputs/ImageInput/__stories__/WithInvalidImageDimension/index.js +0 -71
- package/cjs/inputs/ImageInput/__stories__/WithInvalidImageDimension.js.map +0 -7
- package/cjs/inputs/ImageInput/__stories__/WithInvalidImageSize/index.js +0 -68
- package/cjs/inputs/ImageInput/__stories__/WithInvalidImageSize.js.map +0 -7
- package/cjs/inputs/Input/Input.stories/index.js +0 -72
- package/cjs/inputs/Input/Input.stories.js.map +0 -7
- package/cjs/inputs/Input/__stories__/AFM/index.js +0 -63
- package/cjs/inputs/Input/__stories__/AFM.js.map +0 -7
- package/cjs/inputs/Input/__stories__/Boolean/index.js +0 -64
- package/cjs/inputs/Input/__stories__/Boolean.js.map +0 -7
- package/cjs/inputs/Input/__stories__/IBAN/index.js +0 -64
- package/cjs/inputs/Input/__stories__/IBAN.js.map +0 -7
- package/cjs/inputs/Input/__stories__/Integer/index.js +0 -78
- package/cjs/inputs/Input/__stories__/Integer.js.map +0 -7
- package/cjs/inputs/Input/__stories__/LandlineNumber/index.js +0 -67
- package/cjs/inputs/Input/__stories__/LandlineNumber.js.map +0 -7
- package/cjs/inputs/Input/__stories__/MobilePhone/index.js +0 -67
- package/cjs/inputs/Input/__stories__/MobilePhone.js.map +0 -7
- package/cjs/inputs/Input/__stories__/PhoneNumber/index.js +0 -66
- package/cjs/inputs/Input/__stories__/PhoneNumber.js.map +0 -7
- package/cjs/inputs/Input/__stories__/PostalCode/index.js +0 -64
- package/cjs/inputs/Input/__stories__/PostalCode.js.map +0 -7
- package/cjs/inputs/Input/__stories__/String/index.js +0 -64
- package/cjs/inputs/Input/__stories__/String.js.map +0 -7
- package/cjs/inputs/Input/__stories__/TextWithLimit/index.js +0 -64
- package/cjs/inputs/Input/__stories__/TextWithLimit.js.map +0 -7
- package/cjs/inputs/Label/Label.stories/index.js +0 -45
- package/cjs/inputs/Label/Label.stories.js.map +0 -7
- package/cjs/inputs/Label/__stories__/Default/index.js +0 -72
- package/cjs/inputs/Label/__stories__/Default.js.map +0 -7
- package/cjs/inputs/OtpInput/OtpInput.stories/index.js +0 -45
- package/cjs/inputs/OtpInput/OtpInput.stories.js.map +0 -7
- package/cjs/inputs/OtpInput/__stories__/Default/index.js +0 -64
- package/cjs/inputs/OtpInput/__stories__/Default.js.map +0 -7
- package/cjs/inputs/Radio/Radio.stories/index.js +0 -51
- package/cjs/inputs/Radio/Radio.stories.js.map +0 -7
- package/cjs/inputs/Radio/__stories__/Conditional/index.js +0 -133
- package/cjs/inputs/Radio/__stories__/Conditional.js.map +0 -7
- package/cjs/inputs/Radio/__stories__/Default/index.js +0 -81
- package/cjs/inputs/Radio/__stories__/Default.js.map +0 -7
- package/cjs/inputs/Radio/__stories__/WithDivider/index.js +0 -82
- package/cjs/inputs/Radio/__stories__/WithDivider.js.map +0 -7
- package/cjs/inputs/Select/Select.stories/index.js +0 -45
- package/cjs/inputs/Select/Select.stories.js.map +0 -7
- package/cjs/inputs/Select/__stories__/Default/index.js +0 -86
- package/cjs/inputs/Select/__stories__/Default.js.map +0 -7
- package/inputs/AutoCompleteInput/AutoComplete.stories/index.js +0 -14
- package/inputs/AutoCompleteInput/AutoComplete.stories/package.json +0 -6
- package/inputs/AutoCompleteInput/AutoComplete.stories.js.map +0 -7
- package/inputs/AutoCompleteInput/__stories__/Default/index.js +0 -50
- package/inputs/AutoCompleteInput/__stories__/Default/package.json +0 -6
- package/inputs/AutoCompleteInput/__stories__/Default.js.map +0 -7
- package/inputs/AutoCompleteInput/__stories__/Multiple/index.js +0 -51
- package/inputs/AutoCompleteInput/__stories__/Multiple/package.json +0 -6
- package/inputs/AutoCompleteInput/__stories__/Multiple.js.map +0 -7
- package/inputs/Checkboxes/Checkboxes.stories/index.js +0 -16
- package/inputs/Checkboxes/Checkboxes.stories/package.json +0 -6
- package/inputs/Checkboxes/Checkboxes.stories.js.map +0 -7
- package/inputs/Checkboxes/__stories__/Conditional/index.js +0 -100
- package/inputs/Checkboxes/__stories__/Conditional/package.json +0 -6
- package/inputs/Checkboxes/__stories__/Conditional.js.map +0 -7
- package/inputs/Checkboxes/__stories__/Default/index.js +0 -44
- package/inputs/Checkboxes/__stories__/Default/package.json +0 -6
- package/inputs/Checkboxes/__stories__/Default.js.map +0 -7
- package/inputs/Checkboxes/__stories__/WithDivider/index.js +0 -45
- package/inputs/Checkboxes/__stories__/WithDivider/package.json +0 -6
- package/inputs/Checkboxes/__stories__/WithDivider.js.map +0 -7
- package/inputs/DateInput/DateInput.stories/index.js +0 -12
- package/inputs/DateInput/DateInput.stories/package.json +0 -6
- package/inputs/DateInput/DateInput.stories.js.map +0 -7
- package/inputs/DateInput/__stories__/Default/index.js +0 -28
- package/inputs/DateInput/__stories__/Default/package.json +0 -6
- package/inputs/DateInput/__stories__/Default.js.map +0 -7
- package/inputs/FileInput/FileInput.stories/index.js +0 -12
- package/inputs/FileInput/FileInput.stories/package.json +0 -6
- package/inputs/FileInput/FileInput.stories.js.map +0 -7
- package/inputs/FileInput/__stories__/Default/index.js +0 -28
- package/inputs/FileInput/__stories__/Default/package.json +0 -6
- package/inputs/FileInput/__stories__/Default.js.map +0 -7
- package/inputs/ImageInput/ImageInput.stories/index.js +0 -16
- package/inputs/ImageInput/ImageInput.stories/package.json +0 -6
- package/inputs/ImageInput/ImageInput.stories.js.map +0 -7
- package/inputs/ImageInput/__stories__/Default/index.js +0 -30
- package/inputs/ImageInput/__stories__/Default/package.json +0 -6
- package/inputs/ImageInput/__stories__/Default.js.map +0 -7
- package/inputs/ImageInput/__stories__/WithInvalidImageDimension/index.js +0 -38
- package/inputs/ImageInput/__stories__/WithInvalidImageDimension/package.json +0 -6
- package/inputs/ImageInput/__stories__/WithInvalidImageDimension.js.map +0 -7
- package/inputs/ImageInput/__stories__/WithInvalidImageSize/index.js +0 -35
- package/inputs/ImageInput/__stories__/WithInvalidImageSize/package.json +0 -6
- package/inputs/ImageInput/__stories__/WithInvalidImageSize.js.map +0 -7
- package/inputs/Input/Input.stories/index.js +0 -30
- package/inputs/Input/Input.stories.js.map +0 -7
- package/inputs/Input/__stories__/AFM/index.js +0 -30
- package/inputs/Input/__stories__/AFM/package.json +0 -6
- package/inputs/Input/__stories__/AFM.js.map +0 -7
- package/inputs/Input/__stories__/Boolean/index.js +0 -31
- package/inputs/Input/__stories__/Boolean/package.json +0 -6
- package/inputs/Input/__stories__/Boolean.js.map +0 -7
- package/inputs/Input/__stories__/IBAN/index.js +0 -31
- package/inputs/Input/__stories__/IBAN/package.json +0 -6
- package/inputs/Input/__stories__/IBAN.js.map +0 -7
- package/inputs/Input/__stories__/Integer/index.js +0 -45
- package/inputs/Input/__stories__/Integer/package.json +0 -6
- package/inputs/Input/__stories__/Integer.js.map +0 -7
- package/inputs/Input/__stories__/LandlineNumber/index.js +0 -34
- package/inputs/Input/__stories__/LandlineNumber/package.json +0 -6
- package/inputs/Input/__stories__/LandlineNumber.js.map +0 -7
- package/inputs/Input/__stories__/MobilePhone/index.js +0 -34
- package/inputs/Input/__stories__/MobilePhone/package.json +0 -6
- package/inputs/Input/__stories__/MobilePhone.js.map +0 -7
- package/inputs/Input/__stories__/PhoneNumber/index.js +0 -33
- package/inputs/Input/__stories__/PhoneNumber/package.json +0 -6
- package/inputs/Input/__stories__/PhoneNumber.js.map +0 -7
- package/inputs/Input/__stories__/PostalCode/index.js +0 -31
- package/inputs/Input/__stories__/PostalCode/package.json +0 -6
- package/inputs/Input/__stories__/PostalCode.js.map +0 -7
- package/inputs/Input/__stories__/String/index.js +0 -31
- package/inputs/Input/__stories__/String/package.json +0 -6
- package/inputs/Input/__stories__/String.js.map +0 -7
- package/inputs/Input/__stories__/TextWithLimit/index.js +0 -31
- package/inputs/Input/__stories__/TextWithLimit/package.json +0 -6
- package/inputs/Input/__stories__/TextWithLimit.js.map +0 -7
- package/inputs/Label/Label.stories/index.js +0 -12
- package/inputs/Label/Label.stories/package.json +0 -6
- package/inputs/Label/Label.stories.js.map +0 -7
- package/inputs/Label/__stories__/Default/index.js +0 -39
- package/inputs/Label/__stories__/Default/package.json +0 -6
- package/inputs/Label/__stories__/Default.js.map +0 -7
- package/inputs/OtpInput/OtpInput.stories/index.js +0 -12
- package/inputs/OtpInput/OtpInput.stories/package.json +0 -6
- package/inputs/OtpInput/OtpInput.stories.js.map +0 -7
- package/inputs/OtpInput/__stories__/Default/index.js +0 -31
- package/inputs/OtpInput/__stories__/Default/package.json +0 -6
- package/inputs/OtpInput/__stories__/Default.js.map +0 -7
- package/inputs/Radio/Radio.stories/index.js +0 -16
- package/inputs/Radio/Radio.stories/package.json +0 -6
- package/inputs/Radio/Radio.stories.js.map +0 -7
- package/inputs/Radio/__stories__/Conditional/index.js +0 -100
- package/inputs/Radio/__stories__/Conditional/package.json +0 -6
- package/inputs/Radio/__stories__/Conditional.js.map +0 -7
- package/inputs/Radio/__stories__/Default/index.js +0 -48
- package/inputs/Radio/__stories__/Default/package.json +0 -6
- package/inputs/Radio/__stories__/Default.js.map +0 -7
- package/inputs/Radio/__stories__/WithDivider/index.js +0 -49
- package/inputs/Radio/__stories__/WithDivider/package.json +0 -6
- package/inputs/Radio/__stories__/WithDivider.js.map +0 -7
- package/inputs/Select/Select.stories/index.js +0 -12
- package/inputs/Select/Select.stories/package.json +0 -6
- package/inputs/Select/Select.stories.js.map +0 -7
- package/inputs/Select/__stories__/Default/index.js +0 -53
- package/inputs/Select/__stories__/Default/package.json +0 -6
- package/inputs/Select/__stories__/Default.js.map +0 -7
- package/lazy.d.ts +0 -72
- package/lazy.js.map +0 -7
- package/registry.d.ts +0 -70
- package/registry.js.map +0 -7
- package/src/index.tsx +0 -178
- package/src/inputs/ImageInput/index.mdx +0 -19
- package/src/inputs/Input/index.mdx +0 -95
- package/src/inputs/Label/index.mdx +0 -0
- /package/src/Field/{index.mdx → doc.mdx} +0 -0
package/src/validators/index.ts
CHANGED
|
@@ -1,6 +1,4 @@
|
|
|
1
1
|
import { MutableRefObject, useMemo } from 'react';
|
|
2
|
-
import dayjs from 'dayjs';
|
|
3
|
-
import customParseFormat from 'dayjs/plugin/customParseFormat';
|
|
4
2
|
import * as yup from 'yup';
|
|
5
3
|
import { AnyObjectSchema, StringSchema } from 'yup';
|
|
6
4
|
import { RequiredArraySchema } from 'yup/lib/array';
|
|
@@ -22,16 +20,15 @@ import {
|
|
|
22
20
|
POSTALCODE_VALIDATOR,
|
|
23
21
|
UUID4_VALIDATOR,
|
|
24
22
|
IMAGE_DIMENSION_VALIDATOR,
|
|
23
|
+
DATE_VALIDATOR,
|
|
24
|
+
LATER_THAN_VALIDATOR,
|
|
25
|
+
EARLIER_THAN_VALIDATOR,
|
|
26
|
+
DATETIME_VALIDATOR,
|
|
27
|
+
LATER_THAN_DATETIME_VALIDATOR,
|
|
28
|
+
EARLIER_THAN_DATETIME_VALIDATOR,
|
|
25
29
|
} from '@digigov/form/validators/utils';
|
|
26
30
|
import { INT_VALIDATOR } from '@digigov/form/validators/utils/int';
|
|
27
31
|
import { NUMBER_VALIDATOR } from '@digigov/form/validators/utils/number';
|
|
28
|
-
dayjs.extend(customParseFormat);
|
|
29
|
-
|
|
30
|
-
const VALID_DATE_FORMATS = ['DD/MM/YYYY'];
|
|
31
|
-
const DATE_CACHE = {};
|
|
32
|
-
const getDate = (v) => {
|
|
33
|
-
return DATE_CACHE[v] ? DATE_CACHE[v] : dayjs(v, VALID_DATE_FORMATS, true);
|
|
34
|
-
};
|
|
35
32
|
|
|
36
33
|
export const getYUPTypeMap = (): Record<string, any> => {
|
|
37
34
|
const yupTypeMap = {
|
|
@@ -47,8 +44,28 @@ export const getYUPTypeMap = (): Record<string, any> => {
|
|
|
47
44
|
.nullable()
|
|
48
45
|
.test(FILE_MAX_SIZE_VALIDATOR(field));
|
|
49
46
|
},
|
|
50
|
-
string: yup.
|
|
51
|
-
|
|
47
|
+
string: (field): yup.StringSchema => {
|
|
48
|
+
if (field.trim) {
|
|
49
|
+
return yup.string().trim();
|
|
50
|
+
} else {
|
|
51
|
+
return yup.string();
|
|
52
|
+
}
|
|
53
|
+
},
|
|
54
|
+
boolean: (): yup.BooleanSchema<
|
|
55
|
+
boolean | null | undefined,
|
|
56
|
+
AnyObject,
|
|
57
|
+
boolean | null | undefined
|
|
58
|
+
> => {
|
|
59
|
+
return yup
|
|
60
|
+
.boolean()
|
|
61
|
+
.nullable()
|
|
62
|
+
.transform((value) => {
|
|
63
|
+
if (value === '' || typeof value === 'string') return null;
|
|
64
|
+
if (typeof value === 'boolean') return value;
|
|
65
|
+
if (value === 0 || value === 1) return Boolean(value);
|
|
66
|
+
return value;
|
|
67
|
+
});
|
|
68
|
+
},
|
|
52
69
|
object: (
|
|
53
70
|
field
|
|
54
71
|
):
|
|
@@ -100,24 +117,39 @@ export const getYUPTypeMap = (): Record<string, any> => {
|
|
|
100
117
|
number: (): MixedSchema =>
|
|
101
118
|
yup
|
|
102
119
|
.mixed()
|
|
103
|
-
.transform((_, val) => (val !== '' ? Number(val) :
|
|
120
|
+
.transform((_, val) => (val !== '' ? Number(val) : undefined))
|
|
104
121
|
.test(NUMBER_VALIDATOR()),
|
|
105
122
|
int: (): MixedSchema =>
|
|
106
123
|
yup
|
|
107
124
|
.mixed()
|
|
108
|
-
.transform((_, val) => (val !== '' ? Number(val) :
|
|
125
|
+
.transform((_, val) => (val !== '' ? Number(val) : undefined))
|
|
109
126
|
.test(NUMBER_VALIDATOR())
|
|
110
127
|
.test(INT_VALIDATOR()),
|
|
111
|
-
email: (): yup.StringSchema =>
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
128
|
+
email: (field): yup.StringSchema =>
|
|
129
|
+
field.trim
|
|
130
|
+
? yup.string().trim().email('form.error.email')
|
|
131
|
+
: yup.string().email('form.error.email'),
|
|
132
|
+
afm: (field): yup.StringSchema =>
|
|
133
|
+
field.trim
|
|
134
|
+
? yup.string().trim().test(AFM_VALIDATOR)
|
|
135
|
+
: yup.string().test(AFM_VALIDATOR),
|
|
136
|
+
uuid4: (field): yup.StringSchema =>
|
|
137
|
+
field.trim
|
|
138
|
+
? yup.string().trim().test(UUID4_VALIDATOR)
|
|
139
|
+
: yup.string().test(UUID4_VALIDATOR),
|
|
140
|
+
iban: (field): yup.StringSchema =>
|
|
141
|
+
field.trim
|
|
142
|
+
? yup.string().trim().test(IBAN_VALIDATOR(field))
|
|
143
|
+
: yup.string().trim().test(IBAN_VALIDATOR(field)),
|
|
144
|
+
otp: (field): yup.StringSchema =>
|
|
145
|
+
yup.string().trim().test(OTP_VALIDATOR(field)),
|
|
116
146
|
text: (field): yup.StringSchema => {
|
|
117
147
|
if (field?.extra?.limit?.max || !!field?.extra?.limit?.min) {
|
|
118
|
-
return
|
|
148
|
+
return field.trim
|
|
149
|
+
? yup.string().trim().test(TEXT_LIMIT_VALIDATOR(field))
|
|
150
|
+
: yup.string().test(TEXT_LIMIT_VALIDATOR(field));
|
|
119
151
|
} else {
|
|
120
|
-
return yup.string();
|
|
152
|
+
return field.trim ? yup.string().trim() : yup.string();
|
|
121
153
|
}
|
|
122
154
|
},
|
|
123
155
|
image: (field): MixedSchema => {
|
|
@@ -134,11 +166,17 @@ export const getYUPTypeMap = (): Record<string, any> => {
|
|
|
134
166
|
.test(IMAGE_DIMENSION_VALIDATOR(field));
|
|
135
167
|
},
|
|
136
168
|
postal_code: (field): yup.StringSchema =>
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
169
|
+
field.trim
|
|
170
|
+
? yup.string().trim().test(POSTALCODE_VALIDATOR(field))
|
|
171
|
+
: yup.string().test(POSTALCODE_VALIDATOR(field)),
|
|
172
|
+
mobile_phone: (field): yup.StringSchema =>
|
|
173
|
+
field.trim
|
|
174
|
+
? yup.string().trim().test(MOBILE_PHONE_VALIDATOR)
|
|
175
|
+
: yup.string().test(MOBILE_PHONE_VALIDATOR),
|
|
140
176
|
phone_number: (field): yup.StringSchema =>
|
|
141
|
-
|
|
177
|
+
field.trim
|
|
178
|
+
? yup.string().trim().test(PHONE_NUMBER_VALIDATOR(field))
|
|
179
|
+
: yup.string().test(PHONE_NUMBER_VALIDATOR(field)),
|
|
142
180
|
'choice:multiple': (): yup.ArraySchema<
|
|
143
181
|
yup.StringSchema<string | undefined, AnyObject, string | undefined>,
|
|
144
182
|
AnyObject,
|
|
@@ -150,69 +188,32 @@ export const getYUPTypeMap = (): Record<string, any> => {
|
|
|
150
188
|
AnyObject,
|
|
151
189
|
string | null | undefined
|
|
152
190
|
> => yup.string().nullable(),
|
|
153
|
-
date: (
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
if (params.max) {
|
|
164
|
-
let maxDate;
|
|
165
|
-
if (params.max === 'now') {
|
|
166
|
-
const today = new Date();
|
|
167
|
-
maxDate = new Date(today);
|
|
168
|
-
} else {
|
|
169
|
-
maxDate = getDate(params.max).toDate();
|
|
170
|
-
}
|
|
171
|
-
const maxNextDate = new Date(maxDate);
|
|
172
|
-
maxNextDate.setDate(maxDate.getDate() + 1);
|
|
173
|
-
simpleDate = simpleDate.test({
|
|
174
|
-
name: 'earlier-than',
|
|
175
|
-
message: {
|
|
176
|
-
key: 'form.error.date.earlier_than',
|
|
177
|
-
context: {
|
|
178
|
-
maxDate: maxNextDate.toLocaleDateString(),
|
|
179
|
-
},
|
|
180
|
-
},
|
|
181
|
-
test: function (value) {
|
|
182
|
-
if (!value) return true;
|
|
183
|
-
const date = getDate(value);
|
|
184
|
-
const isValid = +date.toDate() < +maxDate;
|
|
185
|
-
return isValid;
|
|
186
|
-
},
|
|
187
|
-
});
|
|
191
|
+
date: (
|
|
192
|
+
field
|
|
193
|
+
): yup.StringSchema<
|
|
194
|
+
string | null | undefined,
|
|
195
|
+
AnyObject,
|
|
196
|
+
string | null | undefined
|
|
197
|
+
> => {
|
|
198
|
+
let schema = yup.string().nullable();
|
|
199
|
+
if (field?.extra?.min) {
|
|
200
|
+
schema = schema.test(LATER_THAN_VALIDATOR(field));
|
|
188
201
|
}
|
|
189
|
-
if (
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
key: 'form.error.date.later_than',
|
|
203
|
-
context: {
|
|
204
|
-
minDate: minPreviousDate.toLocaleDateString(),
|
|
205
|
-
},
|
|
206
|
-
},
|
|
207
|
-
test: function (value) {
|
|
208
|
-
if (!value) return true;
|
|
209
|
-
const date = getDate(value);
|
|
210
|
-
const isValid = +date.toDate() > +minDate;
|
|
211
|
-
return isValid;
|
|
212
|
-
},
|
|
213
|
-
});
|
|
202
|
+
if (field?.extra?.max) {
|
|
203
|
+
schema = schema.test(EARLIER_THAN_VALIDATOR(field));
|
|
204
|
+
} else {
|
|
205
|
+
schema = schema.test(DATE_VALIDATOR);
|
|
206
|
+
}
|
|
207
|
+
return schema;
|
|
208
|
+
},
|
|
209
|
+
datetime: (field): yup.StringSchema => {
|
|
210
|
+
if (field?.extra?.min) {
|
|
211
|
+
return yup.string().test(LATER_THAN_DATETIME_VALIDATOR(field));
|
|
212
|
+
}
|
|
213
|
+
if (field?.extra?.max) {
|
|
214
|
+
return yup.string().test(EARLIER_THAN_DATETIME_VALIDATOR(field));
|
|
214
215
|
}
|
|
215
|
-
return
|
|
216
|
+
return yup.string().test(DATETIME_VALIDATOR);
|
|
216
217
|
},
|
|
217
218
|
};
|
|
218
219
|
return yupTypeMap;
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
import dayjs from 'dayjs';
|
|
2
|
+
import customParseFormat from 'dayjs/plugin/customParseFormat';
|
|
3
|
+
import { FieldSpec } from '@digigov/form/types';
|
|
4
|
+
import { ValidatorSchema } from '@digigov/form/validators/types';
|
|
5
|
+
|
|
6
|
+
dayjs.extend(customParseFormat);
|
|
7
|
+
|
|
8
|
+
const VALID_DATE_FORMATS = ['DD/MM/YYYY'];
|
|
9
|
+
const DATE_CACHE = {};
|
|
10
|
+
|
|
11
|
+
const getDate = (v: string) => {
|
|
12
|
+
return DATE_CACHE[v] ? DATE_CACHE[v] : dayjs(v, VALID_DATE_FORMATS, true);
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
// Function to check partial date completion
|
|
16
|
+
const checkPartialDate = (value: string) => {
|
|
17
|
+
console.log("value.split('/')", value.split('/'));
|
|
18
|
+
const [day, month, year] = value.split('/');
|
|
19
|
+
if (day && !month && !year) {
|
|
20
|
+
return 'form.error.date.invalid_month_year';
|
|
21
|
+
}
|
|
22
|
+
if (!day && month && !year) {
|
|
23
|
+
return 'form.error.date.invalid_day_year';
|
|
24
|
+
}
|
|
25
|
+
if (!day && !month && year) {
|
|
26
|
+
return 'form.error.date.invalid_day_month';
|
|
27
|
+
}
|
|
28
|
+
if (day && month && !year) {
|
|
29
|
+
return 'form.error.date.invalid_year';
|
|
30
|
+
}
|
|
31
|
+
if (day && !month && year) {
|
|
32
|
+
return 'form.error.date.invalid_month';
|
|
33
|
+
}
|
|
34
|
+
if (!day && month && year) {
|
|
35
|
+
return 'form.error.date.invalid_day';
|
|
36
|
+
} else {
|
|
37
|
+
return 'form.error.date.invalid';
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
export const LATER_THAN_VALIDATOR = (field: FieldSpec): ValidatorSchema => {
|
|
42
|
+
let minDate;
|
|
43
|
+
const params = field.extra || {};
|
|
44
|
+
if (params.min === 'now') {
|
|
45
|
+
const today = new Date();
|
|
46
|
+
minDate = new Date(today);
|
|
47
|
+
} else {
|
|
48
|
+
minDate = getDate(params.min).toDate();
|
|
49
|
+
}
|
|
50
|
+
const minPreviousDate = new Date(minDate);
|
|
51
|
+
minPreviousDate.setDate(minDate.getDate() - 1);
|
|
52
|
+
return {
|
|
53
|
+
name: 'later-than',
|
|
54
|
+
message: {
|
|
55
|
+
key: 'form.error.date.later_than',
|
|
56
|
+
context: {
|
|
57
|
+
minDate: minPreviousDate.toLocaleDateString(),
|
|
58
|
+
},
|
|
59
|
+
},
|
|
60
|
+
test: function (value: string) {
|
|
61
|
+
if (!value) return true;
|
|
62
|
+
const date = getDate(value);
|
|
63
|
+
const isValid = +date.toDate() > +minDate;
|
|
64
|
+
return isValid;
|
|
65
|
+
},
|
|
66
|
+
};
|
|
67
|
+
};
|
|
68
|
+
|
|
69
|
+
export const EARLIER_THAN_VALIDATOR = (field: FieldSpec): ValidatorSchema => {
|
|
70
|
+
let maxDate;
|
|
71
|
+
const params = field.extra || {};
|
|
72
|
+
if (params.max === 'now') {
|
|
73
|
+
const today = new Date();
|
|
74
|
+
maxDate = new Date(today);
|
|
75
|
+
} else {
|
|
76
|
+
maxDate = getDate(params.max).toDate();
|
|
77
|
+
}
|
|
78
|
+
const maxNextDate = new Date(maxDate);
|
|
79
|
+
maxNextDate.setDate(maxDate.getDate() + 1);
|
|
80
|
+
return {
|
|
81
|
+
name: 'earlier-than',
|
|
82
|
+
message: {
|
|
83
|
+
key: 'form.error.date.earlier_than',
|
|
84
|
+
context: {
|
|
85
|
+
maxDate: maxNextDate.toLocaleDateString(),
|
|
86
|
+
},
|
|
87
|
+
},
|
|
88
|
+
test: function (value: string) {
|
|
89
|
+
if (!value) return true;
|
|
90
|
+
const date = getDate(value);
|
|
91
|
+
const isValid = +date.toDate() < +maxDate;
|
|
92
|
+
return isValid;
|
|
93
|
+
},
|
|
94
|
+
};
|
|
95
|
+
};
|
|
96
|
+
|
|
97
|
+
export const DATE_VALIDATOR = {
|
|
98
|
+
name: 'date-validator',
|
|
99
|
+
message: (v): string => {
|
|
100
|
+
return checkPartialDate(v.value);
|
|
101
|
+
},
|
|
102
|
+
test: function (value: string) {
|
|
103
|
+
if (!value) return true;
|
|
104
|
+
const date = getDate(value);
|
|
105
|
+
return date.isValid();
|
|
106
|
+
},
|
|
107
|
+
};
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
import dayjs from 'dayjs';
|
|
2
|
+
import customParseFormat from 'dayjs/plugin/customParseFormat';
|
|
3
|
+
import { FieldSpec } from '@digigov/form/types';
|
|
4
|
+
import { ValidatorSchema } from '@digigov/form/validators/types';
|
|
5
|
+
|
|
6
|
+
dayjs.extend(customParseFormat);
|
|
7
|
+
|
|
8
|
+
const VALID_DATETIME_FORMATS = ['DD/MM/YYYY HH:mm'];
|
|
9
|
+
const DATETIME_CACHE = {};
|
|
10
|
+
|
|
11
|
+
const getDateTime = (v: string) => {
|
|
12
|
+
return DATETIME_CACHE[v]
|
|
13
|
+
? DATETIME_CACHE[v]
|
|
14
|
+
: dayjs(v, VALID_DATETIME_FORMATS, true);
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
// Function to check partial datetime completion
|
|
18
|
+
const checkPartialDateTime = (value: string) => {
|
|
19
|
+
const [datePart, timePart] = value.split(' ');
|
|
20
|
+
const [day, month, year] = datePart.split('/');
|
|
21
|
+
const [hours, minutes] = timePart ? timePart.split(':') : [null, null];
|
|
22
|
+
|
|
23
|
+
// Check date part first
|
|
24
|
+
if (day && !month && !year) {
|
|
25
|
+
return 'form.error.datetime.invalid_month_year';
|
|
26
|
+
}
|
|
27
|
+
if (!day && month && !year) {
|
|
28
|
+
return 'form.error.datetime.invalid_day_year';
|
|
29
|
+
}
|
|
30
|
+
if (!day && !month && year) {
|
|
31
|
+
return 'form.error.datetime.invalid_day_month';
|
|
32
|
+
}
|
|
33
|
+
if (day && month && !year) {
|
|
34
|
+
return 'form.error.datetime.invalid_year';
|
|
35
|
+
}
|
|
36
|
+
if (day && !month && year) {
|
|
37
|
+
return 'form.error.datetime.invalid_month';
|
|
38
|
+
}
|
|
39
|
+
if (!day && month && year) {
|
|
40
|
+
return 'form.error.datetime.invalid_day';
|
|
41
|
+
}
|
|
42
|
+
// If date is complete, check time part
|
|
43
|
+
if (day && month && year) {
|
|
44
|
+
if (hours && !minutes) {
|
|
45
|
+
return 'form.error.datetime.invalid_minutes';
|
|
46
|
+
}
|
|
47
|
+
if (!hours && minutes) {
|
|
48
|
+
return 'form.error.datetime.invalid_hours';
|
|
49
|
+
}
|
|
50
|
+
if (!hours && !minutes) {
|
|
51
|
+
return 'form.error.datetime.invalid';
|
|
52
|
+
}
|
|
53
|
+
if (hours && minutes) {
|
|
54
|
+
const hoursNum = parseInt(hours);
|
|
55
|
+
const minutesNum = parseInt(minutes);
|
|
56
|
+
if (hoursNum < 0 || hoursNum > 23) {
|
|
57
|
+
return 'form.error.datetime.invalid_hours_range';
|
|
58
|
+
}
|
|
59
|
+
if (minutesNum < 0 || minutesNum > 59) {
|
|
60
|
+
return 'form.error.datetime.invalid_minutes_range';
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
return 'form.error.datetime.invalid';
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
export const LATER_THAN_DATETIME_VALIDATOR = (
|
|
69
|
+
field: FieldSpec
|
|
70
|
+
): ValidatorSchema => {
|
|
71
|
+
let minDateTime;
|
|
72
|
+
const params = field.extra || {};
|
|
73
|
+
if (params.min === 'now') {
|
|
74
|
+
minDateTime = dayjs();
|
|
75
|
+
} else {
|
|
76
|
+
minDateTime = getDateTime(params.min);
|
|
77
|
+
}
|
|
78
|
+
return {
|
|
79
|
+
name: 'later-than-datetime',
|
|
80
|
+
message: {
|
|
81
|
+
key: 'form.error.datetime.later_than',
|
|
82
|
+
context: {
|
|
83
|
+
minDateTime: minDateTime.format('DD/MM/YYYY HH:mm'),
|
|
84
|
+
},
|
|
85
|
+
},
|
|
86
|
+
test: function (value: string) {
|
|
87
|
+
if (!value) return true;
|
|
88
|
+
const datetime = getDateTime(value);
|
|
89
|
+
return datetime.isValid() && datetime.isAfter(minDateTime);
|
|
90
|
+
},
|
|
91
|
+
};
|
|
92
|
+
};
|
|
93
|
+
|
|
94
|
+
export const EARLIER_THAN_DATETIME_VALIDATOR = (
|
|
95
|
+
field: FieldSpec
|
|
96
|
+
): ValidatorSchema => {
|
|
97
|
+
let maxDateTime;
|
|
98
|
+
const params = field.extra || {};
|
|
99
|
+
if (params.max === 'now') {
|
|
100
|
+
maxDateTime = dayjs();
|
|
101
|
+
} else {
|
|
102
|
+
maxDateTime = getDateTime(params.max);
|
|
103
|
+
}
|
|
104
|
+
return {
|
|
105
|
+
name: 'earlier-than-datetime',
|
|
106
|
+
message: {
|
|
107
|
+
key: 'form.error.datetime.earlier_than',
|
|
108
|
+
context: {
|
|
109
|
+
maxDateTime: maxDateTime.format('DD/MM/YYYY HH:mm'),
|
|
110
|
+
},
|
|
111
|
+
},
|
|
112
|
+
test: function (value: string) {
|
|
113
|
+
if (!value) return true;
|
|
114
|
+
const datetime = getDateTime(value);
|
|
115
|
+
return datetime.isValid() && datetime.isBefore(maxDateTime);
|
|
116
|
+
},
|
|
117
|
+
};
|
|
118
|
+
};
|
|
119
|
+
|
|
120
|
+
export const DATETIME_VALIDATOR = {
|
|
121
|
+
name: 'datetime-validator',
|
|
122
|
+
message: (v): string => {
|
|
123
|
+
return checkPartialDateTime(v.value);
|
|
124
|
+
},
|
|
125
|
+
test: function (value: string) {
|
|
126
|
+
if (!value) return true;
|
|
127
|
+
const datetime = getDateTime(value);
|
|
128
|
+
return datetime.isValid();
|
|
129
|
+
},
|
|
130
|
+
};
|
|
@@ -6,15 +6,17 @@ const DEFAULT_FILE_MAX_SIZE = 10000000;
|
|
|
6
6
|
export const FILE_MAX_SIZE_VALIDATOR = (field: FieldSpec): ValidatorSchema => ({
|
|
7
7
|
name: 'file-max-size-validator',
|
|
8
8
|
message: {
|
|
9
|
-
key:
|
|
9
|
+
key:
|
|
10
|
+
field.type === 'file' ? 'form.error.file_size' : 'form.error.image_size',
|
|
10
11
|
context: {
|
|
11
|
-
maxSizeToMb:
|
|
12
|
+
maxSizeToMb:
|
|
13
|
+
(field?.extra?.limit?.maxSize || DEFAULT_FILE_MAX_SIZE) / 1000000,
|
|
12
14
|
},
|
|
13
15
|
},
|
|
14
16
|
test: (value: File[]): boolean => {
|
|
15
17
|
if (value) {
|
|
16
18
|
for (const file of value) {
|
|
17
|
-
const maxSize = field?.extra?.limit?.maxSize || DEFAULT_FILE_MAX_SIZE
|
|
19
|
+
const maxSize = field?.extra?.limit?.maxSize || DEFAULT_FILE_MAX_SIZE;
|
|
18
20
|
if (file.size > maxSize) {
|
|
19
21
|
return false;
|
|
20
22
|
}
|
|
@@ -11,6 +11,8 @@ export * from '@digigov/form/validators/utils/phone';
|
|
|
11
11
|
export * from '@digigov/form/validators/utils/postal_code';
|
|
12
12
|
export * from '@digigov/form/validators/utils/uuid4';
|
|
13
13
|
export * from '@digigov/form/validators/utils/text_limit';
|
|
14
|
+
export * from '@digigov/form/validators/utils/date';
|
|
15
|
+
export * from '@digigov/form/validators/utils/datetime';
|
|
14
16
|
|
|
15
17
|
export function getYupField(field: FieldSpec, yupTypeMap: Record<string, any>) {
|
|
16
18
|
const yupField = yupTypeMap[field?.type || 'string'] || yupTypeMap['string'];
|
|
@@ -13,7 +13,7 @@ export const INT_VALIDATOR = (): ValidatorSchema => {
|
|
|
13
13
|
name: 'int-validator',
|
|
14
14
|
message: 'form.error.positive_integer_number',
|
|
15
15
|
test: (value: number): boolean => {
|
|
16
|
-
if (value ===
|
|
16
|
+
if (value === undefined) {
|
|
17
17
|
return true;
|
|
18
18
|
}
|
|
19
19
|
return validateIntNumber(value);
|
|
@@ -9,7 +9,7 @@ export const NUMBER_VALIDATOR = (): ValidatorSchema => {
|
|
|
9
9
|
name: 'number-validator',
|
|
10
10
|
message: 'form.error.number',
|
|
11
11
|
test: (value: number): boolean => {
|
|
12
|
-
if (value ===
|
|
12
|
+
if (value === undefined) {
|
|
13
13
|
return true;
|
|
14
14
|
}
|
|
15
15
|
return validateNumber(value);
|
|
@@ -138,7 +138,7 @@ function isNumberOfType(phoneNumber: string, country: string, type: string) {
|
|
|
138
138
|
}
|
|
139
139
|
export function validatePhoneNumber(
|
|
140
140
|
phoneNumber: string,
|
|
141
|
-
countries:
|
|
141
|
+
countries: string[] = ['gr'],
|
|
142
142
|
typeOfPhoneNumber?: PhoneNumberType
|
|
143
143
|
): boolean {
|
|
144
144
|
if (!countries || countries.length === 0) {
|
|
@@ -4,7 +4,7 @@ import { ValidatorSchema } from '@digigov/form/validators/types';
|
|
|
4
4
|
const CODE_REGEX = /^[12345678][0-9]{4}$/;
|
|
5
5
|
export function validatePostalCode(
|
|
6
6
|
number: string,
|
|
7
|
-
countries:
|
|
7
|
+
countries: string[]
|
|
8
8
|
): boolean {
|
|
9
9
|
if (!countries) {
|
|
10
10
|
return false;
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
const UUID4_PATTERN =
|
|
1
|
+
const UUID4_PATTERN =
|
|
2
|
+
/^[0-9A-F]{8}-[0-9A-F]{4}-[4][0-9A-F]{3}-[89AB][0-9A-F]{3}-[0-9A-F]{12}$/i;
|
|
2
3
|
|
|
3
4
|
export function validateUUID4(uuid4: string): boolean {
|
|
4
5
|
if (uuid4.length !== 36) {
|
|
@@ -75,14 +75,14 @@ it('throws if given country is not supported', () => {
|
|
|
75
75
|
);
|
|
76
76
|
});
|
|
77
77
|
|
|
78
|
-
it('validates
|
|
78
|
+
it('validates phone number type mobile with gr country code', () => {
|
|
79
79
|
expect(validatePhoneNumber('6934100982', ['GR'], 'mobile')).toBe(true);
|
|
80
80
|
});
|
|
81
81
|
|
|
82
|
-
it('validates
|
|
82
|
+
it('validates phone number with no type and gr country code', () => {
|
|
83
83
|
expect(validatePhoneNumber('6934100982', ['gr'], null)).toBe(true);
|
|
84
84
|
});
|
|
85
85
|
|
|
86
|
-
it('validates
|
|
86
|
+
it('validates invalid phone number with no type and gr country code', () => {
|
|
87
87
|
expect(validatePhoneNumber('41446681800', ['gr'], null)).toBe(false);
|
|
88
88
|
});
|
package/types.d.ts
CHANGED
|
@@ -1,11 +1,10 @@
|
|
|
1
|
-
/// <reference types="react" />
|
|
2
1
|
import { UseFormReturn, UseFormProps } from 'react-hook-form';
|
|
3
2
|
import { FieldComponentRegistry, FieldLabelProps, FieldSpec, FormData } from '@digigov/form/Field/types';
|
|
4
3
|
import { ValidatorSchema } from '@digigov/form/validators/types';
|
|
5
4
|
export * from '@digigov/form/Field/types';
|
|
6
|
-
export
|
|
5
|
+
export interface FieldError {
|
|
7
6
|
message: string;
|
|
8
|
-
}
|
|
7
|
+
}
|
|
9
8
|
export interface FieldsetSpec {
|
|
10
9
|
key: string;
|
|
11
10
|
fields: string[];
|
|
@@ -46,6 +45,7 @@ export interface FormBuilderProps {
|
|
|
46
45
|
validatorRegistry?: Record<string, ValidatorSchema[]>;
|
|
47
46
|
componentRegistry?: FieldComponentRegistry;
|
|
48
47
|
grid?: boolean;
|
|
48
|
+
controlledFieldsOnly?: boolean;
|
|
49
49
|
}
|
|
50
50
|
export interface FormBaseProps extends Omit<FormBuilderProps, 'fields' | 'fieldsets' | 'auto'> {
|
|
51
51
|
fieldsetsMap?: Record<string, FieldsetSpec>;
|
package/types.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/types.tsx"],
|
|
4
|
-
"sourcesContent": ["import { UseFormReturn, UseFormProps } from 'react-hook-form';\nimport {\n FieldComponentRegistry,\n FieldLabelProps,\n FieldSpec,\n FormData,\n} from '@digigov/form/Field/types';\nimport { ValidatorSchema } from '@digigov/form/validators/types';\nexport * from '@digigov/form/Field/types';\nexport
|
|
4
|
+
"sourcesContent": ["import { UseFormReturn, UseFormProps } from 'react-hook-form';\nimport {\n FieldComponentRegistry,\n FieldLabelProps,\n FieldSpec,\n FormData,\n} from '@digigov/form/Field/types';\nimport { ValidatorSchema } from '@digigov/form/validators/types';\nexport * from '@digigov/form/Field/types';\nexport interface FieldError {\n message: string;\n}\n\nexport interface FieldsetSpec {\n key: string;\n fields: string[];\n label?: FieldLabelProps;\n body?: React.ReactNode;\n}\n\nexport interface FormContextProps {\n fieldsetsMap?: Record<string, FieldsetSpec>;\n fieldsMap: Record<string, FieldSpec>;\n control: UseFormReturn['control'];\n register: UseFormReturn['register'];\n trigger: UseFormReturn['trigger'];\n clearErrors: UseFormReturn['clearErrors'];\n watch: UseFormReturn['watch'];\n getFieldState: UseFormReturn['getFieldState'];\n setValue: UseFormReturn['setValue'];\n getValues: UseFormReturn['getValues'];\n unregister: UseFormReturn['unregister'];\n formState: UseFormReturn['formState'];\n reset: UseFormReturn['reset'];\n resetField: UseFormReturn['resetField'];\n registerField: (field: FieldSpec) => void;\n errors: UseFormReturn['formState']['errors'];\n componentRegistry?: FieldComponentRegistry;\n submit: () => Promise<void>;\n}\n\nexport interface FormBuilderProps {\n fields?: FieldSpec[];\n fieldsets?: FieldsetSpec[];\n initial?: FormData;\n onSubmit?: (data: FormData) => void | null | FieldError[];\n mode?: UseFormProps['mode'];\n reValidateMode?: UseFormProps['reValidateMode'];\n criteriaMode?: UseFormProps['criteriaMode'];\n children?: React.ReactNode;\n shouldFocusError?: boolean;\n auto?: boolean;\n validatorRegistry?: Record<string, ValidatorSchema[]>;\n componentRegistry?: FieldComponentRegistry;\n grid?: boolean;\n controlledFieldsOnly?: boolean;\n}\n\nexport interface FormBaseProps\n extends Omit<FormBuilderProps, 'fields' | 'fieldsets' | 'auto'> {\n fieldsetsMap?: Record<string, FieldsetSpec>;\n fieldsMap: Record<string, FieldSpec>;\n registerField: (field: FieldSpec) => void;\n resolver: any;\n}\n"],
|
|
5
5
|
"mappings": "AAQA,cAAc;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
package/utils/index.js
CHANGED
|
@@ -34,7 +34,8 @@ const yupResolver = (schema, schemaOptions = {}, resolverOptions = {}) => async
|
|
|
34
34
|
values,
|
|
35
35
|
Object.assign({ abortEarly: false }, schemaOptions, { context })
|
|
36
36
|
);
|
|
37
|
-
options.shouldUseNativeValidation
|
|
37
|
+
if (options.shouldUseNativeValidation)
|
|
38
|
+
validateFieldsNatively({}, options);
|
|
38
39
|
return {
|
|
39
40
|
values: resolverOptions.rawValues ? values : result,
|
|
40
41
|
errors: {}
|
package/utils.js.map
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/utils.ts"],
|
|
4
|
-
"sourcesContent": ["import { validateFieldsNatively } from '@hookform/resolvers';\nimport { appendErrors, FieldError } from 'react-hook-form';\nimport * as Yup from 'yup';\n\n/**\n * Why `path!` ? because it could be `undefined` in some case\n * https://github.com/jquense/yup#validationerrorerrors-string--arraystring-value-any-path-string\n */\nconst parseErrorSchema = (\n error: Yup.ValidationError,\n validateAllFieldCriteria: boolean\n) => {\n return (error.inner || []).reduce<Record<string, FieldError>>(\n (previous, error) => {\n error.path = error.path?.replace(/\\[([0-9]+)\\]/g, '.$1');\n if (!previous[error.path!]) {\n previous[error.path!] = { message: error.message, type: error.type! };\n }\n\n if (validateAllFieldCriteria) {\n const types = previous[error.path!].types;\n const messages = types && types[error.type!];\n\n previous[error.path!] = appendErrors(\n error.path!,\n validateAllFieldCriteria,\n previous,\n error.type!,\n messages\n ? ([] as string[]).concat(messages as string[], error.message)\n : error.message\n ) as FieldError;\n }\n\n return previous;\n },\n {}\n );\n};\n\nexport const yupResolver =\n (schema: any, schemaOptions: any = {}, resolverOptions: any = {}) =>\n async (values, context, options) => {\n try {\n if (schemaOptions.context && process.env.NODE_ENV === 'development') {\n
|
|
5
|
-
"mappings": "AAAA,SAAS,8BAA8B;AACvC,SAAS,oBAAgC;AAOzC,MAAM,mBAAmB,CACvB,OACA,6BACG;AACH,UAAQ,MAAM,SAAS,CAAC,GAAG;AAAA,IACzB,CAAC,UAAUA,WAAU;AACnB,MAAAA,OAAM,OAAOA,OAAM,MAAM,QAAQ,iBAAiB,KAAK;AACvD,UAAI,CAAC,SAASA,OAAM,IAAK,GAAG;AAC1B,iBAASA,OAAM,IAAK,IAAI,EAAE,SAASA,OAAM,SAAS,MAAMA,OAAM,KAAM;AAAA,MACtE;AAEA,UAAI,0BAA0B;AAC5B,cAAM,QAAQ,SAASA,OAAM,IAAK,EAAE;AACpC,cAAM,WAAW,SAAS,MAAMA,OAAM,IAAK;AAE3C,iBAASA,OAAM,IAAK,IAAI;AAAA,UACtBA,OAAM;AAAA,UACN;AAAA,UACA;AAAA,UACAA,OAAM;AAAA,UACN,WACK,CAAC,EAAe,OAAO,UAAsBA,OAAM,OAAO,IAC3DA,OAAM;AAAA,QACZ;AAAA,MACF;AAEA,aAAO;AAAA,IACT;AAAA,IACA,CAAC;AAAA,EACH;AACF;AAEO,MAAM,cACX,CAAC,QAAa,gBAAqB,CAAC,GAAG,kBAAuB,CAAC,MAC/D,OAAO,QAAQ,SAAS,YAAY;AAClC,MAAI;AACF,QAAI,cAAc,WAAW,QAAQ,IAAI,aAAa,eAAe;
|
|
4
|
+
"sourcesContent": ["import { validateFieldsNatively } from '@hookform/resolvers';\nimport { appendErrors, FieldError } from 'react-hook-form';\nimport * as Yup from 'yup';\n\n/**\n * Why `path!` ? because it could be `undefined` in some case\n * https://github.com/jquense/yup#validationerrorerrors-string--arraystring-value-any-path-string\n */\nconst parseErrorSchema = (\n error: Yup.ValidationError,\n validateAllFieldCriteria: boolean\n) => {\n return (error.inner || []).reduce<Record<string, FieldError>>(\n (previous, error) => {\n error.path = error.path?.replace(/\\[([0-9]+)\\]/g, '.$1');\n if (!previous[error.path!]) {\n previous[error.path!] = { message: error.message, type: error.type! };\n }\n\n if (validateAllFieldCriteria) {\n const types = previous[error.path!].types;\n const messages = types && types[error.type!];\n\n previous[error.path!] = appendErrors(\n error.path!,\n validateAllFieldCriteria,\n previous,\n error.type!,\n messages\n ? ([] as string[]).concat(messages as string[], error.message)\n : error.message\n ) as FieldError;\n }\n\n return previous;\n },\n {}\n );\n};\n\nexport const yupResolver =\n (schema: any, schemaOptions: any = {}, resolverOptions: any = {}) =>\n async (values, context, options) => {\n try {\n if (schemaOptions.context && process.env.NODE_ENV === 'development') {\n console.warn(\n \"You should not used the yup options context. Please, use the 'useForm' context object instead\"\n );\n }\n\n const result = await schema[\n resolverOptions.mode === 'sync' ? 'validateSync' : 'validate'\n ](\n values,\n Object.assign({ abortEarly: false }, schemaOptions, { context })\n );\n\n if (options.shouldUseNativeValidation)\n validateFieldsNatively({}, options);\n\n return {\n values: resolverOptions.rawValues ? values : result,\n errors: {},\n };\n } catch (e) {\n if (!e.inner) {\n throw e;\n }\n\n const parsed = parseErrorSchema(\n e,\n !options.shouldUseNativeValidation && options.criteriaMode === 'all'\n );\n return {\n values: {},\n errors: parsed,\n };\n }\n };\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,8BAA8B;AACvC,SAAS,oBAAgC;AAOzC,MAAM,mBAAmB,CACvB,OACA,6BACG;AACH,UAAQ,MAAM,SAAS,CAAC,GAAG;AAAA,IACzB,CAAC,UAAUA,WAAU;AACnB,MAAAA,OAAM,OAAOA,OAAM,MAAM,QAAQ,iBAAiB,KAAK;AACvD,UAAI,CAAC,SAASA,OAAM,IAAK,GAAG;AAC1B,iBAASA,OAAM,IAAK,IAAI,EAAE,SAASA,OAAM,SAAS,MAAMA,OAAM,KAAM;AAAA,MACtE;AAEA,UAAI,0BAA0B;AAC5B,cAAM,QAAQ,SAASA,OAAM,IAAK,EAAE;AACpC,cAAM,WAAW,SAAS,MAAMA,OAAM,IAAK;AAE3C,iBAASA,OAAM,IAAK,IAAI;AAAA,UACtBA,OAAM;AAAA,UACN;AAAA,UACA;AAAA,UACAA,OAAM;AAAA,UACN,WACK,CAAC,EAAe,OAAO,UAAsBA,OAAM,OAAO,IAC3DA,OAAM;AAAA,QACZ;AAAA,MACF;AAEA,aAAO;AAAA,IACT;AAAA,IACA,CAAC;AAAA,EACH;AACF;AAEO,MAAM,cACX,CAAC,QAAa,gBAAqB,CAAC,GAAG,kBAAuB,CAAC,MAC/D,OAAO,QAAQ,SAAS,YAAY;AAClC,MAAI;AACF,QAAI,cAAc,WAAW,QAAQ,IAAI,aAAa,eAAe;AACnE,cAAQ;AAAA,QACN;AAAA,MACF;AAAA,IACF;AAEA,UAAM,SAAS,MAAM,OACnB,gBAAgB,SAAS,SAAS,iBAAiB,UACrD;AAAA,MACE;AAAA,MACA,OAAO,OAAO,EAAE,YAAY,MAAM,GAAG,eAAe,EAAE,QAAQ,CAAC;AAAA,IACjE;AAEA,QAAI,QAAQ;AACV,6BAAuB,CAAC,GAAG,OAAO;AAEpC,WAAO;AAAA,MACL,QAAQ,gBAAgB,YAAY,SAAS;AAAA,MAC7C,QAAQ,CAAC;AAAA,IACX;AAAA,EACF,SAAS,GAAG;AACV,QAAI,CAAC,EAAE,OAAO;AACZ,YAAM;AAAA,IACR;AAEA,UAAM,SAAS;AAAA,MACb;AAAA,MACA,CAAC,QAAQ,6BAA6B,QAAQ,iBAAiB;AAAA,IACjE;AACA,WAAO;AAAA,MACL,QAAQ,CAAC;AAAA,MACT,QAAQ;AAAA,IACV;AAAA,EACF;AACF;",
|
|
6
6
|
"names": ["error"]
|
|
7
7
|
}
|