@digigov/form 0.6.9 → 0.7.1
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/CHANGELOG.md +24 -1
- package/Field/FieldBase.js +110 -0
- package/Field/{ConditionalField.js → FieldConditional.js} +9 -29
- package/Field/FieldContainer.js +62 -0
- package/Field/index.js +11 -251
- package/Field/types.js +5 -0
- package/Field/utils.js +146 -0
- package/Fieldset/FieldsetWithContext.js +63 -0
- package/Fieldset/index.js +4 -63
- package/Fieldset/types.js +5 -0
- package/FormBuilder.js +178 -0
- package/FormContext.js +14 -0
- package/Questions/Questions.js +105 -0
- package/Questions/QuestionsContext.js +20 -0
- package/Questions/Step/ReviewStep.js +11 -7
- package/Questions/Step/Step.js +93 -0
- package/Questions/Step/StepArrayReview.js +79 -0
- package/Questions/Step/StepContext.js +37 -0
- package/Questions/Step/StepDescription.js +2 -2
- package/Questions/Step/StepForm.js +10 -6
- package/Questions/Step/StepTitle.js +2 -2
- package/Questions/Step/getAddMoreFields.js +31 -0
- package/Questions/Step/index.js +81 -200
- package/Questions/Step/types.js +5 -0
- package/Questions/__snapshots__/index.spec.tsx.snap +461 -2499
- package/Questions/getNextStep.js +30 -0
- package/Questions/index.js +4 -150
- package/Questions/types.js +5 -0
- package/es/Field/FieldBase.js +93 -0
- package/es/Field/{ConditionalField.js → FieldConditional.js} +5 -28
- package/es/Field/FieldContainer.js +40 -0
- package/es/Field/index.js +8 -233
- package/es/Field/types.js +1 -0
- package/es/Field/utils.js +122 -0
- package/es/Fieldset/FieldsetWithContext.js +41 -0
- package/es/Fieldset/index.js +3 -51
- package/es/Fieldset/types.js +1 -0
- package/es/FormBuilder.js +148 -0
- package/es/FormContext.js +5 -0
- package/es/Questions/Questions.js +84 -0
- package/es/Questions/QuestionsContext.js +11 -0
- package/es/Questions/Step/ReviewStep.js +5 -3
- package/es/Questions/Step/Step.js +69 -0
- package/es/Questions/Step/StepArrayReview.js +50 -0
- package/es/Questions/Step/StepContext.js +27 -0
- package/es/Questions/Step/StepDescription.js +1 -1
- package/es/Questions/Step/StepForm.js +4 -2
- package/es/Questions/Step/StepTitle.js +1 -1
- package/es/Questions/Step/getAddMoreFields.js +22 -0
- package/es/Questions/Step/index.js +13 -165
- package/es/Questions/Step/types.js +1 -0
- package/es/Questions/__snapshots__/index.spec.tsx.snap +461 -2499
- package/es/Questions/getNextStep.js +23 -0
- package/es/Questions/index.js +2 -119
- package/es/Questions/index.spec.js +2 -1
- package/es/Questions/types.js +1 -0
- package/es/index.js +2 -153
- package/es/inputs/index.js +5 -4
- package/es/internal.js +31 -0
- package/es/types.js +1 -0
- package/es/utils.js +5 -3
- package/es/validators/index.js +155 -0
- package/es/validators/types.js +1 -0
- package/es/validators/utils/afm.js +35 -0
- package/es/validators/utils/file.js +52 -0
- package/es/validators/utils/iban.js +123 -0
- package/es/validators/utils/index.js +105 -0
- package/es/validators/utils/phone.js +122 -0
- package/es/validators/utils/postal_code.js +29 -0
- package/es/validators/utils/uuid4.js +20 -0
- package/{esm → es/validators}/validators.spec.js +1 -1
- package/esm/Field/FieldBase.js +93 -0
- package/esm/Field/{ConditionalField.js → FieldConditional.js} +5 -28
- package/esm/Field/FieldContainer.js +40 -0
- package/esm/Field/index.js +8 -233
- package/esm/Field/types.js +1 -0
- package/esm/Field/utils.js +122 -0
- package/esm/Fieldset/FieldsetWithContext.js +41 -0
- package/esm/Fieldset/index.js +3 -51
- package/esm/Fieldset/types.js +1 -0
- package/esm/FormBuilder.js +148 -0
- package/esm/FormContext.js +5 -0
- package/esm/Questions/Questions.js +84 -0
- package/esm/Questions/QuestionsContext.js +11 -0
- package/esm/Questions/Step/ReviewStep.js +5 -3
- package/esm/Questions/Step/Step.js +69 -0
- package/esm/Questions/Step/StepArrayReview.js +50 -0
- package/esm/Questions/Step/StepContext.js +27 -0
- package/esm/Questions/Step/StepDescription.js +1 -1
- package/esm/Questions/Step/StepForm.js +4 -2
- package/esm/Questions/Step/StepTitle.js +1 -1
- package/esm/Questions/Step/getAddMoreFields.js +22 -0
- package/esm/Questions/Step/index.js +13 -165
- package/esm/Questions/Step/types.js +1 -0
- package/esm/Questions/__snapshots__/index.spec.tsx.snap +461 -2499
- package/esm/Questions/getNextStep.js +23 -0
- package/esm/Questions/index.js +2 -119
- package/esm/Questions/index.spec.js +2 -1
- package/esm/Questions/types.js +1 -0
- package/esm/index.js +3 -154
- package/esm/inputs/index.js +5 -4
- package/esm/internal.js +31 -0
- package/esm/types.js +1 -0
- package/esm/utils.js +5 -3
- package/esm/validators/index.js +155 -0
- package/esm/validators/types.js +1 -0
- package/esm/validators/utils/afm.js +35 -0
- package/esm/validators/utils/file.js +52 -0
- package/esm/validators/utils/iban.js +123 -0
- package/esm/validators/utils/index.js +105 -0
- package/esm/validators/utils/phone.js +122 -0
- package/esm/validators/utils/postal_code.js +29 -0
- package/esm/validators/utils/uuid4.js +20 -0
- package/{es → esm/validators}/validators.spec.js +1 -1
- package/index.js +8 -191
- package/inputs/index.js +13 -5
- package/internal.js +356 -0
- package/libs/form/src/Field/FieldBase.d.ts +3 -0
- package/libs/form/src/Field/FieldConditional.d.ts +4 -0
- package/libs/form/src/Field/FieldContainer.d.ts +4 -0
- package/libs/form/src/Field/index.d.ts +1 -62
- package/libs/form/src/Field/types.d.ts +75 -0
- package/libs/form/src/Field/utils.d.ts +5 -0
- package/libs/form/src/Fieldset/FieldsetWithContext.d.ts +4 -0
- package/libs/form/src/Fieldset/index.d.ts +2 -12
- package/libs/form/src/Fieldset/types.d.ts +6 -0
- package/libs/form/src/FormBuilder.d.ts +5 -0
- package/libs/form/src/FormContext.d.ts +3 -0
- package/libs/form/src/Questions/Questions.d.ts +8 -0
- package/libs/form/src/Questions/QuestionsContext.d.ts +3 -0
- package/libs/form/src/Questions/Step/ReviewStep.d.ts +1 -0
- package/libs/form/src/Questions/Step/Step.d.ts +9 -0
- package/libs/form/src/Questions/Step/StepArrayReview.d.ts +4 -0
- package/libs/form/src/Questions/Step/StepContext.d.ts +4 -0
- package/libs/form/src/Questions/Step/StepForm.d.ts +2 -1
- package/libs/form/src/Questions/Step/getAddMoreFields.d.ts +3 -0
- package/libs/form/src/Questions/Step/index.d.ts +12 -47
- package/libs/form/src/Questions/Step/types.d.ts +31 -0
- package/libs/form/src/Questions/getNextStep.d.ts +2 -0
- package/libs/form/src/Questions/index.d.ts +1 -28
- package/libs/form/src/Questions/types.d.ts +19 -0
- package/libs/form/src/index.d.ts +2 -73
- package/libs/form/src/inputs/Checkboxes/index.d.ts +1 -1
- package/libs/form/src/inputs/DateInput/index.d.ts +1 -2
- package/libs/form/src/inputs/FileInput/index.d.ts +1 -1
- package/libs/form/src/inputs/Input/index.d.ts +1 -1
- package/libs/form/src/inputs/Label/index.d.ts +2 -1
- package/libs/form/src/inputs/Radio/index.d.ts +1 -1
- package/libs/form/src/inputs/Select/index.d.ts +1 -1
- package/libs/form/src/inputs/index.d.ts +4 -3
- package/libs/form/src/internal.d.ts +31 -0
- package/libs/form/src/types.d.ts +70 -0
- package/libs/form/src/validators/index.d.ts +8 -0
- package/libs/form/src/validators/types.d.ts +2 -0
- package/libs/form/src/validators/utils/afm.d.ts +6 -0
- package/libs/form/src/validators/utils/file.d.ts +1 -0
- package/libs/form/src/validators/utils/iban.d.ts +2 -0
- package/libs/form/src/validators/utils/index.d.ts +12 -0
- package/libs/form/src/validators/utils/phone.d.ts +9 -0
- package/libs/form/src/validators/utils/postal_code.d.ts +2 -0
- package/libs/form/src/validators/utils/uuid4.d.ts +6 -0
- package/libs/form/src/{validators.spec.d.ts → validators/validators.spec.d.ts} +0 -0
- package/libs/ui/src/core/Accordion/index.d.ts +3 -3
- package/libs/ui/src/core/Base/index.d.ts +3 -0
- package/libs/ui/src/core/Blockquote/index.d.ts +1 -1
- package/libs/ui/src/core/Button/BackButton.d.ts +1 -1
- package/libs/ui/src/core/Button/ButtonLink.d.ts +1 -1
- package/libs/ui/src/core/Button/index.d.ts +1 -1
- package/libs/ui/src/core/Divider/index.d.ts +1 -1
- package/libs/ui/src/core/Form/index.d.ts +3 -0
- package/libs/ui/src/core/Label/index.d.ts +4 -0
- package/libs/ui/src/core/Link/index.d.ts +1 -0
- package/libs/ui/src/core/NavList/NavHorizontal.d.ts +3 -0
- package/libs/ui/src/core/NavList/NavHorizontalList.d.ts +3 -0
- package/libs/ui/src/core/NavList/NavHorizontalListItem.d.ts +3 -0
- package/libs/ui/src/core/NavList/NavList.d.ts +1 -14
- package/libs/ui/src/core/NavList/NavListBase.d.ts +4 -0
- package/libs/ui/src/core/NavList/NavListItem.d.ts +1 -0
- package/libs/ui/src/core/NavList/NavListItemBase.d.ts +2 -1
- package/libs/ui/src/core/NavList/NavListSubMenu.d.ts +1 -1
- package/libs/ui/src/core/NavList/NavVertical.d.ts +3 -0
- package/libs/ui/src/core/NavList/NavVerticalItem.d.ts +3 -0
- package/libs/ui/src/core/NavList/index.d.ts +5 -0
- package/libs/ui/src/core/NavList/types.d.ts +14 -0
- package/libs/ui/src/core/SkipLink/index.d.ts +3 -0
- package/libs/ui/src/core/SvgIcon/index.d.ts +1 -0
- package/libs/ui/src/core/Table/TableFloatingScroll.d.ts +2 -0
- package/libs/ui/src/core/Table/index.d.ts +1 -0
- package/libs/ui/src/core/index.d.ts +4 -0
- package/libs/ui/src/layouts/Grid/index.d.ts +1 -0
- package/libs/ui/src/typography/Caption/index.d.ts +3 -2
- package/libs/ui/src/typography/Title/index.d.ts +2 -1
- package/libs-ui/react-core/src/Accordion/index.d.ts +3 -3
- package/libs-ui/react-core/src/AccordionControls/index.d.ts +3 -3
- package/libs-ui/react-core/src/AccordionSection/index.d.ts +3 -3
- package/libs-ui/react-core/src/AccordionSectionContent/index.d.ts +3 -3
- package/libs-ui/react-core/src/AccordionSectionHeader/index.d.ts +3 -3
- package/libs-ui/react-core/src/AccordionSectionSummary/index.d.ts +4 -3
- package/libs-ui/react-core/src/AccordionSectionSummaryHeading/index.d.ts +3 -3
- package/libs-ui/react-core/src/BackLink/index.d.ts +3 -3
- package/libs-ui/react-core/src/Base/index.d.ts +43 -0
- package/libs-ui/react-core/src/Blockquote/index.d.ts +3 -3
- package/libs-ui/react-core/src/Breadcrumbs/index.d.ts +3 -3
- package/libs-ui/react-core/src/BreadcrumbsList/index.d.ts +3 -3
- package/libs-ui/react-core/src/BreadcrumbsListItem/index.d.ts +3 -3
- package/libs-ui/react-core/src/Button/index.d.ts +3 -3
- package/libs-ui/react-core/src/ButtonGroup/index.d.ts +3 -3
- package/libs-ui/react-core/src/ButtonLink/index.d.ts +3 -3
- package/libs-ui/react-core/src/CallToAction/index.d.ts +1 -1
- package/libs-ui/react-core/src/Card/index.d.ts +3 -3
- package/libs-ui/react-core/src/CardAction/index.d.ts +3 -3
- package/libs-ui/react-core/src/CardHeading/index.d.ts +3 -3
- package/libs-ui/react-core/src/CardText/index.d.ts +3 -3
- package/libs-ui/react-core/src/CheckIcon/index.d.ts +15 -0
- package/libs-ui/react-core/src/Checkbox/index.d.ts +3 -3
- package/libs-ui/react-core/src/CheckboxItem/index.d.ts +3 -3
- package/libs-ui/react-core/src/Confirmation/index.d.ts +3 -3
- package/libs-ui/react-core/src/ConfirmationBody/index.d.ts +3 -3
- package/libs-ui/react-core/src/ConfirmationTitle/index.d.ts +3 -3
- package/libs-ui/react-core/src/DateInput/index.d.ts +3 -3
- package/libs-ui/react-core/src/DateInputItem/index.d.ts +3 -3
- package/libs-ui/react-core/src/Details/index.d.ts +3 -3
- package/libs-ui/react-core/src/DetailsContent/index.d.ts +3 -3
- package/libs-ui/react-core/src/DetailsSummary/index.d.ts +3 -3
- package/libs-ui/react-core/src/ErrorMessage/index.d.ts +3 -3
- package/libs-ui/react-core/src/ErrorSummary/index.d.ts +3 -3
- package/libs-ui/react-core/src/Field/index.d.ts +3 -3
- package/libs-ui/react-core/src/Fieldset/index.d.ts +3 -3
- package/libs-ui/react-core/src/FieldsetLegend/index.d.ts +3 -3
- package/libs-ui/react-core/src/FileUpload/index.d.ts +3 -3
- package/libs-ui/react-core/src/Form/index.d.ts +11 -0
- package/libs-ui/react-core/src/Grid/index.d.ts +3 -3
- package/libs-ui/react-core/src/Heading/index.d.ts +3 -3
- package/libs-ui/react-core/src/HeadingCaption/index.d.ts +3 -3
- package/libs-ui/react-core/src/Hidden/index.d.ts +3 -3
- package/libs-ui/react-core/src/Hint/index.d.ts +3 -3
- package/libs-ui/react-core/src/Label/index.d.ts +3 -3
- package/libs-ui/react-core/src/LabelTitle/index.d.ts +7 -7
- package/libs-ui/react-core/src/Link/index.d.ts +3 -3
- package/libs-ui/react-core/src/List/index.d.ts +3 -3
- package/libs-ui/react-core/src/ListItem/index.d.ts +3 -3
- package/libs-ui/react-core/src/NavHorizontal/index.d.ts +16 -0
- package/libs-ui/react-core/src/NavHorizontalList/index.d.ts +10 -0
- package/libs-ui/react-core/src/NavHorizontalListItem/index.d.ts +18 -0
- package/libs-ui/react-core/src/NavVertical/index.d.ts +11 -0
- package/libs-ui/react-core/src/NavVerticalItem/index.d.ts +14 -0
- package/libs-ui/react-core/src/NormalText/index.d.ts +3 -3
- package/libs-ui/react-core/src/NotificationBanner/index.d.ts +3 -3
- package/libs-ui/react-core/src/NotificationBannerContent/index.d.ts +3 -3
- package/libs-ui/react-core/src/NotificationBannerHeader/index.d.ts +3 -3
- package/libs-ui/react-core/src/NotificationBannerHeading/index.d.ts +3 -3
- package/libs-ui/react-core/src/NotificationBannerLink/index.d.ts +3 -3
- package/libs-ui/react-core/src/Paragraph/index.d.ts +3 -3
- package/libs-ui/react-core/src/PhaseBanner/index.d.ts +3 -3
- package/libs-ui/react-core/src/PhaseBannerHeaderContainer/index.d.ts +3 -3
- package/libs-ui/react-core/src/PhaseBannerTag/index.d.ts +3 -3
- package/libs-ui/react-core/src/PhaseBannerText/index.d.ts +3 -3
- package/libs-ui/react-core/src/Radio/index.d.ts +3 -3
- package/libs-ui/react-core/src/RadioItem/index.d.ts +3 -3
- package/libs-ui/react-core/src/SectionBreak/index.d.ts +3 -3
- package/libs-ui/react-core/src/Select/index.d.ts +3 -3
- package/libs-ui/react-core/src/SelectOption/index.d.ts +3 -3
- package/libs-ui/react-core/src/SkipLink/index.d.ts +10 -0
- package/libs-ui/react-core/src/SummaryList/index.d.ts +3 -3
- package/libs-ui/react-core/src/SummaryListItem/index.d.ts +3 -3
- package/libs-ui/react-core/src/SummaryListItemAction/index.d.ts +3 -3
- package/libs-ui/react-core/src/SummaryListItemKey/index.d.ts +3 -3
- package/libs-ui/react-core/src/SummaryListItemValue/index.d.ts +3 -3
- package/libs-ui/react-core/src/SvgIcon/index.d.ts +3 -3
- package/libs-ui/react-core/src/Table/index.d.ts +3 -3
- package/libs-ui/react-core/src/TableBody/index.d.ts +3 -3
- package/libs-ui/react-core/src/TableCaption/index.d.ts +3 -3
- package/libs-ui/react-core/src/TableContainer/index.d.ts +3 -3
- package/libs-ui/react-core/src/TableDataCell/index.d.ts +3 -3
- package/libs-ui/react-core/src/TableHead/index.d.ts +3 -3
- package/libs-ui/react-core/src/TableHeadCell/index.d.ts +3 -3
- package/libs-ui/react-core/src/TableNoDataRow/index.d.ts +3 -3
- package/libs-ui/react-core/src/TableRow/index.d.ts +3 -3
- package/libs-ui/react-core/src/Tabs/index.d.ts +3 -3
- package/libs-ui/react-core/src/TabsHeading/index.d.ts +3 -3
- package/libs-ui/react-core/src/TabsList/index.d.ts +3 -3
- package/libs-ui/react-core/src/TabsListItem/index.d.ts +3 -3
- package/libs-ui/react-core/src/TabsPanel/index.d.ts +3 -3
- package/libs-ui/react-core/src/TextArea/index.d.ts +3 -3
- package/libs-ui/react-core/src/TextInput/index.d.ts +3 -3
- package/libs-ui/react-core/src/UncheckIcon/index.d.ts +4 -4
- package/libs-ui/react-core/src/VisuallyHidden/index.d.ts +3 -3
- package/libs-ui/react-core/src/WarningText/index.d.ts +3 -3
- package/package.json +3 -2
- package/types.js +5 -0
- package/utils.js +6 -4
- package/validators/index.js +181 -0
- package/validators/types.js +5 -0
- package/validators/utils/afm.js +45 -0
- package/validators/utils/file.js +62 -0
- package/validators/utils/iban.js +134 -0
- package/validators/utils/index.js +210 -0
- package/validators/utils/phone.js +144 -0
- package/validators/utils/postal_code.js +40 -0
- package/validators/utils/uuid4.js +30 -0
- package/validators/validators.spec.js +88 -0
- package/es/validators.js +0 -626
- package/esm/validators.js +0 -626
- package/libs/form/src/Field/ConditionalField.d.ts +0 -17
- package/libs/form/src/validators.d.ts +0 -14
- package/validators.js +0 -662
- package/validators.spec.js +0 -88
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
export function getNextStep(currentStep, steps, data) {
|
|
2
|
+
if (currentStep.nextStep) {
|
|
3
|
+
var nextStepName = currentStep.nextStep(data);
|
|
4
|
+
|
|
5
|
+
if (nextStepName) {
|
|
6
|
+
return steps.find(function (step) {
|
|
7
|
+
return step.name === nextStepName;
|
|
8
|
+
});
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
var currentStepIndex = steps.findIndex(function (step) {
|
|
13
|
+
return step.name === currentStep.name;
|
|
14
|
+
});
|
|
15
|
+
var nextStep = steps.slice(currentStepIndex + 1).find(function (step) {
|
|
16
|
+
if (step.show) {
|
|
17
|
+
return step.show(data);
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
return true;
|
|
21
|
+
});
|
|
22
|
+
return nextStep;
|
|
23
|
+
}
|
package/esm/Questions/index.js
CHANGED
|
@@ -1,120 +1,3 @@
|
|
|
1
|
-
import
|
|
2
|
-
import React, { useState, createContext, useEffect } from 'react';
|
|
3
|
-
var isBrowser = typeof window !== 'undefined';
|
|
4
|
-
var defaultStep = {
|
|
5
|
-
name: ''
|
|
6
|
-
};
|
|
7
|
-
export var QuestionsContext = /*#__PURE__*/createContext({
|
|
8
|
-
currentStep: defaultStep,
|
|
9
|
-
steps: [],
|
|
10
|
-
submitStep: function submitStep() {
|
|
11
|
-
return null;
|
|
12
|
-
}
|
|
13
|
-
});
|
|
14
|
-
|
|
15
|
-
function getNextStep(currentStep, steps, data) {
|
|
16
|
-
if (currentStep.nextStep) {
|
|
17
|
-
var nextStepName = currentStep.nextStep(data);
|
|
18
|
-
|
|
19
|
-
if (nextStepName) {
|
|
20
|
-
return steps.find(function (step) {
|
|
21
|
-
return step.name === nextStepName;
|
|
22
|
-
});
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
var currentStepIndex = steps.findIndex(function (step) {
|
|
27
|
-
return step.name === currentStep.name;
|
|
28
|
-
});
|
|
29
|
-
var nextStep = steps.slice(currentStepIndex + 1).find(function (step) {
|
|
30
|
-
if (step.show) {
|
|
31
|
-
return step.show(data);
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
return true;
|
|
35
|
-
});
|
|
36
|
-
return nextStep;
|
|
37
|
-
}
|
|
38
|
-
/**
|
|
39
|
-
* The Question component accepts question data as props
|
|
40
|
-
* uses composable components to provide a wholesome UX
|
|
41
|
-
*
|
|
42
|
-
*/
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
export var Questions = function Questions(_ref) {
|
|
46
|
-
var name = _ref.name,
|
|
47
|
-
steps = _ref.steps,
|
|
48
|
-
_ref$initialData = _ref.initialData,
|
|
49
|
-
initialData = _ref$initialData === void 0 ? {} : _ref$initialData,
|
|
50
|
-
onChange = _ref.onChange,
|
|
51
|
-
onSubmit = _ref.onSubmit,
|
|
52
|
-
onActiveStep = _ref.onActiveStep,
|
|
53
|
-
forceStepName = _ref.forceStepName,
|
|
54
|
-
_ref$localDraft = _ref.localDraft,
|
|
55
|
-
localDraft = _ref$localDraft === void 0 ? false : _ref$localDraft,
|
|
56
|
-
children = _ref.children;
|
|
57
|
-
|
|
58
|
-
var _useState = useState({
|
|
59
|
-
name: ''
|
|
60
|
-
}),
|
|
61
|
-
_useState2 = _slicedToArray(_useState, 2),
|
|
62
|
-
currentStep = _useState2[0],
|
|
63
|
-
setCurrentStep = _useState2[1];
|
|
64
|
-
|
|
65
|
-
useEffect(function () {
|
|
66
|
-
if (!forceStepName) {
|
|
67
|
-
setCurrentStep(steps[0]);
|
|
68
|
-
}
|
|
69
|
-
}, [forceStepName, steps]);
|
|
70
|
-
useEffect(function () {
|
|
71
|
-
if (forceStepName !== currentStep.name) {
|
|
72
|
-
var forceStep = steps.find(function (_ref2) {
|
|
73
|
-
var name = _ref2.name;
|
|
74
|
-
return name === forceStepName;
|
|
75
|
-
});
|
|
76
|
-
forceStep && setCurrentStep(forceStep);
|
|
77
|
-
}
|
|
78
|
-
}, [forceStepName]);
|
|
79
|
-
var localData = isBrowser && localDraft && window.localStorage.getItem("questions-".concat(name));
|
|
80
|
-
|
|
81
|
-
var _useState3 = useState(localData && JSON.parse(localData) || initialData),
|
|
82
|
-
_useState4 = _slicedToArray(_useState3, 2),
|
|
83
|
-
data = _useState4[0],
|
|
84
|
-
setData = _useState4[1];
|
|
85
|
-
|
|
86
|
-
var submitStep = function submitStep(stepName, stepData) {
|
|
87
|
-
data[stepName] = stepData;
|
|
88
|
-
|
|
89
|
-
if (localDraft) {
|
|
90
|
-
isBrowser && window.localStorage.setItem("questions-".concat(name), JSON.stringify(data));
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
if (onChange) {
|
|
94
|
-
onChange && onChange(data);
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
setData(data);
|
|
98
|
-
var nextStep = getNextStep(currentStep, steps, data);
|
|
99
|
-
|
|
100
|
-
if (nextStep) {
|
|
101
|
-
onActiveStep && onActiveStep(nextStep);
|
|
102
|
-
setCurrentStep(nextStep);
|
|
103
|
-
} else {
|
|
104
|
-
onSubmit(data);
|
|
105
|
-
}
|
|
106
|
-
};
|
|
107
|
-
|
|
108
|
-
return /*#__PURE__*/React.createElement(QuestionsContext.Provider, {
|
|
109
|
-
value: {
|
|
110
|
-
steps: steps,
|
|
111
|
-
currentStep: currentStep,
|
|
112
|
-
submitStep: submitStep,
|
|
113
|
-
data: data,
|
|
114
|
-
onActiveStep: onActiveStep
|
|
115
|
-
}
|
|
116
|
-
}, children);
|
|
117
|
-
};
|
|
1
|
+
import { Questions } from '@digigov/form/Questions/Questions';
|
|
118
2
|
export default Questions;
|
|
119
|
-
export * from '@digigov/form/Questions/Step';
|
|
120
|
-
export * from '@digigov/form';
|
|
3
|
+
export * from '@digigov/form/Questions/Step';
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import * as React from 'react';
|
|
2
2
|
import { mount } from 'enzyme';
|
|
3
|
-
import
|
|
3
|
+
import { Step, StepForm, StepQuote, StepTitle } from '@digigov/form/Questions';
|
|
4
|
+
import Questions from '@digigov/form/Questions';
|
|
4
5
|
import { Field } from '@digigov/form';
|
|
5
6
|
var steps = [{
|
|
6
7
|
name: 'intro',
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
package/esm/index.js
CHANGED
|
@@ -1,159 +1,8 @@
|
|
|
1
|
-
/** @license Digigov v0.
|
|
1
|
+
/** @license Digigov v0.7.1
|
|
2
2
|
*
|
|
3
3
|
* This source code is licensed under the BSD-2-Clause license found in the
|
|
4
4
|
* LICENSE file in the root directory of this source tree.
|
|
5
5
|
*/
|
|
6
|
-
|
|
7
|
-
import
|
|
8
|
-
import _extends from "@babel/runtime/helpers/extends";
|
|
9
|
-
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
|
|
10
|
-
var _excluded = ["onSubmit", "children", "registerField", "fieldsMap", "fieldsetsMap", "resolver", "mode", "initial", "reValidateMode", "shouldFocusError", "criteriaMode", "componentRegistry"],
|
|
11
|
-
_excluded2 = ["fields", "fieldsets", "initial", "onSubmit", "children", "reValidateMode", "mode", "shouldFocusError", "criteriaMode", "auto", "validatorRegistry", "componentRegistry"];
|
|
12
|
-
|
|
13
|
-
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
14
|
-
import React, { createContext, useCallback, useRef } from 'react';
|
|
15
|
-
import { useForm } from 'react-hook-form';
|
|
16
|
-
import { yupResolver } from '@digigov/form/utils';
|
|
17
|
-
import Grid from '@digigov/ui/layouts/Grid';
|
|
18
|
-
import { useValidationSchema } from '@digigov/form/validators';
|
|
19
|
-
import Fieldset from '@digigov/form/Fieldset';
|
|
20
|
-
import Field from '@digigov/form/Field';
|
|
21
|
-
export * from '@digigov/form/Fieldset';
|
|
22
|
-
export * from '@digigov/form/Field';
|
|
23
|
-
export var FormContext = /*#__PURE__*/createContext({
|
|
24
|
-
fieldsMap: {},
|
|
25
|
-
fieldsetsMap: {}
|
|
26
|
-
});
|
|
27
|
-
export var FormBase = /*#__PURE__*/React.forwardRef(function FormBase(_ref, ref) {
|
|
28
|
-
var onSubmit = _ref.onSubmit,
|
|
29
|
-
children = _ref.children,
|
|
30
|
-
registerField = _ref.registerField,
|
|
31
|
-
fieldsMap = _ref.fieldsMap,
|
|
32
|
-
fieldsetsMap = _ref.fieldsetsMap,
|
|
33
|
-
resolver = _ref.resolver,
|
|
34
|
-
mode = _ref.mode,
|
|
35
|
-
initial = _ref.initial,
|
|
36
|
-
reValidateMode = _ref.reValidateMode,
|
|
37
|
-
shouldFocusError = _ref.shouldFocusError,
|
|
38
|
-
criteriaMode = _ref.criteriaMode,
|
|
39
|
-
componentRegistry = _ref.componentRegistry,
|
|
40
|
-
props = _objectWithoutProperties(_ref, _excluded);
|
|
41
|
-
|
|
42
|
-
var form = useForm({
|
|
43
|
-
resolver: resolver,
|
|
44
|
-
mode: mode,
|
|
45
|
-
defaultValues: initial,
|
|
46
|
-
reValidateMode: reValidateMode,
|
|
47
|
-
shouldFocusError: shouldFocusError,
|
|
48
|
-
criteriaMode: criteriaMode
|
|
49
|
-
});
|
|
50
|
-
var handleSubmit = useCallback(function (data) {
|
|
51
|
-
var errors = onSubmit && onSubmit(data);
|
|
52
|
-
|
|
53
|
-
if (errors) {
|
|
54
|
-
for (var key in errors) {
|
|
55
|
-
form.setError(key, errors[key]);
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
}, [onSubmit]);
|
|
59
|
-
var ctx = {
|
|
60
|
-
fieldsMap: fieldsMap,
|
|
61
|
-
fieldsetsMap: fieldsetsMap,
|
|
62
|
-
control: form.control,
|
|
63
|
-
register: form.register,
|
|
64
|
-
registerField: registerField,
|
|
65
|
-
errors: form.errors,
|
|
66
|
-
reset: form.reset,
|
|
67
|
-
componentRegistry: componentRegistry
|
|
68
|
-
};
|
|
69
|
-
return /*#__PURE__*/React.createElement(FormContext.Provider, {
|
|
70
|
-
value: ctx
|
|
71
|
-
}, /*#__PURE__*/React.createElement("form", _extends({
|
|
72
|
-
onSubmit: form.handleSubmit(handleSubmit),
|
|
73
|
-
ref: ref
|
|
74
|
-
}, props), /*#__PURE__*/React.createElement(Grid, {
|
|
75
|
-
container: true
|
|
76
|
-
}, /*#__PURE__*/React.createElement(Grid, {
|
|
77
|
-
item: true,
|
|
78
|
-
xs: 12
|
|
79
|
-
}, children))));
|
|
80
|
-
});
|
|
81
|
-
export var FormBuilder = /*#__PURE__*/React.forwardRef(function FormBuilder(_ref2, ref) {
|
|
82
|
-
var _ref2$fields = _ref2.fields,
|
|
83
|
-
fields = _ref2$fields === void 0 ? [] : _ref2$fields,
|
|
84
|
-
fieldsets = _ref2.fieldsets,
|
|
85
|
-
_ref2$initial = _ref2.initial,
|
|
86
|
-
initial = _ref2$initial === void 0 ? {} : _ref2$initial,
|
|
87
|
-
onSubmit = _ref2.onSubmit,
|
|
88
|
-
children = _ref2.children,
|
|
89
|
-
_ref2$reValidateMode = _ref2.reValidateMode,
|
|
90
|
-
reValidateMode = _ref2$reValidateMode === void 0 ? 'onSubmit' : _ref2$reValidateMode,
|
|
91
|
-
_ref2$mode = _ref2.mode,
|
|
92
|
-
mode = _ref2$mode === void 0 ? 'onSubmit' : _ref2$mode,
|
|
93
|
-
_ref2$shouldFocusErro = _ref2.shouldFocusError,
|
|
94
|
-
shouldFocusError = _ref2$shouldFocusErro === void 0 ? true : _ref2$shouldFocusErro,
|
|
95
|
-
_ref2$criteriaMode = _ref2.criteriaMode,
|
|
96
|
-
criteriaMode = _ref2$criteriaMode === void 0 ? 'firstError' : _ref2$criteriaMode,
|
|
97
|
-
_ref2$auto = _ref2.auto,
|
|
98
|
-
auto = _ref2$auto === void 0 ? false : _ref2$auto,
|
|
99
|
-
validatorRegistry = _ref2.validatorRegistry,
|
|
100
|
-
componentRegistry = _ref2.componentRegistry,
|
|
101
|
-
props = _objectWithoutProperties(_ref2, _excluded2);
|
|
102
|
-
|
|
103
|
-
var fieldsState = useRef(fields);
|
|
104
|
-
var setFieldsState = useCallback(function (newFields) {
|
|
105
|
-
fieldsState.current = newFields;
|
|
106
|
-
}, []);
|
|
107
|
-
var schema = useValidationSchema(fieldsState, validatorRegistry);
|
|
108
|
-
var registerField = useCallback(function (field) {
|
|
109
|
-
setFieldsState([].concat(_toConsumableArray(fieldsState.current), [field]));
|
|
110
|
-
}, []);
|
|
111
|
-
var resolver;
|
|
112
|
-
var fieldsMap;
|
|
113
|
-
var fieldsetsMap;
|
|
114
|
-
var fieldChildren;
|
|
115
|
-
|
|
116
|
-
if (schema) {
|
|
117
|
-
resolver = yupResolver(schema);
|
|
118
|
-
fieldsMap = fields ? fields.reduce(function (map, field) {
|
|
119
|
-
return _extends({}, map, _defineProperty({}, field.key, field));
|
|
120
|
-
}, {}) : {};
|
|
121
|
-
fieldsetsMap = fieldsets && fieldsets.reduce(function (map, fieldset) {
|
|
122
|
-
return _extends({}, map, _defineProperty({}, fieldset.key, fieldset));
|
|
123
|
-
}, {});
|
|
124
|
-
|
|
125
|
-
if (auto) {
|
|
126
|
-
if (fieldsets) {
|
|
127
|
-
fieldChildren = fieldsets.map(function (fieldset) {
|
|
128
|
-
return /*#__PURE__*/React.createElement(Fieldset, {
|
|
129
|
-
key: fieldset.key,
|
|
130
|
-
name: fieldset.key
|
|
131
|
-
});
|
|
132
|
-
});
|
|
133
|
-
} else if (fields) {
|
|
134
|
-
fieldChildren = fields.map(function (field) {
|
|
135
|
-
return /*#__PURE__*/React.createElement(Field, {
|
|
136
|
-
key: field.key,
|
|
137
|
-
name: field.key
|
|
138
|
-
});
|
|
139
|
-
});
|
|
140
|
-
}
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
return /*#__PURE__*/React.createElement(FormBase, _extends({
|
|
145
|
-
resolver: resolver,
|
|
146
|
-
fieldsetsMap: fieldsetsMap,
|
|
147
|
-
fieldsMap: fieldsMap,
|
|
148
|
-
registerField: registerField,
|
|
149
|
-
initial: initial,
|
|
150
|
-
reValidateMode: reValidateMode,
|
|
151
|
-
mode: mode,
|
|
152
|
-
shouldFocusError: shouldFocusError,
|
|
153
|
-
criteriaMode: criteriaMode,
|
|
154
|
-
onSubmit: onSubmit,
|
|
155
|
-
componentRegistry: componentRegistry,
|
|
156
|
-
ref: ref
|
|
157
|
-
}, props), fieldChildren, children);
|
|
158
|
-
});
|
|
6
|
+
export * from '@digigov/form/internal';
|
|
7
|
+
import FormBuilder from '@digigov/form/FormBuilder';
|
|
159
8
|
export default FormBuilder;
|
package/esm/inputs/index.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
export { default as FileInput } from '@digigov/form/inputs/FileInput';
|
|
2
|
-
export { default as Select } from '@digigov/form/inputs/Select';
|
|
3
1
|
export { default as Checkboxes } from '@digigov/form/inputs/Checkboxes';
|
|
4
|
-
export { default as
|
|
2
|
+
export { default as DateInput } from '@digigov/form/inputs/DateInput';
|
|
3
|
+
export { default as FileInput } from '@digigov/form/inputs/FileInput';
|
|
5
4
|
export { default as Input } from '@digigov/form/inputs/Input';
|
|
6
|
-
export { default as
|
|
5
|
+
export { default as Label } from '@digigov/form/inputs/Label';
|
|
6
|
+
export { default as Radio } from '@digigov/form/inputs/Radio';
|
|
7
|
+
export { default as Select } from '@digigov/form/inputs/Select';
|
package/esm/internal.js
ADDED
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
export { default as Field } from '@digigov/form/Field';
|
|
2
|
+
export * from '@digigov/form/Field';
|
|
3
|
+
export { default as FieldConditional } from '@digigov/form/Field/FieldConditional';
|
|
4
|
+
export * from '@digigov/form/Field/FieldConditional';
|
|
5
|
+
export { default as Fieldset } from '@digigov/form/Fieldset';
|
|
6
|
+
export * from '@digigov/form/Fieldset';
|
|
7
|
+
export { default as FormBuilder } from '@digigov/form/FormBuilder';
|
|
8
|
+
export * from '@digigov/form/FormBuilder';
|
|
9
|
+
export { Step } from '@digigov/form/Questions/Step';
|
|
10
|
+
export * from '@digigov/form/Questions/Step';
|
|
11
|
+
export { default as Questions } from '@digigov/form/Questions';
|
|
12
|
+
export * from '@digigov/form/Questions';
|
|
13
|
+
export { default as Checkboxes } from '@digigov/form/inputs/Checkboxes';
|
|
14
|
+
export * from '@digigov/form/inputs/Checkboxes';
|
|
15
|
+
export { default as DateInput } from '@digigov/form/inputs/DateInput';
|
|
16
|
+
export * from '@digigov/form/inputs/DateInput';
|
|
17
|
+
export { default as FileInput } from '@digigov/form/inputs/FileInput';
|
|
18
|
+
export * from '@digigov/form/inputs/FileInput';
|
|
19
|
+
export { default as Input } from '@digigov/form/inputs/Input';
|
|
20
|
+
export * from '@digigov/form/inputs/Input';
|
|
21
|
+
export { default as Label } from '@digigov/form/inputs/Label';
|
|
22
|
+
export * from '@digigov/form/inputs/Label';
|
|
23
|
+
export { default as Radio } from '@digigov/form/inputs/Radio';
|
|
24
|
+
export * from '@digigov/form/inputs/Radio';
|
|
25
|
+
export { default as Select } from '@digigov/form/inputs/Select';
|
|
26
|
+
export * from '@digigov/form/inputs/Select';
|
|
27
|
+
export * from '@digigov/form/inputs';
|
|
28
|
+
export * from '@digigov/form/internal';
|
|
29
|
+
export * from '@digigov/form/types';
|
|
30
|
+
export * from '@digigov/form/utils';
|
|
31
|
+
export * from '@digigov/form/validators';
|
package/esm/types.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
package/esm/utils.js
CHANGED
|
@@ -1,9 +1,11 @@
|
|
|
1
|
-
import
|
|
1
|
+
import _typeof from "@babel/runtime/helpers/typeof";
|
|
2
2
|
import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
|
|
3
3
|
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
4
4
|
import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray";
|
|
5
5
|
import _extends from "@babel/runtime/helpers/extends";
|
|
6
6
|
|
|
7
|
+
function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return exports; }; var exports = {}, Op = Object.prototype, hasOwn = Op.hasOwnProperty, $Symbol = "function" == typeof Symbol ? Symbol : {}, iteratorSymbol = $Symbol.iterator || "@@iterator", asyncIteratorSymbol = $Symbol.asyncIterator || "@@asyncIterator", toStringTagSymbol = $Symbol.toStringTag || "@@toStringTag"; function define(obj, key, value) { return Object.defineProperty(obj, key, { value: value, enumerable: !0, configurable: !0, writable: !0 }), obj[key]; } try { define({}, ""); } catch (err) { define = function define(obj, key, value) { return obj[key] = value; }; } function wrap(innerFn, outerFn, self, tryLocsList) { var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator, generator = Object.create(protoGenerator.prototype), context = new Context(tryLocsList || []); return generator._invoke = function (innerFn, self, context) { var state = "suspendedStart"; return function (method, arg) { if ("executing" === state) throw new Error("Generator is already running"); if ("completed" === state) { if ("throw" === method) throw arg; return doneResult(); } for (context.method = method, context.arg = arg;;) { var delegate = context.delegate; if (delegate) { var delegateResult = maybeInvokeDelegate(delegate, context); if (delegateResult) { if (delegateResult === ContinueSentinel) continue; return delegateResult; } } if ("next" === context.method) context.sent = context._sent = context.arg;else if ("throw" === context.method) { if ("suspendedStart" === state) throw state = "completed", context.arg; context.dispatchException(context.arg); } else "return" === context.method && context.abrupt("return", context.arg); state = "executing"; var record = tryCatch(innerFn, self, context); if ("normal" === record.type) { if (state = context.done ? "completed" : "suspendedYield", record.arg === ContinueSentinel) continue; return { value: record.arg, done: context.done }; } "throw" === record.type && (state = "completed", context.method = "throw", context.arg = record.arg); } }; }(innerFn, self, context), generator; } function tryCatch(fn, obj, arg) { try { return { type: "normal", arg: fn.call(obj, arg) }; } catch (err) { return { type: "throw", arg: err }; } } exports.wrap = wrap; var ContinueSentinel = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var IteratorPrototype = {}; define(IteratorPrototype, iteratorSymbol, function () { return this; }); var getProto = Object.getPrototypeOf, NativeIteratorPrototype = getProto && getProto(getProto(values([]))); NativeIteratorPrototype && NativeIteratorPrototype !== Op && hasOwn.call(NativeIteratorPrototype, iteratorSymbol) && (IteratorPrototype = NativeIteratorPrototype); var Gp = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(IteratorPrototype); function defineIteratorMethods(prototype) { ["next", "throw", "return"].forEach(function (method) { define(prototype, method, function (arg) { return this._invoke(method, arg); }); }); } function AsyncIterator(generator, PromiseImpl) { function invoke(method, arg, resolve, reject) { var record = tryCatch(generator[method], generator, arg); if ("throw" !== record.type) { var result = record.arg, value = result.value; return value && "object" == _typeof(value) && hasOwn.call(value, "__await") ? PromiseImpl.resolve(value.__await).then(function (value) { invoke("next", value, resolve, reject); }, function (err) { invoke("throw", err, resolve, reject); }) : PromiseImpl.resolve(value).then(function (unwrapped) { result.value = unwrapped, resolve(result); }, function (error) { return invoke("throw", error, resolve, reject); }); } reject(record.arg); } var previousPromise; this._invoke = function (method, arg) { function callInvokeWithMethodAndArg() { return new PromiseImpl(function (resolve, reject) { invoke(method, arg, resolve, reject); }); } return previousPromise = previousPromise ? previousPromise.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); }; } function maybeInvokeDelegate(delegate, context) { var method = delegate.iterator[context.method]; if (undefined === method) { if (context.delegate = null, "throw" === context.method) { if (delegate.iterator["return"] && (context.method = "return", context.arg = undefined, maybeInvokeDelegate(delegate, context), "throw" === context.method)) return ContinueSentinel; context.method = "throw", context.arg = new TypeError("The iterator does not provide a 'throw' method"); } return ContinueSentinel; } var record = tryCatch(method, delegate.iterator, context.arg); if ("throw" === record.type) return context.method = "throw", context.arg = record.arg, context.delegate = null, ContinueSentinel; var info = record.arg; return info ? info.done ? (context[delegate.resultName] = info.value, context.next = delegate.nextLoc, "return" !== context.method && (context.method = "next", context.arg = undefined), context.delegate = null, ContinueSentinel) : info : (context.method = "throw", context.arg = new TypeError("iterator result is not an object"), context.delegate = null, ContinueSentinel); } function pushTryEntry(locs) { var entry = { tryLoc: locs[0] }; 1 in locs && (entry.catchLoc = locs[1]), 2 in locs && (entry.finallyLoc = locs[2], entry.afterLoc = locs[3]), this.tryEntries.push(entry); } function resetTryEntry(entry) { var record = entry.completion || {}; record.type = "normal", delete record.arg, entry.completion = record; } function Context(tryLocsList) { this.tryEntries = [{ tryLoc: "root" }], tryLocsList.forEach(pushTryEntry, this), this.reset(!0); } function values(iterable) { if (iterable) { var iteratorMethod = iterable[iteratorSymbol]; if (iteratorMethod) return iteratorMethod.call(iterable); if ("function" == typeof iterable.next) return iterable; if (!isNaN(iterable.length)) { var i = -1, next = function next() { for (; ++i < iterable.length;) { if (hasOwn.call(iterable, i)) return next.value = iterable[i], next.done = !1, next; } return next.value = undefined, next.done = !0, next; }; return next.next = next; } } return { next: doneResult }; } function doneResult() { return { value: undefined, done: !0 }; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, define(Gp, "constructor", GeneratorFunctionPrototype), define(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, toStringTagSymbol, "GeneratorFunction"), exports.isGeneratorFunction = function (genFun) { var ctor = "function" == typeof genFun && genFun.constructor; return !!ctor && (ctor === GeneratorFunction || "GeneratorFunction" === (ctor.displayName || ctor.name)); }, exports.mark = function (genFun) { return Object.setPrototypeOf ? Object.setPrototypeOf(genFun, GeneratorFunctionPrototype) : (genFun.__proto__ = GeneratorFunctionPrototype, define(genFun, toStringTagSymbol, "GeneratorFunction")), genFun.prototype = Object.create(Gp), genFun; }, exports.awrap = function (arg) { return { __await: arg }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, asyncIteratorSymbol, function () { return this; }), exports.AsyncIterator = AsyncIterator, exports.async = function (innerFn, outerFn, self, tryLocsList, PromiseImpl) { void 0 === PromiseImpl && (PromiseImpl = Promise); var iter = new AsyncIterator(wrap(innerFn, outerFn, self, tryLocsList), PromiseImpl); return exports.isGeneratorFunction(outerFn) ? iter : iter.next().then(function (result) { return result.done ? result.value : iter.next(); }); }, defineIteratorMethods(Gp), define(Gp, toStringTagSymbol, "Generator"), define(Gp, iteratorSymbol, function () { return this; }), define(Gp, "toString", function () { return "[object Generator]"; }), exports.keys = function (object) { var keys = []; for (var key in object) { keys.push(key); } return keys.reverse(), function next() { for (; keys.length;) { var key = keys.pop(); if (key in object) return next.value = key, next.done = !1, next; } return next.done = !0, next; }; }, exports.values = values, Context.prototype = { constructor: Context, reset: function reset(skipTempReset) { if (this.prev = 0, this.next = 0, this.sent = this._sent = undefined, this.done = !1, this.delegate = null, this.method = "next", this.arg = undefined, this.tryEntries.forEach(resetTryEntry), !skipTempReset) for (var name in this) { "t" === name.charAt(0) && hasOwn.call(this, name) && !isNaN(+name.slice(1)) && (this[name] = undefined); } }, stop: function stop() { this.done = !0; var rootRecord = this.tryEntries[0].completion; if ("throw" === rootRecord.type) throw rootRecord.arg; return this.rval; }, dispatchException: function dispatchException(exception) { if (this.done) throw exception; var context = this; function handle(loc, caught) { return record.type = "throw", record.arg = exception, context.next = loc, caught && (context.method = "next", context.arg = undefined), !!caught; } for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i], record = entry.completion; if ("root" === entry.tryLoc) return handle("end"); if (entry.tryLoc <= this.prev) { var hasCatch = hasOwn.call(entry, "catchLoc"), hasFinally = hasOwn.call(entry, "finallyLoc"); if (hasCatch && hasFinally) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } else if (hasCatch) { if (this.prev < entry.catchLoc) return handle(entry.catchLoc, !0); } else { if (!hasFinally) throw new Error("try statement without catch or finally"); if (this.prev < entry.finallyLoc) return handle(entry.finallyLoc); } } } }, abrupt: function abrupt(type, arg) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc <= this.prev && hasOwn.call(entry, "finallyLoc") && this.prev < entry.finallyLoc) { var finallyEntry = entry; break; } } finallyEntry && ("break" === type || "continue" === type) && finallyEntry.tryLoc <= arg && arg <= finallyEntry.finallyLoc && (finallyEntry = null); var record = finallyEntry ? finallyEntry.completion : {}; return record.type = type, record.arg = arg, finallyEntry ? (this.method = "next", this.next = finallyEntry.finallyLoc, ContinueSentinel) : this.complete(record); }, complete: function complete(record, afterLoc) { if ("throw" === record.type) throw record.arg; return "break" === record.type || "continue" === record.type ? this.next = record.arg : "return" === record.type ? (this.rval = this.arg = record.arg, this.method = "return", this.next = "end") : "normal" === record.type && afterLoc && (this.next = afterLoc), ContinueSentinel; }, finish: function finish(finallyLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.finallyLoc === finallyLoc) return this.complete(entry.completion, entry.afterLoc), resetTryEntry(entry), ContinueSentinel; } }, "catch": function _catch(tryLoc) { for (var i = this.tryEntries.length - 1; i >= 0; --i) { var entry = this.tryEntries[i]; if (entry.tryLoc === tryLoc) { var record = entry.completion; if ("throw" === record.type) { var thrown = record.arg; resetTryEntry(entry); } return thrown; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(iterable, resultName, nextLoc) { return this.delegate = { iterator: values(iterable), resultName: resultName, nextLoc: nextLoc }, "next" === this.method && (this.arg = undefined), ContinueSentinel; } }, exports; }
|
|
8
|
+
|
|
7
9
|
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
8
10
|
var parseErrorSchema = function parseErrorSchema(error, validateAllFieldCriteria) {
|
|
9
11
|
return Array.isArray(error.inner) && error.inner.length ? error.inner.reduce(function (previous, _ref) {
|
|
@@ -29,11 +31,11 @@ export var yupResolver = function yupResolver(schema) {
|
|
|
29
31
|
abortEarly: false
|
|
30
32
|
};
|
|
31
33
|
return /*#__PURE__*/function () {
|
|
32
|
-
var _ref4 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(values, context) {
|
|
34
|
+
var _ref4 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(values, context) {
|
|
33
35
|
var validateAllFieldCriteria,
|
|
34
36
|
parsedErrors,
|
|
35
37
|
_args = arguments;
|
|
36
|
-
return _regeneratorRuntime.wrap(function _callee$(_context) {
|
|
38
|
+
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
37
39
|
while (1) {
|
|
38
40
|
switch (_context.prev = _context.next) {
|
|
39
41
|
case 0:
|
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
import _typeof from "@babel/runtime/helpers/typeof";
|
|
2
|
+
import * as yup from 'yup';
|
|
3
|
+
import { useMemo } from 'react';
|
|
4
|
+
import dayjs from 'dayjs';
|
|
5
|
+
import customParseFormat from 'dayjs/plugin/customParseFormat';
|
|
6
|
+
import { getYupObjectShape, AFM_VALIDATOR, FILE_MAX_SIZE_VALIDATOR, IBAN_VALIDATOR, MOBILE_PHONE_VALIDATOR, PHONE_NUMBER_VALIDATOR, POSTALCODE_VALIDATOR, UUID4_VALIDATOR } from '@digigov/form/validators/utils';
|
|
7
|
+
dayjs.extend(customParseFormat);
|
|
8
|
+
var VALID_DATE_FORMATS = ['DD/MM/YYYY'];
|
|
9
|
+
var DATE_CACHE = {};
|
|
10
|
+
|
|
11
|
+
var getDate = function getDate(v) {
|
|
12
|
+
return DATE_CACHE[v] ? DATE_CACHE[v] : dayjs(v, VALID_DATE_FORMATS, true);
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
export var getYUPTypeMap = function getYUPTypeMap() {
|
|
16
|
+
var yupTypeMap = {
|
|
17
|
+
file: function file(field) {
|
|
18
|
+
return yup.mixed().transform(function (value) {
|
|
19
|
+
if (!value.length) {
|
|
20
|
+
return null;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
return value;
|
|
24
|
+
}).nullable().test(FILE_MAX_SIZE_VALIDATOR(field));
|
|
25
|
+
},
|
|
26
|
+
string: yup.string,
|
|
27
|
+
text: yup.string,
|
|
28
|
+
"boolean": yup["boolean"],
|
|
29
|
+
object: function object(field) {
|
|
30
|
+
return getYupObjectShape(field.extra.fields, yupTypeMap);
|
|
31
|
+
},
|
|
32
|
+
array: function array(field) {
|
|
33
|
+
if (_typeof(field.extra.of) === 'object') {
|
|
34
|
+
// else if the field is an object then it is a scalar type
|
|
35
|
+
// eg. number, string etc.
|
|
36
|
+
return yup.array().of(yupTypeMap[field.extra.of.type](field.extra.of)); // .min(field.extra.min)
|
|
37
|
+
// .max(field.extra.max)
|
|
38
|
+
// .length(field.extra.length)
|
|
39
|
+
// .required(field.required);
|
|
40
|
+
} else if (typeof field.extra.of === 'string') {
|
|
41
|
+
return yup.array().of(yupTypeMap[field.extra.of]());
|
|
42
|
+
} else {
|
|
43
|
+
// in any other case it will be string
|
|
44
|
+
return yup.array().of(yup.string());
|
|
45
|
+
}
|
|
46
|
+
},
|
|
47
|
+
"int": function int() {
|
|
48
|
+
return yup.number().typeError('form.error.number').positive('form.error.positive_number');
|
|
49
|
+
},
|
|
50
|
+
email: function email() {
|
|
51
|
+
return yup.string().email('form.error.email');
|
|
52
|
+
},
|
|
53
|
+
afm: function afm() {
|
|
54
|
+
return yup.string().test(AFM_VALIDATOR);
|
|
55
|
+
},
|
|
56
|
+
uuid4: function uuid4() {
|
|
57
|
+
return yup.string().test(UUID4_VALIDATOR);
|
|
58
|
+
},
|
|
59
|
+
iban: function iban(field) {
|
|
60
|
+
return yup.string().test(IBAN_VALIDATOR(field));
|
|
61
|
+
},
|
|
62
|
+
postal_code: function postal_code(field) {
|
|
63
|
+
return yup.string().test(POSTALCODE_VALIDATOR(field));
|
|
64
|
+
},
|
|
65
|
+
mobile_phone: function mobile_phone() {
|
|
66
|
+
return yup.string().test(MOBILE_PHONE_VALIDATOR);
|
|
67
|
+
},
|
|
68
|
+
phone_number: function phone_number(field) {
|
|
69
|
+
return yup.string().test(PHONE_NUMBER_VALIDATOR(field));
|
|
70
|
+
},
|
|
71
|
+
'choice:multiple': function choiceMultiple() {
|
|
72
|
+
return yup.array().of(yup.string()).nullable();
|
|
73
|
+
},
|
|
74
|
+
'choice:single': function choiceSingle() {
|
|
75
|
+
return yup.string().nullable();
|
|
76
|
+
},
|
|
77
|
+
date: function date(field) {
|
|
78
|
+
var simpleDate = yup.string().nullable(true).test('date', 'form.error.date.invalid', function (value) {
|
|
79
|
+
if (!value) return true;
|
|
80
|
+
value = getDate(value);
|
|
81
|
+
return value.isValid();
|
|
82
|
+
});
|
|
83
|
+
var params = field.extra || {};
|
|
84
|
+
|
|
85
|
+
if (params.max) {
|
|
86
|
+
var maxDate;
|
|
87
|
+
|
|
88
|
+
if (params.max === 'now') {
|
|
89
|
+
var today = new Date();
|
|
90
|
+
maxDate = new Date(today);
|
|
91
|
+
} else {
|
|
92
|
+
maxDate = getDate(params.max).toDate();
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
var maxNextDate = new Date(maxDate);
|
|
96
|
+
maxNextDate.setDate(maxDate.getDate() + 1);
|
|
97
|
+
simpleDate = simpleDate.test({
|
|
98
|
+
name: 'earlier-than',
|
|
99
|
+
message: {
|
|
100
|
+
key: 'form.error.date.earlier_than',
|
|
101
|
+
context: {
|
|
102
|
+
maxDate: maxNextDate.toLocaleDateString()
|
|
103
|
+
}
|
|
104
|
+
},
|
|
105
|
+
test: function test(value) {
|
|
106
|
+
if (!value) return true;
|
|
107
|
+
value = getDate(value);
|
|
108
|
+
var isValid = +value.toDate() < +maxDate;
|
|
109
|
+
return isValid;
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
if (params.min) {
|
|
115
|
+
var minDate;
|
|
116
|
+
|
|
117
|
+
if (params.min === 'now') {
|
|
118
|
+
var _today = new Date();
|
|
119
|
+
|
|
120
|
+
minDate = new Date(_today);
|
|
121
|
+
} else {
|
|
122
|
+
minDate = getDate(params.min).toDate();
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
var minPreviousDate = new Date(minDate);
|
|
126
|
+
minPreviousDate.setDate(minDate.getDate() - 1);
|
|
127
|
+
simpleDate = simpleDate.test({
|
|
128
|
+
name: 'later-than',
|
|
129
|
+
message: {
|
|
130
|
+
key: 'form.error.date.later_than',
|
|
131
|
+
context: {
|
|
132
|
+
minDate: minPreviousDate.toLocaleDateString()
|
|
133
|
+
}
|
|
134
|
+
},
|
|
135
|
+
test: function test(value) {
|
|
136
|
+
if (!value) return true;
|
|
137
|
+
value = getDate(value);
|
|
138
|
+
var isValid = +value.toDate() > +minDate;
|
|
139
|
+
return isValid;
|
|
140
|
+
}
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
return simpleDate;
|
|
145
|
+
}
|
|
146
|
+
};
|
|
147
|
+
return yupTypeMap;
|
|
148
|
+
};
|
|
149
|
+
// Create a yup validation schema from given fields input
|
|
150
|
+
export function useValidationSchema(fields, validatorRegistry) {
|
|
151
|
+
return useMemo(function () {
|
|
152
|
+
var yupTypeMap = getYUPTypeMap();
|
|
153
|
+
return getYupObjectShape(fields, yupTypeMap, validatorRegistry);
|
|
154
|
+
}, []);
|
|
155
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
export function validateAFM(afm) {
|
|
2
|
+
if (afm.length !== 9) {
|
|
3
|
+
// "afm should be 9 digits"
|
|
4
|
+
return false;
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
if (!/^\d+$/.test(afm)) {
|
|
8
|
+
// "This is not a number"
|
|
9
|
+
return false;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
if (afm === '0'.repeat(9)) {
|
|
13
|
+
// "This is zero number (000000000)"
|
|
14
|
+
return false;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
var sum = afm.substring(0, 8).split('').reduce(function (s, v, i) {
|
|
18
|
+
return s + (parseInt(v) << 8 - i);
|
|
19
|
+
}, 0);
|
|
20
|
+
var calc = sum % 11;
|
|
21
|
+
var d9 = parseInt(afm[8]);
|
|
22
|
+
var valid = calc % 10 === d9;
|
|
23
|
+
return valid;
|
|
24
|
+
}
|
|
25
|
+
export var AFM_VALIDATOR = {
|
|
26
|
+
name: 'afm-validator',
|
|
27
|
+
message: 'form.error.afm',
|
|
28
|
+
test: function test(value) {
|
|
29
|
+
if (value) {
|
|
30
|
+
return validateAFM(value);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
return true;
|
|
34
|
+
}
|
|
35
|
+
};
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
|
|
2
|
+
|
|
3
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
4
|
+
|
|
5
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
6
|
+
|
|
7
|
+
var DEFAULT_FILE_MAX_SIZE = 10000000;
|
|
8
|
+
export var FILE_MAX_SIZE_VALIDATOR = function FILE_MAX_SIZE_VALIDATOR(field) {
|
|
9
|
+
return {
|
|
10
|
+
name: 'file-max-size-validator',
|
|
11
|
+
message: 'form.error.file_size',
|
|
12
|
+
test: function test(value) {
|
|
13
|
+
if (field.extra && field.extra.maxSize && value) {
|
|
14
|
+
var _iterator = _createForOfIteratorHelper(value),
|
|
15
|
+
_step;
|
|
16
|
+
|
|
17
|
+
try {
|
|
18
|
+
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
19
|
+
var file = _step.value;
|
|
20
|
+
|
|
21
|
+
if (file.size >= field.extra.maxSize) {
|
|
22
|
+
return false;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
} catch (err) {
|
|
26
|
+
_iterator.e(err);
|
|
27
|
+
} finally {
|
|
28
|
+
_iterator.f();
|
|
29
|
+
}
|
|
30
|
+
} else if (value) {
|
|
31
|
+
var _iterator2 = _createForOfIteratorHelper(value),
|
|
32
|
+
_step2;
|
|
33
|
+
|
|
34
|
+
try {
|
|
35
|
+
for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
|
|
36
|
+
var _file = _step2.value;
|
|
37
|
+
|
|
38
|
+
if (_file.size >= DEFAULT_FILE_MAX_SIZE) {
|
|
39
|
+
return false;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
} catch (err) {
|
|
43
|
+
_iterator2.e(err);
|
|
44
|
+
} finally {
|
|
45
|
+
_iterator2.f();
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
return true;
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
};
|