envoc-form 3.1.0 → 4.0.1-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.
Files changed (422) hide show
  1. package/README.md +10 -1
  2. package/dist/css/envoc-form-styles.css +0 -113
  3. package/dist/css/envoc-form-styles.css.map +1 -1
  4. package/es/AddressInput/AddressInput.d.ts +15 -0
  5. package/es/AddressInput/AddressInput.js +21 -97
  6. package/es/AddressInput/UsStates.d.ts +3 -0
  7. package/es/AddressInput/UsStates.js +53 -152
  8. package/es/ConfirmBaseForm/ConfirmBaseForm.d.ts +10 -0
  9. package/es/ConfirmBaseForm/ConfirmBaseForm.js +35 -43
  10. package/es/ConfirmDeleteForm/ConfirmDeleteForm.d.ts +11 -0
  11. package/es/ConfirmDeleteForm/ConfirmDeleteForm.js +54 -40
  12. package/es/DatePickerInput/DatePickerInput.d.ts +14 -0
  13. package/es/DatePickerInput/DatePickerInput.js +63 -95
  14. package/es/Field/CustomFieldInputProps.d.ts +7 -0
  15. package/es/Field/CustomFieldInputProps.js +1 -0
  16. package/es/Field/CustomFieldMetaProps.d.ts +4 -0
  17. package/es/Field/CustomFieldMetaProps.js +1 -0
  18. package/es/Field/Field.d.ts +22 -0
  19. package/es/Field/Field.js +46 -0
  20. package/es/Field/FieldErrorScrollTarget.d.ts +2 -0
  21. package/es/Field/FieldErrorScrollTarget.js +11 -0
  22. package/es/Field/FieldNameContext.d.ts +3 -0
  23. package/es/Field/FieldNameContext.js +3 -0
  24. package/es/Field/FieldSection.d.ts +7 -0
  25. package/es/Field/FieldSection.js +20 -0
  26. package/es/Field/InjectedFieldProps.d.ts +7 -0
  27. package/es/Field/InjectedFieldProps.js +1 -0
  28. package/es/Field/useStandardField.d.ts +15 -0
  29. package/es/Field/useStandardField.js +93 -0
  30. package/es/FieldArray/FieldArray.d.ts +15 -0
  31. package/es/FieldArray/FieldArray.js +80 -0
  32. package/es/File/FileGroup.d.ts +8 -0
  33. package/es/File/FileGroup.js +50 -0
  34. package/es/File/FileList.d.ts +6 -0
  35. package/es/File/FileList.js +20 -0
  36. package/es/File/humanFileSize.d.ts +1 -0
  37. package/es/File/humanFileSize.js +6 -0
  38. package/es/Form/FocusError.d.ts +5 -0
  39. package/es/Form/FocusError.js +41 -53
  40. package/es/Form/Form.d.ts +22 -0
  41. package/es/Form/Form.js +111 -125
  42. package/es/Form/FormBasedPreventNavigation.d.ts +5 -0
  43. package/es/Form/FormBasedPreventNavigation.js +53 -30
  44. package/es/Form/ServerErrorContext.d.ts +10 -0
  45. package/es/Form/ServerErrorContext.js +8 -6
  46. package/es/FormActions.d.ts +7 -0
  47. package/es/FormActions.js +22 -0
  48. package/es/Group.d.ts +13 -0
  49. package/es/Group.js +22 -0
  50. package/es/Input/IconInputGroup.d.ts +9 -0
  51. package/es/Input/IconInputGroup.js +40 -0
  52. package/es/Input/InputGroup.d.ts +12 -0
  53. package/es/Input/InputGroup.js +33 -0
  54. package/es/Input/MoneyInputGroup.d.ts +7 -0
  55. package/es/Input/MoneyInputGroup.js +41 -0
  56. package/es/Input/NumberInputGroup.d.ts +7 -0
  57. package/es/Input/NumberInputGroup.js +41 -0
  58. package/es/Input/StringInputGroup.d.ts +7 -0
  59. package/es/Input/StringInputGroup.js +40 -0
  60. package/es/Normalization/NormalizationFunction.d.ts +4 -0
  61. package/es/Normalization/NormalizationFunction.js +1 -0
  62. package/es/Normalization/normalizers.d.ts +2 -0
  63. package/es/Normalization/normalizers.js +30 -0
  64. package/es/Select/BooleanSelectGroup.d.ts +7 -0
  65. package/es/Select/BooleanSelectGroup.js +27 -0
  66. package/es/Select/NumberSelectGroup.d.ts +8 -0
  67. package/es/Select/NumberSelectGroup.js +19 -0
  68. package/es/Select/SelectGroup.d.ts +22 -0
  69. package/es/Select/SelectGroup.js +59 -0
  70. package/es/Select/SelectGroupPropsHelper.d.ts +3 -0
  71. package/es/Select/SelectGroupPropsHelper.js +1 -0
  72. package/es/Select/StringSelectGroup.d.ts +8 -0
  73. package/es/Select/StringSelectGroup.js +19 -0
  74. package/es/StandardFormActions.d.ts +6 -0
  75. package/es/StandardFormActions.js +23 -24
  76. package/es/SubmitFormButton.d.ts +7 -0
  77. package/es/SubmitFormButton.js +37 -23
  78. package/es/Validation/ValidatedApiResult.d.ts +6 -0
  79. package/es/Validation/ValidatedApiResult.js +1 -0
  80. package/es/Validation/ValidationError.d.ts +5 -0
  81. package/es/Validation/ValidationError.js +1 -0
  82. package/es/Validation/ValidationFunction.d.ts +4 -0
  83. package/es/Validation/ValidationFunction.js +1 -0
  84. package/es/Validation/validators.d.ts +15 -0
  85. package/es/Validation/validators.js +73 -0
  86. package/es/__Tests__/FormTestBase.d.ts +27 -0
  87. package/es/__Tests__/FormTestBase.js +83 -12
  88. package/{src/__Tests__/index.js → es/__Tests__/index.d.ts} +0 -0
  89. package/es/__Tests__/index.js +2 -2
  90. package/es/index.d.ts +57 -0
  91. package/es/index.js +41 -20
  92. package/es/utils/objectContainsNonSerializableProperty.d.ts +1 -0
  93. package/es/utils/objectContainsNonSerializableProperty.js +14 -16
  94. package/es/utils/objectToFormData.d.ts +10 -0
  95. package/es/utils/objectToFormData.js +77 -65
  96. package/es/utils/typeChecks.d.ts +8 -0
  97. package/es/utils/typeChecks.js +18 -25
  98. package/lib/AddressInput/AddressInput.d.ts +15 -0
  99. package/lib/AddressInput/AddressInput.js +27 -123
  100. package/lib/AddressInput/UsStates.d.ts +3 -0
  101. package/lib/AddressInput/UsStates.js +55 -159
  102. package/lib/ConfirmBaseForm/ConfirmBaseForm.d.ts +10 -0
  103. package/lib/ConfirmBaseForm/ConfirmBaseForm.js +41 -57
  104. package/lib/ConfirmDeleteForm/ConfirmDeleteForm.d.ts +11 -0
  105. package/lib/ConfirmDeleteForm/ConfirmDeleteForm.js +60 -56
  106. package/lib/DatePickerInput/DatePickerInput.d.ts +14 -0
  107. package/lib/DatePickerInput/DatePickerInput.js +69 -113
  108. package/lib/Field/CustomFieldInputProps.d.ts +7 -0
  109. package/lib/Field/CustomFieldInputProps.js +2 -0
  110. package/lib/Field/CustomFieldMetaProps.d.ts +4 -0
  111. package/lib/Field/CustomFieldMetaProps.js +2 -0
  112. package/lib/Field/Field.d.ts +22 -0
  113. package/lib/Field/Field.js +51 -0
  114. package/lib/Field/FieldErrorScrollTarget.d.ts +2 -0
  115. package/lib/Field/FieldErrorScrollTarget.js +14 -0
  116. package/lib/Field/FieldNameContext.d.ts +3 -0
  117. package/lib/Field/FieldNameContext.js +9 -0
  118. package/lib/Field/FieldSection.d.ts +7 -0
  119. package/lib/Field/FieldSection.js +23 -0
  120. package/lib/Field/InjectedFieldProps.d.ts +7 -0
  121. package/lib/Field/InjectedFieldProps.js +2 -0
  122. package/lib/Field/useStandardField.d.ts +15 -0
  123. package/lib/Field/useStandardField.js +96 -0
  124. package/lib/FieldArray/FieldArray.d.ts +15 -0
  125. package/lib/FieldArray/FieldArray.js +86 -0
  126. package/lib/File/FileGroup.d.ts +8 -0
  127. package/lib/File/FileGroup.js +55 -0
  128. package/lib/File/FileList.d.ts +6 -0
  129. package/lib/File/FileList.js +23 -0
  130. package/lib/File/humanFileSize.d.ts +1 -0
  131. package/lib/File/humanFileSize.js +10 -0
  132. package/lib/Form/FocusError.d.ts +5 -0
  133. package/lib/Form/FocusError.js +47 -66
  134. package/lib/Form/Form.d.ts +22 -0
  135. package/lib/Form/Form.js +117 -153
  136. package/lib/Form/FormBasedPreventNavigation.d.ts +5 -0
  137. package/lib/Form/FormBasedPreventNavigation.js +56 -39
  138. package/lib/Form/ServerErrorContext.d.ts +10 -0
  139. package/lib/Form/ServerErrorContext.js +14 -18
  140. package/lib/FormActions.d.ts +7 -0
  141. package/lib/FormActions.js +28 -0
  142. package/lib/Group.d.ts +13 -0
  143. package/lib/Group.js +28 -0
  144. package/lib/Input/IconInputGroup.d.ts +9 -0
  145. package/lib/Input/IconInputGroup.js +45 -0
  146. package/lib/Input/InputGroup.d.ts +12 -0
  147. package/lib/Input/InputGroup.js +38 -0
  148. package/lib/Input/MoneyInputGroup.d.ts +7 -0
  149. package/lib/Input/MoneyInputGroup.js +46 -0
  150. package/lib/Input/NumberInputGroup.d.ts +7 -0
  151. package/lib/Input/NumberInputGroup.js +46 -0
  152. package/lib/Input/StringInputGroup.d.ts +7 -0
  153. package/lib/Input/StringInputGroup.js +45 -0
  154. package/lib/Normalization/NormalizationFunction.d.ts +4 -0
  155. package/lib/Normalization/NormalizationFunction.js +2 -0
  156. package/lib/Normalization/normalizers.d.ts +2 -0
  157. package/lib/Normalization/normalizers.js +35 -0
  158. package/lib/Select/BooleanSelectGroup.d.ts +7 -0
  159. package/lib/Select/BooleanSelectGroup.js +34 -0
  160. package/lib/Select/NumberSelectGroup.d.ts +8 -0
  161. package/lib/Select/NumberSelectGroup.js +27 -0
  162. package/lib/Select/SelectGroup.d.ts +22 -0
  163. package/lib/Select/SelectGroup.js +65 -0
  164. package/lib/Select/SelectGroupPropsHelper.d.ts +3 -0
  165. package/lib/Select/SelectGroupPropsHelper.js +2 -0
  166. package/lib/Select/StringSelectGroup.d.ts +8 -0
  167. package/lib/Select/StringSelectGroup.js +27 -0
  168. package/lib/StandardFormActions.d.ts +6 -0
  169. package/lib/StandardFormActions.js +29 -37
  170. package/lib/SubmitFormButton.d.ts +7 -0
  171. package/lib/SubmitFormButton.js +42 -38
  172. package/lib/Validation/ValidatedApiResult.d.ts +6 -0
  173. package/lib/Validation/ValidatedApiResult.js +2 -0
  174. package/lib/Validation/ValidationError.d.ts +5 -0
  175. package/lib/Validation/ValidationError.js +2 -0
  176. package/lib/Validation/ValidationFunction.d.ts +4 -0
  177. package/lib/Validation/ValidationFunction.js +2 -0
  178. package/lib/Validation/validators.d.ts +15 -0
  179. package/lib/Validation/validators.js +86 -0
  180. package/lib/__Tests__/FormTestBase.d.ts +27 -0
  181. package/lib/__Tests__/FormTestBase.js +86 -25
  182. package/lib/__Tests__/index.d.ts +2 -0
  183. package/lib/__Tests__/index.js +8 -15
  184. package/lib/index.d.ts +57 -0
  185. package/lib/index.js +101 -174
  186. package/lib/utils/objectContainsNonSerializableProperty.d.ts +1 -0
  187. package/lib/utils/objectContainsNonSerializableProperty.js +17 -24
  188. package/lib/utils/objectToFormData.d.ts +10 -0
  189. package/lib/utils/objectToFormData.js +79 -73
  190. package/lib/utils/typeChecks.d.ts +8 -0
  191. package/lib/utils/typeChecks.js +29 -58
  192. package/package.json +106 -100
  193. package/src/AddressInput/{AddesssInput.test.js → AddressInput.test.tsx} +7 -3
  194. package/src/AddressInput/AddressInput.tsx +72 -0
  195. package/src/AddressInput/{UsStates.js → UsStates.ts} +3 -1
  196. package/src/AddressInput/__snapshots__/AddressInput.test.tsx.snap +175 -0
  197. package/src/ConfirmBaseForm/ConfirmBaseForm.test.tsx +24 -0
  198. package/src/ConfirmBaseForm/ConfirmBaseForm.tsx +50 -0
  199. package/src/ConfirmBaseForm/__snapshots__/{ConfirmBaseForm.test.js.snap → ConfirmBaseForm.test.tsx.snap} +2 -2
  200. package/src/ConfirmDeleteForm/{ConfirmDeleteForm.test.js → ConfirmDeleteForm.test.tsx} +3 -3
  201. package/src/ConfirmDeleteForm/ConfirmDeleteForm.tsx +67 -0
  202. package/src/ConfirmDeleteForm/__snapshots__/{ConfirmDeleteForm.test.js.snap → ConfirmDeleteForm.test.tsx.snap} +2 -2
  203. package/src/DatePickerInput/DatePickerInput.test.tsx +48 -0
  204. package/src/DatePickerInput/DatePickerInput.tsx +85 -0
  205. package/src/DatePickerInput/__snapshots__/DatePickerInput.test.tsx.snap +151 -0
  206. package/src/Field/CustomFieldInputProps.ts +10 -0
  207. package/src/Field/CustomFieldMetaProps.ts +5 -0
  208. package/src/Field/Field.tsx +90 -0
  209. package/src/Field/FieldErrorScrollTarget.tsx +11 -0
  210. package/src/Field/FieldNameContext.ts +6 -0
  211. package/src/Field/FieldSection.tsx +18 -0
  212. package/src/Field/InjectedFieldProps.ts +8 -0
  213. package/src/Field/useStandardField.ts +121 -0
  214. package/src/FieldArray/FieldArray.tsx +133 -0
  215. package/src/File/FileGroup.test.tsx +35 -0
  216. package/src/File/FileGroup.tsx +71 -0
  217. package/src/File/FileList.tsx +19 -0
  218. package/src/File/__snapshots__/FileGroup.test.tsx.snap +32 -0
  219. package/src/File/humanFileSize.ts +8 -0
  220. package/src/Form/{FocusError.js → FocusError.tsx} +10 -6
  221. package/src/Form/Form.test.tsx +14 -0
  222. package/src/Form/{Form.js → Form.tsx} +71 -31
  223. package/src/Form/FormBasedPreventNavigation.tsx +74 -0
  224. package/src/Form/ServerErrorContext.ts +17 -0
  225. package/src/Form/__snapshots__/{Form.test.js.snap → Form.test.tsx.snap} +1 -1
  226. package/src/FormActions.tsx +34 -0
  227. package/src/Group.tsx +43 -0
  228. package/src/Input/IconInputGroup.tsx +48 -0
  229. package/src/Input/InputGroup.tsx +57 -0
  230. package/src/Input/MoneyInputGroup.tsx +44 -0
  231. package/src/Input/NumberInputGroup.tsx +42 -0
  232. package/src/Input/StringInputGroup.tsx +40 -0
  233. package/src/Input/__Tests__/IconInputGroup.test.tsx +35 -0
  234. package/src/Input/__Tests__/MoneyInputGroup.test.tsx +37 -0
  235. package/src/Input/__Tests__/NumberInputGroup.test.tsx +35 -0
  236. package/src/Input/__Tests__/StringInputGroup.test.tsx +27 -0
  237. package/src/Input/__Tests__/__snapshots__/IconInputGroup.test.tsx.snap +29 -0
  238. package/src/Input/__Tests__/__snapshots__/MoneyInputGroup.test.tsx.snap +31 -0
  239. package/src/Input/__Tests__/__snapshots__/NumberInputGroup.test.tsx.snap +29 -0
  240. package/src/Input/__Tests__/__snapshots__/StringInputGroup.test.tsx.snap +28 -0
  241. package/src/Normalization/NormalizationFunction.ts +4 -0
  242. package/src/{normalizers.js → Normalization/normalizers.ts} +5 -5
  243. package/src/Select/BooleanSelectGroup.tsx +27 -0
  244. package/src/Select/NumberSelectGroup.tsx +14 -0
  245. package/src/Select/SelectGroup.tsx +106 -0
  246. package/src/Select/SelectGroupPropsHelper.ts +4 -0
  247. package/src/Select/StringSelectGroup.tsx +14 -0
  248. package/src/Select/__tests__/BooleanSelectGroup.test.tsx +35 -0
  249. package/src/Select/__tests__/NumberSelectGroup.test.tsx +87 -0
  250. package/src/Select/__tests__/StringSelectGroup.test.tsx +89 -0
  251. package/src/Select/__tests__/__snapshots__/BooleanSelectGroup.test.tsx.snap +99 -0
  252. package/src/Select/__tests__/__snapshots__/NumberSelectGroup.test.tsx.snap +197 -0
  253. package/src/Select/__tests__/__snapshots__/StringSelectGroup.test.tsx.snap +197 -0
  254. package/src/{StandardFormActions.js → StandardFormActions.tsx} +12 -6
  255. package/src/SubmitFormButton.tsx +44 -0
  256. package/src/Validation/ValidatedApiResult.ts +8 -0
  257. package/src/Validation/ValidationError.ts +6 -0
  258. package/src/Validation/ValidationFunction.ts +4 -0
  259. package/src/{validators/validators.test.js → Validation/validators.test.tsx} +6 -4
  260. package/src/Validation/validators.ts +92 -0
  261. package/src/__Tests__/FormTestBase.tsx +63 -0
  262. package/src/__Tests__/{StandardFormActions.test.js → StandardFormActions.test.tsx} +2 -8
  263. package/src/__Tests__/{SubmitFormButton.test.js → SubmitFormButton.test.tsx} +2 -8
  264. package/src/__Tests__/__snapshots__/{StandardFormActions.test.js.snap → StandardFormActions.test.tsx.snap} +2 -2
  265. package/src/__Tests__/__snapshots__/{SubmitFormButton.test.js.snap → SubmitFormButton.test.tsx.snap} +1 -1
  266. package/src/__Tests__/index.ts +3 -0
  267. package/src/index.ts +114 -0
  268. package/src/react-app-env.d.ts +1 -0
  269. package/src/styles.scss +0 -7
  270. package/src/utils/{objectContainsNonSerializableProperty.test.js → objectContainsNonSerializableProperty.test.tsx} +0 -0
  271. package/src/utils/{objectContainsNonSerializableProperty.js → objectContainsNonSerializableProperty.ts} +4 -2
  272. package/src/utils/{objectToFormData.test.js → objectToFormData.test.tsx} +0 -0
  273. package/src/utils/{objectToFormData.js → objectToFormData.ts} +29 -13
  274. package/src/utils/typeChecks.ts +18 -0
  275. package/es/AddressInput/index.js +0 -2
  276. package/es/BoolInput/BoolInput.js +0 -10
  277. package/es/BoolInput/InlineBoolInput.js +0 -10
  278. package/es/BoolInput/boolOptions.js +0 -8
  279. package/es/BoolInput/index.js +0 -3
  280. package/es/ConfirmBaseForm/index.js +0 -2
  281. package/es/ConfirmDeleteForm/index.js +0 -2
  282. package/es/DatePickerInput/index.js +0 -2
  283. package/es/ErrorScrollTarget.js +0 -10
  284. package/es/FileInput/DefaultFileList.js +0 -36
  285. package/es/FileInput/DropzoneFileInput.js +0 -58
  286. package/es/FileInput/FileInput.js +0 -62
  287. package/es/FileInput/index.js +0 -3
  288. package/es/Form/index.js +0 -3
  289. package/es/FormGroup.js +0 -22
  290. package/es/FormGroupWrapper.js +0 -22
  291. package/es/FormInput/FormInput.js +0 -206
  292. package/es/FormInput/index.js +0 -2
  293. package/es/FormInputArray/FormInputArray.js +0 -225
  294. package/es/FormInputArray/index.js +0 -2
  295. package/es/FormSection.js +0 -11
  296. package/es/IconInput.js +0 -33
  297. package/es/InlineFormInput/InlineFormInput.js +0 -8
  298. package/es/InlineFormInput/index.js +0 -2
  299. package/es/MoneyInput/InlineMoneyInput.js +0 -7
  300. package/es/MoneyInput/MoneyInput.js +0 -7
  301. package/es/MoneyInput/index.js +0 -3
  302. package/es/MoneyInput/moneyInputProps.js +0 -13
  303. package/es/NestedFormFieldContext.js +0 -4
  304. package/es/ReactSelectField/ReactSelectField.js +0 -128
  305. package/es/ReactSelectField/index.js +0 -2
  306. package/es/normalizers.js +0 -39
  307. package/es/selectors.js +0 -6
  308. package/es/useStandardFormInput.js +0 -119
  309. package/es/utils/index.js +0 -3
  310. package/es/validators/index.js +0 -2
  311. package/es/validators/validators.js +0 -94
  312. package/lib/AddressInput/index.js +0 -13
  313. package/lib/BoolInput/BoolInput.js +0 -23
  314. package/lib/BoolInput/InlineBoolInput.js +0 -23
  315. package/lib/BoolInput/boolOptions.js +0 -15
  316. package/lib/BoolInput/index.js +0 -23
  317. package/lib/ConfirmBaseForm/index.js +0 -13
  318. package/lib/ConfirmDeleteForm/index.js +0 -13
  319. package/lib/DatePickerInput/index.js +0 -13
  320. package/lib/ErrorScrollTarget.js +0 -20
  321. package/lib/FileInput/DefaultFileList.js +0 -47
  322. package/lib/FileInput/DropzoneFileInput.js +0 -75
  323. package/lib/FileInput/FileInput.js +0 -82
  324. package/lib/FileInput/index.js +0 -23
  325. package/lib/Form/index.js +0 -23
  326. package/lib/FormGroup.js +0 -33
  327. package/lib/FormGroupWrapper.js +0 -37
  328. package/lib/FormInput/FormInput.js +0 -229
  329. package/lib/FormInput/index.js +0 -13
  330. package/lib/FormInputArray/FormInputArray.js +0 -248
  331. package/lib/FormInputArray/index.js +0 -13
  332. package/lib/FormSection.js +0 -28
  333. package/lib/IconInput.js +0 -51
  334. package/lib/InlineFormInput/InlineFormInput.js +0 -20
  335. package/lib/InlineFormInput/index.js +0 -13
  336. package/lib/MoneyInput/InlineMoneyInput.js +0 -20
  337. package/lib/MoneyInput/MoneyInput.js +0 -20
  338. package/lib/MoneyInput/index.js +0 -23
  339. package/lib/MoneyInput/moneyInputProps.js +0 -26
  340. package/lib/NestedFormFieldContext.js +0 -16
  341. package/lib/ReactSelectField/ReactSelectField.js +0 -152
  342. package/lib/ReactSelectField/index.js +0 -31
  343. package/lib/normalizers.js +0 -51
  344. package/lib/selectors.js +0 -18
  345. package/lib/useStandardFormInput.js +0 -135
  346. package/lib/utils/index.js +0 -23
  347. package/lib/validators/index.js +0 -17
  348. package/lib/validators/validators.js +0 -130
  349. package/src/AddressInput/AddressInput.js +0 -73
  350. package/src/AddressInput/__snapshots__/AddesssInput.test.js.snap +0 -207
  351. package/src/AddressInput/index.js +0 -2
  352. package/src/BoolInput/BoolInput.js +0 -7
  353. package/src/BoolInput/BoolInput.test.js +0 -23
  354. package/src/BoolInput/InlineBoolInput.js +0 -7
  355. package/src/BoolInput/__snapshots__/BoolInput.test.js.snap +0 -89
  356. package/src/BoolInput/boolOptions.js +0 -6
  357. package/src/BoolInput/index.js +0 -4
  358. package/src/ConfirmBaseForm/ConfirmBaseForm.js +0 -37
  359. package/src/ConfirmBaseForm/ConfirmBaseForm.test.js +0 -14
  360. package/src/ConfirmBaseForm/index.js +0 -2
  361. package/src/ConfirmDeleteForm/ConfirmDeleteForm.js +0 -39
  362. package/src/ConfirmDeleteForm/index.js +0 -2
  363. package/src/DatePickerInput/DatePickerInput.js +0 -49
  364. package/src/DatePickerInput/DatePickerInput.test.js +0 -74
  365. package/src/DatePickerInput/__snapshots__/DatePickerInput.test.js.snap +0 -134
  366. package/src/DatePickerInput/date-picker-input.scss +0 -42
  367. package/src/DatePickerInput/index.js +0 -3
  368. package/src/ErrorScrollTarget.js +0 -6
  369. package/src/FileInput/DefaultFileList.js +0 -39
  370. package/src/FileInput/DropzoneFileInput.js +0 -56
  371. package/src/FileInput/DropzoneFileInput.test.js +0 -24
  372. package/src/FileInput/FileInput.js +0 -77
  373. package/src/FileInput/FileInput.test.js +0 -24
  374. package/src/FileInput/__snapshots__/DropzoneFileInput.test.js.snap +0 -57
  375. package/src/FileInput/__snapshots__/FileInput.test.js.snap +0 -58
  376. package/src/FileInput/file-input.scss +0 -58
  377. package/src/FileInput/index.js +0 -4
  378. package/src/Form/Form.test.js +0 -23
  379. package/src/Form/FormBasedPreventNavigation.js +0 -25
  380. package/src/Form/ServerErrorContext.js +0 -7
  381. package/src/Form/index.js +0 -3
  382. package/src/FormGroup.js +0 -30
  383. package/src/FormGroupWrapper.js +0 -28
  384. package/src/FormInput/FormInput.js +0 -145
  385. package/src/FormInput/FormInput.test.js +0 -66
  386. package/src/FormInput/__snapshots__/FormInput.test.js.snap +0 -323
  387. package/src/FormInput/form-input.scss +0 -9
  388. package/src/FormInput/index.js +0 -2
  389. package/src/FormInputArray/FormInputArray.js +0 -224
  390. package/src/FormInputArray/FormInputArray.test.js +0 -108
  391. package/src/FormInputArray/__snapshots__/FormInputArray.test.js.snap +0 -52
  392. package/src/FormInputArray/form-input-array.scss +0 -13
  393. package/src/FormInputArray/index.js +0 -2
  394. package/src/FormSection.js +0 -13
  395. package/src/IconInput.js +0 -31
  396. package/src/InlineFormInput/InlineFormInput.js +0 -6
  397. package/src/InlineFormInput/InlineFormInput.test.js +0 -23
  398. package/src/InlineFormInput/__snapshots__/InlineFormInput.test.js.snap +0 -26
  399. package/src/InlineFormInput/index.js +0 -3
  400. package/src/InlineFormInput/inline-form-input.scss +0 -3
  401. package/src/MoneyInput/InlineMoneyInput.js +0 -7
  402. package/src/MoneyInput/MoneyInput.js +0 -7
  403. package/src/MoneyInput/MoneyInputs.test.js +0 -43
  404. package/src/MoneyInput/__snapshots__/MoneyInputs.test.js.snap +0 -81
  405. package/src/MoneyInput/index.js +0 -4
  406. package/src/MoneyInput/money-input.scss +0 -3
  407. package/src/MoneyInput/moneyInputProps.js +0 -12
  408. package/src/NestedFormFieldContext.js +0 -6
  409. package/src/ReactSelectField/ReactSelectField.js +0 -122
  410. package/src/ReactSelectField/index.js +0 -6
  411. package/src/ReactSelectField/react-select-field.scss +0 -5
  412. package/src/SubmitFormButton.js +0 -28
  413. package/src/__Tests__/FormTestBase.js +0 -14
  414. package/src/__Tests__/IconInput.test.js +0 -23
  415. package/src/__Tests__/__snapshots__/IconInput.test.js.snap +0 -38
  416. package/src/index.js +0 -45
  417. package/src/selectors.js +0 -3
  418. package/src/useStandardFormInput.js +0 -118
  419. package/src/utils/index.js +0 -3
  420. package/src/utils/typeChecks.js +0 -18
  421. package/src/validators/index.js +0 -2
  422. package/src/validators/validators.js +0 -93
