@digigov/form 1.2.0-dcbd7ded → 2.0.0-2445d5cb
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/FieldBase/index.js +103 -76
- package/Field/FieldBase.js.map +7 -0
- package/Field/FieldBaseContainer/index.js +29 -37
- package/Field/FieldBaseContainer.js.map +7 -0
- package/Field/FieldConditional/index.js +75 -53
- package/Field/FieldConditional.js.map +7 -0
- package/Field/index.js +99 -63
- package/Field/index.js.map +7 -0
- package/Field/types/index.js +1 -1
- package/Field/types.d.ts +36 -3
- package/Field/types.js.map +7 -0
- package/Field/utils/calculateField/index.js +27 -0
- package/{inputs/Input/__stories__/Default → Field/utils/calculateField}/package.json +1 -1
- package/Field/utils/calculateField.d.ts +2 -0
- package/Field/utils/calculateField.js.map +7 -0
- package/Field/utils/evaluateFieldWithConditions/index.js +26 -0
- package/Field/utils/evaluateFieldWithConditions/package.json +6 -0
- package/Field/utils/evaluateFieldWithConditions.d.ts +2 -0
- package/Field/utils/evaluateFieldWithConditions.js.map +7 -0
- package/Field/utils/index.d.ts +3 -0
- package/Field/utils/index.js +25 -117
- package/Field/utils/index.js.map +7 -0
- package/Field/utils/useField/index.js +51 -0
- package/{FormBuilder/FormBuilder → Field/utils/useField}/package.json +1 -1
- package/Field/utils/useField.d.ts +2 -0
- package/Field/utils/useField.js.map +7 -0
- package/FieldArray/FieldArray.stories/index.js +12 -6
- package/FieldArray/FieldArray.stories.d.ts +2 -2
- package/FieldArray/FieldArray.stories.js.map +7 -0
- package/FieldArray/__stories__/Default/index.js +87 -80
- package/FieldArray/__stories__/Default.d.ts +2 -2
- package/FieldArray/__stories__/Default.js.map +7 -0
- package/FieldArray/__stories__/WithExactLength/index.js +87 -80
- package/FieldArray/__stories__/WithExactLength.d.ts +2 -2
- package/FieldArray/__stories__/WithExactLength.js.map +7 -0
- package/FieldArray/index.js +72 -59
- package/FieldArray/index.js.map +7 -0
- package/FieldArray/index.test.d.ts +1 -0
- package/FieldObject/index.d.ts +1 -0
- package/FieldObject/index.js +66 -52
- package/FieldObject/index.js.map +7 -0
- package/Fieldset/FieldsetWithContext/index.js +27 -31
- package/Fieldset/FieldsetWithContext.js.map +7 -0
- package/Fieldset/index.js +27 -29
- package/Fieldset/index.js.map +7 -0
- package/Fieldset/types/index.js +1 -1
- package/Fieldset/types.d.ts +2 -0
- package/Fieldset/types.js.map +7 -0
- package/Form.stories/index.js +7 -3
- package/Form.stories.js.map +7 -0
- package/FormBuilder/FormBuilder.stories/index.js +10 -5
- package/FormBuilder/FormBuilder.stories.d.ts +1 -1
- package/FormBuilder/FormBuilder.stories.js.map +7 -0
- package/FormBuilder/__stories__/Default/index.js +27 -21
- package/FormBuilder/__stories__/Default.d.ts +2 -2
- package/FormBuilder/__stories__/Default.js.map +7 -0
- package/FormBuilder/index.d.ts +2 -1
- package/FormBuilder/index.js +14 -2
- package/FormBuilder/index.js.map +7 -0
- package/FormBuilder/index.test.d.ts +1 -0
- package/FormBuilder/scenarios.test.d.ts +88 -0
- package/FormContext/index.js +7 -3
- package/FormContext.js.map +7 -0
- package/MultiplicityField/MultiplicityField.stories/index.js +20 -10
- package/MultiplicityField/MultiplicityField.stories.d.ts +6 -6
- package/MultiplicityField/MultiplicityField.stories.js.map +7 -0
- package/MultiplicityField/__stories__/Default/index.js +90 -85
- package/MultiplicityField/__stories__/Default.d.ts +2 -2
- package/MultiplicityField/__stories__/Default.js.map +7 -0
- package/MultiplicityField/__stories__/PreviewDisplay/index.js +70 -72
- package/MultiplicityField/__stories__/PreviewDisplay.d.ts +2 -2
- package/MultiplicityField/__stories__/PreviewDisplay.js.map +7 -0
- package/MultiplicityField/__stories__/WithExactLength/index.js +87 -80
- package/MultiplicityField/__stories__/WithExactLength.d.ts +2 -2
- package/MultiplicityField/__stories__/WithExactLength.js.map +7 -0
- package/MultiplicityField/__stories__/WithMaxLength/index.js +90 -83
- package/MultiplicityField/__stories__/WithMaxLength.d.ts +2 -2
- package/MultiplicityField/__stories__/WithMaxLength.js.map +7 -0
- package/MultiplicityField/__stories__/WithMinAndMaxLength/index.js +91 -84
- package/MultiplicityField/__stories__/WithMinAndMaxLength.d.ts +2 -2
- package/MultiplicityField/__stories__/WithMinAndMaxLength.js.map +7 -0
- package/MultiplicityField/__stories__/WithMinLength/index.js +90 -83
- package/MultiplicityField/__stories__/WithMinLength.d.ts +2 -2
- package/MultiplicityField/__stories__/WithMinLength.js.map +7 -0
- package/MultiplicityField/add-objects/index.js +133 -132
- package/MultiplicityField/add-objects.d.ts +2 -1
- package/MultiplicityField/add-objects.js.map +7 -0
- package/MultiplicityField/index.d.ts +2 -19
- package/MultiplicityField/index.js +109 -106
- package/MultiplicityField/index.js.map +7 -0
- package/MultiplicityField/index.test.d.ts +1 -0
- package/MultiplicityField/types/index.js +1 -0
- package/{validators/validators.spec → MultiplicityField/types}/package.json +1 -1
- package/MultiplicityField/types.d.ts +19 -0
- package/MultiplicityField/types.js.map +7 -0
- package/Questions/Questions/index.js +44 -53
- package/Questions/Questions.js.map +7 -0
- package/Questions/Questions.stories/index.js +10 -5
- package/Questions/Questions.stories.d.ts +1 -1
- package/Questions/Questions.stories.js.map +7 -0
- package/Questions/QuestionsContext/index.js +9 -9
- package/Questions/QuestionsContext.js.map +7 -0
- package/Questions/Step/ReviewStep/index.js +35 -47
- package/Questions/Step/ReviewStep.js.map +7 -0
- package/Questions/Step/Step/index.js +39 -47
- package/Questions/Step/Step.js.map +7 -0
- package/Questions/Step/StepArrayReview/index.js +41 -45
- package/Questions/Step/StepArrayReview.js.map +7 -0
- package/Questions/Step/StepContext/index.js +15 -19
- package/Questions/Step/StepContext.js.map +7 -0
- package/Questions/Step/StepDescription/index.js +22 -22
- package/Questions/Step/StepDescription.js.map +7 -0
- package/Questions/Step/StepForm/index.js +33 -43
- package/Questions/Step/StepForm.js.map +7 -0
- package/Questions/Step/StepQuote/index.js +10 -9
- package/Questions/Step/StepQuote.js.map +7 -0
- package/Questions/Step/StepTitle/index.js +40 -38
- package/Questions/Step/StepTitle.d.ts +1 -0
- package/Questions/Step/StepTitle.js.map +7 -0
- package/Questions/Step/getAddMoreFields/index.js +28 -20
- package/Questions/Step/getAddMoreFields.js.map +7 -0
- package/Questions/Step/index.d.ts +0 -1
- package/Questions/Step/index.js +16 -13
- package/Questions/Step/index.js.map +7 -0
- package/Questions/Step/types/index.js +1 -1
- package/Questions/Step/types.d.ts +2 -0
- package/Questions/Step/types.js.map +7 -0
- package/Questions/__stories__/Default/index.js +106 -100
- package/Questions/__stories__/Default.d.ts +2 -2
- package/Questions/__stories__/Default.js.map +7 -0
- package/Questions/getNextStep/index.js +12 -10
- package/Questions/getNextStep.js.map +7 -0
- package/Questions/index.js +7 -3
- package/Questions/index.js.map +7 -0
- package/Questions/index.test.d.ts +1 -0
- package/Questions/types/index.js +1 -1
- package/Questions/types.d.ts +2 -0
- package/Questions/types.js.map +7 -0
- package/cjs/Field/FieldBase/index.js +135 -82
- package/cjs/Field/FieldBase.js.map +7 -0
- package/cjs/Field/FieldBaseContainer/index.js +61 -43
- package/cjs/Field/FieldBaseContainer.js.map +7 -0
- package/cjs/Field/FieldConditional/index.js +107 -59
- package/cjs/Field/FieldConditional.js.map +7 -0
- package/cjs/Field/index.js +128 -72
- package/cjs/Field/index.js.map +7 -0
- package/cjs/Field/types/index.js +16 -5
- package/cjs/Field/types.js.map +7 -0
- package/cjs/Field/utils/calculateField/index.js +50 -0
- package/cjs/Field/utils/calculateField.js.map +7 -0
- package/cjs/Field/utils/evaluateFieldWithConditions/index.js +49 -0
- package/cjs/Field/utils/evaluateFieldWithConditions.js.map +7 -0
- package/cjs/Field/utils/index.js +69 -141
- package/cjs/Field/utils/index.js.map +7 -0
- package/cjs/Field/utils/useField/index.js +74 -0
- package/cjs/Field/utils/useField.js.map +7 -0
- package/cjs/FieldArray/FieldArray.stories/index.js +46 -36
- package/cjs/FieldArray/FieldArray.stories.js.map +7 -0
- package/cjs/FieldArray/__stories__/Default/index.js +119 -89
- package/cjs/FieldArray/__stories__/Default.js.map +7 -0
- package/cjs/FieldArray/__stories__/WithExactLength/index.js +119 -89
- package/cjs/FieldArray/__stories__/WithExactLength.js.map +7 -0
- package/cjs/FieldArray/index.js +104 -65
- package/cjs/FieldArray/index.js.map +7 -0
- package/cjs/FieldObject/index.js +95 -61
- package/cjs/FieldObject/index.js.map +7 -0
- package/cjs/Fieldset/FieldsetWithContext/index.js +54 -40
- package/cjs/Fieldset/FieldsetWithContext.js.map +7 -0
- package/cjs/Fieldset/index.js +61 -39
- package/cjs/Fieldset/index.js.map +7 -0
- package/cjs/Fieldset/types/index.js +16 -5
- package/cjs/Fieldset/types.js.map +7 -0
- package/cjs/Form.stories/index.js +25 -8
- package/cjs/Form.stories.js.map +7 -0
- package/cjs/FormBuilder/FormBuilder.stories/index.js +43 -24
- package/cjs/FormBuilder/FormBuilder.stories.js.map +7 -0
- package/cjs/FormBuilder/__stories__/Default/index.js +60 -31
- package/cjs/FormBuilder/__stories__/Default.js.map +7 -0
- package/cjs/FormBuilder/index.js +33 -7
- package/cjs/FormBuilder/index.js.map +7 -0
- package/cjs/FormContext/index.js +29 -8
- package/cjs/FormContext.js.map +7 -0
- package/cjs/MultiplicityField/MultiplicityField.stories/index.js +58 -84
- package/cjs/MultiplicityField/MultiplicityField.stories.js.map +7 -0
- package/cjs/MultiplicityField/__stories__/Default/index.js +122 -94
- package/cjs/MultiplicityField/__stories__/Default.js.map +7 -0
- package/cjs/MultiplicityField/__stories__/PreviewDisplay/index.js +85 -81
- package/cjs/MultiplicityField/__stories__/PreviewDisplay.js.map +7 -0
- package/cjs/MultiplicityField/__stories__/WithExactLength/index.js +119 -89
- package/cjs/MultiplicityField/__stories__/WithExactLength.js.map +7 -0
- package/cjs/MultiplicityField/__stories__/WithMaxLength/index.js +122 -92
- package/cjs/MultiplicityField/__stories__/WithMaxLength.js.map +7 -0
- package/cjs/MultiplicityField/__stories__/WithMinAndMaxLength/index.js +123 -93
- package/cjs/MultiplicityField/__stories__/WithMinAndMaxLength.js.map +7 -0
- package/cjs/MultiplicityField/__stories__/WithMinLength/index.js +122 -92
- package/cjs/MultiplicityField/__stories__/WithMinLength.js.map +7 -0
- package/cjs/MultiplicityField/add-objects/index.js +160 -138
- package/cjs/MultiplicityField/add-objects.js.map +7 -0
- package/cjs/MultiplicityField/index.js +142 -115
- package/cjs/MultiplicityField/index.js.map +7 -0
- package/cjs/MultiplicityField/types/index.js +16 -0
- package/cjs/MultiplicityField/types.js.map +7 -0
- package/cjs/Questions/Questions/index.js +76 -62
- package/cjs/Questions/Questions.js.map +7 -0
- package/cjs/Questions/Questions.stories/index.js +43 -24
- package/cjs/Questions/Questions.stories.js.map +7 -0
- package/cjs/Questions/QuestionsContext/index.js +31 -14
- package/cjs/Questions/QuestionsContext.js.map +7 -0
- package/cjs/Questions/Step/ReviewStep/index.js +61 -56
- package/cjs/Questions/Step/ReviewStep.js.map +7 -0
- package/cjs/Questions/Step/Step/index.js +71 -56
- package/cjs/Questions/Step/Step.js.map +7 -0
- package/cjs/Questions/Step/StepArrayReview/index.js +65 -54
- package/cjs/Questions/Step/StepArrayReview.js.map +7 -0
- package/cjs/Questions/Step/StepContext/index.js +37 -24
- package/cjs/Questions/Step/StepContext.js.map +7 -0
- package/cjs/Questions/Step/StepDescription/index.js +55 -31
- package/cjs/Questions/Step/StepDescription.js.map +7 -0
- package/cjs/Questions/Step/StepForm/index.js +65 -52
- package/cjs/Questions/Step/StepForm.js.map +7 -0
- package/cjs/Questions/Step/StepQuote/index.js +42 -15
- package/cjs/Questions/Step/StepQuote.js.map +7 -0
- package/cjs/Questions/Step/StepTitle/index.js +72 -47
- package/cjs/Questions/Step/StepTitle.js.map +7 -0
- package/cjs/Questions/Step/getAddMoreFields/index.js +50 -25
- package/cjs/Questions/Step/getAddMoreFields.js.map +7 -0
- package/cjs/Questions/Step/index.js +59 -143
- package/cjs/Questions/Step/index.js.map +7 -0
- package/cjs/Questions/Step/types/index.js +16 -5
- package/cjs/Questions/Step/types.js.map +7 -0
- package/cjs/Questions/__stories__/Default/index.js +132 -109
- package/cjs/Questions/__stories__/Default.js.map +7 -0
- package/cjs/Questions/getNextStep/index.js +33 -14
- package/cjs/Questions/getNextStep.js.map +7 -0
- package/cjs/Questions/index.js +29 -19
- package/cjs/Questions/index.js.map +7 -0
- package/cjs/Questions/types/index.js +16 -5
- package/cjs/Questions/types.js.map +7 -0
- package/cjs/index.js +190 -19
- package/cjs/index.js.map +7 -0
- package/cjs/inputs/AutoCompleteInput/AutoComplete.stories/index.js +46 -24
- package/cjs/inputs/AutoCompleteInput/AutoComplete.stories.js.map +7 -0
- package/cjs/inputs/AutoCompleteInput/__stories__/Default/index.js +78 -51
- package/cjs/inputs/AutoCompleteInput/__stories__/Default.js.map +7 -0
- package/cjs/inputs/AutoCompleteInput/__stories__/Multiple/index.js +84 -0
- package/cjs/inputs/AutoCompleteInput/__stories__/Multiple.js.map +7 -0
- package/cjs/inputs/AutoCompleteInput/index.js +89 -46
- package/cjs/inputs/AutoCompleteInput/index.js.map +7 -0
- package/cjs/inputs/Checkboxes/Checkboxes.stories/index.js +49 -48
- package/cjs/inputs/Checkboxes/Checkboxes.stories.js.map +7 -0
- package/cjs/inputs/Checkboxes/__stories__/Conditional/index.js +120 -89
- package/cjs/inputs/Checkboxes/__stories__/Conditional.js.map +7 -0
- package/cjs/inputs/Checkboxes/__stories__/Default/index.js +73 -46
- package/cjs/inputs/Checkboxes/__stories__/Default.js.map +7 -0
- package/cjs/inputs/Checkboxes/__stories__/WithDivider/index.js +74 -47
- package/cjs/inputs/Checkboxes/__stories__/WithDivider.js.map +7 -0
- package/cjs/inputs/Checkboxes/index.js +102 -96
- package/cjs/inputs/Checkboxes/index.js.map +7 -0
- package/cjs/inputs/DateInput/DateInput.stories/index.js +43 -24
- package/cjs/inputs/DateInput/DateInput.stories.js.map +7 -0
- package/cjs/inputs/DateInput/__stories__/Default/index.js +56 -28
- package/cjs/inputs/DateInput/__stories__/Default.js.map +7 -0
- package/cjs/inputs/DateInput/index.js +122 -109
- package/cjs/inputs/DateInput/index.js.map +7 -0
- package/cjs/inputs/FileInput/FileInput.stories/index.js +43 -24
- package/cjs/inputs/FileInput/FileInput.stories.js.map +7 -0
- package/cjs/inputs/FileInput/__stories__/Default/index.js +57 -26
- package/cjs/inputs/FileInput/__stories__/Default.js.map +7 -0
- package/cjs/inputs/FileInput/index.js +76 -63
- package/cjs/inputs/FileInput/index.js.map +7 -0
- package/cjs/inputs/ImageInput/ImageInput.stories/index.js +49 -48
- package/cjs/inputs/ImageInput/ImageInput.stories.js.map +7 -0
- package/cjs/inputs/ImageInput/__stories__/Default/index.js +58 -33
- package/cjs/inputs/ImageInput/__stories__/Default.js.map +7 -0
- package/cjs/inputs/ImageInput/__stories__/WithInvalidImageDimension/index.js +65 -40
- package/cjs/inputs/ImageInput/__stories__/WithInvalidImageDimension.js.map +7 -0
- package/cjs/inputs/ImageInput/__stories__/WithInvalidImageSize/index.js +62 -37
- package/cjs/inputs/ImageInput/__stories__/WithInvalidImageSize.js.map +7 -0
- package/cjs/inputs/ImageInput/index.js +90 -83
- package/cjs/inputs/ImageInput/index.js.map +7 -0
- package/cjs/inputs/Input/Input.stories/index.js +70 -132
- package/cjs/inputs/Input/Input.stories.js.map +7 -0
- package/cjs/inputs/Input/__stories__/AFM/index.js +60 -29
- package/cjs/inputs/Input/__stories__/AFM.js.map +7 -0
- package/cjs/inputs/Input/__stories__/Boolean/index.js +61 -30
- package/cjs/inputs/Input/__stories__/Boolean.js.map +7 -0
- package/cjs/inputs/Input/__stories__/IBAN/index.js +61 -30
- package/cjs/inputs/Input/__stories__/IBAN.js.map +7 -0
- package/cjs/inputs/Input/__stories__/Integer/index.js +75 -38
- package/cjs/inputs/Input/__stories__/Integer.js.map +7 -0
- package/cjs/inputs/Input/__stories__/LandlineNumber/index.js +64 -33
- package/cjs/inputs/Input/__stories__/LandlineNumber.js.map +7 -0
- package/cjs/inputs/Input/__stories__/MobilePhone/index.js +64 -33
- package/cjs/inputs/Input/__stories__/MobilePhone.js.map +7 -0
- package/cjs/inputs/Input/__stories__/PhoneNumber/index.js +63 -32
- package/cjs/inputs/Input/__stories__/PhoneNumber.js.map +7 -0
- package/cjs/inputs/Input/__stories__/PostalCode/index.js +60 -31
- package/cjs/inputs/Input/__stories__/PostalCode.js.map +7 -0
- package/cjs/inputs/Input/__stories__/String/index.js +64 -0
- package/cjs/inputs/Input/__stories__/String.js.map +7 -0
- package/cjs/inputs/Input/__stories__/TextWithLimit/index.js +64 -0
- package/cjs/inputs/Input/__stories__/TextWithLimit.js.map +7 -0
- package/cjs/inputs/Input/index.js +86 -72
- package/cjs/inputs/Input/index.js.map +7 -0
- package/cjs/inputs/Input/inputsInputScenarios/index.js +439 -0
- package/cjs/inputs/Input/inputsInputScenarios.js.map +7 -0
- package/cjs/inputs/Label/Label.stories/index.js +43 -24
- package/cjs/inputs/Label/Label.stories.js.map +7 -0
- package/cjs/inputs/Label/__stories__/Default/index.js +68 -33
- package/cjs/inputs/Label/__stories__/Default.js.map +7 -0
- package/cjs/inputs/Label/index.js +45 -24
- package/cjs/inputs/Label/index.js.map +7 -0
- package/cjs/inputs/OtpInput/OtpInput.stories/index.js +43 -24
- package/cjs/inputs/OtpInput/OtpInput.stories.js.map +7 -0
- package/cjs/inputs/OtpInput/__stories__/Default/index.js +59 -34
- package/cjs/inputs/OtpInput/__stories__/Default.js.map +7 -0
- package/cjs/inputs/OtpInput/index.js +142 -112
- package/cjs/inputs/OtpInput/index.js.map +7 -0
- package/cjs/inputs/Radio/Radio.stories/index.js +49 -48
- package/cjs/inputs/Radio/Radio.stories.js.map +7 -0
- package/cjs/inputs/Radio/__stories__/Conditional/index.js +120 -89
- package/cjs/inputs/Radio/__stories__/Conditional.js.map +7 -0
- package/cjs/inputs/Radio/__stories__/Default/index.js +77 -51
- package/cjs/inputs/Radio/__stories__/Default.js.map +7 -0
- package/cjs/inputs/Radio/__stories__/WithDivider/index.js +78 -52
- package/cjs/inputs/Radio/__stories__/WithDivider.js.map +7 -0
- package/cjs/inputs/Radio/index.js +84 -61
- package/cjs/inputs/Radio/index.js.map +7 -0
- package/cjs/inputs/Select/Select.stories/index.js +43 -24
- package/cjs/inputs/Select/Select.stories.js.map +7 -0
- package/cjs/inputs/Select/__stories__/Default/index.js +82 -57
- package/cjs/inputs/Select/__stories__/Default.js.map +7 -0
- package/cjs/inputs/Select/index.js +55 -36
- package/cjs/inputs/Select/index.js.map +7 -0
- package/cjs/inputs/index.js +62 -69
- package/cjs/inputs/index.js.map +7 -0
- package/cjs/inputs/inputsScenarios/index.js +540 -0
- package/cjs/inputs/inputsScenarios.js.map +7 -0
- package/cjs/internal/index.js +36 -346
- package/cjs/internal.js.map +7 -0
- package/cjs/lazy/index.js +94 -516
- package/cjs/lazy.js.map +7 -0
- package/cjs/locales/el/index.js +35 -0
- package/cjs/locales/el.js.map +7 -0
- package/cjs/registry/index.js +180 -142
- package/cjs/registry.js.map +7 -0
- package/cjs/types/index.js +22 -5
- package/cjs/types.js.map +7 -0
- package/cjs/utils/index.js +78 -83
- package/cjs/utils.js.map +7 -0
- package/cjs/validators/index.js +130 -128
- package/cjs/validators/index.js.map +7 -0
- package/cjs/validators/types/index.js +16 -5
- package/cjs/validators/types.js.map +7 -0
- package/cjs/validators/utils/afm/index.js +38 -21
- package/cjs/validators/utils/afm.js.map +7 -0
- package/cjs/validators/utils/file/index.js +44 -47
- package/cjs/validators/utils/file.js.map +7 -0
- package/cjs/validators/utils/iban/index.js +36 -17
- package/cjs/validators/utils/iban.js.map +7 -0
- package/cjs/validators/utils/image/index.js +88 -112
- package/cjs/validators/utils/image.js.map +7 -0
- package/cjs/validators/utils/index.js +95 -159
- package/cjs/validators/utils/index.js.map +7 -0
- package/cjs/validators/utils/int/index.js +34 -12
- package/cjs/validators/utils/int.js.map +7 -0
- package/cjs/validators/utils/number/index.js +33 -11
- package/cjs/validators/utils/number.js.map +7 -0
- package/cjs/validators/utils/otp/index.js +35 -13
- package/cjs/validators/utils/otp.js.map +7 -0
- package/cjs/validators/utils/phone/index.js +113 -58
- package/cjs/validators/utils/phone.js.map +7 -0
- package/cjs/validators/utils/postal_code/index.js +36 -16
- package/cjs/validators/utils/postal_code.js.map +7 -0
- package/cjs/validators/utils/text_limit/index.js +40 -25
- package/cjs/validators/utils/text_limit.js.map +7 -0
- package/cjs/validators/utils/uuid4/index.js +34 -13
- package/cjs/validators/utils/uuid4.js.map +7 -0
- package/index.d.ts +7 -1
- package/index.js +156 -4
- package/index.js.map +7 -0
- package/inputs/AutoCompleteInput/AutoComplete.stories/index.js +12 -5
- package/inputs/AutoCompleteInput/AutoComplete.stories.d.ts +2 -1
- package/inputs/AutoCompleteInput/AutoComplete.stories.js.map +7 -0
- package/inputs/AutoCompleteInput/__stories__/Default/index.js +46 -42
- package/inputs/AutoCompleteInput/__stories__/Default.d.ts +3 -2
- package/inputs/AutoCompleteInput/__stories__/Default.js.map +7 -0
- package/inputs/AutoCompleteInput/__stories__/Multiple/index.js +51 -0
- package/inputs/AutoCompleteInput/__stories__/Multiple/package.json +6 -0
- package/inputs/AutoCompleteInput/__stories__/Multiple.d.ts +3 -0
- package/inputs/AutoCompleteInput/__stories__/Multiple.js.map +7 -0
- package/inputs/AutoCompleteInput/index.d.ts +1 -1
- package/inputs/AutoCompleteInput/index.js +57 -37
- package/inputs/AutoCompleteInput/index.js.map +7 -0
- package/inputs/AutoCompleteInput/index.test.d.ts +1 -0
- package/inputs/Checkboxes/Checkboxes.stories/index.js +14 -7
- package/inputs/Checkboxes/Checkboxes.stories.d.ts +3 -3
- package/inputs/Checkboxes/Checkboxes.stories.js.map +7 -0
- package/inputs/Checkboxes/__stories__/Conditional/index.js +88 -80
- package/inputs/Checkboxes/__stories__/Conditional.d.ts +3 -2
- package/inputs/Checkboxes/__stories__/Conditional.js.map +7 -0
- package/inputs/Checkboxes/__stories__/Default/index.js +40 -36
- package/inputs/Checkboxes/__stories__/Default.d.ts +2 -2
- package/inputs/Checkboxes/__stories__/Default.js.map +7 -0
- package/inputs/Checkboxes/__stories__/WithDivider/index.js +41 -37
- package/inputs/Checkboxes/__stories__/WithDivider.d.ts +2 -2
- package/inputs/Checkboxes/__stories__/WithDivider.js.map +7 -0
- package/inputs/Checkboxes/index.d.ts +1 -0
- package/inputs/Checkboxes/index.js +70 -87
- package/inputs/Checkboxes/index.js.map +7 -0
- package/inputs/Checkboxes/index.test.d.ts +1 -0
- package/inputs/DateInput/DateInput.stories/index.js +10 -5
- package/inputs/DateInput/DateInput.stories.d.ts +1 -1
- package/inputs/DateInput/DateInput.stories.js.map +7 -0
- package/inputs/DateInput/__stories__/Default/index.js +23 -18
- package/inputs/DateInput/__stories__/Default.d.ts +2 -2
- package/inputs/DateInput/__stories__/Default.js.map +7 -0
- package/inputs/DateInput/index.d.ts +2 -2
- package/inputs/DateInput/index.js +89 -99
- package/inputs/DateInput/index.js.map +7 -0
- package/inputs/DateInput/index.test.d.ts +1 -0
- package/inputs/FileInput/FileInput.stories/index.js +10 -5
- package/inputs/FileInput/FileInput.stories.d.ts +1 -1
- package/inputs/FileInput/FileInput.stories.js.map +7 -0
- package/inputs/FileInput/__stories__/Default/index.js +24 -16
- package/inputs/FileInput/__stories__/Default.d.ts +2 -2
- package/inputs/FileInput/__stories__/Default.js.map +7 -0
- package/inputs/FileInput/index.js +44 -54
- package/inputs/FileInput/index.js.map +7 -0
- package/inputs/FileInput/index.test.d.ts +1 -0
- package/inputs/ImageInput/ImageInput.stories/index.js +14 -7
- package/inputs/ImageInput/ImageInput.stories.d.ts +3 -3
- package/inputs/ImageInput/ImageInput.stories.js.map +7 -0
- package/inputs/ImageInput/__stories__/Default/index.js +25 -23
- package/inputs/ImageInput/__stories__/Default.d.ts +2 -2
- package/inputs/ImageInput/__stories__/Default.js.map +7 -0
- package/inputs/ImageInput/__stories__/WithInvalidImageDimension/index.js +32 -30
- package/inputs/ImageInput/__stories__/WithInvalidImageDimension.d.ts +2 -2
- package/inputs/ImageInput/__stories__/WithInvalidImageDimension.js.map +7 -0
- package/inputs/ImageInput/__stories__/WithInvalidImageSize/index.js +29 -27
- package/inputs/ImageInput/__stories__/WithInvalidImageSize.d.ts +2 -2
- package/inputs/ImageInput/__stories__/WithInvalidImageSize.js.map +7 -0
- package/inputs/ImageInput/index.js +58 -75
- package/inputs/ImageInput/index.js.map +7 -0
- package/inputs/ImageInput/index.test.d.ts +1 -0
- package/inputs/Input/Input.stories/index.js +28 -14
- package/inputs/Input/Input.stories.d.ts +10 -10
- package/inputs/Input/Input.stories.js.map +7 -0
- package/inputs/Input/__stories__/AFM/index.js +27 -19
- package/inputs/Input/__stories__/AFM.d.ts +2 -2
- package/inputs/Input/__stories__/AFM.js.map +7 -0
- package/inputs/Input/__stories__/Boolean/index.js +28 -20
- package/inputs/Input/__stories__/Boolean.d.ts +2 -2
- package/inputs/Input/__stories__/Boolean.js.map +7 -0
- package/inputs/Input/__stories__/IBAN/index.js +28 -20
- package/inputs/Input/__stories__/IBAN.d.ts +2 -2
- package/inputs/Input/__stories__/IBAN.js.map +7 -0
- package/inputs/Input/__stories__/Integer/index.js +43 -29
- package/inputs/Input/__stories__/Integer.d.ts +2 -2
- package/inputs/Input/__stories__/Integer.js.map +7 -0
- package/inputs/Input/__stories__/LandlineNumber/index.js +31 -23
- package/inputs/Input/__stories__/LandlineNumber.d.ts +2 -2
- package/inputs/Input/__stories__/LandlineNumber.js.map +7 -0
- package/inputs/Input/__stories__/MobilePhone/index.js +31 -23
- package/inputs/Input/__stories__/MobilePhone.d.ts +2 -2
- package/inputs/Input/__stories__/MobilePhone.js.map +7 -0
- package/inputs/Input/__stories__/PhoneNumber/index.js +30 -22
- package/inputs/Input/__stories__/PhoneNumber.d.ts +2 -2
- package/inputs/Input/__stories__/PhoneNumber.js.map +7 -0
- package/inputs/Input/__stories__/PostalCode/index.js +27 -21
- package/inputs/Input/__stories__/PostalCode.d.ts +2 -2
- package/inputs/Input/__stories__/PostalCode.js.map +7 -0
- package/inputs/Input/__stories__/String/index.js +31 -0
- package/inputs/Input/__stories__/String/package.json +6 -0
- package/inputs/Input/__stories__/String.d.ts +3 -0
- package/inputs/Input/__stories__/String.js.map +7 -0
- package/inputs/Input/__stories__/TextWithLimit/index.js +31 -0
- package/inputs/Input/__stories__/TextWithLimit/package.json +6 -0
- package/inputs/Input/__stories__/TextWithLimit.d.ts +3 -0
- package/inputs/Input/__stories__/TextWithLimit.js.map +7 -0
- package/inputs/Input/index.js +55 -67
- package/inputs/Input/index.js.map +7 -0
- package/inputs/Input/index.test.d.ts +1 -0
- package/inputs/Input/inputsInputScenarios/index.js +406 -0
- package/inputs/Input/inputsInputScenarios/package.json +6 -0
- package/inputs/Input/inputsInputScenarios.d.ts +57 -0
- package/inputs/Input/inputsInputScenarios.js.map +7 -0
- package/inputs/Label/Label.stories/index.js +10 -5
- package/inputs/Label/Label.stories.d.ts +1 -1
- package/inputs/Label/Label.stories.js.map +7 -0
- package/inputs/Label/__stories__/Default/index.js +35 -23
- package/inputs/Label/__stories__/Default.d.ts +2 -2
- package/inputs/Label/__stories__/Default.js.map +7 -0
- package/inputs/Label/index.d.ts +1 -1
- package/inputs/Label/index.js +12 -17
- package/inputs/Label/index.js.map +7 -0
- package/inputs/Label/index.test.d.ts +1 -0
- package/inputs/OtpInput/OtpInput.stories/index.js +10 -5
- package/inputs/OtpInput/OtpInput.stories.d.ts +1 -1
- package/inputs/OtpInput/OtpInput.stories.js.map +7 -0
- package/inputs/OtpInput/__stories__/Default/index.js +26 -24
- package/inputs/OtpInput/__stories__/Default.d.ts +2 -2
- package/inputs/OtpInput/__stories__/Default.js.map +7 -0
- package/inputs/OtpInput/index.d.ts +9 -2
- package/inputs/OtpInput/index.js +109 -103
- package/inputs/OtpInput/index.js.map +7 -0
- package/inputs/OtpInput/index.test.d.ts +1 -0
- package/inputs/Radio/Radio.stories/index.js +14 -7
- package/inputs/Radio/Radio.stories.d.ts +3 -3
- package/inputs/Radio/Radio.stories.js.map +7 -0
- package/inputs/Radio/__stories__/Conditional/index.js +88 -80
- package/inputs/Radio/__stories__/Conditional.d.ts +3 -2
- package/inputs/Radio/__stories__/Conditional.js.map +7 -0
- package/inputs/Radio/__stories__/Default/index.js +44 -41
- package/inputs/Radio/__stories__/Default.d.ts +2 -2
- package/inputs/Radio/__stories__/Default.js.map +7 -0
- package/inputs/Radio/__stories__/WithDivider/index.js +45 -42
- package/inputs/Radio/__stories__/WithDivider.d.ts +2 -2
- package/inputs/Radio/__stories__/WithDivider.js.map +7 -0
- package/inputs/Radio/index.d.ts +1 -0
- package/inputs/Radio/index.js +52 -55
- package/inputs/Radio/index.js.map +7 -0
- package/inputs/Radio/index.test.d.ts +1 -0
- package/inputs/Select/Select.stories/index.js +10 -5
- package/inputs/Select/Select.stories.d.ts +1 -1
- package/inputs/Select/Select.stories.js.map +7 -0
- package/inputs/Select/__stories__/Default/index.js +49 -47
- package/inputs/Select/__stories__/Default.d.ts +2 -2
- package/inputs/Select/__stories__/Default.js.map +7 -0
- package/inputs/Select/index.js +24 -31
- package/inputs/Select/index.js.map +7 -0
- package/inputs/Select/index.test.d.ts +1 -0
- package/inputs/index.js +21 -9
- package/inputs/index.js.map +7 -0
- package/inputs/inputsScenarios/index.js +506 -0
- package/inputs/inputsScenarios/package.json +6 -0
- package/inputs/inputsScenarios.d.ts +338 -0
- package/inputs/inputsScenarios.js.map +7 -0
- package/internal/index.js +10 -34
- package/internal.d.ts +2 -31
- package/internal.js.map +7 -0
- package/lazy/index.js +66 -395
- package/lazy.d.ts +33 -30
- package/lazy.js.map +7 -0
- package/locales/el/index.js +6 -0
- package/{Questions/index.spec → locales/el}/package.json +1 -1
- package/locales/el.d.ts +2 -0
- package/locales/el.js.map +7 -0
- package/package.json +7 -8
- package/registry/index.js +152 -134
- package/registry.d.ts +7 -1
- package/registry.js.map +7 -0
- package/src/Field/FieldBase.tsx +2 -0
- package/src/Field/FieldConditional.tsx +1 -1
- package/src/Field/index.tsx +19 -3
- package/src/Field/types.tsx +64 -3
- package/src/Field/utils/calculateField.ts +49 -0
- package/src/Field/utils/evaluateFieldWithConditions.ts +30 -0
- package/src/Field/utils/index.ts +59 -0
- package/src/Field/utils/useField.ts +54 -0
- package/src/FieldArray/FieldArray.stories.js +2 -2
- package/src/FieldArray/index.test.tsx +24 -0
- package/src/FieldArray/index.tsx +11 -3
- package/src/FieldObject/index.tsx +10 -3
- package/src/Fieldset/types.tsx +3 -1
- package/src/FormBuilder/FormBuilder.stories.js +1 -1
- package/src/FormBuilder/index.test.tsx +20 -0
- package/src/FormBuilder/index.tsx +7 -2
- package/src/FormBuilder/scenarios.test.tsx +1864 -0
- package/src/MultiplicityField/MultiplicityField.stories.js +6 -6
- package/src/MultiplicityField/__stories__/PreviewDisplay.tsx +2 -2
- package/src/MultiplicityField/__stories__/WithExactLength.tsx +1 -1
- package/src/MultiplicityField/__stories__/WithMaxLength.tsx +1 -1
- package/src/MultiplicityField/__stories__/WithMinAndMaxLength.tsx +1 -1
- package/src/MultiplicityField/__stories__/WithMinLength.tsx +1 -1
- package/src/MultiplicityField/add-objects.tsx +23 -9
- package/src/MultiplicityField/index.test.tsx +40 -0
- package/src/MultiplicityField/index.tsx +9 -26
- package/src/MultiplicityField/types.ts +22 -0
- package/src/Questions/Questions.stories.js +1 -1
- package/src/Questions/Step/StepTitle.tsx +1 -0
- package/src/Questions/Step/index.ts +0 -1
- package/src/Questions/Step/types.tsx +1 -0
- package/src/Questions/__snapshots__/index.spec.tsx.snap +67 -586
- package/src/Questions/index.mdx +4 -4
- package/src/Questions/index.spec.tsx +3 -3
- package/src/Questions/index.test.tsx +20 -0
- package/src/Questions/types.tsx +1 -0
- package/src/{FormBuilder/FormBuilder.tsx → index.tsx} +21 -9
- package/src/inputs/AutoCompleteInput/AutoComplete.stories.js +2 -1
- package/src/inputs/AutoCompleteInput/__stories__/Default.tsx +27 -18
- package/src/inputs/AutoCompleteInput/__stories__/Multiple.tsx +54 -0
- package/src/inputs/AutoCompleteInput/index.mdx +29 -0
- package/src/inputs/AutoCompleteInput/index.test.tsx +24 -0
- package/src/inputs/AutoCompleteInput/index.tsx +25 -14
- package/src/inputs/Checkboxes/Checkboxes.stories.js +3 -3
- package/src/inputs/Checkboxes/__stories__/Conditional.tsx +2 -3
- package/src/inputs/Checkboxes/index.mdx +33 -0
- package/src/inputs/Checkboxes/index.test.tsx +29 -0
- package/src/inputs/Checkboxes/index.tsx +30 -27
- package/src/inputs/DateInput/DateInput.stories.js +1 -1
- package/src/inputs/DateInput/__stories__/Default.tsx +21 -15
- package/src/inputs/DateInput/index.mdx +23 -0
- package/src/inputs/DateInput/index.test.tsx +20 -0
- package/src/inputs/DateInput/index.tsx +3 -3
- package/src/inputs/FileInput/FileInput.stories.js +1 -1
- package/src/inputs/FileInput/index.mdx +19 -0
- package/src/inputs/FileInput/index.test.tsx +20 -0
- package/src/inputs/ImageInput/ImageInput.stories.js +3 -3
- package/src/inputs/ImageInput/index.mdx +19 -0
- package/src/inputs/ImageInput/index.test.tsx +28 -0
- package/src/inputs/Input/Input.stories.js +10 -10
- package/src/inputs/Input/__stories__/{Default.tsx → String.tsx} +2 -2
- package/src/inputs/Input/__stories__/{TextWithCharacterLimit.tsx → TextWithLimit.tsx} +2 -2
- package/src/inputs/Input/index.mdx +90 -3
- package/src/inputs/Input/index.test.tsx +56 -0
- package/src/inputs/Input/inputsInputScenarios.ts +405 -0
- package/src/inputs/Label/Label.stories.js +1 -1
- package/src/inputs/Label/__stories__/Default.tsx +3 -1
- package/src/inputs/Label/index.test.tsx +20 -0
- package/src/inputs/Label/index.tsx +1 -4
- package/src/inputs/OtpInput/OtpInput.stories.js +1 -1
- package/src/inputs/OtpInput/index.mdx +23 -0
- package/src/inputs/OtpInput/index.test.tsx +20 -0
- package/src/inputs/OtpInput/index.tsx +2 -2
- package/src/inputs/Radio/Radio.stories.js +3 -3
- package/src/inputs/Radio/__stories__/Conditional.tsx +2 -0
- package/src/inputs/Radio/index.mdx +33 -0
- package/src/inputs/Radio/index.test.tsx +28 -0
- package/src/inputs/Radio/index.tsx +6 -3
- package/src/inputs/Select/Select.stories.js +1 -1
- package/src/inputs/Select/index.mdx +17 -0
- package/src/inputs/Select/index.test.tsx +20 -0
- package/src/inputs/inputsScenarios.ts +503 -0
- package/src/internal.ts +2 -31
- package/src/lazy.js +18 -15
- package/src/locales/el.ts +3 -0
- package/src/registry.js +14 -2
- package/src/types.tsx +9 -63
- package/src/utils.ts +34 -33
- package/src/validators/index.ts +5 -0
- package/src/validators/utils/file.ts +9 -9
- package/src/validators/utils/phone.ts +62 -71
- package/src/validators/validators.spec.ts +3 -37
- package/types/index.js +2 -1
- package/types.d.ts +4 -33
- package/types.js.map +7 -0
- package/utils/index.js +56 -77
- package/utils.js.map +7 -0
- package/validators/index.js +101 -110
- package/validators/index.js.map +7 -0
- package/validators/types/index.js +1 -1
- package/validators/types.js.map +7 -0
- package/validators/utils/afm/index.js +16 -16
- package/validators/utils/afm.js.map +7 -0
- package/validators/utils/file/index.js +22 -42
- package/validators/utils/file.js.map +7 -0
- package/validators/utils/iban/index.js +14 -12
- package/validators/utils/iban.js.map +7 -0
- package/validators/utils/image/index.js +66 -106
- package/validators/utils/image.js.map +7 -0
- package/validators/utils/index.js +54 -48
- package/validators/utils/index.js.map +7 -0
- package/validators/utils/int/index.js +12 -7
- package/validators/utils/int.js.map +7 -0
- package/validators/utils/number/index.js +11 -6
- package/validators/utils/number.js.map +7 -0
- package/validators/utils/otp/index.js +13 -8
- package/validators/utils/otp.js.map +7 -0
- package/validators/utils/phone/index.js +89 -51
- package/validators/utils/phone.js.map +7 -0
- package/validators/utils/postal_code/index.js +14 -11
- package/validators/utils/postal_code.js.map +7 -0
- package/validators/utils/text_limit/index.js +18 -20
- package/validators/utils/text_limit.js.map +7 -0
- package/validators/utils/uuid4/index.js +12 -8
- package/validators/utils/uuid4.js.map +7 -0
- package/Field/index.mdx +0 -6
- package/Field/utils.d.ts +0 -5
- package/FieldArray/FieldArray.stories.playwright.json +0 -353
- package/FormBuilder/FormBuilder/index.js +0 -152
- package/FormBuilder/FormBuilder.d.ts +0 -5
- package/FormBuilder/FormBuilder.mdx +0 -256
- package/FormBuilder/FormBuilder.stories.playwright.json +0 -52
- package/MultiplicityField/MultiplicityField.mdx +0 -590
- package/MultiplicityField/MultiplicityField.stories.playwright.json +0 -1370
- package/Questions/__snapshots__/index.spec.tsx.snap +0 -596
- package/Questions/index.mdx +0 -415
- package/Questions/index.spec/index.js +0 -59
- package/cjs/Field/index.mdx +0 -6
- package/cjs/FieldArray/FieldArray.stories.playwright.json +0 -353
- package/cjs/FormBuilder/FormBuilder/index.js +0 -162
- package/cjs/FormBuilder/FormBuilder.mdx +0 -256
- package/cjs/FormBuilder/FormBuilder.stories.playwright.json +0 -52
- package/cjs/MultiplicityField/MultiplicityField.mdx +0 -590
- package/cjs/MultiplicityField/MultiplicityField.stories.playwright.json +0 -1370
- package/cjs/Questions/__snapshots__/index.spec.tsx.snap +0 -596
- package/cjs/Questions/index.mdx +0 -415
- package/cjs/Questions/index.spec/index.js +0 -63
- package/cjs/create-simple-form.mdx +0 -539
- package/cjs/index.mdx +0 -51
- package/cjs/inputs/Checkboxes/Checkboxes.stories.playwright.json +0 -85
- package/cjs/inputs/Checkboxes/index.mdx +0 -0
- package/cjs/inputs/DateInput/DateInput.stories.playwright.json +0 -72
- package/cjs/inputs/FileInput/FileInput.stories.playwright.json +0 -75
- package/cjs/inputs/ImageInput/ImageInput.stories.playwright.json +0 -77
- package/cjs/inputs/Input/Input.stories.playwright.json +0 -376
- package/cjs/inputs/Input/__stories__/Default/index.js +0 -33
- package/cjs/inputs/Input/__stories__/TextWithCharacterLimit/index.js +0 -39
- package/cjs/inputs/Input/index.mdx +0 -8
- package/cjs/inputs/Label/Label.stories.playwright.json +0 -40
- package/cjs/inputs/Label/index.mdx +0 -0
- package/cjs/inputs/Radio/Radio.stories.playwright.json +0 -73
- package/cjs/inputs/Radio/index.mdx +0 -0
- package/cjs/inputs/Select/Select.stories.playwright.json +0 -22
- package/cjs/installation.mdx +0 -68
- package/cjs/validators/validators.spec/index.js +0 -87
- package/create-simple-form.mdx +0 -539
- package/index.mdx +0 -51
- package/inputs/Checkboxes/Checkboxes.stories.playwright.json +0 -85
- package/inputs/Checkboxes/index.mdx +0 -0
- package/inputs/DateInput/DateInput.stories.playwright.json +0 -72
- package/inputs/FileInput/FileInput.stories.playwright.json +0 -75
- package/inputs/ImageInput/ImageInput.stories.playwright.json +0 -77
- package/inputs/Input/Input.stories.playwright.json +0 -376
- package/inputs/Input/__stories__/Default/index.js +0 -23
- package/inputs/Input/__stories__/Default.d.ts +0 -3
- package/inputs/Input/__stories__/TextWithCharacterLimit/index.js +0 -29
- package/inputs/Input/__stories__/TextWithCharacterLimit/package.json +0 -6
- package/inputs/Input/__stories__/TextWithCharacterLimit.d.ts +0 -3
- package/inputs/Input/index.mdx +0 -8
- package/inputs/Label/Label.stories.playwright.json +0 -40
- package/inputs/Label/index.mdx +0 -0
- package/inputs/Radio/Radio.stories.playwright.json +0 -73
- package/inputs/Radio/index.mdx +0 -0
- package/inputs/Select/Select.stories.playwright.json +0 -22
- package/installation.mdx +0 -68
- package/src/Field/utils.ts +0 -191
- package/src/FieldArray/FieldArray.stories.playwright.json +0 -353
- package/src/FormBuilder/FormBuilder.stories.playwright.json +0 -52
- package/src/MultiplicityField/MultiplicityField.stories.playwright.json +0 -1370
- package/src/index.ts +0 -3
- package/src/inputs/Checkboxes/Checkboxes.stories.playwright.json +0 -85
- package/src/inputs/DateInput/DateInput.stories.playwright.json +0 -72
- package/src/inputs/FileInput/FileInput.stories.playwright.json +0 -75
- package/src/inputs/ImageInput/ImageInput.stories.playwright.json +0 -77
- package/src/inputs/Input/Input.stories.playwright.json +0 -376
- package/src/inputs/Label/Label.stories.playwright.json +0 -40
- package/src/inputs/Radio/Radio.stories.playwright.json +0 -73
- package/src/inputs/Select/Select.stories.playwright.json +0 -22
- package/validators/validators.spec/index.js +0 -85
package/src/registry.js
CHANGED
|
@@ -4,13 +4,15 @@ import * as _digigov_form_Field_FieldBaseContainer from '@digigov/form/Field/Fie
|
|
|
4
4
|
import * as _digigov_form_Field_FieldConditional from '@digigov/form/Field/FieldConditional';
|
|
5
5
|
import * as _digigov_form_Field from '@digigov/form/Field';
|
|
6
6
|
import * as _digigov_form_Field_types from '@digigov/form/Field/types';
|
|
7
|
+
import * as _digigov_form_Field_utils_calculateField from '@digigov/form/Field/utils/calculateField';
|
|
8
|
+
import * as _digigov_form_Field_utils_evaluateFieldWithConditions from '@digigov/form/Field/utils/evaluateFieldWithConditions';
|
|
7
9
|
import * as _digigov_form_Field_utils from '@digigov/form/Field/utils';
|
|
10
|
+
import * as _digigov_form_Field_utils_useField from '@digigov/form/Field/utils/useField';
|
|
8
11
|
import * as _digigov_form_FieldArray from '@digigov/form/FieldArray';
|
|
9
12
|
import * as _digigov_form_FieldObject from '@digigov/form/FieldObject';
|
|
10
13
|
import * as _digigov_form_Fieldset_FieldsetWithContext from '@digigov/form/Fieldset/FieldsetWithContext';
|
|
11
14
|
import * as _digigov_form_Fieldset from '@digigov/form/Fieldset';
|
|
12
15
|
import * as _digigov_form_Fieldset_types from '@digigov/form/Fieldset/types';
|
|
13
|
-
import * as _digigov_form_FormBuilder_FormBuilder from '@digigov/form/FormBuilder/FormBuilder';
|
|
14
16
|
import * as _digigov_form_FormBuilder from '@digigov/form/FormBuilder';
|
|
15
17
|
import * as _digigov_form_FormContext from '@digigov/form/FormContext';
|
|
16
18
|
import * as _digigov_form from '@digigov/form';
|
|
@@ -21,13 +23,17 @@ import * as _digigov_form_inputs_FileInput from '@digigov/form/inputs/FileInput'
|
|
|
21
23
|
import * as _digigov_form_inputs_ImageInput from '@digigov/form/inputs/ImageInput';
|
|
22
24
|
import * as _digigov_form_inputs from '@digigov/form/inputs';
|
|
23
25
|
import * as _digigov_form_inputs_Input from '@digigov/form/inputs/Input';
|
|
26
|
+
import * as _digigov_form_inputs_Input_inputsInputScenarios from '@digigov/form/inputs/Input/inputsInputScenarios';
|
|
27
|
+
import * as _digigov_form_inputs_inputsScenarios from '@digigov/form/inputs/inputsScenarios';
|
|
24
28
|
import * as _digigov_form_inputs_Label from '@digigov/form/inputs/Label';
|
|
25
29
|
import * as _digigov_form_inputs_OtpInput from '@digigov/form/inputs/OtpInput';
|
|
26
30
|
import * as _digigov_form_inputs_Radio from '@digigov/form/inputs/Radio';
|
|
27
31
|
import * as _digigov_form_inputs_Select from '@digigov/form/inputs/Select';
|
|
28
32
|
import * as _digigov_form_internal from '@digigov/form/internal';
|
|
33
|
+
import * as _digigov_form_locales_el from '@digigov/form/locales/el';
|
|
29
34
|
import * as _digigov_form_MultiplicityField_add_objects from '@digigov/form/MultiplicityField/add-objects';
|
|
30
35
|
import * as _digigov_form_MultiplicityField from '@digigov/form/MultiplicityField';
|
|
36
|
+
import * as _digigov_form_MultiplicityField_types from '@digigov/form/MultiplicityField/types';
|
|
31
37
|
import * as _digigov_form_Questions_getNextStep from '@digigov/form/Questions/getNextStep';
|
|
32
38
|
import * as _digigov_form_Questions from '@digigov/form/Questions';
|
|
33
39
|
import * as _digigov_form_Questions_Questions from '@digigov/form/Questions/Questions';
|
|
@@ -85,13 +91,15 @@ export default {
|
|
|
85
91
|
'@digigov/form/Field/FieldConditional': lazyImport(_digigov_form_Field_FieldConditional),
|
|
86
92
|
'@digigov/form/Field': lazyImport(_digigov_form_Field),
|
|
87
93
|
'@digigov/form/Field/types': lazyImport(_digigov_form_Field_types),
|
|
94
|
+
'@digigov/form/Field/utils/calculateField': lazyImport(_digigov_form_Field_utils_calculateField),
|
|
95
|
+
'@digigov/form/Field/utils/evaluateFieldWithConditions': lazyImport(_digigov_form_Field_utils_evaluateFieldWithConditions),
|
|
88
96
|
'@digigov/form/Field/utils': lazyImport(_digigov_form_Field_utils),
|
|
97
|
+
'@digigov/form/Field/utils/useField': lazyImport(_digigov_form_Field_utils_useField),
|
|
89
98
|
'@digigov/form/FieldArray': lazyImport(_digigov_form_FieldArray),
|
|
90
99
|
'@digigov/form/FieldObject': lazyImport(_digigov_form_FieldObject),
|
|
91
100
|
'@digigov/form/Fieldset/FieldsetWithContext': lazyImport(_digigov_form_Fieldset_FieldsetWithContext),
|
|
92
101
|
'@digigov/form/Fieldset': lazyImport(_digigov_form_Fieldset),
|
|
93
102
|
'@digigov/form/Fieldset/types': lazyImport(_digigov_form_Fieldset_types),
|
|
94
|
-
'@digigov/form/FormBuilder/FormBuilder': lazyImport(_digigov_form_FormBuilder_FormBuilder),
|
|
95
103
|
'@digigov/form/FormBuilder': lazyImport(_digigov_form_FormBuilder),
|
|
96
104
|
'@digigov/form/FormContext': lazyImport(_digigov_form_FormContext),
|
|
97
105
|
'@digigov/form': lazyImport(_digigov_form),
|
|
@@ -102,13 +110,17 @@ export default {
|
|
|
102
110
|
'@digigov/form/inputs/ImageInput': lazyImport(_digigov_form_inputs_ImageInput),
|
|
103
111
|
'@digigov/form/inputs': lazyImport(_digigov_form_inputs),
|
|
104
112
|
'@digigov/form/inputs/Input': lazyImport(_digigov_form_inputs_Input),
|
|
113
|
+
'@digigov/form/inputs/Input/inputsInputScenarios': lazyImport(_digigov_form_inputs_Input_inputsInputScenarios),
|
|
114
|
+
'@digigov/form/inputs/inputsScenarios': lazyImport(_digigov_form_inputs_inputsScenarios),
|
|
105
115
|
'@digigov/form/inputs/Label': lazyImport(_digigov_form_inputs_Label),
|
|
106
116
|
'@digigov/form/inputs/OtpInput': lazyImport(_digigov_form_inputs_OtpInput),
|
|
107
117
|
'@digigov/form/inputs/Radio': lazyImport(_digigov_form_inputs_Radio),
|
|
108
118
|
'@digigov/form/inputs/Select': lazyImport(_digigov_form_inputs_Select),
|
|
109
119
|
'@digigov/form/internal': lazyImport(_digigov_form_internal),
|
|
120
|
+
'@digigov/form/locales/el': lazyImport(_digigov_form_locales_el),
|
|
110
121
|
'@digigov/form/MultiplicityField/add-objects': lazyImport(_digigov_form_MultiplicityField_add_objects),
|
|
111
122
|
'@digigov/form/MultiplicityField': lazyImport(_digigov_form_MultiplicityField),
|
|
123
|
+
'@digigov/form/MultiplicityField/types': lazyImport(_digigov_form_MultiplicityField_types),
|
|
112
124
|
'@digigov/form/Questions/getNextStep': lazyImport(_digigov_form_Questions_getNextStep),
|
|
113
125
|
'@digigov/form/Questions': lazyImport(_digigov_form_Questions),
|
|
114
126
|
'@digigov/form/Questions/Questions': lazyImport(_digigov_form_Questions_Questions),
|
package/src/types.tsx
CHANGED
|
@@ -1,70 +1,16 @@
|
|
|
1
1
|
import { UseFormReturn, UseFormProps } from 'react-hook-form';
|
|
2
|
-
import {
|
|
2
|
+
import {
|
|
3
|
+
FieldComponentRegistry,
|
|
4
|
+
FieldLabelProps,
|
|
5
|
+
FieldSpec,
|
|
6
|
+
FormData,
|
|
7
|
+
} from '@digigov/form/Field/types';
|
|
3
8
|
import { ValidatorSchema } from '@digigov/form/validators/types';
|
|
4
|
-
|
|
5
|
-
|
|
9
|
+
export * from '@digigov/form/Field/types';
|
|
6
10
|
export type FieldError = {
|
|
7
11
|
message: string;
|
|
8
12
|
};
|
|
9
13
|
|
|
10
|
-
export type FieldLabelProps = {
|
|
11
|
-
primary?: string;
|
|
12
|
-
secondary?: string;
|
|
13
|
-
};
|
|
14
|
-
|
|
15
|
-
export interface FieldCondition {
|
|
16
|
-
is: string | string[] | number | number[] | boolean | boolean[];
|
|
17
|
-
then?: Partial<FieldSpec>;
|
|
18
|
-
else?: Partial<FieldSpec>;
|
|
19
|
-
}
|
|
20
|
-
export interface FieldSpec {
|
|
21
|
-
key: string; // !TODO rename key to name;
|
|
22
|
-
type?:
|
|
23
|
-
| 'int'
|
|
24
|
-
| 'string'
|
|
25
|
-
| 'text'
|
|
26
|
-
| 'boolean'
|
|
27
|
-
| 'email'
|
|
28
|
-
| 'uuid4'
|
|
29
|
-
| 'choice:multiple'
|
|
30
|
-
| 'choice:single'
|
|
31
|
-
| 'mobile_phone'
|
|
32
|
-
| 'date'
|
|
33
|
-
| 'otp'
|
|
34
|
-
| 'afm'
|
|
35
|
-
| 'iban'
|
|
36
|
-
| 'file'
|
|
37
|
-
| 'image'
|
|
38
|
-
| 'postal_code'
|
|
39
|
-
| 'phone_number'
|
|
40
|
-
| 'array'
|
|
41
|
-
| 'object';
|
|
42
|
-
component?: any;
|
|
43
|
-
maxLength?: number;
|
|
44
|
-
condition?: Record<string, FieldCondition>;
|
|
45
|
-
controlled?: boolean;
|
|
46
|
-
label?: FieldLabelProps;
|
|
47
|
-
extra?: {
|
|
48
|
-
[key: string]: any;
|
|
49
|
-
};
|
|
50
|
-
editable?: boolean;
|
|
51
|
-
required?: boolean;
|
|
52
|
-
enabled?: boolean;
|
|
53
|
-
layout?: Record<
|
|
54
|
-
string,
|
|
55
|
-
| GridProps['xs']
|
|
56
|
-
| GridProps['sm']
|
|
57
|
-
| GridProps['md']
|
|
58
|
-
| GridProps['lg']
|
|
59
|
-
| GridProps['xl']
|
|
60
|
-
>;
|
|
61
|
-
validators?: ValidatorSchema[];
|
|
62
|
-
wrapper?: 'label' | 'fieldset';
|
|
63
|
-
maxWidth?: string;
|
|
64
|
-
maxHeight?: string;
|
|
65
|
-
width?: string;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
14
|
export interface FieldsetSpec {
|
|
69
15
|
key: string;
|
|
70
16
|
fields: string[];
|
|
@@ -72,8 +18,6 @@ export interface FieldsetSpec {
|
|
|
72
18
|
body?: React.ReactNode;
|
|
73
19
|
}
|
|
74
20
|
|
|
75
|
-
export type FormData = UseFormProps['defaultValues'];
|
|
76
|
-
|
|
77
21
|
export interface FormContextProps {
|
|
78
22
|
fieldsetsMap?: Record<string, FieldsetSpec>;
|
|
79
23
|
fieldsMap: Record<string, FieldSpec>;
|
|
@@ -88,9 +32,11 @@ export interface FormContextProps {
|
|
|
88
32
|
unregister: UseFormReturn['unregister'];
|
|
89
33
|
formState: UseFormReturn['formState'];
|
|
90
34
|
reset: UseFormReturn['reset'];
|
|
35
|
+
resetField: UseFormReturn['resetField'];
|
|
91
36
|
registerField: (field: FieldSpec) => void;
|
|
92
37
|
errors: UseFormReturn['formState']['errors'];
|
|
93
38
|
componentRegistry?: FieldComponentRegistry;
|
|
39
|
+
submit: () => Promise<void>;
|
|
94
40
|
}
|
|
95
41
|
|
|
96
42
|
export interface FormBuilderProps {
|
package/src/utils.ts
CHANGED
|
@@ -38,41 +38,42 @@ const parseErrorSchema = (
|
|
|
38
38
|
);
|
|
39
39
|
};
|
|
40
40
|
|
|
41
|
-
export const yupResolver =
|
|
42
|
-
schema: any,
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
41
|
+
export const yupResolver =
|
|
42
|
+
(schema: any, schemaOptions: any = {}, resolverOptions: any = {}) =>
|
|
43
|
+
async (values, context, options) => {
|
|
44
|
+
try {
|
|
45
|
+
if (schemaOptions.context && process.env.NODE_ENV === 'development') {
|
|
46
|
+
// eslint-disable-next-line no-console
|
|
47
|
+
console.warn(
|
|
48
|
+
"You should not used the yup options context. Please, use the 'useForm' context object instead"
|
|
49
|
+
);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
const result = await schema[
|
|
53
|
+
resolverOptions.mode === 'sync' ? 'validateSync' : 'validate'
|
|
54
|
+
](
|
|
55
|
+
values,
|
|
56
|
+
Object.assign({ abortEarly: false }, schemaOptions, { context })
|
|
51
57
|
);
|
|
52
|
-
}
|
|
53
58
|
|
|
54
|
-
|
|
55
|
-
resolverOptions.mode === 'sync' ? 'validateSync' : 'validate'
|
|
56
|
-
](values, Object.assign({ abortEarly: false }, schemaOptions, { context }));
|
|
59
|
+
options.shouldUseNativeValidation && validateFieldsNatively({}, options);
|
|
57
60
|
|
|
58
|
-
|
|
61
|
+
return {
|
|
62
|
+
values: resolverOptions.rawValues ? values : result,
|
|
63
|
+
errors: {},
|
|
64
|
+
};
|
|
65
|
+
} catch (e) {
|
|
66
|
+
if (!e.inner) {
|
|
67
|
+
throw e;
|
|
68
|
+
}
|
|
59
69
|
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
70
|
+
const parsed = parseErrorSchema(
|
|
71
|
+
e,
|
|
72
|
+
!options.shouldUseNativeValidation && options.criteriaMode === 'all'
|
|
73
|
+
);
|
|
74
|
+
return {
|
|
75
|
+
values: {},
|
|
76
|
+
errors: parsed,
|
|
77
|
+
};
|
|
67
78
|
}
|
|
68
|
-
|
|
69
|
-
const parsed = parseErrorSchema(
|
|
70
|
-
e,
|
|
71
|
-
!options.shouldUseNativeValidation && options.criteriaMode === 'all'
|
|
72
|
-
);
|
|
73
|
-
return {
|
|
74
|
-
values: {},
|
|
75
|
-
errors: parsed,
|
|
76
|
-
};
|
|
77
|
-
}
|
|
78
|
-
};
|
|
79
|
+
};
|
package/src/validators/index.ts
CHANGED
|
@@ -97,6 +97,11 @@ export const getYUPTypeMap = (): Record<string, any> => {
|
|
|
97
97
|
return yup.array().of(yup.string());
|
|
98
98
|
}
|
|
99
99
|
},
|
|
100
|
+
number: (): MixedSchema =>
|
|
101
|
+
yup
|
|
102
|
+
.mixed()
|
|
103
|
+
.transform((_, val) => (val !== '' ? Number(val) : null))
|
|
104
|
+
.test(NUMBER_VALIDATOR()),
|
|
100
105
|
int: (): MixedSchema =>
|
|
101
106
|
yup
|
|
102
107
|
.mixed()
|
|
@@ -5,17 +5,17 @@ const DEFAULT_FILE_MAX_SIZE = 10000000;
|
|
|
5
5
|
|
|
6
6
|
export const FILE_MAX_SIZE_VALIDATOR = (field: FieldSpec): ValidatorSchema => ({
|
|
7
7
|
name: 'file-max-size-validator',
|
|
8
|
-
message:
|
|
8
|
+
message: {
|
|
9
|
+
key: 'form.error.file_size',
|
|
10
|
+
context: {
|
|
11
|
+
maxSizeToMb: (field?.extra?.limit.maxSize || DEFAULT_FILE_MAX_SIZE) / 1000000,
|
|
12
|
+
},
|
|
13
|
+
},
|
|
9
14
|
test: (value: File[]): boolean => {
|
|
10
|
-
if (
|
|
11
|
-
for (const file of value) {
|
|
12
|
-
if (file.size >= field.extra.limit.maxSize) {
|
|
13
|
-
return false;
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
} else if (value) {
|
|
15
|
+
if (value) {
|
|
17
16
|
for (const file of value) {
|
|
18
|
-
|
|
17
|
+
const maxSize = field?.extra?.limit?.maxSize || DEFAULT_FILE_MAX_SIZE
|
|
18
|
+
if (file.size > maxSize) {
|
|
19
19
|
return false;
|
|
20
20
|
}
|
|
21
21
|
}
|
|
@@ -4,20 +4,20 @@ import { ValidatorSchema } from '@digigov/form/validators/types';
|
|
|
4
4
|
export type PhoneNumberType = 'landline' | 'mobile' | null;
|
|
5
5
|
// add more countries from here libphonenumber-js/metadata.full.json
|
|
6
6
|
const countryPhoneData = {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
7
|
+
GR: [
|
|
8
|
+
'30',
|
|
9
|
+
'00',
|
|
10
|
+
'5005000\\d{3}|8\\d{9,11}|(?:[269]\\d|70)\\d{8}',
|
|
11
11
|
[10, 11, 12],
|
|
12
12
|
[
|
|
13
|
-
[
|
|
13
|
+
['(\\d{2})(\\d{4})(\\d{4})', '$1 $2 $3', ['21|7']],
|
|
14
14
|
[
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
[
|
|
15
|
+
'(\\d{4})(\\d{6})',
|
|
16
|
+
'$1 $2',
|
|
17
|
+
['2(?:2|3[2-57-9]|4[2-469]|5[2-59]|6[2-9]|7[2-69]|8[2-49])|5'],
|
|
18
18
|
],
|
|
19
|
-
[
|
|
20
|
-
[
|
|
19
|
+
['(\\d{3})(\\d{3})(\\d{4})', '$1 $2 $3', ['[2689]']],
|
|
20
|
+
['(\\d{3})(\\d{3,4})(\\d{5})', '$1 $2 $3', ['8']],
|
|
21
21
|
],
|
|
22
22
|
0,
|
|
23
23
|
0,
|
|
@@ -27,93 +27,77 @@ const countryPhoneData = {
|
|
|
27
27
|
0,
|
|
28
28
|
[
|
|
29
29
|
[
|
|
30
|
-
|
|
31
|
-
[10]
|
|
30
|
+
'2(?:1\\d\\d|2(?:2[1-46-9]|[36][1-8]|4[1-7]|5[1-4]|7[1-5]|[89][1-9])|3(?:1\\d|2[1-57]|[35][1-3]|4[13]|7[1-7]|8[124-6]|9[1-79])|4(?:1\\d|2[1-8]|3[1-4]|4[13-5]|6[1-578]|9[1-5])|5(?:1\\d|[29][1-4]|3[1-5]|4[124]|5[1-6])|6(?:1\\d|[269][1-6]|3[1245]|4[1-7]|5[13-9]|7[14]|8[1-5])|7(?:1\\d|2[1-5]|3[1-6]|4[1-7]|5[1-57]|6[135]|9[125-7])|8(?:1\\d|2[1-5]|[34][1-4]|9[1-57]))\\d{6}',
|
|
31
|
+
[10],
|
|
32
32
|
],
|
|
33
|
-
[
|
|
34
|
-
[
|
|
35
|
-
[
|
|
36
|
-
[
|
|
33
|
+
['68[57-9]\\d{7}|(?:69|94)\\d{8}', [10]],
|
|
34
|
+
['800\\d{7,9}'],
|
|
35
|
+
['90[19]\\d{7}', [10]],
|
|
36
|
+
['70\\d{8}', [10]],
|
|
37
37
|
0,
|
|
38
|
-
[
|
|
38
|
+
['5005000\\d{3}', [10]],
|
|
39
39
|
0,
|
|
40
40
|
0,
|
|
41
|
-
[
|
|
42
|
-
]
|
|
43
|
-
]
|
|
44
|
-
}
|
|
41
|
+
['8(?:0[16]|12|[27]5|50)\\d{7}', [10]],
|
|
42
|
+
],
|
|
43
|
+
],
|
|
44
|
+
};
|
|
45
45
|
|
|
46
46
|
function expandPhoneNumberStructure(compressed) {
|
|
47
47
|
const countries = Object.keys(compressed);
|
|
48
|
-
const expanded: any = {}
|
|
48
|
+
const expanded: any = {};
|
|
49
49
|
for (const country of countries) {
|
|
50
50
|
expanded[country] = {
|
|
51
51
|
fixedLine: {
|
|
52
52
|
possibleLengths: {
|
|
53
|
-
_national:
|
|
54
|
-
compressed[country][3].map(
|
|
55
|
-
String
|
|
56
|
-
),
|
|
53
|
+
_national: compressed[country][3].map(String),
|
|
57
54
|
},
|
|
58
|
-
nationalNumberPattern:
|
|
59
|
-
compressed[country][11][0][0],
|
|
55
|
+
nationalNumberPattern: compressed[country][11][0][0],
|
|
60
56
|
},
|
|
61
57
|
mobile: {
|
|
62
|
-
nationalNumberPattern:
|
|
63
|
-
compressed[country][11][1][0],
|
|
58
|
+
nationalNumberPattern: compressed[country][11][1][0],
|
|
64
59
|
},
|
|
65
60
|
tollFree: {
|
|
66
|
-
nationalNumberPattern:
|
|
67
|
-
compressed[country][11][2][0],
|
|
61
|
+
nationalNumberPattern: compressed[country][11][2][0],
|
|
68
62
|
},
|
|
69
63
|
premiumRate: {
|
|
70
|
-
nationalNumberPattern:
|
|
71
|
-
compressed[country][11][3][0],
|
|
64
|
+
nationalNumberPattern: compressed[country][11][3][0],
|
|
72
65
|
},
|
|
73
66
|
sharedCost: {
|
|
74
|
-
nationalNumberPattern:
|
|
75
|
-
compressed[country][11][9][0],
|
|
67
|
+
nationalNumberPattern: compressed[country][11][9][0],
|
|
76
68
|
},
|
|
77
69
|
personalNumber: {
|
|
78
|
-
nationalNumberPattern:
|
|
79
|
-
compressed[country][11][4][0],
|
|
70
|
+
nationalNumberPattern: compressed[country][11][4][0],
|
|
80
71
|
},
|
|
81
72
|
uan: {
|
|
82
|
-
nationalNumberPattern:
|
|
83
|
-
compressed[country][11][6][0],
|
|
73
|
+
nationalNumberPattern: compressed[country][11][6][0],
|
|
84
74
|
},
|
|
85
75
|
id: country,
|
|
86
|
-
countryCode:
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
compressed[country][1],
|
|
90
|
-
|
|
91
|
-
}
|
|
76
|
+
countryCode: compressed[country][0],
|
|
77
|
+
internationalPrefix: compressed[country][1],
|
|
78
|
+
};
|
|
92
79
|
}
|
|
93
80
|
return expanded;
|
|
94
81
|
}
|
|
95
82
|
const PHONENUMBER_SPEC = expandPhoneNumberStructure(countryPhoneData);
|
|
96
|
-
export function discoverPhoneType(
|
|
97
|
-
phoneNumber: string,
|
|
98
|
-
config: any
|
|
99
|
-
): string {
|
|
83
|
+
export function discoverPhoneType(phoneNumber: string, config: any): string {
|
|
100
84
|
const cleanNumber = phoneNumber
|
|
101
|
-
.replace(/\D/g,
|
|
102
|
-
.replace(/\s/g,
|
|
103
|
-
.replace(/^\+/,
|
|
104
|
-
.replace(new RegExp(
|
|
105
|
-
.replace(new RegExp(
|
|
85
|
+
.replace(/\D/g, '')
|
|
86
|
+
.replace(/\s/g, '')
|
|
87
|
+
.replace(/^\+/, '')
|
|
88
|
+
.replace(new RegExp('^' + config.internationalPrefix, ''), '')
|
|
89
|
+
.replace(new RegExp('^' + config.countryCode, ''), '');
|
|
106
90
|
const categories = {
|
|
107
|
-
|
|
91
|
+
landline: config.fixedLine,
|
|
108
92
|
mobile: config.mobile,
|
|
109
|
-
|
|
110
|
-
|
|
93
|
+
'toll-free': config.tollFree,
|
|
94
|
+
'premium-rate': config.premiumRate,
|
|
111
95
|
};
|
|
112
96
|
|
|
113
97
|
for (const [categoryName, categoryDetails] of Object.entries(categories)) {
|
|
114
98
|
const pattern = new RegExp(
|
|
115
|
-
|
|
116
|
-
|
|
99
|
+
'^(' + categoryDetails.nationalNumberPattern.replace(/\s/g, '') + ')$',
|
|
100
|
+
''
|
|
117
101
|
);
|
|
118
102
|
if (cleanNumber.match(pattern)) {
|
|
119
103
|
return categoryName; // Returns the category name if the number matches the pattern
|
|
@@ -121,32 +105,36 @@ export function discoverPhoneType(
|
|
|
121
105
|
}
|
|
122
106
|
|
|
123
107
|
// If no category matches, return 'Unknown'
|
|
124
|
-
return
|
|
108
|
+
return 'unknown';
|
|
125
109
|
}
|
|
126
110
|
function getNumberType(phoneNumber: string, country: string) {
|
|
127
111
|
const spec = PHONENUMBER_SPEC[country.toUpperCase()];
|
|
128
|
-
if(!spec) {
|
|
112
|
+
if (!spec) {
|
|
129
113
|
throw new Error(`Country ${country} is not supported`);
|
|
130
114
|
}
|
|
131
115
|
const type = discoverPhoneType(phoneNumber, spec);
|
|
132
116
|
return type;
|
|
133
117
|
}
|
|
134
118
|
|
|
135
|
-
function isPhoneNumberValid(
|
|
119
|
+
function isPhoneNumberValid(
|
|
120
|
+
phoneNumber: string,
|
|
121
|
+
countries: string[],
|
|
122
|
+
types = ['mobile', 'landline']
|
|
123
|
+
) {
|
|
136
124
|
return countries.some((country) => {
|
|
137
125
|
const numberType = getNumberType(phoneNumber, country);
|
|
138
126
|
if (numberType && types.includes(numberType)) {
|
|
139
|
-
return true
|
|
127
|
+
return true;
|
|
140
128
|
}
|
|
141
|
-
return false
|
|
142
|
-
})
|
|
129
|
+
return false;
|
|
130
|
+
});
|
|
143
131
|
}
|
|
144
132
|
function isNumberOfType(phoneNumber: string, country: string, type: string) {
|
|
145
133
|
const numberType = getNumberType(phoneNumber, country);
|
|
146
134
|
if (numberType === type) {
|
|
147
|
-
return true
|
|
135
|
+
return true;
|
|
148
136
|
}
|
|
149
|
-
return false
|
|
137
|
+
return false;
|
|
150
138
|
}
|
|
151
139
|
export function validatePhoneNumber(
|
|
152
140
|
phoneNumber: string,
|
|
@@ -156,12 +144,15 @@ export function validatePhoneNumber(
|
|
|
156
144
|
if (!countries || countries.length === 0) {
|
|
157
145
|
return true;
|
|
158
146
|
}
|
|
159
|
-
return isPhoneNumberValid(
|
|
147
|
+
return isPhoneNumberValid(
|
|
148
|
+
phoneNumber,
|
|
149
|
+
countries,
|
|
150
|
+
typeOfPhoneNumber ? [typeOfPhoneNumber] : undefined
|
|
151
|
+
);
|
|
160
152
|
}
|
|
161
153
|
|
|
162
|
-
|
|
163
154
|
function validateMobile(value): boolean {
|
|
164
|
-
return isNumberOfType(value, 'gr','mobile');
|
|
155
|
+
return isNumberOfType(value, 'gr', 'mobile');
|
|
165
156
|
}
|
|
166
157
|
|
|
167
158
|
export const MOBILE_PHONE_VALIDATOR = {
|
|
@@ -69,54 +69,20 @@ it('validates phone number type landline with greek country code', () => {
|
|
|
69
69
|
expect(validatePhoneNumber('2102934896', ['GR'], 'landline')).toBe(true);
|
|
70
70
|
});
|
|
71
71
|
|
|
72
|
-
it('
|
|
73
|
-
expect(validatePhoneNumber('2102934896', ['CH'], 'landline')).
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
it('validates phone number type landline with ch and gr countries code', () => {
|
|
77
|
-
expect(validatePhoneNumber('2102934896', ['GR', 'CH'], 'landline')).toBe(
|
|
78
|
-
true
|
|
79
|
-
);
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
it('validatesphone number type landline with ch and gr countries code', () => {
|
|
83
|
-
expect(validatePhoneNumber('41446681800', ['GR', 'CH'], 'landline')).toBe(
|
|
84
|
-
true
|
|
72
|
+
it('throws if given country is not supported', () => {
|
|
73
|
+
expect(() => validatePhoneNumber('2102934896', ['CH'], 'landline')).toThrow(
|
|
74
|
+
'Country CH is not supported'
|
|
85
75
|
);
|
|
86
76
|
});
|
|
87
77
|
|
|
88
|
-
it('validates phone number type landline with ch and gr countries code but phone number is mobile', () => {
|
|
89
|
-
expect(validatePhoneNumber('2102934896', ['GR', 'CH'], 'mobile')).toBe(false);
|
|
90
|
-
});
|
|
91
|
-
|
|
92
|
-
it('validates phone number type mobile with ch and gr countries code', () => {
|
|
93
|
-
expect(validatePhoneNumber('6934100982', ['GR', 'CH'], 'mobile')).toBe(true);
|
|
94
|
-
});
|
|
95
|
-
|
|
96
78
|
it('validates phone number type mobile with gr country code', () => {
|
|
97
79
|
expect(validatePhoneNumber('6934100982', ['GR'], 'mobile')).toBe(true);
|
|
98
80
|
});
|
|
99
81
|
|
|
100
|
-
it('validates phone number type mobile with ch country code', () => {
|
|
101
|
-
expect(validatePhoneNumber('6934100982', ['CH'], 'mobile')).toBe(false);
|
|
102
|
-
});
|
|
103
|
-
|
|
104
|
-
it('validates phone number with no type and ch country code', () => {
|
|
105
|
-
expect(validatePhoneNumber('6934100982', ['CH'], null)).toBe(false);
|
|
106
|
-
});
|
|
107
|
-
|
|
108
82
|
it('validates phone number with no type and gr country code', () => {
|
|
109
83
|
expect(validatePhoneNumber('6934100982', ['gr'], null)).toBe(true);
|
|
110
84
|
});
|
|
111
85
|
|
|
112
|
-
it('validates phone number with no type and ch country code', () => {
|
|
113
|
-
expect(validatePhoneNumber('41446681800', ['CH'], null)).toBe(true);
|
|
114
|
-
});
|
|
115
|
-
|
|
116
86
|
it('validates phone number with no type and gr country code', () => {
|
|
117
87
|
expect(validatePhoneNumber('41446681800', ['gr'], null)).toBe(false);
|
|
118
88
|
});
|
|
119
|
-
|
|
120
|
-
it('validates phone number with no type and gr and ch countries code', () => {
|
|
121
|
-
expect(validatePhoneNumber('41446681800', ['gr', 'ch'], null)).toBe(true);
|
|
122
|
-
});
|
package/types/index.js
CHANGED
|
@@ -1 +1,2 @@
|
|
|
1
|
-
export
|
|
1
|
+
export * from "@digigov/form/Field/types";
|
|
2
|
+
//# sourceMappingURL=types.js.map
|
package/types.d.ts
CHANGED
|
@@ -1,48 +1,17 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
2
|
import { UseFormReturn, UseFormProps } from 'react-hook-form';
|
|
3
|
-
import { FieldComponentRegistry } from '@digigov/form/Field/types';
|
|
3
|
+
import { FieldComponentRegistry, FieldLabelProps, FieldSpec, FormData } from '@digigov/form/Field/types';
|
|
4
4
|
import { ValidatorSchema } from '@digigov/form/validators/types';
|
|
5
|
-
|
|
5
|
+
export * from '@digigov/form/Field/types';
|
|
6
6
|
export type FieldError = {
|
|
7
7
|
message: string;
|
|
8
8
|
};
|
|
9
|
-
export type FieldLabelProps = {
|
|
10
|
-
primary?: string;
|
|
11
|
-
secondary?: string;
|
|
12
|
-
};
|
|
13
|
-
export interface FieldCondition {
|
|
14
|
-
is: string | string[] | number | number[] | boolean | boolean[];
|
|
15
|
-
then?: Partial<FieldSpec>;
|
|
16
|
-
else?: Partial<FieldSpec>;
|
|
17
|
-
}
|
|
18
|
-
export interface FieldSpec {
|
|
19
|
-
key: string;
|
|
20
|
-
type?: 'int' | 'string' | 'text' | 'boolean' | 'email' | 'uuid4' | 'choice:multiple' | 'choice:single' | 'mobile_phone' | 'date' | 'otp' | 'afm' | 'iban' | 'file' | 'image' | 'postal_code' | 'phone_number' | 'array' | 'object';
|
|
21
|
-
component?: any;
|
|
22
|
-
maxLength?: number;
|
|
23
|
-
condition?: Record<string, FieldCondition>;
|
|
24
|
-
controlled?: boolean;
|
|
25
|
-
label?: FieldLabelProps;
|
|
26
|
-
extra?: {
|
|
27
|
-
[key: string]: any;
|
|
28
|
-
};
|
|
29
|
-
editable?: boolean;
|
|
30
|
-
required?: boolean;
|
|
31
|
-
enabled?: boolean;
|
|
32
|
-
layout?: Record<string, GridProps['xs'] | GridProps['sm'] | GridProps['md'] | GridProps['lg'] | GridProps['xl']>;
|
|
33
|
-
validators?: ValidatorSchema[];
|
|
34
|
-
wrapper?: 'label' | 'fieldset';
|
|
35
|
-
maxWidth?: string;
|
|
36
|
-
maxHeight?: string;
|
|
37
|
-
width?: string;
|
|
38
|
-
}
|
|
39
9
|
export interface FieldsetSpec {
|
|
40
10
|
key: string;
|
|
41
11
|
fields: string[];
|
|
42
12
|
label?: FieldLabelProps;
|
|
43
13
|
body?: React.ReactNode;
|
|
44
14
|
}
|
|
45
|
-
export type FormData = UseFormProps['defaultValues'];
|
|
46
15
|
export interface FormContextProps {
|
|
47
16
|
fieldsetsMap?: Record<string, FieldsetSpec>;
|
|
48
17
|
fieldsMap: Record<string, FieldSpec>;
|
|
@@ -57,9 +26,11 @@ export interface FormContextProps {
|
|
|
57
26
|
unregister: UseFormReturn['unregister'];
|
|
58
27
|
formState: UseFormReturn['formState'];
|
|
59
28
|
reset: UseFormReturn['reset'];
|
|
29
|
+
resetField: UseFormReturn['resetField'];
|
|
60
30
|
registerField: (field: FieldSpec) => void;
|
|
61
31
|
errors: UseFormReturn['formState']['errors'];
|
|
62
32
|
componentRegistry?: FieldComponentRegistry;
|
|
33
|
+
submit: () => Promise<void>;
|
|
63
34
|
}
|
|
64
35
|
export interface FormBuilderProps {
|
|
65
36
|
fields?: FieldSpec[];
|
package/types.js.map
ADDED
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 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 type 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}\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
|
+
"mappings": "AAQA,cAAc;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|