envoc-form 5.0.9 → 6.0.1-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.
Files changed (352) hide show
  1. package/README.md +4930 -1645
  2. package/dist/index.cjs +25531 -0
  3. package/dist/index.d.ts +624 -0
  4. package/dist/index.js +25461 -0
  5. package/package.json +73 -77
  6. package/dist/css/envoc-form-styles.css +0 -3
  7. package/dist/css/envoc-form-styles.css.map +0 -1
  8. package/es/AddressInput/AddressInput.d.ts +0 -24
  9. package/es/AddressInput/AddressInput.js +0 -20
  10. package/es/AddressInput/UsStates.d.ts +0 -3
  11. package/es/AddressInput/UsStates.js +0 -53
  12. package/es/ConfirmBaseForm/ConfirmBaseForm.d.ts +0 -26
  13. package/es/ConfirmBaseForm/ConfirmBaseForm.js +0 -42
  14. package/es/ConfirmDeleteForm/ConfirmDeleteForm.d.ts +0 -24
  15. package/es/ConfirmDeleteForm/ConfirmDeleteForm.js +0 -60
  16. package/es/DatePicker/DatePickerGroup.d.ts +0 -13
  17. package/es/DatePicker/DatePickerGroup.js +0 -88
  18. package/es/DatePicker/DatePickerHelper.d.ts +0 -3
  19. package/es/DatePicker/DatePickerHelper.js +0 -1
  20. package/es/DatePicker/StringDateOnlyPickerGroup.d.ts +0 -9
  21. package/es/DatePicker/StringDateOnlyPickerGroup.js +0 -29
  22. package/es/DatePicker/StringDatePickerGroup.d.ts +0 -9
  23. package/es/DatePicker/StringDatePickerGroup.js +0 -24
  24. package/es/DateTimePicker/DateTimePickerGroup.d.ts +0 -12
  25. package/es/DateTimePicker/DateTimePickerGroup.js +0 -87
  26. package/es/DateTimePicker/DateTimePickerHelper.d.ts +0 -3
  27. package/es/DateTimePicker/DateTimePickerHelper.js +0 -1
  28. package/es/DateTimePicker/StringDateTimePickerGroup.d.ts +0 -9
  29. package/es/DateTimePicker/StringDateTimePickerGroup.js +0 -53
  30. package/es/Field/CustomFieldInputProps.d.ts +0 -7
  31. package/es/Field/CustomFieldInputProps.js +0 -1
  32. package/es/Field/CustomFieldMetaProps.d.ts +0 -4
  33. package/es/Field/CustomFieldMetaProps.js +0 -1
  34. package/es/Field/Field.d.ts +0 -29
  35. package/es/Field/Field.js +0 -59
  36. package/es/Field/FieldErrorScrollTarget.d.ts +0 -2
  37. package/es/Field/FieldErrorScrollTarget.js +0 -12
  38. package/es/Field/FieldNameContext.d.ts +0 -3
  39. package/es/Field/FieldNameContext.js +0 -3
  40. package/es/Field/FieldSection.d.ts +0 -7
  41. package/es/Field/FieldSection.js +0 -9
  42. package/es/Field/InjectedFieldProps.d.ts +0 -7
  43. package/es/Field/InjectedFieldProps.js +0 -1
  44. package/es/Field/StandAloneInput.d.ts +0 -13
  45. package/es/Field/StandAloneInput.js +0 -50
  46. package/es/Field/useStandardField.d.ts +0 -21
  47. package/es/Field/useStandardField.js +0 -92
  48. package/es/FieldArray/FieldArray.d.ts +0 -24
  49. package/es/FieldArray/FieldArray.js +0 -77
  50. package/es/File/FileGroup.d.ts +0 -10
  51. package/es/File/FileGroup.js +0 -53
  52. package/es/File/FileList.d.ts +0 -5
  53. package/es/File/FileList.js +0 -10
  54. package/es/File/humanFileSize.d.ts +0 -1
  55. package/es/File/humanFileSize.js +0 -6
  56. package/es/Form/FocusError.d.ts +0 -7
  57. package/es/Form/FocusError.js +0 -42
  58. package/es/Form/Form.d.ts +0 -33
  59. package/es/Form/Form.js +0 -141
  60. package/es/Form/FormBasedPreventNavigation.d.ts +0 -6
  61. package/es/Form/FormBasedPreventNavigation.js +0 -20
  62. package/es/Form/LegacyFormBasedPreventNavigation.d.ts +0 -17
  63. package/es/Form/LegacyFormBasedPreventNavigation.js +0 -69
  64. package/es/Form/NewFormBasedPreventNavigation.d.ts +0 -14
  65. package/es/Form/NewFormBasedPreventNavigation.js +0 -39
  66. package/es/Form/ServerErrorContext.d.ts +0 -11
  67. package/es/Form/ServerErrorContext.js +0 -9
  68. package/es/FormActions.d.ts +0 -12
  69. package/es/FormActions.js +0 -16
  70. package/es/FormDefaults.d.ts +0 -4
  71. package/es/FormDefaults.js +0 -2
  72. package/es/Group.d.ts +0 -16
  73. package/es/Group.js +0 -14
  74. package/es/Input/CheckboxGroup.d.ts +0 -6
  75. package/es/Input/CheckboxGroup.js +0 -14
  76. package/es/Input/CheckboxInputGroup.d.ts +0 -13
  77. package/es/Input/CheckboxInputGroup.js +0 -41
  78. package/es/Input/IconInputGroup.d.ts +0 -12
  79. package/es/Input/IconInputGroup.js +0 -43
  80. package/es/Input/InputGroup.d.ts +0 -12
  81. package/es/Input/InputGroup.js +0 -34
  82. package/es/Input/MoneyInputGroup.d.ts +0 -9
  83. package/es/Input/MoneyInputGroup.js +0 -43
  84. package/es/Input/NumberInputGroup.d.ts +0 -9
  85. package/es/Input/NumberInputGroup.js +0 -43
  86. package/es/Input/PhoneNumberInputGroup.d.ts +0 -10
  87. package/es/Input/PhoneNumberInputGroup.js +0 -47
  88. package/es/Input/StringInputGroup.d.ts +0 -8
  89. package/es/Input/StringInputGroup.js +0 -43
  90. package/es/Normalization/NormalizationFunction.d.ts +0 -4
  91. package/es/Normalization/NormalizationFunction.js +0 -1
  92. package/es/Normalization/normalizers.d.ts +0 -4
  93. package/es/Normalization/normalizers.js +0 -32
  94. package/es/Select/BooleanSelectGroup.d.ts +0 -7
  95. package/es/Select/BooleanSelectGroup.js +0 -28
  96. package/es/Select/NumberSelectGroup.d.ts +0 -9
  97. package/es/Select/NumberSelectGroup.js +0 -21
  98. package/es/Select/SelectGroup.d.ts +0 -29
  99. package/es/Select/SelectGroup.js +0 -65
  100. package/es/Select/SelectGroupPropsHelper.d.ts +0 -3
  101. package/es/Select/SelectGroupPropsHelper.js +0 -1
  102. package/es/Select/StringSelectGroup.d.ts +0 -9
  103. package/es/Select/StringSelectGroup.js +0 -21
  104. package/es/StandardFormActions.d.ts +0 -11
  105. package/es/StandardFormActions.js +0 -14
  106. package/es/SubmitFormButton.d.ts +0 -10
  107. package/es/SubmitFormButton.js +0 -40
  108. package/es/TextArea/TextAreaGroup.d.ts +0 -9
  109. package/es/TextArea/TextAreaGroup.js +0 -35
  110. package/es/Validation/ValidatedApiResult.d.ts +0 -6
  111. package/es/Validation/ValidatedApiResult.js +0 -1
  112. package/es/Validation/ValidationError.d.ts +0 -5
  113. package/es/Validation/ValidationError.js +0 -1
  114. package/es/Validation/ValidationFunction.d.ts +0 -4
  115. package/es/Validation/ValidationFunction.js +0 -1
  116. package/es/Validation/validators.d.ts +0 -18
  117. package/es/Validation/validators.js +0 -77
  118. package/es/index.d.ts +0 -81
  119. package/es/index.js +0 -55
  120. package/es/setupTests.d.ts +0 -1
  121. package/es/setupTests.js +0 -1
  122. package/es/utils/objectContainsNonSerializableProperty.d.ts +0 -1
  123. package/es/utils/objectContainsNonSerializableProperty.js +0 -14
  124. package/es/utils/objectToFormData.d.ts +0 -10
  125. package/es/utils/objectToFormData.js +0 -77
  126. package/es/utils/typeChecks.d.ts +0 -8
  127. package/es/utils/typeChecks.js +0 -18
  128. package/lib/AddressInput/AddressInput.d.ts +0 -24
  129. package/lib/AddressInput/AddressInput.js +0 -26
  130. package/lib/AddressInput/UsStates.d.ts +0 -3
  131. package/lib/AddressInput/UsStates.js +0 -55
  132. package/lib/ConfirmBaseForm/ConfirmBaseForm.d.ts +0 -26
  133. package/lib/ConfirmBaseForm/ConfirmBaseForm.js +0 -45
  134. package/lib/ConfirmDeleteForm/ConfirmDeleteForm.d.ts +0 -24
  135. package/lib/ConfirmDeleteForm/ConfirmDeleteForm.js +0 -66
  136. package/lib/DatePicker/DatePickerGroup.d.ts +0 -13
  137. package/lib/DatePicker/DatePickerGroup.js +0 -96
  138. package/lib/DatePicker/DatePickerHelper.d.ts +0 -3
  139. package/lib/DatePicker/DatePickerHelper.js +0 -2
  140. package/lib/DatePicker/StringDateOnlyPickerGroup.d.ts +0 -9
  141. package/lib/DatePicker/StringDateOnlyPickerGroup.js +0 -35
  142. package/lib/DatePicker/StringDatePickerGroup.d.ts +0 -9
  143. package/lib/DatePicker/StringDatePickerGroup.js +0 -30
  144. package/lib/DateTimePicker/DateTimePickerGroup.d.ts +0 -12
  145. package/lib/DateTimePicker/DateTimePickerGroup.js +0 -93
  146. package/lib/DateTimePicker/DateTimePickerHelper.d.ts +0 -3
  147. package/lib/DateTimePicker/DateTimePickerHelper.js +0 -2
  148. package/lib/DateTimePicker/StringDateTimePickerGroup.d.ts +0 -9
  149. package/lib/DateTimePicker/StringDateTimePickerGroup.js +0 -59
  150. package/lib/Field/CustomFieldInputProps.d.ts +0 -7
  151. package/lib/Field/CustomFieldInputProps.js +0 -2
  152. package/lib/Field/CustomFieldMetaProps.d.ts +0 -4
  153. package/lib/Field/CustomFieldMetaProps.js +0 -2
  154. package/lib/Field/Field.d.ts +0 -29
  155. package/lib/Field/Field.js +0 -64
  156. package/lib/Field/FieldErrorScrollTarget.d.ts +0 -2
  157. package/lib/Field/FieldErrorScrollTarget.js +0 -15
  158. package/lib/Field/FieldNameContext.d.ts +0 -3
  159. package/lib/Field/FieldNameContext.js +0 -9
  160. package/lib/Field/FieldSection.d.ts +0 -7
  161. package/lib/Field/FieldSection.js +0 -12
  162. package/lib/Field/InjectedFieldProps.d.ts +0 -7
  163. package/lib/Field/InjectedFieldProps.js +0 -2
  164. package/lib/Field/StandAloneInput.d.ts +0 -13
  165. package/lib/Field/StandAloneInput.js +0 -76
  166. package/lib/Field/useStandardField.d.ts +0 -21
  167. package/lib/Field/useStandardField.js +0 -95
  168. package/lib/FieldArray/FieldArray.d.ts +0 -24
  169. package/lib/FieldArray/FieldArray.js +0 -83
  170. package/lib/File/FileGroup.d.ts +0 -10
  171. package/lib/File/FileGroup.js +0 -58
  172. package/lib/File/FileList.d.ts +0 -5
  173. package/lib/File/FileList.js +0 -13
  174. package/lib/File/humanFileSize.d.ts +0 -1
  175. package/lib/File/humanFileSize.js +0 -10
  176. package/lib/Form/FocusError.d.ts +0 -7
  177. package/lib/Form/FocusError.js +0 -48
  178. package/lib/Form/Form.d.ts +0 -33
  179. package/lib/Form/Form.js +0 -147
  180. package/lib/Form/FormBasedPreventNavigation.d.ts +0 -6
  181. package/lib/Form/FormBasedPreventNavigation.js +0 -26
  182. package/lib/Form/LegacyFormBasedPreventNavigation.d.ts +0 -17
  183. package/lib/Form/LegacyFormBasedPreventNavigation.js +0 -72
  184. package/lib/Form/NewFormBasedPreventNavigation.d.ts +0 -14
  185. package/lib/Form/NewFormBasedPreventNavigation.js +0 -42
  186. package/lib/Form/ServerErrorContext.d.ts +0 -11
  187. package/lib/Form/ServerErrorContext.js +0 -15
  188. package/lib/FormActions.d.ts +0 -12
  189. package/lib/FormActions.js +0 -22
  190. package/lib/FormDefaults.d.ts +0 -4
  191. package/lib/FormDefaults.js +0 -5
  192. package/lib/Group.d.ts +0 -16
  193. package/lib/Group.js +0 -20
  194. package/lib/Input/CheckboxGroup.d.ts +0 -6
  195. package/lib/Input/CheckboxGroup.js +0 -20
  196. package/lib/Input/CheckboxInputGroup.d.ts +0 -13
  197. package/lib/Input/CheckboxInputGroup.js +0 -46
  198. package/lib/Input/IconInputGroup.d.ts +0 -12
  199. package/lib/Input/IconInputGroup.js +0 -48
  200. package/lib/Input/InputGroup.d.ts +0 -12
  201. package/lib/Input/InputGroup.js +0 -39
  202. package/lib/Input/MoneyInputGroup.d.ts +0 -9
  203. package/lib/Input/MoneyInputGroup.js +0 -48
  204. package/lib/Input/NumberInputGroup.d.ts +0 -9
  205. package/lib/Input/NumberInputGroup.js +0 -48
  206. package/lib/Input/PhoneNumberInputGroup.d.ts +0 -10
  207. package/lib/Input/PhoneNumberInputGroup.js +0 -52
  208. package/lib/Input/StringInputGroup.d.ts +0 -8
  209. package/lib/Input/StringInputGroup.js +0 -48
  210. package/lib/Normalization/NormalizationFunction.d.ts +0 -4
  211. package/lib/Normalization/NormalizationFunction.js +0 -2
  212. package/lib/Normalization/normalizers.d.ts +0 -4
  213. package/lib/Normalization/normalizers.js +0 -37
  214. package/lib/Select/BooleanSelectGroup.d.ts +0 -7
  215. package/lib/Select/BooleanSelectGroup.js +0 -35
  216. package/lib/Select/NumberSelectGroup.d.ts +0 -9
  217. package/lib/Select/NumberSelectGroup.js +0 -29
  218. package/lib/Select/SelectGroup.d.ts +0 -29
  219. package/lib/Select/SelectGroup.js +0 -71
  220. package/lib/Select/SelectGroupPropsHelper.d.ts +0 -3
  221. package/lib/Select/SelectGroupPropsHelper.js +0 -2
  222. package/lib/Select/StringSelectGroup.d.ts +0 -9
  223. package/lib/Select/StringSelectGroup.js +0 -29
  224. package/lib/StandardFormActions.d.ts +0 -11
  225. package/lib/StandardFormActions.js +0 -20
  226. package/lib/SubmitFormButton.d.ts +0 -10
  227. package/lib/SubmitFormButton.js +0 -45
  228. package/lib/TextArea/TextAreaGroup.d.ts +0 -9
  229. package/lib/TextArea/TextAreaGroup.js +0 -40
  230. package/lib/Validation/ValidatedApiResult.d.ts +0 -6
  231. package/lib/Validation/ValidatedApiResult.js +0 -2
  232. package/lib/Validation/ValidationError.d.ts +0 -5
  233. package/lib/Validation/ValidationError.js +0 -2
  234. package/lib/Validation/ValidationFunction.d.ts +0 -4
  235. package/lib/Validation/ValidationFunction.js +0 -2
  236. package/lib/Validation/validators.d.ts +0 -18
  237. package/lib/Validation/validators.js +0 -90
  238. package/lib/index.d.ts +0 -81
  239. package/lib/index.js +0 -126
  240. package/lib/setupTests.d.ts +0 -1
  241. package/lib/setupTests.js +0 -3
  242. package/lib/utils/objectContainsNonSerializableProperty.d.ts +0 -1
  243. package/lib/utils/objectContainsNonSerializableProperty.js +0 -17
  244. package/lib/utils/objectToFormData.d.ts +0 -10
  245. package/lib/utils/objectToFormData.js +0 -79
  246. package/lib/utils/typeChecks.d.ts +0 -8
  247. package/lib/utils/typeChecks.js +0 -29
  248. package/src/AddressInput/AddressInput.test.tsx +0 -27
  249. package/src/AddressInput/AddressInput.tsx +0 -82
  250. package/src/AddressInput/UsStates.ts +0 -55
  251. package/src/AddressInput/__snapshots__/AddressInput.test.tsx.snap +0 -183
  252. package/src/ConfirmBaseForm/ConfirmBaseForm.test.tsx +0 -24
  253. package/src/ConfirmBaseForm/ConfirmBaseForm.tsx +0 -74
  254. package/src/ConfirmBaseForm/__snapshots__/ConfirmBaseForm.test.tsx.snap +0 -23
  255. package/src/ConfirmDeleteForm/ConfirmDeleteForm.test.tsx +0 -24
  256. package/src/ConfirmDeleteForm/ConfirmDeleteForm.tsx +0 -87
  257. package/src/ConfirmDeleteForm/__snapshots__/ConfirmDeleteForm.test.tsx.snap +0 -25
  258. package/src/DatePicker/DatePicker.test.tsx +0 -48
  259. package/src/DatePicker/DatePickerGroup.tsx +0 -115
  260. package/src/DatePicker/DatePickerHelper.ts +0 -4
  261. package/src/DatePicker/StringDateOnlyPickerGroup.tsx +0 -28
  262. package/src/DatePicker/StringDatePickerGroup.tsx +0 -20
  263. package/src/DatePicker/__snapshots__/DatePicker.test.tsx.snap +0 -152
  264. package/src/DateTimePicker/DateTimePicker.test.tsx +0 -243
  265. package/src/DateTimePicker/DateTimePickerGroup.tsx +0 -116
  266. package/src/DateTimePicker/DateTimePickerHelper.ts +0 -4
  267. package/src/DateTimePicker/StringDateTimePickerGroup.tsx +0 -61
  268. package/src/DateTimePicker/__snapshots__/DateTimePicker.test.tsx.snap +0 -217
  269. package/src/Field/CustomFieldInputProps.ts +0 -10
  270. package/src/Field/CustomFieldMetaProps.ts +0 -5
  271. package/src/Field/Field.tsx +0 -127
  272. package/src/Field/FieldErrorScrollTarget.tsx +0 -12
  273. package/src/Field/FieldNameContext.ts +0 -6
  274. package/src/Field/FieldSection.tsx +0 -18
  275. package/src/Field/InjectedFieldProps.ts +0 -8
  276. package/src/Field/StandAloneInput.tsx +0 -55
  277. package/src/Field/useStandardField.ts +0 -125
  278. package/src/FieldArray/FieldArray.tsx +0 -154
  279. package/src/File/FileGroup.test.tsx +0 -35
  280. package/src/File/FileGroup.tsx +0 -82
  281. package/src/File/FileList.tsx +0 -21
  282. package/src/File/__snapshots__/FileGroup.test.tsx.snap +0 -34
  283. package/src/File/humanFileSize.ts +0 -8
  284. package/src/Form/FocusError.tsx +0 -55
  285. package/src/Form/Form.test.tsx +0 -14
  286. package/src/Form/Form.tsx +0 -234
  287. package/src/Form/FormBasedPreventNavigation.tsx +0 -56
  288. package/src/Form/LegacyFormBasedPreventNavigation.tsx +0 -77
  289. package/src/Form/NewFormBasedPreventNavigation.tsx +0 -59
  290. package/src/Form/ServerErrorContext.ts +0 -18
  291. package/src/Form/__snapshots__/Form.test.tsx.snap +0 -10
  292. package/src/FormActions.tsx +0 -47
  293. package/src/FormDefaults.ts +0 -2
  294. package/src/Group.tsx +0 -62
  295. package/src/Input/CheckboxGroup.tsx +0 -60
  296. package/src/Input/CheckboxInputGroup.tsx +0 -78
  297. package/src/Input/IconInputGroup.tsx +0 -54
  298. package/src/Input/InputGroup.tsx +0 -69
  299. package/src/Input/MoneyInputGroup.tsx +0 -47
  300. package/src/Input/NumberInputGroup.tsx +0 -45
  301. package/src/Input/PhoneNumberInputGroup.tsx +0 -45
  302. package/src/Input/StringInputGroup.tsx +0 -50
  303. package/src/Input/__Tests__/CheckboxInputGroup.test.tsx +0 -26
  304. package/src/Input/__Tests__/IconInputGroup.test.tsx +0 -35
  305. package/src/Input/__Tests__/MoneyInputGroup.test.tsx +0 -37
  306. package/src/Input/__Tests__/NumberInputGroup.test.tsx +0 -35
  307. package/src/Input/__Tests__/PhoneNumberInputGroup.test.tsx +0 -36
  308. package/src/Input/__Tests__/StringInputGroup.test.tsx +0 -27
  309. package/src/Input/__Tests__/__snapshots__/CheckboxInputGroup.test.tsx.snap +0 -33
  310. package/src/Input/__Tests__/__snapshots__/IconInputGroup.test.tsx.snap +0 -32
  311. package/src/Input/__Tests__/__snapshots__/MoneyInputGroup.test.tsx.snap +0 -34
  312. package/src/Input/__Tests__/__snapshots__/NumberInputGroup.test.tsx.snap +0 -32
  313. package/src/Input/__Tests__/__snapshots__/PhoneNumberInputGroup.test.tsx.snap +0 -33
  314. package/src/Input/__Tests__/__snapshots__/StringInputGroup.test.tsx.snap +0 -31
  315. package/src/Normalization/NormalizationFunction.ts +0 -4
  316. package/src/Normalization/normalizers.ts +0 -44
  317. package/src/Select/BooleanSelectGroup.tsx +0 -28
  318. package/src/Select/NumberSelectGroup.tsx +0 -16
  319. package/src/Select/SelectGroup.tsx +0 -132
  320. package/src/Select/SelectGroupPropsHelper.ts +0 -4
  321. package/src/Select/StringSelectGroup.tsx +0 -16
  322. package/src/Select/__tests__/BooleanSelectGroup.test.tsx +0 -35
  323. package/src/Select/__tests__/NumberSelectGroup.test.tsx +0 -87
  324. package/src/Select/__tests__/StringSelectGroup.test.tsx +0 -89
  325. package/src/Select/__tests__/__snapshots__/BooleanSelectGroup.test.tsx.snap +0 -99
  326. package/src/Select/__tests__/__snapshots__/NumberSelectGroup.test.tsx.snap +0 -197
  327. package/src/Select/__tests__/__snapshots__/StringSelectGroup.test.tsx.snap +0 -197
  328. package/src/StandardFormActions.tsx +0 -41
  329. package/src/SubmitFormButton.tsx +0 -54
  330. package/src/TextArea/TextAreaGroup.tsx +0 -64
  331. package/src/Validation/ValidatedApiResult.ts +0 -8
  332. package/src/Validation/ValidationError.ts +0 -6
  333. package/src/Validation/ValidationFunction.ts +0 -4
  334. package/src/Validation/validators.test.tsx +0 -81
  335. package/src/Validation/validators.ts +0 -97
  336. package/src/__Tests__/FormTestBase.tsx +0 -66
  337. package/src/__Tests__/RealisticForm.test.tsx +0 -82
  338. package/src/__Tests__/StandardFormActions.test.tsx +0 -17
  339. package/src/__Tests__/SubmitFormButton.test.tsx +0 -17
  340. package/src/__Tests__/__snapshots__/StandardFormActions.test.tsx.snap +0 -27
  341. package/src/__Tests__/__snapshots__/SubmitFormButton.test.tsx.snap +0 -20
  342. package/src/__Tests__/index.ts +0 -3
  343. package/src/_variables.scss +0 -11
  344. package/src/index.ts +0 -163
  345. package/src/react-app-env.d.ts +0 -1
  346. package/src/setupTests.ts +0 -1
  347. package/src/styles.scss +0 -0
  348. package/src/utils/objectContainsNonSerializableProperty.test.tsx +0 -49
  349. package/src/utils/objectContainsNonSerializableProperty.ts +0 -17
  350. package/src/utils/objectToFormData.test.tsx +0 -76
  351. package/src/utils/objectToFormData.ts +0 -105
  352. package/src/utils/typeChecks.ts +0 -18