@@ -0,0 +1,175 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`AddressInput has matching snapshot 1`] = `
4
+ <DocumentFragment>
5
+ <form
6
+ action="#"
7
+ >
8
+ <div
9
+ class="string-group input-group group"
10
+ >
11
+ <div
12
+ id="normaladdressinput.address1-error-scroll-target"
13
+ style="display: none;"
14
+ />
15
+ <label
16
+ for="normalAddressInput.address1"
17
+ >
18
+ Address 1
19
+ </label>
20
+ <input
21
+ class="string-group input-group"
22
+ name="normalAddressInput.address1"
23
+ placeholder="Address, Line 1"
24
+ value=""
25
+ />
26
+ </div>
27
+ <div
28
+ class="string-group input-group group"
29
+ >
30
+ <div
31
+ id="normaladdressinput.address2-error-scroll-target"
32
+ style="display: none;"
33
+ />
34
+ <label
35
+ for="normalAddressInput.address2"
36
+ >
37
+ Address 2
38
+ </label>
39
+ <input
40
+ class="string-group input-group"
41
+ name="normalAddressInput.address2"
42
+ placeholder="Address, Line 2"
43
+ value=""
44
+ />
45
+ </div>
46
+ <div
47
+ class="string-group input-group group"
48
+ >
49
+ <div
50
+ id="normaladdressinput.city-error-scroll-target"
51
+ style="display: none;"
52
+ />
53
+ <label
54
+ for="normalAddressInput.city"
55
+ >
56
+ City
57
+ </label>
58
+ <input
59
+ class="string-group input-group"
60
+ name="normalAddressInput.city"
61
+ placeholder="City"
62
+ value=""
63
+ />
64
+ </div>
65
+ <div
66
+ class="select-group group"
67
+ >
68
+ <div
69
+ id="normaladdressinput.state-error-scroll-target"
70
+ style="display: none;"
71
+ />
72
+ <label
73
+ for="normalAddressInput.state"
74
+ >
75
+ State
76
+ </label>
77
+ <div
78
+ class="select-group css-b62m3t-container"
79
+ >
80
+ <span
81
+ class="css-1f43avz-a11yText-A11yText"
82
+ id="react-select-3-live-region"
83
+ />
84
+ <span
85
+ aria-atomic="false"
86
+ aria-live="polite"
87
+ aria-relevant="additions text"
88
+ class="css-1f43avz-a11yText-A11yText"
89
+ />
90
+ <div
91
+ class="react-select__control css-1s2u09g-control"
92
+ >
93
+ <div
94
+ class="react-select__value-container css-dlobye-Component"
95
+ >
96
+ <div
97
+ class="react-select__placeholder css-14el2xx-placeholder"
98
+ id="react-select-3-placeholder"
99
+ >
100
+ State
101
+ </div>
102
+ <div
103
+ class="react-select__input-container css-1u4kn00-Component"
104
+ data-value=""
105
+ >
106
+ <input
107
+ aria-autocomplete="list"
108
+ aria-controls="react-select-3-listbox"
109
+ aria-describedby="react-select-3-placeholder"
110
+ aria-expanded="false"
111
+ aria-haspopup="true"
112
+ aria-owns="react-select-3-listbox"
113
+ autocapitalize="none"
114
+ autocomplete="off"
115
+ autocorrect="off"
116
+ class="react-select__input"
117
+ id="normalAddressInput.state"
118
+ role="combobox"
119
+ spellcheck="false"
120
+ style="opacity: 1; width: 100%; grid-area: 1 / 2; min-width: 2px; border: 0px; margin: 0px; outline: 0; padding: 0px;"
121
+ tabindex="0"
122
+ type="text"
123
+ value=""
124
+ />
125
+ </div>
126
+ </div>
127
+ <div
128
+ class="react-select__indicators css-ny0e4k-Component"
129
+ >
130
+ <span
131
+ class="react-select__indicator-separator css-1okebmr-indicatorSeparator"
132
+ />
133
+ <div
134
+ aria-hidden="true"
135
+ class="react-select__indicator react-select__dropdown-indicator css-tlfecz-indicatorContainer"
136
+ >
137
+ <svg
138
+ aria-hidden="true"
139
+ class="css-tj5bde-Svg"
140
+ focusable="false"
141
+ height="20"
142
+ viewBox="0 0 20 20"
143
+ width="20"
144
+ >
145
+ <path
146
+ d="M4.516 7.548c0.436-0.446 1.043-0.481 1.576 0l3.908 3.747 3.908-3.747c0.533-0.481 1.141-0.446 1.574 0 0.436 0.445 0.408 1.197 0 1.615-0.406 0.418-4.695 4.502-4.695 4.502-0.217 0.223-0.502 0.335-0.787 0.335s-0.57-0.112-0.789-0.335c0 0-4.287-4.084-4.695-4.502s-0.436-1.17 0-1.615z"
147
+ />
148
+ </svg>
149
+ </div>
150
+ </div>
151
+ </div>
152
+ </div>
153
+ </div>
154
+ <div
155
+ class="string-group input-group group"
156
+ >
157
+ <div
158
+ id="normaladdressinput.zipcode-error-scroll-target"
159
+ style="display: none;"
160
+ />
161
+ <label
162
+ for="normalAddressInput.zipCode"
163
+ >
164
+ Zip
165
+ </label>
166
+ <input
167
+ class="string-group input-group"
168
+ name="normalAddressInput.zipCode"
169
+ placeholder="Zip"
170
+ value=""
171
+ />
172
+ </div>
173
+ </form>
174
+ </DocumentFragment>
175
+ `;
@@ -0,0 +1,24 @@
1
+ import React from 'react';
2
+ import { render } from '@testing-library/react';
3
+ import { useAxiosRequestProps } from 'envoc-request';
4
+ import ConfirmBaseForm from './ConfirmBaseForm';
5
+
6
+ describe('ConfirmBaseForm', () => {
7
+ it('Renders without error', () => {
8
+ render(<ConfirmBaseForm request={confirmBaseFormRequest} />);
9
+ });
10
+
11
+ it('has matching snapshot', () => {
12
+ const renderResult = render(
13
+ <ConfirmBaseForm request={confirmBaseFormRequest} />
14
+ );
15
+ expect(renderResult.asFragment()).toMatchSnapshot();
16
+ });
17
+ });
18
+
19
+ const confirmBaseFormRequest = {
20
+ method: 'get',
21
+ url: `/boop`,
22
+ onComplete: () => {},
23
+ onError: () => {},
24
+ } as useAxiosRequestProps;
@@ -0,0 +1,50 @@
1
+ import React, { MouseEventHandler } from 'react';
2
+ import classNames from 'classnames';
3
+ import { useAxiosRequest, useAxiosRequestProps } from 'envoc-request';
4
+
5
+ // TODO: change the style prop type to Tailwind type (does this exist before Tailwind 3.1 ???), or
6
+ // should this just be type 'string'
7
+ export interface ConfirmBaseFormProps {
8
+ handleCancel?: MouseEventHandler<HTMLButtonElement>;
9
+ request: useAxiosRequestProps;
10
+ style?: React.CSSProperties;
11
+ title?: string;
12
+ children?: React.ReactNode;
13
+ }
14
+
15
+ // TODO: ask about how we should use 'children'
16
+ export default function ConfirmBaseForm({
17
+ handleCancel,
18
+ request,
19
+ style,
20
+ title,
21
+ children,
22
+ ...props
23
+ }: ConfirmBaseFormProps) {
24
+ const webRequest = useAxiosRequest(
25
+ Object.assign({}, request, { autoExecute: false })
26
+ );
27
+ const onCancel = handleCancel ?? goBack;
28
+
29
+ return (
30
+ <div style={{ textAlign: 'center', ...style }} {...props}>
31
+ <h3>{title}</h3>
32
+ {children}
33
+ <button
34
+ className={classNames('confirm-base-form-yes-button')}
35
+ type="button"
36
+ onClick={webRequest.submitRequest}>
37
+ Yes
38
+ </button>
39
+ <button
40
+ className={classNames('confirm-base-form-cancel-button')}
41
+ type="button"
42
+ onClick={onCancel}>
43
+ Cancel
44
+ </button>
45
+ </div>
46
+ );
47
+ function goBack() {
48
+ window.history.back();
49
+ }
50
+ }
@@ -7,13 +7,13 @@ exports[`ConfirmBaseForm has matching snapshot 1`] = `
7
7
  >
8
8
  <h3 />
9
9
  <button
10
- class="btn btn-danger"
10
+ class="confirm-base-form-yes-button"
11
11
  type="button"
12
12
  >
13
13
  Yes
14
14
  </button>
15
15
  <button
16
- class="btn btn-link"
16
+ class="confirm-base-form-cancel-button"
17
17
  type="button"
18
18
  >
19
19
  Cancel
@@ -1,6 +1,6 @@
1
1
  import React from 'react';
2
2
  import { HashRouter } from 'react-router-dom';
3
- import { render, screen } from '@testing-library/react';
3
+ import { render } from '@testing-library/react';
4
4
 
5
5
  import ConfirmDeleteForm from './ConfirmDeleteForm';
6
6
 
@@ -8,7 +8,7 @@ describe('ConfirmDeleteForm', () => {
8
8
  it('Renders without error', () => {
9
9
  render(
10
10
  <HashRouter>
11
- <ConfirmDeleteForm />
11
+ <ConfirmDeleteForm form="foo" />
12
12
  </HashRouter>
13
13
  );
14
14
  });
@@ -16,7 +16,7 @@ describe('ConfirmDeleteForm', () => {
16
16
  it('has matching snapshot', () => {
17
17
  const renderResult = render(
18
18
  <HashRouter>
19
- <ConfirmDeleteForm />
19
+ <ConfirmDeleteForm form="foo" />
20
20
  </HashRouter>
21
21
  );
22
22
  expect(renderResult.asFragment()).toMatchSnapshot();
@@ -0,0 +1,67 @@
1
+ import React from 'react';
2
+ import { useNavigate, useParams } from 'react-router-dom';
3
+ import { toast } from 'react-toastify';
4
+ import { useAxiosRequestProps } from 'envoc-request';
5
+ import ConfirmBaseForm, { ConfirmBaseFormProps } from '../ConfirmBaseForm/ConfirmBaseForm';
6
+
7
+ export interface ConfirmDeleteFormProps
8
+ extends Pick<ConfirmBaseFormProps, 'style'> {
9
+ successUrl?: string;
10
+ form: string;
11
+ title?: string;
12
+ handleComplete?: Function;
13
+ handleError?: Function;
14
+ children?: React.ReactNode;
15
+ }
16
+
17
+ export default function ConfirmDeleteForm({
18
+ successUrl,
19
+ form,
20
+ title,
21
+ handleComplete,
22
+ handleError,
23
+ children,
24
+ ...props
25
+ }: ConfirmDeleteFormProps) {
26
+ const navigate = useNavigate();
27
+ const { entityId } = useParams();
28
+ const onComplete =
29
+ handleComplete ??
30
+ function () {
31
+ toast.success('Deleted!');
32
+ goBack();
33
+ };
34
+ const onError =
35
+ handleError ??
36
+ function (error: any) {
37
+ toast.error(
38
+ error.response?.data?.validationFailures[0]?.errorMessage ??
39
+ 'Something went wrong talking to the portal. Contact support if this continues.'
40
+ );
41
+ };
42
+
43
+ const request = {
44
+ method: 'delete',
45
+ url: `/api/${form}/${entityId}`,
46
+ onComplete: onComplete,
47
+ onError: onError,
48
+ } as useAxiosRequestProps;
49
+
50
+ return (
51
+ <ConfirmBaseForm
52
+ request={request}
53
+ handleCancel={goBack}
54
+ title={title ?? 'Are you sure you want to delete this?'}
55
+ {...props}>
56
+ {children}
57
+ </ConfirmBaseForm>
58
+ );
59
+
60
+ function goBack() {
61
+ if (successUrl) {
62
+ navigate(successUrl);
63
+ } else {
64
+ navigate(-1);
65
+ }
66
+ }
67
+ }
@@ -9,13 +9,13 @@ exports[`ConfirmDeleteForm has matching snapshot 1`] = `
9
9
  Are you sure you want to delete this?
