envoc-form 5.0.2 → 5.0.4-0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +4650 -1250
- package/dist/index.cjs +21523 -0
- package/dist/index.d.ts +575 -0
- package/dist/index.js +21456 -0
- package/package.json +107 -111
- package/dist/css/envoc-form-styles.css +0 -3
- package/dist/css/envoc-form-styles.css.map +0 -1
- package/es/AddressInput/AddressInput.d.ts +0 -24
- package/es/AddressInput/AddressInput.js +0 -20
- package/es/AddressInput/UsStates.d.ts +0 -3
- package/es/AddressInput/UsStates.js +0 -53
- package/es/ConfirmBaseForm/ConfirmBaseForm.d.ts +0 -26
- package/es/ConfirmBaseForm/ConfirmBaseForm.js +0 -42
- package/es/ConfirmDeleteForm/ConfirmDeleteForm.d.ts +0 -24
- package/es/ConfirmDeleteForm/ConfirmDeleteForm.js +0 -60
- package/es/DatePicker/DatePickerGroup.d.ts +0 -13
- package/es/DatePicker/DatePickerGroup.js +0 -87
- package/es/DatePicker/DatePickerHelper.d.ts +0 -3
- package/es/DatePicker/DatePickerHelper.js +0 -1
- package/es/DatePicker/StringDateOnlyPickerGroup.d.ts +0 -9
- package/es/DatePicker/StringDateOnlyPickerGroup.js +0 -29
- package/es/DatePicker/StringDatePickerGroup.d.ts +0 -9
- package/es/DatePicker/StringDatePickerGroup.js +0 -24
- package/es/Field/CustomFieldInputProps.d.ts +0 -7
- package/es/Field/CustomFieldInputProps.js +0 -1
- package/es/Field/CustomFieldMetaProps.d.ts +0 -4
- package/es/Field/CustomFieldMetaProps.js +0 -1
- package/es/Field/Field.d.ts +0 -28
- package/es/Field/Field.js +0 -51
- package/es/Field/FieldErrorScrollTarget.d.ts +0 -2
- package/es/Field/FieldErrorScrollTarget.js +0 -12
- package/es/Field/FieldNameContext.d.ts +0 -3
- package/es/Field/FieldNameContext.js +0 -3
- package/es/Field/FieldSection.d.ts +0 -7
- package/es/Field/FieldSection.js +0 -9
- package/es/Field/InjectedFieldProps.d.ts +0 -7
- package/es/Field/InjectedFieldProps.js +0 -1
- package/es/Field/StandAloneInput.d.ts +0 -13
- package/es/Field/StandAloneInput.js +0 -50
- package/es/Field/useStandardField.d.ts +0 -21
- package/es/Field/useStandardField.js +0 -92
- package/es/FieldArray/FieldArray.d.ts +0 -24
- package/es/FieldArray/FieldArray.js +0 -77
- package/es/File/FileGroup.d.ts +0 -10
- package/es/File/FileGroup.js +0 -53
- package/es/File/FileList.d.ts +0 -5
- package/es/File/FileList.js +0 -10
- package/es/File/humanFileSize.d.ts +0 -1
- package/es/File/humanFileSize.js +0 -6
- package/es/Form/FocusError.d.ts +0 -7
- package/es/Form/FocusError.js +0 -42
- package/es/Form/Form.d.ts +0 -33
- package/es/Form/Form.js +0 -141
- package/es/Form/FormBasedPreventNavigation.d.ts +0 -6
- package/es/Form/FormBasedPreventNavigation.js +0 -20
- package/es/Form/LegacyFormBasedPreventNavigation.d.ts +0 -17
- package/es/Form/LegacyFormBasedPreventNavigation.js +0 -69
- package/es/Form/NewFormBasedPreventNavigation.d.ts +0 -14
- package/es/Form/NewFormBasedPreventNavigation.js +0 -39
- package/es/Form/ServerErrorContext.d.ts +0 -11
- package/es/Form/ServerErrorContext.js +0 -9
- package/es/FormActions.d.ts +0 -12
- package/es/FormActions.js +0 -16
- package/es/FormDefaults.d.ts +0 -4
- package/es/FormDefaults.js +0 -2
- package/es/Group.d.ts +0 -16
- package/es/Group.js +0 -14
- package/es/Input/IconInputGroup.d.ts +0 -12
- package/es/Input/IconInputGroup.js +0 -43
- package/es/Input/InputGroup.d.ts +0 -12
- package/es/Input/InputGroup.js +0 -34
- package/es/Input/MoneyInputGroup.d.ts +0 -9
- package/es/Input/MoneyInputGroup.js +0 -43
- package/es/Input/NumberInputGroup.d.ts +0 -9
- package/es/Input/NumberInputGroup.js +0 -43
- package/es/Input/PhoneNumberInputGroup.d.ts +0 -10
- package/es/Input/PhoneNumberInputGroup.js +0 -47
- package/es/Input/StringInputGroup.d.ts +0 -8
- package/es/Input/StringInputGroup.js +0 -43
- package/es/Normalization/NormalizationFunction.d.ts +0 -4
- package/es/Normalization/NormalizationFunction.js +0 -1
- package/es/Normalization/normalizers.d.ts +0 -4
- package/es/Normalization/normalizers.js +0 -32
- package/es/Select/BooleanSelectGroup.d.ts +0 -7
- package/es/Select/BooleanSelectGroup.js +0 -28
- package/es/Select/NumberSelectGroup.d.ts +0 -9
- package/es/Select/NumberSelectGroup.js +0 -21
- package/es/Select/SelectGroup.d.ts +0 -27
- package/es/Select/SelectGroup.js +0 -65
- package/es/Select/SelectGroupPropsHelper.d.ts +0 -3
- package/es/Select/SelectGroupPropsHelper.js +0 -1
- package/es/Select/StringSelectGroup.d.ts +0 -9
- package/es/Select/StringSelectGroup.js +0 -21
- package/es/StandardFormActions.d.ts +0 -11
- package/es/StandardFormActions.js +0 -14
- package/es/SubmitFormButton.d.ts +0 -10
- package/es/SubmitFormButton.js +0 -40
- package/es/TextArea/TextAreaGroup.d.ts +0 -9
- package/es/TextArea/TextAreaGroup.js +0 -35
- package/es/Validation/ValidatedApiResult.d.ts +0 -6
- package/es/Validation/ValidatedApiResult.js +0 -1
- package/es/Validation/ValidationError.d.ts +0 -5
- package/es/Validation/ValidationError.js +0 -1
- package/es/Validation/ValidationFunction.d.ts +0 -4
- package/es/Validation/ValidationFunction.js +0 -1
- package/es/Validation/validators.d.ts +0 -18
- package/es/Validation/validators.js +0 -77
- package/es/index.d.ts +0 -75
- package/es/index.js +0 -51
- package/es/setupTests.d.ts +0 -1
- package/es/setupTests.js +0 -1
- package/es/utils/objectContainsNonSerializableProperty.d.ts +0 -1
- package/es/utils/objectContainsNonSerializableProperty.js +0 -14
- package/es/utils/objectToFormData.d.ts +0 -10
- package/es/utils/objectToFormData.js +0 -77
- package/es/utils/typeChecks.d.ts +0 -8
- package/es/utils/typeChecks.js +0 -18
- package/lib/AddressInput/AddressInput.d.ts +0 -24
- package/lib/AddressInput/AddressInput.js +0 -26
- package/lib/AddressInput/UsStates.d.ts +0 -3
- package/lib/AddressInput/UsStates.js +0 -55
- package/lib/ConfirmBaseForm/ConfirmBaseForm.d.ts +0 -26
- package/lib/ConfirmBaseForm/ConfirmBaseForm.js +0 -48
- package/lib/ConfirmDeleteForm/ConfirmDeleteForm.d.ts +0 -24
- package/lib/ConfirmDeleteForm/ConfirmDeleteForm.js +0 -66
- package/lib/DatePicker/DatePickerGroup.d.ts +0 -13
- package/lib/DatePicker/DatePickerGroup.js +0 -95
- package/lib/DatePicker/DatePickerHelper.d.ts +0 -3
- package/lib/DatePicker/DatePickerHelper.js +0 -2
- package/lib/DatePicker/StringDateOnlyPickerGroup.d.ts +0 -9
- package/lib/DatePicker/StringDateOnlyPickerGroup.js +0 -35
- package/lib/DatePicker/StringDatePickerGroup.d.ts +0 -9
- package/lib/DatePicker/StringDatePickerGroup.js +0 -30
- package/lib/Field/CustomFieldInputProps.d.ts +0 -7
- package/lib/Field/CustomFieldInputProps.js +0 -2
- package/lib/Field/CustomFieldMetaProps.d.ts +0 -4
- package/lib/Field/CustomFieldMetaProps.js +0 -2
- package/lib/Field/Field.d.ts +0 -28
- package/lib/Field/Field.js +0 -56
- package/lib/Field/FieldErrorScrollTarget.d.ts +0 -2
- package/lib/Field/FieldErrorScrollTarget.js +0 -15
- package/lib/Field/FieldNameContext.d.ts +0 -3
- package/lib/Field/FieldNameContext.js +0 -9
- package/lib/Field/FieldSection.d.ts +0 -7
- package/lib/Field/FieldSection.js +0 -12
- package/lib/Field/InjectedFieldProps.d.ts +0 -7
- package/lib/Field/InjectedFieldProps.js +0 -2
- package/lib/Field/StandAloneInput.d.ts +0 -13
- package/lib/Field/StandAloneInput.js +0 -76
- package/lib/Field/useStandardField.d.ts +0 -21
- package/lib/Field/useStandardField.js +0 -95
- package/lib/FieldArray/FieldArray.d.ts +0 -24
- package/lib/FieldArray/FieldArray.js +0 -83
- package/lib/File/FileGroup.d.ts +0 -10
- package/lib/File/FileGroup.js +0 -58
- package/lib/File/FileList.d.ts +0 -5
- package/lib/File/FileList.js +0 -13
- package/lib/File/humanFileSize.d.ts +0 -1
- package/lib/File/humanFileSize.js +0 -10
- package/lib/Form/FocusError.d.ts +0 -7
- package/lib/Form/FocusError.js +0 -48
- package/lib/Form/Form.d.ts +0 -33
- package/lib/Form/Form.js +0 -147
- package/lib/Form/FormBasedPreventNavigation.d.ts +0 -6
- package/lib/Form/FormBasedPreventNavigation.js +0 -26
- package/lib/Form/LegacyFormBasedPreventNavigation.d.ts +0 -17
- package/lib/Form/LegacyFormBasedPreventNavigation.js +0 -72
- package/lib/Form/NewFormBasedPreventNavigation.d.ts +0 -14
- package/lib/Form/NewFormBasedPreventNavigation.js +0 -42
- package/lib/Form/ServerErrorContext.d.ts +0 -11
- package/lib/Form/ServerErrorContext.js +0 -15
- package/lib/FormActions.d.ts +0 -12
- package/lib/FormActions.js +0 -22
- package/lib/FormDefaults.d.ts +0 -4
- package/lib/FormDefaults.js +0 -5
- package/lib/Group.d.ts +0 -16
- package/lib/Group.js +0 -20
- package/lib/Input/IconInputGroup.d.ts +0 -12
- package/lib/Input/IconInputGroup.js +0 -48
- package/lib/Input/InputGroup.d.ts +0 -12
- package/lib/Input/InputGroup.js +0 -39
- package/lib/Input/MoneyInputGroup.d.ts +0 -9
- package/lib/Input/MoneyInputGroup.js +0 -48
- package/lib/Input/NumberInputGroup.d.ts +0 -9
- package/lib/Input/NumberInputGroup.js +0 -48
- package/lib/Input/PhoneNumberInputGroup.d.ts +0 -10
- package/lib/Input/PhoneNumberInputGroup.js +0 -52
- package/lib/Input/StringInputGroup.d.ts +0 -8
- package/lib/Input/StringInputGroup.js +0 -48
- package/lib/Normalization/NormalizationFunction.d.ts +0 -4
- package/lib/Normalization/NormalizationFunction.js +0 -2
- package/lib/Normalization/normalizers.d.ts +0 -4
- package/lib/Normalization/normalizers.js +0 -37
- package/lib/Select/BooleanSelectGroup.d.ts +0 -7
- package/lib/Select/BooleanSelectGroup.js +0 -35
- package/lib/Select/NumberSelectGroup.d.ts +0 -9
- package/lib/Select/NumberSelectGroup.js +0 -29
- package/lib/Select/SelectGroup.d.ts +0 -27
- package/lib/Select/SelectGroup.js +0 -71
- package/lib/Select/SelectGroupPropsHelper.d.ts +0 -3
- package/lib/Select/SelectGroupPropsHelper.js +0 -2
- package/lib/Select/StringSelectGroup.d.ts +0 -9
- package/lib/Select/StringSelectGroup.js +0 -29
- package/lib/StandardFormActions.d.ts +0 -11
- package/lib/StandardFormActions.js +0 -20
- package/lib/SubmitFormButton.d.ts +0 -10
- package/lib/SubmitFormButton.js +0 -45
- package/lib/TextArea/TextAreaGroup.d.ts +0 -9
- package/lib/TextArea/TextAreaGroup.js +0 -40
- package/lib/Validation/ValidatedApiResult.d.ts +0 -6
- package/lib/Validation/ValidatedApiResult.js +0 -2
- package/lib/Validation/ValidationError.d.ts +0 -5
- package/lib/Validation/ValidationError.js +0 -2
- package/lib/Validation/ValidationFunction.d.ts +0 -4
- package/lib/Validation/ValidationFunction.js +0 -2
- package/lib/Validation/validators.d.ts +0 -18
- package/lib/Validation/validators.js +0 -90
- package/lib/index.d.ts +0 -75
- package/lib/index.js +0 -119
- package/lib/setupTests.d.ts +0 -1
- package/lib/setupTests.js +0 -3
- package/lib/utils/objectContainsNonSerializableProperty.d.ts +0 -1
- package/lib/utils/objectContainsNonSerializableProperty.js +0 -17
- package/lib/utils/objectToFormData.d.ts +0 -10
- package/lib/utils/objectToFormData.js +0 -79
- package/lib/utils/typeChecks.d.ts +0 -8
- package/lib/utils/typeChecks.js +0 -29
- package/src/AddressInput/AddressInput.test.tsx +0 -27
- package/src/AddressInput/AddressInput.tsx +0 -82
- package/src/AddressInput/UsStates.ts +0 -55
- package/src/AddressInput/__snapshots__/AddressInput.test.tsx.snap +0 -182
- package/src/ConfirmBaseForm/ConfirmBaseForm.test.tsx +0 -24
- package/src/ConfirmBaseForm/ConfirmBaseForm.tsx +0 -74
- package/src/ConfirmBaseForm/__snapshots__/ConfirmBaseForm.test.tsx.snap +0 -23
- package/src/ConfirmDeleteForm/ConfirmDeleteForm.test.tsx +0 -24
- package/src/ConfirmDeleteForm/ConfirmDeleteForm.tsx +0 -87
- package/src/ConfirmDeleteForm/__snapshots__/ConfirmDeleteForm.test.tsx.snap +0 -25
- package/src/DatePicker/DatePicker.test.tsx +0 -48
- package/src/DatePicker/DatePickerGroup.tsx +0 -115
- package/src/DatePicker/DatePickerHelper.ts +0 -4
- package/src/DatePicker/StringDateOnlyPickerGroup.tsx +0 -28
- package/src/DatePicker/StringDatePickerGroup.tsx +0 -20
- package/src/DatePicker/__snapshots__/DatePicker.test.tsx.snap +0 -152
- package/src/Field/CustomFieldInputProps.ts +0 -10
- package/src/Field/CustomFieldMetaProps.ts +0 -5
- package/src/Field/Field.tsx +0 -113
- package/src/Field/FieldErrorScrollTarget.tsx +0 -12
- package/src/Field/FieldNameContext.ts +0 -6
- package/src/Field/FieldSection.tsx +0 -18
- package/src/Field/InjectedFieldProps.ts +0 -8
- package/src/Field/StandAloneInput.tsx +0 -55
- package/src/Field/useStandardField.ts +0 -125
- package/src/FieldArray/FieldArray.tsx +0 -154
- package/src/File/FileGroup.test.tsx +0 -35
- package/src/File/FileGroup.tsx +0 -85
- package/src/File/FileList.tsx +0 -21
- package/src/File/__snapshots__/FileGroup.test.tsx.snap +0 -34
- package/src/File/humanFileSize.ts +0 -8
- package/src/Form/FocusError.tsx +0 -55
- package/src/Form/Form.test.tsx +0 -14
- package/src/Form/Form.tsx +0 -237
- package/src/Form/FormBasedPreventNavigation.tsx +0 -56
- package/src/Form/LegacyFormBasedPreventNavigation.tsx +0 -77
- package/src/Form/NewFormBasedPreventNavigation.tsx +0 -59
- package/src/Form/ServerErrorContext.ts +0 -18
- package/src/Form/__snapshots__/Form.test.tsx.snap +0 -10
- package/src/FormActions.tsx +0 -47
- package/src/FormDefaults.ts +0 -2
- package/src/Group.tsx +0 -62
- package/src/Input/IconInputGroup.tsx +0 -54
- package/src/Input/InputGroup.tsx +0 -72
- package/src/Input/MoneyInputGroup.tsx +0 -50
- package/src/Input/NumberInputGroup.tsx +0 -48
- package/src/Input/PhoneNumberInputGroup.tsx +0 -45
- package/src/Input/StringInputGroup.tsx +0 -53
- package/src/Input/__Tests__/IconInputGroup.test.tsx +0 -35
- package/src/Input/__Tests__/MoneyInputGroup.test.tsx +0 -37
- package/src/Input/__Tests__/NumberInputGroup.test.tsx +0 -35
- package/src/Input/__Tests__/PhoneNumberInputGroup.test.tsx +0 -36
- package/src/Input/__Tests__/StringInputGroup.test.tsx +0 -27
- package/src/Input/__Tests__/__snapshots__/IconInputGroup.test.tsx.snap +0 -32
- package/src/Input/__Tests__/__snapshots__/MoneyInputGroup.test.tsx.snap +0 -34
- package/src/Input/__Tests__/__snapshots__/NumberInputGroup.test.tsx.snap +0 -32
- package/src/Input/__Tests__/__snapshots__/PhoneNumberInputGroup.test.tsx.snap +0 -33
- package/src/Input/__Tests__/__snapshots__/StringInputGroup.test.tsx.snap +0 -31
- package/src/Normalization/NormalizationFunction.ts +0 -4
- package/src/Normalization/normalizers.ts +0 -44
- package/src/Select/BooleanSelectGroup.tsx +0 -28
- package/src/Select/NumberSelectGroup.tsx +0 -16
- package/src/Select/SelectGroup.tsx +0 -124
- package/src/Select/SelectGroupPropsHelper.ts +0 -4
- package/src/Select/StringSelectGroup.tsx +0 -16
- package/src/Select/__tests__/BooleanSelectGroup.test.tsx +0 -35
- package/src/Select/__tests__/NumberSelectGroup.test.tsx +0 -87
- package/src/Select/__tests__/StringSelectGroup.test.tsx +0 -89
- package/src/Select/__tests__/__snapshots__/BooleanSelectGroup.test.tsx.snap +0 -98
- package/src/Select/__tests__/__snapshots__/NumberSelectGroup.test.tsx.snap +0 -195
- package/src/Select/__tests__/__snapshots__/StringSelectGroup.test.tsx.snap +0 -195
- package/src/StandardFormActions.tsx +0 -41
- package/src/SubmitFormButton.tsx +0 -54
- package/src/TextArea/TextAreaGroup.tsx +0 -64
- package/src/Validation/ValidatedApiResult.ts +0 -8
- package/src/Validation/ValidationError.ts +0 -6
- package/src/Validation/ValidationFunction.ts +0 -4
- package/src/Validation/validators.test.tsx +0 -81
- package/src/Validation/validators.ts +0 -97
- package/src/__Tests__/FormTestBase.tsx +0 -64
- package/src/__Tests__/RealisticForm.test.tsx +0 -82
- package/src/__Tests__/StandardFormActions.test.tsx +0 -17
- package/src/__Tests__/SubmitFormButton.test.tsx +0 -17
- package/src/__Tests__/__snapshots__/StandardFormActions.test.tsx.snap +0 -27
- package/src/__Tests__/__snapshots__/SubmitFormButton.test.tsx.snap +0 -20
- package/src/__Tests__/index.ts +0 -3
- package/src/_variables.scss +0 -11
- package/src/index.ts +0 -153
- package/src/react-app-env.d.ts +0 -1
- package/src/setupTests.ts +0 -1
- package/src/styles.scss +0 -0
- package/src/utils/objectContainsNonSerializableProperty.test.tsx +0 -49
- package/src/utils/objectContainsNonSerializableProperty.ts +0 -17
- package/src/utils/objectToFormData.test.tsx +0 -76
- package/src/utils/objectToFormData.ts +0 -105
- package/src/utils/typeChecks.ts +0 -18
package/package.json
CHANGED
@@ -1,111 +1,107 @@
|
|
1
|
-
{
|
2
|
-
"name": "envoc-form",
|
3
|
-
"version": "5.0.
|
4
|
-
"description": "Envoc form components",
|
5
|
-
"keywords": [
|
6
|
-
"react-component",
|
7
|
-
"react",
|
8
|
-
"forms",
|
9
|
-
"components",
|
10
|
-
"envoc"
|
11
|
-
],
|
12
|
-
"homepage": "",
|
13
|
-
"repository": "",
|
14
|
-
"license": "MIT",
|
15
|
-
"author": "Envoc Developers",
|
16
|
-
"
|
17
|
-
"
|
18
|
-
"
|
19
|
-
"
|
20
|
-
|
21
|
-
"
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
"
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
"
|
39
|
-
"
|
40
|
-
"date-
|
41
|
-
"
|
42
|
-
"
|
43
|
-
"
|
44
|
-
"react-
|
45
|
-
"
|
46
|
-
"
|
47
|
-
"
|
48
|
-
|
49
|
-
|
50
|
-
"
|
51
|
-
"
|
52
|
-
"
|
53
|
-
"
|
54
|
-
"@
|
55
|
-
"@
|
56
|
-
"@
|
57
|
-
|
58
|
-
|
59
|
-
"@
|
60
|
-
"@
|
61
|
-
"@
|
62
|
-
"@
|
63
|
-
"@
|
64
|
-
"@
|
65
|
-
"
|
66
|
-
"
|
67
|
-
"
|
68
|
-
"
|
69
|
-
"
|
70
|
-
"
|
71
|
-
"
|
72
|
-
"
|
73
|
-
"
|
74
|
-
"
|
75
|
-
"
|
76
|
-
"
|
77
|
-
"
|
78
|
-
"
|
79
|
-
"
|
80
|
-
"
|
81
|
-
"
|
82
|
-
"
|
83
|
-
"
|
84
|
-
"
|
85
|
-
"
|
86
|
-
"
|
87
|
-
|
88
|
-
|
89
|
-
"
|
90
|
-
"
|
91
|
-
"
|
92
|
-
"
|
93
|
-
"
|
94
|
-
|
95
|
-
|
96
|
-
"
|
97
|
-
"
|
98
|
-
|
99
|
-
|
100
|
-
"
|
101
|
-
"
|
102
|
-
"
|
103
|
-
"
|
104
|
-
"
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
"^.+\\.module\\.(css|sass|scss)$"
|
109
|
-
]
|
110
|
-
}
|
111
|
-
}
|
1
|
+
{
|
2
|
+
"name": "envoc-form",
|
3
|
+
"version": "5.0.4-0",
|
4
|
+
"description": "Envoc form components",
|
5
|
+
"keywords": [
|
6
|
+
"react-component",
|
7
|
+
"react",
|
8
|
+
"forms",
|
9
|
+
"components",
|
10
|
+
"envoc"
|
11
|
+
],
|
12
|
+
"homepage": "",
|
13
|
+
"repository": "",
|
14
|
+
"license": "MIT",
|
15
|
+
"author": "Envoc Developers",
|
16
|
+
"main": "dist/index.cjs",
|
17
|
+
"module": "dist/index.js",
|
18
|
+
"types": "dist/index.d.ts",
|
19
|
+
"type": "module",
|
20
|
+
"exports": {
|
21
|
+
".": {
|
22
|
+
"import": {
|
23
|
+
"types": "./dist/index.d.ts",
|
24
|
+
"default": "./dist/index.js"
|
25
|
+
},
|
26
|
+
"require": {
|
27
|
+
"types": "./dist/index.d.ts",
|
28
|
+
"default": "./dist/index.cjs"
|
29
|
+
}
|
30
|
+
}
|
31
|
+
},
|
32
|
+
"files": [
|
33
|
+
"dist"
|
34
|
+
],
|
35
|
+
"sideEffects": false,
|
36
|
+
"dependencies": {
|
37
|
+
"date-fns": "^3.2.0",
|
38
|
+
"envoc-request": "^5.0.4-0",
|
39
|
+
"history": "^5.3.0",
|
40
|
+
"react-date-picker": "^10.6.0",
|
41
|
+
"react-dropzone": "^14.2.3",
|
42
|
+
"react-router": "^6.22.3",
|
43
|
+
"react-select": "^5.8.0",
|
44
|
+
"react-toastify": "^10.0.4",
|
45
|
+
"smoothscroll-polyfill": "^0.4.4",
|
46
|
+
"uuid": "^9.0.1",
|
47
|
+
"clsx": "^2.1.0"
|
48
|
+
},
|
49
|
+
"devDependencies": {
|
50
|
+
"@testing-library/dom": "^9.3.4",
|
51
|
+
"@testing-library/jest-dom": "^6.4.2",
|
52
|
+
"@testing-library/react": "^14.2.1",
|
53
|
+
"@testing-library/user-event": "^14.5.2",
|
54
|
+
"@types/body": "5.1.4",
|
55
|
+
"@types/jest": "^29.5.12",
|
56
|
+
"@types/react": "~18.2.65",
|
57
|
+
"@types/react-dom": "~18.2.21",
|
58
|
+
"@types/smoothscroll-polyfill": "^0.3.4",
|
59
|
+
"@types/uuid": "^9.0.8",
|
60
|
+
"@typescript-eslint/eslint-plugin": "^7.2.0",
|
61
|
+
"@typescript-eslint/parser": "^7.2.0",
|
62
|
+
"@vitejs/plugin-react-swc": "^3.6.0",
|
63
|
+
"@vitest/coverage-v8": "^1.3.1",
|
64
|
+
"@vitest/ui": "^1.3.1",
|
65
|
+
"formik": "^2.4.5",
|
66
|
+
"body": "5.1.0",
|
67
|
+
"concat-md": "^0.5.1",
|
68
|
+
"cross-env": "7.0.3",
|
69
|
+
"eslint": "^8.57.0",
|
70
|
+
"eslint-config-prettier": "^9.1.0",
|
71
|
+
"eslint-plugin-jest-dom": "^5.1.0",
|
72
|
+
"eslint-plugin-react": "^7.34.0",
|
73
|
+
"eslint-plugin-react-hooks": "^4.6.0",
|
74
|
+
"identity-obj-proxy": "^3.0.0",
|
75
|
+
"react": "~18",
|
76
|
+
"react-dom": "~18",
|
77
|
+
"react-router-dom": "^6.22.3",
|
78
|
+
"rimraf": "^5.0.5",
|
79
|
+
"sass": "^1.71.1",
|
80
|
+
"typedoc": "^0.25.12",
|
81
|
+
"typedoc-plugin-markdown": "^3.17.1",
|
82
|
+
"typescript": "^5.4.2",
|
83
|
+
"vite": "^5.1.6",
|
84
|
+
"vite-plugin-dts": "^3.7.3",
|
85
|
+
"vitest": "^1.3.1",
|
86
|
+
"jsdom": "^24.0.0"
|
87
|
+
},
|
88
|
+
"peerDependencies": {
|
89
|
+
"@babel/runtime": "^7.14.6",
|
90
|
+
"formik": "^2.2.9",
|
91
|
+
"react": ">=18",
|
92
|
+
"react-dom": ">=18",
|
93
|
+
"react-router-dom": "^6.2.1"
|
94
|
+
},
|
95
|
+
"scripts": {
|
96
|
+
"start": "vite",
|
97
|
+
"build": "yarn verify-imports && yarn build:js && yarn build:docs",
|
98
|
+
"build:docs": "yarn rimraf README.md && yarn typedoc --options typedoc.json src/index.ts && npx concat-md --decrease-title-levels --dir-name-as-title docs > README.md && yarn rimraf docs",
|
99
|
+
"build:js": "tsc && vite build",
|
100
|
+
"clean": "yarn rimraf ./dist",
|
101
|
+
"rebuild": "rimraf ./{dist} && yarn build",
|
102
|
+
"test": "vitest run",
|
103
|
+
"test:watch": "vitest",
|
104
|
+
"test:ui": "vitest --ui",
|
105
|
+
"verify-imports": "node ../../scripts/check-for-scss-imports.js envoc-form"
|
106
|
+
}
|
107
|
+
}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"sourceRoot":"","sources":[],"names":[],"mappings":"","file":"envoc-form-styles.css"}
|
@@ -1,24 +0,0 @@
|
|
1
|
-
import { FormBuilderProp } from '../Form/Form';
|
2
|
-
export interface AddressInputProps {
|
3
|
-
fieldBuilder: Pick<FormBuilderProp<AddressDto>, 'Field'>;
|
4
|
-
name: string;
|
5
|
-
}
|
6
|
-
interface AddressDto {
|
7
|
-
address1?: string | null;
|
8
|
-
address2?: string | null;
|
9
|
-
zipCode?: string | null;
|
10
|
-
city?: string | null;
|
11
|
-
state?: string | null;
|
12
|
-
}
|
13
|
-
/**
|
14
|
-
* Collection of `<Field/>`s for inputting an address. Includes:
|
15
|
-
* ```txt
|
16
|
-
* Address 1
|
17
|
-
* Address 2
|
18
|
-
* City
|
19
|
-
* State
|
20
|
-
* Zip
|
21
|
-
* ```
|
22
|
-
*/
|
23
|
-
export default function AddressInput({ fieldBuilder: { Field }, name, }: AddressInputProps): import("react/jsx-runtime").JSX.Element;
|
24
|
-
export {};
|
@@ -1,20 +0,0 @@
|
|
1
|
-
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
2
|
-
import UsStates from './UsStates';
|
3
|
-
import { SingleStringSelectGroup, StringInputGroup } from '../';
|
4
|
-
import FieldSection from '../Field/FieldSection';
|
5
|
-
import { zipCode as zipCodeNormalizer } from '../Normalization/normalizers';
|
6
|
-
import { required, zipCode as zipCodeValidator, } from '../Validation/validators';
|
7
|
-
/**
|
8
|
-
* Collection of `<Field/>`s for inputting an address. Includes:
|
9
|
-
* ```txt
|
10
|
-
* Address 1
|
11
|
-
* Address 2
|
12
|
-
* City
|
13
|
-
* State
|
14
|
-
* Zip
|
15
|
-
* ```
|
16
|
-
*/
|
17
|
-
export default function AddressInput(_a) {
|
18
|
-
var Field = _a.fieldBuilder.Field, name = _a.name;
|
19
|
-
return (_jsx(_Fragment, { children: _jsxs(FieldSection, { name: name, children: [_jsx(Field, { name: "address1", placeholder: "Address, Line 1", label: "Address 1", Component: StringInputGroup, validate: required }), _jsx(Field, { name: "address2", placeholder: "Address, Line 2", label: "Address 2", Component: StringInputGroup }), _jsx(Field, { name: "city", placeholder: "City", label: "City", Component: StringInputGroup, validate: required }), _jsx(Field, { name: "state", placeholder: "State", label: "State", Component: SingleStringSelectGroup, options: UsStates, validate: required }), _jsx(Field, { name: "zipCode", placeholder: "Zip", label: "Zip", Component: StringInputGroup, normalize: zipCodeNormalizer, validate: [required, zipCodeValidator] })] }) }));
|
20
|
-
}
|
@@ -1,53 +0,0 @@
|
|
1
|
-
var states = [
|
2
|
-
{ label: 'Alabama', value: 'AL' },
|
3
|
-
{ label: 'Alaska', value: 'AK' },
|
4
|
-
{ label: 'Arizona', value: 'AZ' },
|
5
|
-
{ label: 'Arkansas', value: 'AR' },
|
6
|
-
{ label: 'California', value: 'CA' },
|
7
|
-
{ label: 'Colorado', value: 'CO' },
|
8
|
-
{ label: 'Connecticut', value: 'CT' },
|
9
|
-
{ label: 'Delaware', value: 'DE' },
|
10
|
-
{ label: 'Florida', value: 'FL' },
|
11
|
-
{ label: 'Georgia', value: 'GA' },
|
12
|
-
{ label: 'Hawaii', value: 'HI' },
|
13
|
-
{ label: 'Idaho', value: 'ID' },
|
14
|
-
{ label: 'Illinois', value: 'IL' },
|
15
|
-
{ label: 'Indiana', value: 'IN' },
|
16
|
-
{ label: 'Iowa', value: 'IA' },
|
17
|
-
{ label: 'Kansas', value: 'KS' },
|
18
|
-
{ label: 'Kentucky', value: 'KY' },
|
19
|
-
{ label: 'Louisiana', value: 'LA' },
|
20
|
-
{ label: 'Maine', value: 'ME' },
|
21
|
-
{ label: 'Maryland', value: 'MD' },
|
22
|
-
{ label: 'Massachusetts', value: 'MA' },
|
23
|
-
{ label: 'Michigan', value: 'MI' },
|
24
|
-
{ label: 'Minnesota', value: 'MN' },
|
25
|
-
{ label: 'Mississippi', value: 'MS' },
|
26
|
-
{ label: 'Missouri', value: 'MO' },
|
27
|
-
{ label: 'Montana', value: 'MT' },
|
28
|
-
{ label: 'Nebraska', value: 'NE' },
|
29
|
-
{ label: 'Nevada', value: 'NV' },
|
30
|
-
{ label: 'New Hampshire', value: 'NH' },
|
31
|
-
{ label: 'New Jersey', value: 'NJ' },
|
32
|
-
{ label: 'New Mexico', value: 'NM' },
|
33
|
-
{ label: 'New York', value: 'NY' },
|
34
|
-
{ label: 'North Carolina', value: 'NC' },
|
35
|
-
{ label: 'North Dakota', value: 'ND' },
|
36
|
-
{ label: 'Ohio', value: 'OH' },
|
37
|
-
{ label: 'Oklahoma', value: 'OK' },
|
38
|
-
{ label: 'Oregon', value: 'OR' },
|
39
|
-
{ label: 'Pennsylvania', value: 'PA' },
|
40
|
-
{ label: 'Rhode Island', value: 'RI' },
|
41
|
-
{ label: 'South Carolina', value: 'SC' },
|
42
|
-
{ label: 'South Dakota', value: 'SD' },
|
43
|
-
{ label: 'Tennessee', value: 'TN' },
|
44
|
-
{ label: 'Texas', value: 'TX' },
|
45
|
-
{ label: 'Utah', value: 'UT' },
|
46
|
-
{ label: 'Vermont', value: 'VT' },
|
47
|
-
{ label: 'Virginia', value: 'VA' },
|
48
|
-
{ label: 'Washington', value: 'WA' },
|
49
|
-
{ label: 'West Virginia', value: 'WV' },
|
50
|
-
{ label: 'Wisconsin', value: 'WI' },
|
51
|
-
{ label: 'Wyoming', value: 'WY' },
|
52
|
-
];
|
53
|
-
export default states;
|
@@ -1,26 +0,0 @@
|
|
1
|
-
import React, { MouseEventHandler } from 'react';
|
2
|
-
import { useAxiosRequestProps } from 'envoc-request';
|
3
|
-
export interface ConfirmBaseFormProps {
|
4
|
-
/** Function to run when cancel button is clicked. */
|
5
|
-
handleCancel?: MouseEventHandler<HTMLButtonElement>;
|
6
|
-
/** Axios request upon confirmation */
|
7
|
-
request: useAxiosRequestProps;
|
8
|
-
style?: React.CSSProperties;
|
9
|
-
/** `<h3/>` title text on top of the form. */
|
10
|
-
title?: string;
|
11
|
-
/** Custom confirm button text.
|
12
|
-
* @defaultValue `Confirm`
|
13
|
-
*/
|
14
|
-
confirmButtonText?: string;
|
15
|
-
/** CSS class for the buttons. */
|
16
|
-
confirmButtonClass?: string;
|
17
|
-
/** Any components to be rendered in between the title and the buttons. */
|
18
|
-
children?: React.ReactNode;
|
19
|
-
}
|
20
|
-
/**
|
21
|
-
* Confimation dialog. Navigates to a different route to allow the user to either confirm or cancel an action.
|
22
|
-
* Commonly used for confirming delete and archive.
|
23
|
-
*
|
24
|
-
* See `<ConfirmDeleteForm/>` if the confirmation is specifically for deletion.
|
25
|
-
*/
|
26
|
-
export default function ConfirmBaseForm({ handleCancel, request, style, title, confirmButtonText, confirmButtonClass, children, ...props }: ConfirmBaseFormProps): import("react/jsx-runtime").JSX.Element;
|
@@ -1,42 +0,0 @@
|
|
1
|
-
var __assign = (this && this.__assign) || function () {
|
2
|
-
__assign = Object.assign || function(t) {
|
3
|
-
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
4
|
-
s = arguments[i];
|
5
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
6
|
-
t[p] = s[p];
|
7
|
-
}
|
8
|
-
return t;
|
9
|
-
};
|
10
|
-
return __assign.apply(this, arguments);
|
11
|
-
};
|
12
|
-
var __rest = (this && this.__rest) || function (s, e) {
|
13
|
-
var t = {};
|
14
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
15
|
-
t[p] = s[p];
|
16
|
-
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
17
|
-
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
18
|
-
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
19
|
-
t[p[i]] = s[p[i]];
|
20
|
-
}
|
21
|
-
return t;
|
22
|
-
};
|
23
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
24
|
-
import classNames from 'classnames';
|
25
|
-
import { useAxiosRequest } from 'envoc-request';
|
26
|
-
import { FormDefaults } from '../FormDefaults';
|
27
|
-
// TODO: ask about how we should use 'children'
|
28
|
-
/**
|
29
|
-
* Confimation dialog. Navigates to a different route to allow the user to either confirm or cancel an action.
|
30
|
-
* Commonly used for confirming delete and archive.
|
31
|
-
*
|
32
|
-
* See `<ConfirmDeleteForm/>` if the confirmation is specifically for deletion.
|
33
|
-
*/
|
34
|
-
export default function ConfirmBaseForm(_a) {
|
35
|
-
var handleCancel = _a.handleCancel, request = _a.request, style = _a.style, title = _a.title, confirmButtonText = _a.confirmButtonText, confirmButtonClass = _a.confirmButtonClass, children = _a.children, props = __rest(_a, ["handleCancel", "request", "style", "title", "confirmButtonText", "confirmButtonClass", "children"]);
|
36
|
-
var webRequest = useAxiosRequest(Object.assign({}, request, { autoExecute: false }));
|
37
|
-
var onCancel = handleCancel !== null && handleCancel !== void 0 ? handleCancel : goBack;
|
38
|
-
return (_jsxs("div", __assign({ style: __assign({ textAlign: 'center' }, style) }, props, { children: [_jsx("h3", { children: title }), children, _jsx("button", { className: classNames(confirmButtonClass !== null && confirmButtonClass !== void 0 ? confirmButtonClass : FormDefaults.cssClassPrefix + 'confirm-base-form-confirm-button'), type: "button", onClick: webRequest.submitRequest, children: confirmButtonText !== null && confirmButtonText !== void 0 ? confirmButtonText : 'Confirm' }), _jsx("button", { className: classNames(FormDefaults.cssClassPrefix + 'confirm-base-form-cancel-button'), type: "button", onClick: onCancel, children: "Cancel" })] })));
|
39
|
-
function goBack() {
|
40
|
-
window.history.back();
|
41
|
-
}
|
42
|
-
}
|
@@ -1,24 +0,0 @@
|
|
1
|
-
import React from 'react';
|
2
|
-
import { ConfirmBaseFormProps } from '../ConfirmBaseForm/ConfirmBaseForm';
|
3
|
-
export interface ConfirmDeleteFormProps extends Pick<ConfirmBaseFormProps, 'style'> {
|
4
|
-
/** Url to navigate to on success. */
|
5
|
-
successUrl?: string;
|
6
|
-
/** Form name (key) to apply the confirmation on. */
|
7
|
-
form: string;
|
8
|
-
/** Custom message to display.
|
9
|
-
* @defaultValue `Are you sure you want to delete this?`
|
10
|
-
*/
|
11
|
-
title?: string;
|
12
|
-
/** Custom function when the axios request succeeds. */
|
13
|
-
handleComplete?: Function;
|
14
|
-
/** Custom function when the axios request fails. */
|
15
|
-
handleError?: Function;
|
16
|
-
/** Any components to be rendered in between the title and the buttons. */
|
17
|
-
children?: React.ReactNode;
|
18
|
-
}
|
19
|
-
/**
|
20
|
-
* Deletion confirmation. Navigates to a different route to allow the user to either confirm or cancel an action.
|
21
|
-
*
|
22
|
-
* Wraps `<ConfirmBaseForm/>`.
|
23
|
-
*/
|
24
|
-
export default function ConfirmDeleteForm({ successUrl, form, title, handleComplete, handleError, children, ...props }: ConfirmDeleteFormProps): import("react/jsx-runtime").JSX.Element;
|
@@ -1,60 +0,0 @@
|
|
1
|
-
var __assign = (this && this.__assign) || function () {
|
2
|
-
__assign = Object.assign || function(t) {
|
3
|
-
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
4
|
-
s = arguments[i];
|
5
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
6
|
-
t[p] = s[p];
|
7
|
-
}
|
8
|
-
return t;
|
9
|
-
};
|
10
|
-
return __assign.apply(this, arguments);
|
11
|
-
};
|
12
|
-
var __rest = (this && this.__rest) || function (s, e) {
|
13
|
-
var t = {};
|
14
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
15
|
-
t[p] = s[p];
|
16
|
-
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
17
|
-
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
18
|
-
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
19
|
-
t[p[i]] = s[p[i]];
|
20
|
-
}
|
21
|
-
return t;
|
22
|
-
};
|
23
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
24
|
-
import { useNavigate, useParams } from 'react-router-dom';
|
25
|
-
import { toast } from 'react-toastify';
|
26
|
-
import ConfirmBaseForm from '../ConfirmBaseForm/ConfirmBaseForm';
|
27
|
-
import { FormDefaults } from '../FormDefaults';
|
28
|
-
/**
|
29
|
-
* Deletion confirmation. Navigates to a different route to allow the user to either confirm or cancel an action.
|
30
|
-
*
|
31
|
-
* Wraps `<ConfirmBaseForm/>`.
|
32
|
-
*/
|
33
|
-
export default function ConfirmDeleteForm(_a) {
|
34
|
-
var successUrl = _a.successUrl, form = _a.form, title = _a.title, handleComplete = _a.handleComplete, handleError = _a.handleError, children = _a.children, props = __rest(_a, ["successUrl", "form", "title", "handleComplete", "handleError", "children"]);
|
35
|
-
var navigate = useNavigate();
|
36
|
-
var entityId = useParams().entityId;
|
37
|
-
var onComplete = handleComplete !== null && handleComplete !== void 0 ? handleComplete : function () {
|
38
|
-
toast.success('Deleted!');
|
39
|
-
goBack();
|
40
|
-
};
|
41
|
-
var onError = handleError !== null && handleError !== void 0 ? handleError : function (error) {
|
42
|
-
var _a, _b, _c, _d;
|
43
|
-
toast.error((_d = (_c = (_b = (_a = error.response) === null || _a === void 0 ? void 0 : _a.data) === null || _b === void 0 ? void 0 : _b.validationFailures[0]) === null || _c === void 0 ? void 0 : _c.errorMessage) !== null && _d !== void 0 ? _d : 'Something went wrong talking to the portal. Contact support if this continues.');
|
44
|
-
};
|
45
|
-
var request = {
|
46
|
-
method: 'delete',
|
47
|
-
url: "/api/".concat(form, "/").concat(entityId),
|
48
|
-
onComplete: onComplete,
|
49
|
-
onError: onError,
|
50
|
-
};
|
51
|
-
return (_jsx(ConfirmBaseForm, __assign({ request: request, handleCancel: goBack, title: title !== null && title !== void 0 ? title : 'Are you sure you want to delete this?', confirmButtonText: "Yes", confirmButtonClass: FormDefaults.cssClassPrefix + 'confirm-delete-form-yes-button' }, props, { children: children })));
|
52
|
-
function goBack() {
|
53
|
-
if (successUrl) {
|
54
|
-
navigate(successUrl);
|
55
|
-
}
|
56
|
-
else {
|
57
|
-
navigate(-1);
|
58
|
-
}
|
59
|
-
}
|
60
|
-
}
|
@@ -1,13 +0,0 @@
|
|
1
|
-
import { DatePickerProps } from 'react-date-picker/dist/entry.nostyle';
|
2
|
-
import { InjectedFieldProps } from '../Field/InjectedFieldProps';
|
3
|
-
import { GroupProps } from '../Group';
|
4
|
-
export interface DatePickerGroupProps<T> extends InjectedFieldProps<T | undefined | null>, Omit<DatePickerProps, keyof InjectedFieldProps<T> | 'name' | 'value' | 'className'>, Omit<GroupProps, keyof InjectedFieldProps<T> | 'children'> {
|
5
|
-
convert: (arg: Date) => T;
|
6
|
-
}
|
7
|
-
/**
|
8
|
-
* Field for inputting dates. Uses `<Group/>` and `<DatePicker/>`.
|
9
|
-
*
|
10
|
-
* Uses [react-date-picker](https://www.npmjs.com/package/react-date-picker)
|
11
|
-
*/
|
12
|
-
export default function DatePickerGroup<T>({ input, meta, label, helpText, className, required, disabled, convert, ...rest }: DatePickerGroupProps<T>): import("react/jsx-runtime").JSX.Element;
|
13
|
-
export declare function convertToTimeZoneInsensitiveISOString(date: Date): string;
|
@@ -1,87 +0,0 @@
|
|
1
|
-
var __assign = (this && this.__assign) || function () {
|
2
|
-
__assign = Object.assign || function(t) {
|
3
|
-
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
4
|
-
s = arguments[i];
|
5
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
6
|
-
t[p] = s[p];
|
7
|
-
}
|
8
|
-
return t;
|
9
|
-
};
|
10
|
-
return __assign.apply(this, arguments);
|
11
|
-
};
|
12
|
-
var __rest = (this && this.__rest) || function (s, e) {
|
13
|
-
var t = {};
|
14
|
-
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
15
|
-
t[p] = s[p];
|
16
|
-
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
17
|
-
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
18
|
-
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
19
|
-
t[p[i]] = s[p[i]];
|
20
|
-
}
|
21
|
-
return t;
|
22
|
-
};
|
23
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
24
|
-
import { useEffect, useState } from 'react';
|
25
|
-
import DatePicker from 'react-date-picker/dist/entry.nostyle';
|
26
|
-
import classnames from 'classnames';
|
27
|
-
import parseISO from 'date-fns/parseISO';
|
28
|
-
import { FormDefaults } from '../FormDefaults';
|
29
|
-
import Group from '../Group';
|
30
|
-
/**
|
31
|
-
* Field for inputting dates. Uses `<Group/>` and `<DatePicker/>`.
|
32
|
-
*
|
33
|
-
* Uses [react-date-picker](https://www.npmjs.com/package/react-date-picker)
|
34
|
-
*/
|
35
|
-
export default function DatePickerGroup(_a) {
|
36
|
-
var input = _a.input, meta = _a.meta, label = _a.label, helpText = _a.helpText, className = _a.className, required = _a.required, disabled = _a.disabled, convert = _a.convert, rest = __rest(_a, ["input", "meta", "label", "helpText", "className", "required", "disabled", "convert"]);
|
37
|
-
var _b = useState(null), displayDate = _b[0], setDisplayDate = _b[1];
|
38
|
-
useEffect(function () {
|
39
|
-
if (!input.value) {
|
40
|
-
setDisplayDate(null);
|
41
|
-
}
|
42
|
-
else if (typeof input.value === 'string') {
|
43
|
-
if (input.value.indexOf('T') === -1) {
|
44
|
-
setDisplayDate(new Date("".concat(input.value, "T00:00:00.000")));
|
45
|
-
}
|
46
|
-
else {
|
47
|
-
setDisplayDate(new Date(input.value));
|
48
|
-
}
|
49
|
-
}
|
50
|
-
}, [setDisplayDate, input.value]);
|
51
|
-
return (_jsx(Group, { input: input, meta: meta, label: label, helpText: helpText, className: classnames(className, FormDefaults.cssClassPrefix + 'date-picker'), required: required, disabled: disabled, children: _jsx(DatePicker, __assign({}, rest, { className: classnames(FormDefaults.cssClassPrefix + 'date-picker', className), value: displayDate, onChange: handleChange })) }));
|
52
|
-
function handleChange(e) {
|
53
|
-
var onChange = input.onChange;
|
54
|
-
if (onChange === null) {
|
55
|
-
return;
|
56
|
-
}
|
57
|
-
if (!e) {
|
58
|
-
onChange(undefined);
|
59
|
-
setDisplayDate(null);
|
60
|
-
return;
|
61
|
-
}
|
62
|
-
else if (typeof e === 'string') {
|
63
|
-
var parsedValue = parseISO(e.toString().split('T')[0]);
|
64
|
-
setDisplayDate(parsedValue);
|
65
|
-
onChange(convert(parsedValue));
|
66
|
-
}
|
67
|
-
else if (e instanceof Date) {
|
68
|
-
var parsedValue = parseISO(convertToTimeZoneInsensitiveISOString(e).split('T')[0]);
|
69
|
-
setDisplayDate(parsedValue);
|
70
|
-
onChange(convert(parsedValue));
|
71
|
-
}
|
72
|
-
else {
|
73
|
-
// e is instanceof Date[]
|
74
|
-
var parsedValue = parseISO(convertToTimeZoneInsensitiveISOString(e[0]).split('T')[0]);
|
75
|
-
setDisplayDate(parsedValue);
|
76
|
-
onChange(convert(parsedValue));
|
77
|
-
}
|
78
|
-
}
|
79
|
-
}
|
80
|
-
export function convertToTimeZoneInsensitiveISOString(date) {
|
81
|
-
var year = new Intl.DateTimeFormat('en', { year: 'numeric' })
|
82
|
-
.format(date)
|
83
|
-
.padStart(4, '0');
|
84
|
-
var month = new Intl.DateTimeFormat('en', { month: '2-digit' }).format(date);
|
85
|
-
var day = new Intl.DateTimeFormat('en', { day: '2-digit' }).format(date);
|
86
|
-
return "".concat(year, "-").concat(month, "-").concat(day, "T00:00:00.000Z");
|
87
|
-
}
|
@@ -1 +0,0 @@
|
|
1
|
-
export {};
|
@@ -1,9 +0,0 @@
|
|
1
|
-
import { DatePickerHelper } from './DatePickerHelper';
|
2
|
-
export interface StringDateOnlyPickerGroupProps extends DatePickerHelper<string | undefined | null> {
|
3
|
-
}
|
4
|
-
/**
|
5
|
-
* Date picker input that consumes and outputs as a date only string in ISO format `YYYY-MM-DD`.
|
6
|
-
*
|
7
|
-
* Default display to the user is in `MM/DD/YYYY` format.
|
8
|
-
*/
|
9
|
-
export default function StringDatePickerGroup(props: StringDateOnlyPickerGroupProps): import("react/jsx-runtime").JSX.Element;
|