@@ -1,82 +0,0 @@
1
- import { render, screen, waitFor } from '@testing-library/react';
2
- import user from '@testing-library/user-event';
3
- import FormTestBase from './FormTestBase';
4
- import { Form, StringInputGroup, ValidatedApiResult } from '../';
5
- import { PersonDto } from '../__Tests__/FormTestBase';
6
- import StandardFormActions from '../StandardFormActions';
7
- import { validators } from '../';
8
-
9
- const handleSubmitMock = jest.fn((value: PersonDto | FormData) => {
10
- //return value;
11
- return new Promise<ValidatedApiResult>((res, rej) => {
12
- setTimeout(() => {
13
- res({});
14
- }, 15);
15
- });
16
- });
17
-
18
- describe('Realistic Form', () => {
19
- it('Validates, resolves validation, submits values', async () => {
20
- global.scrollTo = jest.fn();
21
- const fullForm = (
22
- <FormTestBase handleSubmit={handleSubmitMock}>
23
- {({ Field }) => (
24
- <>
25
- <Field name="name" label="name" Component={StringInputGroup} />
26
- <Field
27
- name="nameWithIcon"
28
- label="Name with Icon"
29
- Component={StringInputGroup}
30
- validate={validators.required}
31
- />
32
- <StandardFormActions />
33
- <Form.DisplayFormState />
34
- </>
35
- )}
36
- </FormTestBase>
37
- );
38
-
39
- render(fullForm);
40
- const nameInput = screen.getByLabelText('name');
41
- const formSubmitButton = screen.getByRole('button', {
42
- name: 'Submit',
43
- });
44
- //The form should start off with the submit button disabled
45
- expect(formSubmitButton).toBeDisabled();
46
-
47
- //Enter a name into the name input
48
- user.click(nameInput);
49
- user.type(nameInput, 'Travis Overmier');
50
- expect(nameInput).toHaveValue('Travis Overmier');
51
-
52
- //Submit should be enabled, click submit
53
- expect(formSubmitButton).toBeEnabled();
54
- user.click(formSubmitButton);
55
-
56
- //Submit should disable while 'submitting' then re-enable
57
- expect(formSubmitButton).toBeDisabled();
58
- await waitFor(() => {
59
- expect(formSubmitButton).toBeEnabled();
60
- });
61
-
62
- //Validation message should appear
63
- const nameWithIconInput = screen.getByLabelText('Name with Icon');
64
- expect(nameWithIconInput).toHaveErrorMessage('Required');
65
-
66
- //Fill in field, error message goes away
67
- user.type(nameWithIconInput, 'Kyle Joiner');
68
- user.tab();
69
- await waitFor(() => {
70
- expect(nameWithIconInput).not.toHaveErrorMessage();
71
- });
72
-
73
- //Click the submit button
74
- user.click(formSubmitButton);
75
- await waitFor(() => {
76
- expect(handleSubmitMock).toHaveBeenCalled();
77
- expect(JSON.stringify(handleSubmitMock.mock.calls[0][0])).toBe(
78
- `{"name":"Travis Overmier","nameWithIcon":"Kyle Joiner"}`
79
- );
80
- });
81
- });
82
- });
@@ -1,17 +0,0 @@
1
- import React from 'react';
2
- import { render } from '@testing-library/react';
3
- import FormTestBase from './FormTestBase';
4
- import StandardFormActions from '../StandardFormActions';
5
-
6
- describe('StandardFormActions', () => {
7
- it('renders without crashing', () => {
8
- render(<FormTestBase>{() => <StandardFormActions />}</FormTestBase>);
9
- });
10
-
11
- it('has matching snapshot', () => {
12
- const renderResult = render(
13
- <FormTestBase>{() => <StandardFormActions />}</FormTestBase>
14
- );
15
- expect(renderResult.asFragment()).toMatchSnapshot();
16
- });
17
- });
@@ -1,17 +0,0 @@
1
- import React from 'react';
2
- import { render } from '@testing-library/react';
3
- import FormTestBase from './FormTestBase';
4
- import SubmitFormButton from '../SubmitFormButton';
5
-
6
- describe('SubmitFormButton', () => {
7
- it('renders without crashing', () => {
8
- render(<FormTestBase>{() => <SubmitFormButton />}</FormTestBase>);
9
- });
10
-
11
- it('has matching snapshot', () => {
12
- const renderResult = render(
13
- <FormTestBase>{() => <SubmitFormButton />}</FormTestBase>
14
- );
15
- expect(renderResult.asFragment()).toMatchSnapshot();
16
- });
17
- });
@@ -1,27 +0,0 @@
1
- // Jest Snapshot v1, https://goo.gl/fbAQLP
2
-
3
- exports[`StandardFormActions has matching snapshot 1`] = `
4
- <DocumentFragment>
5
- <form
6
- action="#"
7
- class="envoc-form-form"
8
- >
9
- <button
10
- aria-label="Submit"
11
- class="envoc-form-submit-form-button"
12
- disabled=""
13
- title="You haven't made any changes"
14
- type="submit"
15
- >
16
- Submit
17
- </button>
18
-  
19
- <button
20
- class="envoc-form-standard-form-actions-cancel-button"
21
- type="button"
22
- >
23
- Cancel
24
- </button>
25
- </form>
26
- </DocumentFragment>
27
- `;
@@ -1,20 +0,0 @@
1
- // Jest Snapshot v1, https://goo.gl/fbAQLP
2
-
3
- exports[`SubmitFormButton has matching snapshot 1`] = `
4
- <DocumentFragment>
5
- <form
6
- action="#"
7
- class="envoc-form-form"
8
- >
9
- <button
10
- aria-label="Submit"
11
- class="envoc-form-submit-form-button"
12
- disabled=""
13
- title="You haven't made any changes"
14
- type="submit"
15
- >
16
- Submit
17
- </button>
18
- </form>
19
- </DocumentFragment>
20
- `;
@@ -1,3 +0,0 @@
1
- import FormTestBase from './FormTestBase';
2
-
3
- export { FormTestBase };
@@ -1,11 +0,0 @@
1
- //These variables are normally in the template directly,
2
-
3
- $red: #f86c6b;
4
- // Couldn't find these variables directly from coreui/bootstrap
5
- $input-border-color: #c2cfd6;
6
- $input-border-color--focused: #8ad4ee;
7
- $input-box-shadow--focused: 0 0 0 0.2rem rgba(32, 168, 216, 0.25);
8
-
9
- //Taken from react-select because it fit better in the color scheme and is more readable.
10
- $input-disabled-background-color: hsl(0, 0%, 95%);
11
- $input-disabled-border-color: hsl(0, 0%, 90%);
package/src/index.ts DELETED
@@ -1,163 +0,0 @@
1
- // Address
2
- export { default as AddressInput } from './AddressInput/AddressInput';
3
- export type { AddressInputProps } from './AddressInput/AddressInput';
4
-
5
- // Button
6
- export { default as SubmitFormButton } from './SubmitFormButton';
7
- export type { SubmitFormButtonProps } from './SubmitFormButton';
8
-
9
- // ConfirmBaseForm
10
- export { default as ConfirmBaseForm } from './ConfirmBaseForm/ConfirmBaseForm';
11
- export type { ConfirmBaseFormProps } from './ConfirmBaseForm/ConfirmBaseForm';
12
-
13
- // ConfirmDeleteForm
14
- export { default as ConfirmDeleteForm } from './ConfirmDeleteForm/ConfirmDeleteForm';
15
- export type { ConfirmDeleteFormProps } from './ConfirmDeleteForm/ConfirmDeleteForm';
16
-
17
- // Date
18
- export { default as DatePickerGroup } from './DatePicker/DatePickerGroup';
19
- export type { DatePickerGroupProps } from './DatePicker/DatePickerGroup';
20
- export { convertToTimeZoneInsensitiveISOString } from './DatePicker/DatePickerGroup';
21
-
22
- export type { DatePickerHelper } from './DatePicker/DatePickerHelper';
23
-
24
- export { default as StringDatePickerGroup } from './DatePicker/StringDatePickerGroup';
25
- export type { StringDatePickerGroupProps } from './DatePicker/StringDatePickerGroup';
26
-
27
- export { default as StringDateOnlyPickerGroup } from './DatePicker/StringDateOnlyPickerGroup';
28
- export type { StringDateOnlyPickerGroupProps } from './DatePicker/StringDateOnlyPickerGroup';
29
-
30
- // DateTime
31
- export { default as DateTimePickerGroup } from './DateTimePicker/DateTimePickerGroup';
32
- export type { DateTimePickerGroupProps } from './DateTimePicker/DateTimePickerGroup';
33
-
34
- export { default as StringDateTimePickerGroup } from './DateTimePicker/StringDateTimePickerGroup';
35
- export type { StringDateTimePickerGroupProps } from './DateTimePicker/StringDateTimePickerGroup';
36
-
37
- // Field
38
- export { default as Field } from './Field/Field';
39
- export type { FieldProps } from './Field/Field';
40
-
41
- export type { RenderComponent } from './Field/Field';
42
- export type { RenderComponentProps } from './Field/Field';
43
-
44
- export { default as FieldErrorScrollTarget } from './Field/FieldErrorScrollTarget';
45
-
46
- export { FieldNameContext } from './Field/FieldNameContext';
47
-
48
- export type { InjectedFieldProps } from './Field/InjectedFieldProps';
49
-
50
- export { default as StandAloneInput } from './Field/StandAloneInput';
51
-
52
- export type { StandAloneInputProps } from './Field/StandAloneInput';
53
-
54
- export { default as useStandardField } from './Field/useStandardField';
55
- export type { useStandardFieldProps } from './Field/useStandardField';
56
-
57
- // Field Array
58
- export { default as FieldArray } from './FieldArray/FieldArray';
59
- export type {
60
- FieldArrayProps,
61
- ArrayFormBuilderProp,
62
- } from './FieldArray/FieldArray';
63
-
64
- // File
65
- export { default as FileGroup } from './File/FileGroup';
66
- export type { FileGroupProps } from './File/FileGroup';
67
-
68
- // Form
69
- export { default as Form } from './Form/Form';
70
- export type { FormBuilderProp, FormProps } from './Form/Form';
71
- export { ServerErrorContext } from './Form/ServerErrorContext';
72
- export type {
73
- ServerErrorContextProps,
74
- ServerErrors,
75
- } from './Form/ServerErrorContext';
76
-
77
- export { default as FormActions } from './FormActions';
78
- export type { FormActionsProps } from './FormActions';
79
-
80
- export { default as StandardFormActions } from './StandardFormActions';
81
- export type { StandardFormActionsProps } from './StandardFormActions';
82
-
83
- // FormDefaults
84
- export { FormDefaults } from './FormDefaults';
85
-
86
- // Input
87
- export { default as Group } from './Group';
88
- export type { GroupProps } from './Group';
89
-
90
- export { default as IconInputGroup } from './Input/IconInputGroup';
91
- export type { IconInputGroupProps } from './Input/IconInputGroup';
92
-
93
- export { default as InputGroup } from './Input/InputGroup';
94
- export type { InputGroupProps } from './Input/InputGroup';
95
-
96
- export { default as MoneyInputGroup } from './Input/MoneyInputGroup';
97
- export type { MoneyInputGroupProps } from './Input/MoneyInputGroup';
98
-
99
- export { default as NumberInputGroup } from './Input/NumberInputGroup';
100
- export type { NumberInputGroupProps } from './Input/NumberInputGroup';
101
-
102
- export { default as PhoneNumberInputGroup } from './Input/PhoneNumberInputGroup';
103
- export type { PhoneNumberInputGroupProps } from './Input/PhoneNumberInputGroup';
104
-
105
- export { default as StringInputGroup } from './Input/StringInputGroup';
106
- export type { StringInputGroupProps } from './Input/StringInputGroup';
107
-
108
- // Normalization
109
- export type { NormalizationFunction } from './Normalization/NormalizationFunction';
110
- export * as normalizers from './Normalization/normalizers';
111
-
112
- // Select
113
- export { default as SelectGroup } from './Select/SelectGroup';
114
- export type { SelectGroupProps, SelectOption } from './Select/SelectGroup';
115
-
116
- export { BooleanSelectGroup } from './Select/BooleanSelectGroup';
117
- export type { BooleanSelectGroupProps } from './Select/BooleanSelectGroup';
118
-
119
- export { default as CheckboxInputGroup } from './Input/CheckboxInputGroup';
120
- export type { CheckboxInputGroupProps } from './Input/CheckboxInputGroup';
121
-
122
- export {
123
- MultiNumberSelectGroup,
124
- SingleNumberSelectGroup,
125
- } from './Select/NumberSelectGroup';
126
- export type {
127
- MultiNumberSelectGroupProps,
128
- SingleNumberSelectGroupProps,
129
- } from './Select/NumberSelectGroup';
130
-
131
- export type { SelectGroupPropsHelper } from './Select/SelectGroupPropsHelper';
132
-
133
- export {
134
- MultiStringSelectGroup,
135
- SingleStringSelectGroup,
136
- } from './Select/StringSelectGroup';
137
- export type {
138
- MultiStringSelectGroupProps,
139
- SingleStringSelectGroupProps,
140
- } from './Select/StringSelectGroup';
141
-
142
- // Text Area
143
-
144
- export { default as TextAreaGroup } from './TextArea/TextAreaGroup';
145
-
146
- export type { TextAreaGroupProps } from './TextArea/TextAreaGroup';
147
-
148
- // Utils
149
- export { default as objectContainsNonSerializableProperty } from './utils/objectContainsNonSerializableProperty';
150
-
151
- export { default as serialize } from './utils/objectToFormData';
152
- export type { ObjectToFormDataCfgProps } from './utils/objectToFormData';
153
-
154
- export * from './utils/typeChecks';
155
-
156
- // Validation
157
- export type { ValidatedApiResult } from './Validation/ValidatedApiResult';
158
-
159
- export type { ValidationError } from './Validation/ValidationError';
160
-
161
- export type { ValidationFunction } from './Validation/ValidationFunction';
162
-
163
- export * as validators from './Validation/validators';
@@ -1 +0,0 @@
1
- /// <reference types="react-scripts" />
package/src/setupTests.ts DELETED
@@ -1 +0,0 @@
1
- import '@testing-library/jest-dom/extend-expect';
package/src/styles.scss DELETED
File without changes
@@ -1,49 +0,0 @@
1
- import check from './objectContainsNonSerializableProperty';
2
-
3
- describe('Object contains non serializable property checker', () => {
4
- it('Should return true for simple object', () => {
5
- const object = {
6
- name: 'Bob',
7
- age: 20,
8
- favoriteFoods: ['Hamburger', 'Pizza'],
9
- homeAddress: {
10
- addressLine1: '12345 Test Place',
11
- addressLine2: null,
12
- city: 'SomePlace',
13
- state: 'LA',
14
- zip: 12345,
15
- },
16
- };
17
-
18
- const result = check(object);
19
- expect(result).toBe(false);
20
- });
21
-
22
- it('Should return false for direct file property', () => {
23
- const object = {
24
- name: 'Bob',
25
- age: 20,
26
- profilePhoto: new File(['foo'], 'foo.txt', {
27
- type: 'text/plain',
28
- }),
29
- };
30
-
31
- const result = check(object);
32
- expect(result).toBe(true);
33
- });
34
-
35
- it('Should return false for deeply nested file property', () => {
36
- const object = {
37
- a: {
38
- b: {
39
- c: new File(['foo'], 'foo.txt', {
40
- type: 'text/plain',
41
- }),
42
- },
43
- },
44
- };
45
-
46
- const result = check(object);
47
- expect(result).toBe(true);
48
- });
49
- });
@@ -1,17 +0,0 @@
1
- import { isBlob, isFile, isObject } from './typeChecks';
2
-
3
- export default function objectContainsNonSerializableProperty(
4
- object: any
5
- ): boolean {
6
- return Object.entries(object).some((value) => {
7
- if (value) {
8
- if (isBlob(value[1]) || isFile(value[1])) {
9
- return true;
10
- }
11
- if (isObject(value[1])) {
12
- return objectContainsNonSerializableProperty(value[1]);
13
- }
14
- }
15
- return false;
16
- });
17
- }
@@ -1,76 +0,0 @@
1
- import serialize from './objectToFormData';
2
-
3
- const options = {
4
- indices: true,
5
- dotNotation: true,
6
- allowEmptyArrays: true,
7
- noFileListBrackets: true,
8
- };
9
-
10
- const formDataAppend = global.FormData.prototype.append;
11
-
12
- beforeEach(() => {
13
- global.FormData.prototype.append = jest.fn(formDataAppend) as any;
14
- });
15
-
16
- describe('Object To Form Data', () => {
17
- it('properly serializes a simple object', () => {
18
- const object = {
19
- name: 'Bob',
20
- age: 20,
21
- };
22
-
23
- const result = serialize(object, options);
24
- expect(result.get('name')).toBe(object.name);
25
- expect(result.get('age')).toBe('20');
26
- });
27
-
28
- it('properly serializes an object with a non-file array property', () => {
29
- const object = {
30
- name: 'Bob',
31
- age: 20,
32
- favoriteFoods: ['Hamburger', 'Pizza'],
33
- };
34
-
35
- const result = serialize(object, options);
36
- expect(result.get('name')).toBe(object.name);
37
- expect(result.has('favoriteFoods[0]')).toBe(true);
38
- expect(result.get('favoriteFoods[0]')).toBe('Hamburger');
39
- expect(result.has('favoriteFoods[1]')).toBe(true);
40
- expect(result.get('favoriteFoods[1]')).toBe('Pizza');
41
- });
42
-
43
- it('properly serializes a file in a form', () => {
44
- const object = {
45
- a: new File(['foo'], 'foo.txt', {
46
- type: 'text/plain',
47
- }),
48
- };
49
-
50
- const result = serialize(object, options);
51
- expect(result.has('a')).toBe(true);
52
- expect(result.get('a')).toBeInstanceOf(File);
53
- });
54
-
55
- it('properly serializes an object with a file array property', () => {
56
- const foo = new File(['foo'], 'foo.txt', {
57
- type: 'text/plain',
58
- });
59
- const bar = new File(['bar'], 'bar.txt', {
60
- type: 'text/plain',
61
- });
62
- const object = {
63
- fileArray: [foo, bar],
64
- };
65
-
66
- const result = serialize(object, options);
67
- expect(result.append).toHaveBeenCalledTimes(2);
68
- expect(result.append).toHaveBeenNthCalledWith(1, 'fileArray', foo);
69
- expect(result.append).toHaveBeenNthCalledWith(2, 'fileArray', bar);
70
- expect(result.has('fileArray[]')).toBe(false);
71
- expect(result.has('fileArray[0]')).toBe(false);
72
- expect(result.has('fileArray[1]')).toBe(false);
73
- expect(result.has('fileArray')).toBe(true);
74
- expect(result.getAll('fileArray')).toEqual(object.fileArray);
75
- });
76
- });
@@ -1,105 +0,0 @@
1
- // Original: https://github.com/therealparmesh/object-to-formdata/blob/master/src/index.js
2
- // With Multiple Form File Fix: https://github.com/therealparmesh/object-to-formdata/pull/94/files
3
- import {
4
- isArray,
5
- isBlob,
6
- isBoolean,
7
- isDate,
8
- isFile,
9
- isNull,
10
- isObject,
11
- isUndefined,
12
- } from './typeChecks';
13
-
14
- // TODO: make all of these optional?
15
- export interface ObjectToFormDataCfgProps {
16
- indices: boolean;
17
- dotNotation: boolean;
18
- allowEmptyArrays: boolean;
19
- noFileListBrackets: boolean;
20
- nullsAsUndefineds?: boolean;
21
- booleansAsIntegers?: boolean;
22
- }
23
-
24
- // 'pre' is not provided until this function recursively calls itself when 'obj' is an array or object
25
- const serialize = (
26
- obj: any,
27
- cfg: ObjectToFormDataCfgProps,
28
- fd?: FormData,
29
- pre?: string
30
- ) => {
31
- cfg = cfg || {};
32
-
33
- cfg.indices = isUndefined(cfg.indices) ? false : cfg.indices;
34
-
35
- cfg.nullsAsUndefineds = isUndefined(cfg.nullsAsUndefineds)
36
- ? false
37
- : cfg.nullsAsUndefineds;
38
-
39
- cfg.booleansAsIntegers = isUndefined(cfg.booleansAsIntegers)
40
- ? false
41
- : cfg.booleansAsIntegers;
42
-
43
- cfg.allowEmptyArrays = isUndefined(cfg.allowEmptyArrays)
44
- ? false
45
- : cfg.allowEmptyArrays;
46
-
47
- //reverse of normal because we want a different default
48
- cfg.dotNotation = isUndefined(cfg.dotNotation) ? true : cfg.dotNotation;
49
-
50
- fd = fd || new FormData();
51
-
52
- if (isUndefined(obj)) {
53
- return fd;
54
- } else if (isNull(obj) && !!pre) {
55
- if (!cfg.nullsAsUndefineds) {
56
- fd.append(pre, '');
57
- }
58
- } else if (isBoolean(obj) && !!pre) {
59
- if (cfg.booleansAsIntegers) {
60
- fd.append(pre, obj ? '1' : '0');
61
- } else {
62
- fd.append(pre, obj);
63
- }
64
- } else if (isDate(obj) && !!pre) {
65
- fd.append(pre, obj.toISOString());
66
- } else if (isArray(obj)) {
67
- if (obj.length) {
68
- obj.forEach((value: any, index: number) => {
69
- let key;
70
- if (cfg.noFileListBrackets && isFile(value)) {
71
- key = pre;
72
- } else {
73
- key = pre + '[' + (cfg.indices ? index : '') + ']';
74
- }
75
- serialize(value, cfg, fd, key);
76
- });
77
- } else if (cfg.allowEmptyArrays) {
78
- fd.append(pre + '[]', '');
79
- }
80
- } else if (isObject(obj) && !isFile(obj) && !isBlob(obj)) {
81
- Object.keys(obj).forEach((prop) => {
82
- const value = obj[prop];
83
-
84
- if (isArray(value)) {
85
- while (prop.length > 2 && prop.lastIndexOf('[]') === prop.length - 2) {
86
- prop = prop.substring(0, prop.length - 2);
87
- }
88
- }
89
-
90
- const key = pre
91
- ? cfg.dotNotation
92
- ? pre + '.' + prop
93
- : pre + '[' + prop + ']'
94
- : prop;
95
-
96
- serialize(value, cfg, fd, key);
97
- });
98
- } else if (!!pre) {
99
- fd.append(pre, obj);
100
- }
101
-
102
- return fd;
103
- };
104
-
105
- export default serialize;
@@ -1,18 +0,0 @@
1
- export const isUndefined = (value: any) => value === undefined;
2
- export const isNull = (value: any) => value === null;
3
- export const isBoolean = (value: any) => typeof value === 'boolean';
4
- export const isObject = (value: any) => value === Object(value);
5
- export const isArray = (value: any) => Array.isArray(value);
6
- export const isDate = (value: any) => value instanceof Date;
7
-
8
- export const isBlob = (value: any) =>
9
- value &&
10
- typeof value.size === 'number' &&
11
- typeof value.type === 'string' &&
12
- typeof value.slice === 'function';
13
-
14
- export const isFile = (value: any) =>
15
- isBlob(value) &&
16
- typeof value.name === 'string' &&
17
- (typeof value.lastModifiedDate === 'object' ||
18
- typeof value.lastModified === 'number');