10
10
  </h3>
11
11
  <button
12
- class="btn btn-danger"
12
+ class="confirm-base-form-yes-button"
13
13
  type="button"
14
14
  >
15
15
  Yes
16
16
  </button>
17
17
  <button
18
- class="btn btn-link"
18
+ class="confirm-base-form-cancel-button"
19
19
  type="button"
20
20
  >
21
21
  Cancel
@@ -0,0 +1,48 @@
1
+ import React from 'react';
2
+ import { render } from '@testing-library/react';
3
+ import DatePickerInput from './DatePickerInput';
4
+ import FormTestBase from '../__Tests__/FormTestBase';
5
+
6
+ //hack so the datepicker internals don't complain about this not existing in the context of jest
7
+ HTMLCanvasElement.prototype.getContext = () => {};
8
+
9
+ describe('IconInputGroup', () => {
10
+ it('renders without crashing', () => {
11
+ render(
12
+ <FormTestBase>
13
+ {({ Field }) => (
14
+ <Field
15
+ name="favoriteDate"
16
+ Component={DatePickerInput}
17
+ label="Favorite Date"
18
+ monthPlaceholder="mm"
19
+ dayPlaceholder="dd"
20
+ yearPlaceholder="yyyy"
21
+ maxDate={new Date('9/23/2023')}
22
+ minDate={new Date('6/22/2022')}
23
+ />
24
+ )}
25
+ </FormTestBase>
26
+ );
27
+ });
28
+
29
+ it('has matching snapshot', () => {
30
+ const renderResult = render(
31
+ <FormTestBase>
32
+ {({ Field }) => (
33
+ <Field
34
+ name="favoriteDate"
35
+ Component={DatePickerInput}
36
+ label="Favorite Date"
37
+ monthPlaceholder="mm"
38
+ dayPlaceholder="dd"
39
+ yearPlaceholder="yyyy"
40
+ maxDate={new Date('9/23/2023')}
41
+ minDate={new Date('6/22/2022')}
42
+ />
43
+ )}
44
+ </FormTestBase>
45
+ );
46
+ expect(renderResult.asFragment()).toMatchSnapshot();
47
+ });
48
+ });
@@ -0,0 +1,85 @@
1
+ import { useState } from 'react';
2
+ import DatePicker, { DatePickerProps } from 'react-date-picker';
3
+ import classnames from 'classnames';
4
+ import parseISO from 'date-fns/parseISO';
5
+ import { InjectedFieldProps } from '../Field/InjectedFieldProps';
6
+ import Group, { GroupProps } from '../Group';
7
+
8
+ // Docs for react-date-picker https://www.npmjs.com/package/react-date-picker
9
+
10
+ // TODO: pick better home for this
11
+ export interface DateOnly {
12
+ year?: number;
13
+ month?: number;
14
+ day?: number;
15
+ }
16
+
17
+ type InjectedDate = InjectedFieldProps<DateOnly | undefined>;
18
+
19
+ export interface DatePickerInputProps
20
+ extends InjectedDate,
21
+ Omit<DatePickerProps, keyof InjectedDate | 'name' | 'value' | 'className'>,
22
+ Omit<GroupProps, keyof InjectedDate | 'children'> {}
23
+
24
+ export default function DatePickerInput({
25
+ input,
26
+ meta,
27
+ label,
28
+ helpText,
29
+ className,
30
+ disabled,
31
+ ...rest
32
+ }: DatePickerInputProps) {
33
+ const [displayDate, setDisplayDate] = useState<Date | null>(null);
34
+
35
+ function handleChange(e: DatePickerProps['value'] | undefined) {
36
+ const { onChange } = input;
37
+ if (onChange == null) {
38
+ return;
39
+ }
40
+
41
+ if (!e) {
42
+ onChange(undefined);
43
+ setDisplayDate(null);
44
+ return;
45
+ }
46
+
47
+ if (e instanceof Date) {
48
+ const parsedValue = parseISO(e.toISOString().split('T')[0]);
49
+
50
+ setDisplayDate(parsedValue);
51
+ onChange({
52
+ year: e.getFullYear(),
53
+ month: e.getMonth() + 1,
54
+ day: e.getDate(),
55
+ });
56
+ } else {
57
+ // e is instanceof Date[]
58
+ const parsedValue = parseISO(e[0].toISOString().split('T')[0]);
59
+
60
+ setDisplayDate(parsedValue);
61
+ onChange({
62
+ year: e[0].getFullYear(),
63
+ month: e[0].getMonth() + 1,
64
+ day: e[0].getDate(),
65
+ });
66
+ }
67
+ }
68
+
69
+ return (
70
+ <Group
71
+ input={input}
72
+ meta={meta}
73
+ label={label}
74
+ helpText={helpText}
75
+ className={classnames(className, 'date-picker')}
76
+ disabled={disabled}>
77
+ <DatePicker
78
+ {...rest}
79
+ className={classnames('date-picker', className)}
80
+ value={displayDate}
81
+ onChange={handleChange}
82
+ />
83
+ </Group>
84
+ );
85
+ }
@@ -0,0 +1,151 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`IconInputGroup has matching snapshot 1`] = `
4
+ <DocumentFragment>
5
+ <form
6
+ action="#"
7
+ >
8
+ <div
9
+ class="date-picker group"
10
+ >
11
+ <div
12
+ id="favoritedate-error-scroll-target"
13
+ style="display: none;"
14
+ />
15
+ <label
16
+ for="favoriteDate"
17
+ >
18
+ Favorite Date
19
+ </label>
20
+ <div
21
+ class="react-date-picker react-date-picker--closed react-date-picker--enabled date-picker"
22
+ >
23
+ <div
24
+ class="react-date-picker__wrapper"
25
+ >
26
+ <div
27
+ class="react-date-picker__inputGroup"
28
+ >
29
+ <input
30
+ max="2023-09-23"
31
+ min="2022-06-22"
32
+ name="date"
33
+ style="visibility: hidden; position: absolute; z-index: -999;"
34
+ type="date"
35
+ value=""
36
+ />
37
+ <input
38
+ autocomplete="off"
39
+ class="react-date-picker__inputGroup__input react-date-picker__inputGroup__month"
40
+ data-input="true"
41
+ inputmode="numeric"
42
+ max="12"
43
+ min="1"
44
+ name="month"
45
+ placeholder="mm"
46
+ type="number"
47
+ value=""
48
+ />
49
+ <span
50
+ class="react-date-picker__inputGroup__divider"
51
+ >
52
+ /
53
+ </span>
54
+ <input
55
+ autocomplete="off"
56
+ class="react-date-picker__inputGroup__input react-date-picker__inputGroup__day"
57
+ data-input="true"
58
+ inputmode="numeric"
59
+ max="31"
60
+ min="1"
61
+ name="day"
62
+ placeholder="dd"
63
+ type="number"
64
+ value=""
65
+ />
66
+ <span
67
+ class="react-date-picker__inputGroup__divider"
68
+ >
69
+ /
70
+ </span>
71
+ <input
72
+ autocomplete="off"
73
+ class="react-date-picker__inputGroup__input react-date-picker__inputGroup__year"
74
+ data-input="true"
75
+ inputmode="numeric"
76
+ max="2023"
77
+ min="2022"
78
+ name="year"
79
+ placeholder="yyyy"
80
+ step="1"
81
+ type="number"
82
+ value=""
83
+ />
84
+ </div>
85
+ <button
86
+ class="react-date-picker__clear-button react-date-picker__button"
87
+ type="button"
88
+ >
89
+ <svg
90
+ class="react-date-picker__clear-button__icon react-date-picker__button__icon"
91
+ height="19"
92
+ stroke="black"
93
+ stroke-width="2"
94
+ viewBox="0 0 19 19"
95
+ width="19"
96
+ xmlns="http://www.w3.org/2000/svg"
97
+ >
98
+ <line
99
+ x1="4"
100
+ x2="15"
101
+ y1="4"
102
+ y2="15"
103
+ />
104
+ <line
105
+ x1="15"
106
+ x2="4"
107
+ y1="4"
108
+ y2="15"
109
+ />
110
+ </svg>
111
+ </button>
112
+ <button
113
+ class="react-date-picker__calendar-button react-date-picker__button"
114
+ type="button"
115
+ >
116
+ <svg
117
+ class="react-date-picker__calendar-button__icon react-date-picker__button__icon"
118
+ height="19"
119
+ stroke="black"
120
+ stroke-width="2"
121
+ viewBox="0 0 19 19"
122
+ width="19"
123
+ xmlns="http://www.w3.org/2000/svg"
124
+ >
125
+ <rect
126
+ fill="none"
127
+ height="15"
128
+ width="15"
129
+ x="2"
130
+ y="2"
131
+ />
132
+ <line
133
+ x1="6"
134
+ x2="6"
135
+ y1="0"
136
+ y2="4"
137
+ />
138
+ <line
139
+ x1="13"
140
+ x2="13"
141
+ y1="0"
142
+ y2="4"
143
+ />
144
+ </svg>
145
+ </button>
146
+ </div>
147
+ </div>
148
+ </div>
149
+ </form>
150
+ </DocumentFragment>
151
+ `;
@@ -0,0 +1,10 @@
1
+ export interface CustomFieldInputProps<TValue> {
2
+ id: string;
3
+ name: string;
4
+ value: TValue;
5
+ // we want to be more strict than formik is for setting the value
6
+ onChange: (newValue: TValue) => void;
7
+
8
+ // we don't want controlled vs uncontrolled components to behave oddly
9
+ onBlur: () => void;
10
+ }
@@ -0,0 +1,5 @@
1
+ import { FieldMetaProps } from 'formik';
2
+
3
+ export interface CustomFieldMetaProps<TValue> extends FieldMetaProps<TValue> {
4
+ warning: string | undefined;
5
+ }