@toptal/picasso-forms 66.3.2 → 67.0.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 (552) hide show
  1. package/{Autocomplete → dist-package/src/Autocomplete}/Autocomplete.d.ts +1 -0
  2. package/dist-package/src/Autocomplete/Autocomplete.d.ts.map +1 -0
  3. package/dist-package/src/Autocomplete/Autocomplete.js.map +1 -0
  4. package/{Autocomplete → dist-package/src/Autocomplete}/index.d.ts +1 -0
  5. package/dist-package/src/Autocomplete/index.d.ts.map +1 -0
  6. package/dist-package/src/Autocomplete/index.js.map +1 -0
  7. package/{AvatarUpload → dist-package/src/AvatarUpload}/AvatarUpload.d.ts +1 -0
  8. package/dist-package/src/AvatarUpload/AvatarUpload.d.ts.map +1 -0
  9. package/dist-package/src/AvatarUpload/AvatarUpload.js.map +1 -0
  10. package/{AvatarUpload → dist-package/src/AvatarUpload}/index.d.ts +1 -0
  11. package/dist-package/src/AvatarUpload/index.d.ts.map +1 -0
  12. package/dist-package/src/AvatarUpload/index.js.map +1 -0
  13. package/{ButtonCheckbox → dist-package/src/ButtonCheckbox}/ButtonCheckbox.d.ts +1 -0
  14. package/dist-package/src/ButtonCheckbox/ButtonCheckbox.d.ts.map +1 -0
  15. package/dist-package/src/ButtonCheckbox/ButtonCheckbox.js.map +1 -0
  16. package/{ButtonCheckbox → dist-package/src/ButtonCheckbox}/index.d.ts +1 -0
  17. package/dist-package/src/ButtonCheckbox/index.d.ts.map +1 -0
  18. package/dist-package/src/ButtonCheckbox/index.js.map +1 -0
  19. package/{ButtonRadio → dist-package/src/ButtonRadio}/ButtonRadio.d.ts +1 -0
  20. package/dist-package/src/ButtonRadio/ButtonRadio.d.ts.map +1 -0
  21. package/dist-package/src/ButtonRadio/ButtonRadio.js.map +1 -0
  22. package/{ButtonRadio → dist-package/src/ButtonRadio}/index.d.ts +1 -0
  23. package/dist-package/src/ButtonRadio/index.d.ts.map +1 -0
  24. package/dist-package/src/ButtonRadio/index.js.map +1 -0
  25. package/{Checkbox → dist-package/src/Checkbox}/Checkbox.d.ts +1 -0
  26. package/dist-package/src/Checkbox/Checkbox.d.ts.map +1 -0
  27. package/dist-package/src/Checkbox/Checkbox.js.map +1 -0
  28. package/dist-package/src/Checkbox/index.d.ts +3 -0
  29. package/dist-package/src/Checkbox/index.d.ts.map +1 -0
  30. package/dist-package/src/Checkbox/index.js.map +1 -0
  31. package/{CheckboxGroup → dist-package/src/CheckboxGroup}/CheckboxGroup.d.ts +1 -0
  32. package/dist-package/src/CheckboxGroup/CheckboxGroup.d.ts.map +1 -0
  33. package/dist-package/src/CheckboxGroup/CheckboxGroup.js.map +1 -0
  34. package/{CheckboxGroup → dist-package/src/CheckboxGroup}/CheckboxGroupContext.d.ts +1 -0
  35. package/dist-package/src/CheckboxGroup/CheckboxGroupContext.d.ts.map +1 -0
  36. package/dist-package/src/CheckboxGroup/CheckboxGroupContext.js.map +1 -0
  37. package/{CheckboxGroup → dist-package/src/CheckboxGroup}/index.d.ts +1 -0
  38. package/dist-package/src/CheckboxGroup/index.d.ts.map +1 -0
  39. package/dist-package/src/CheckboxGroup/index.js.map +1 -0
  40. package/{DatePicker → dist-package/src/DatePicker}/DatePicker.d.ts +1 -0
  41. package/dist-package/src/DatePicker/DatePicker.d.ts.map +1 -0
  42. package/dist-package/src/DatePicker/DatePicker.js.map +1 -0
  43. package/{DatePicker → dist-package/src/DatePicker}/index.d.ts +1 -0
  44. package/dist-package/src/DatePicker/index.d.ts.map +1 -0
  45. package/dist-package/src/DatePicker/index.js.map +1 -0
  46. package/{Dropzone → dist-package/src/Dropzone}/Dropzone.d.ts +1 -0
  47. package/dist-package/src/Dropzone/Dropzone.d.ts.map +1 -0
  48. package/dist-package/src/Dropzone/Dropzone.js.map +1 -0
  49. package/{Dropzone → dist-package/src/Dropzone}/index.d.ts +1 -0
  50. package/dist-package/src/Dropzone/index.d.ts.map +1 -0
  51. package/dist-package/src/Dropzone/index.js.map +1 -0
  52. package/{Field → dist-package/src/Field}/Field.d.ts +1 -0
  53. package/dist-package/src/Field/Field.d.ts.map +1 -0
  54. package/dist-package/src/Field/Field.js.map +1 -0
  55. package/{Field → dist-package/src/Field}/index.d.ts +1 -0
  56. package/dist-package/src/Field/index.d.ts.map +1 -0
  57. package/dist-package/src/Field/index.js.map +1 -0
  58. package/dist-package/src/FieldBase/index.d.ts +2 -0
  59. package/dist-package/src/FieldBase/index.d.ts.map +1 -0
  60. package/dist-package/src/FieldBase/index.js.map +1 -0
  61. package/dist-package/src/FieldBase/types.d.ts +6 -0
  62. package/dist-package/src/FieldBase/types.d.ts.map +1 -0
  63. package/{FieldBase → dist-package/src/FieldBase}/types.js.map +1 -1
  64. package/{FieldLabel → dist-package/src/FieldLabel}/FieldLabel.d.ts +1 -0
  65. package/dist-package/src/FieldLabel/FieldLabel.d.ts.map +1 -0
  66. package/dist-package/src/FieldLabel/FieldLabel.js.map +1 -0
  67. package/{FieldLabel → dist-package/src/FieldLabel}/index.d.ts +1 -0
  68. package/dist-package/src/FieldLabel/index.d.ts.map +1 -0
  69. package/dist-package/src/FieldLabel/index.js.map +1 -0
  70. package/{FieldWrapper → dist-package/src/FieldWrapper}/FieldWrapper.d.ts +1 -0
  71. package/dist-package/src/FieldWrapper/FieldWrapper.d.ts.map +1 -0
  72. package/dist-package/src/FieldWrapper/FieldWrapper.js.map +1 -0
  73. package/{FieldWrapper → dist-package/src/FieldWrapper}/index.d.ts +1 -0
  74. package/dist-package/src/FieldWrapper/index.d.ts.map +1 -0
  75. package/dist-package/src/FieldWrapper/index.js.map +1 -0
  76. package/{FileInput → dist-package/src/FileInput}/FileInput.d.ts +1 -0
  77. package/dist-package/src/FileInput/FileInput.d.ts.map +1 -0
  78. package/dist-package/src/FileInput/FileInput.js.map +1 -0
  79. package/{FileInput → dist-package/src/FileInput}/index.d.ts +1 -0
  80. package/dist-package/src/FileInput/index.d.ts.map +1 -0
  81. package/dist-package/src/FileInput/index.js.map +1 -0
  82. package/{Form → dist-package/src/Form}/Form.d.ts +1 -0
  83. package/dist-package/src/Form/Form.d.ts.map +1 -0
  84. package/{Form → dist-package/src/Form}/Form.js +1 -1
  85. package/dist-package/src/Form/Form.js.map +1 -0
  86. package/{Form → dist-package/src/Form}/FormContext.d.ts +1 -0
  87. package/dist-package/src/Form/FormContext.d.ts.map +1 -0
  88. package/dist-package/src/Form/FormContext.js.map +1 -0
  89. package/{Form → dist-package/src/Form}/FormRenderer.d.ts +1 -0
  90. package/dist-package/src/Form/FormRenderer.d.ts.map +1 -0
  91. package/dist-package/src/Form/FormRenderer.js.map +1 -0
  92. package/{Form → dist-package/src/Form}/index.d.ts +1 -0
  93. package/dist-package/src/Form/index.d.ts.map +1 -0
  94. package/dist-package/src/Form/index.js.map +1 -0
  95. package/{Form → dist-package/src/Form}/mutators/index.d.ts +1 -0
  96. package/dist-package/src/Form/mutators/index.d.ts.map +1 -0
  97. package/dist-package/src/Form/mutators/index.js.map +1 -0
  98. package/{Form → dist-package/src/Form}/mutators/set-active-field-touched.d.ts +1 -0
  99. package/dist-package/src/Form/mutators/set-active-field-touched.d.ts.map +1 -0
  100. package/dist-package/src/Form/mutators/set-active-field-touched.js.map +1 -0
  101. package/{Form → dist-package/src/Form}/mutators/set-has-multiline-counter.d.ts +1 -0
  102. package/dist-package/src/Form/mutators/set-has-multiline-counter.d.ts.map +1 -0
  103. package/dist-package/src/Form/mutators/set-has-multiline-counter.js.map +1 -0
  104. package/{FormCompound → dist-package/src/FormCompound}/index.d.ts +7 -6
  105. package/dist-package/src/FormCompound/index.d.ts.map +1 -0
  106. package/dist-package/src/FormCompound/index.js.map +1 -0
  107. package/{FormConfig → dist-package/src/FormConfig}/FormConfig.d.ts +1 -0
  108. package/dist-package/src/FormConfig/FormConfig.d.ts.map +1 -0
  109. package/dist-package/src/FormConfig/FormConfig.js.map +1 -0
  110. package/dist-package/src/FormConfig/index.d.ts +2 -0
  111. package/dist-package/src/FormConfig/index.d.ts.map +1 -0
  112. package/dist-package/src/FormConfig/index.js.map +1 -0
  113. package/{Input → dist-package/src/Input}/Input.d.ts +1 -0
  114. package/dist-package/src/Input/Input.d.ts.map +1 -0
  115. package/dist-package/src/Input/Input.js.map +1 -0
  116. package/{Input → dist-package/src/Input}/index.d.ts +1 -0
  117. package/dist-package/src/Input/index.d.ts.map +1 -0
  118. package/dist-package/src/Input/index.js.map +1 -0
  119. package/{InputField → dist-package/src/InputField}/InputField.d.ts +1 -0
  120. package/dist-package/src/InputField/InputField.d.ts.map +1 -0
  121. package/dist-package/src/InputField/InputField.js.map +1 -0
  122. package/{InputField → dist-package/src/InputField}/index.d.ts +1 -0
  123. package/dist-package/src/InputField/index.d.ts.map +1 -0
  124. package/dist-package/src/InputField/index.js.map +1 -0
  125. package/{NumberInput → dist-package/src/NumberInput}/NumberInput.d.ts +1 -0
  126. package/dist-package/src/NumberInput/NumberInput.d.ts.map +1 -0
  127. package/dist-package/src/NumberInput/NumberInput.js.map +1 -0
  128. package/dist-package/src/NumberInput/index.d.ts +3 -0
  129. package/dist-package/src/NumberInput/index.d.ts.map +1 -0
  130. package/dist-package/src/NumberInput/index.js.map +1 -0
  131. package/{PasswordInput → dist-package/src/PasswordInput}/FieldRenderer.d.ts +1 -0
  132. package/dist-package/src/PasswordInput/FieldRenderer.d.ts.map +1 -0
  133. package/dist-package/src/PasswordInput/FieldRenderer.js.map +1 -0
  134. package/{PasswordInput → dist-package/src/PasswordInput}/PasswordInput.d.ts +1 -0
  135. package/dist-package/src/PasswordInput/PasswordInput.d.ts.map +1 -0
  136. package/dist-package/src/PasswordInput/PasswordInput.js.map +1 -0
  137. package/{PasswordInput → dist-package/src/PasswordInput}/index.d.ts +1 -0
  138. package/dist-package/src/PasswordInput/index.d.ts.map +1 -0
  139. package/dist-package/src/PasswordInput/index.js.map +1 -0
  140. package/{PasswordInput → dist-package/src/PasswordInput}/validators.d.ts +1 -0
  141. package/dist-package/src/PasswordInput/validators.d.ts.map +1 -0
  142. package/dist-package/src/PasswordInput/validators.js.map +1 -0
  143. package/{Radio → dist-package/src/Radio}/Radio.d.ts +1 -0
  144. package/dist-package/src/Radio/Radio.d.ts.map +1 -0
  145. package/dist-package/src/Radio/Radio.js.map +1 -0
  146. package/{Radio → dist-package/src/Radio}/index.d.ts +1 -0
  147. package/dist-package/src/Radio/index.d.ts.map +1 -0
  148. package/dist-package/src/Radio/index.js.map +1 -0
  149. package/{RadioGroup → dist-package/src/RadioGroup}/RadioGroup.d.ts +1 -0
  150. package/dist-package/src/RadioGroup/RadioGroup.d.ts.map +1 -0
  151. package/dist-package/src/RadioGroup/RadioGroup.js.map +1 -0
  152. package/{RadioGroup → dist-package/src/RadioGroup}/RadioGroupContext.d.ts +1 -0
  153. package/dist-package/src/RadioGroup/RadioGroupContext.d.ts.map +1 -0
  154. package/dist-package/src/RadioGroup/RadioGroupContext.js.map +1 -0
  155. package/{RadioGroup → dist-package/src/RadioGroup}/index.d.ts +1 -0
  156. package/dist-package/src/RadioGroup/index.d.ts.map +1 -0
  157. package/dist-package/src/RadioGroup/index.js.map +1 -0
  158. package/{Rating → dist-package/src/Rating}/Rating.d.ts +1 -0
  159. package/dist-package/src/Rating/Rating.d.ts.map +1 -0
  160. package/dist-package/src/Rating/Rating.js.map +1 -0
  161. package/{Rating → dist-package/src/Rating}/index.d.ts +1 -0
  162. package/dist-package/src/Rating/index.d.ts.map +1 -0
  163. package/dist-package/src/Rating/index.js.map +1 -0
  164. package/{RichTextEditor → dist-package/src/RichTextEditor}/RichTextEditor.d.ts +2 -1
  165. package/dist-package/src/RichTextEditor/RichTextEditor.d.ts.map +1 -0
  166. package/dist-package/src/RichTextEditor/RichTextEditor.js.map +1 -0
  167. package/dist-package/src/RichTextEditor/hooks/index.d.ts +2 -0
  168. package/dist-package/src/RichTextEditor/hooks/index.d.ts.map +1 -0
  169. package/dist-package/src/RichTextEditor/hooks/index.js.map +1 -0
  170. package/{RichTextEditor → dist-package/src/RichTextEditor}/hooks/use-enforce-highlight-autofill.d.ts +1 -0
  171. package/dist-package/src/RichTextEditor/hooks/use-enforce-highlight-autofill.d.ts.map +1 -0
  172. package/dist-package/src/RichTextEditor/hooks/use-enforce-highlight-autofill.js.map +1 -0
  173. package/{RichTextEditor → dist-package/src/RichTextEditor}/index.d.ts +1 -0
  174. package/dist-package/src/RichTextEditor/index.d.ts.map +1 -0
  175. package/dist-package/src/RichTextEditor/index.js.map +1 -0
  176. package/{Select → dist-package/src/Select}/Select.d.ts +1 -0
  177. package/dist-package/src/Select/Select.d.ts.map +1 -0
  178. package/{Select → dist-package/src/Select}/Select.js +1 -1
  179. package/dist-package/src/Select/Select.js.map +1 -0
  180. package/dist-package/src/Select/index.d.ts +3 -0
  181. package/dist-package/src/Select/index.d.ts.map +1 -0
  182. package/dist-package/src/Select/index.js.map +1 -0
  183. package/{SubmitButton → dist-package/src/SubmitButton}/SubmitButton.d.ts +2 -2
  184. package/dist-package/src/SubmitButton/SubmitButton.d.ts.map +1 -0
  185. package/dist-package/src/SubmitButton/SubmitButton.js.map +1 -0
  186. package/{SubmitButton → dist-package/src/SubmitButton}/index.d.ts +1 -0
  187. package/dist-package/src/SubmitButton/index.d.ts.map +1 -0
  188. package/dist-package/src/SubmitButton/index.js.map +1 -0
  189. package/{Switch → dist-package/src/Switch}/Switch.d.ts +1 -0
  190. package/dist-package/src/Switch/Switch.d.ts.map +1 -0
  191. package/dist-package/src/Switch/Switch.js.map +1 -0
  192. package/{Switch → dist-package/src/Switch}/index.d.ts +1 -0
  193. package/dist-package/src/Switch/index.d.ts.map +1 -0
  194. package/dist-package/src/Switch/index.js.map +1 -0
  195. package/{TagSelector → dist-package/src/TagSelector}/TagSelector.d.ts +1 -0
  196. package/dist-package/src/TagSelector/TagSelector.d.ts.map +1 -0
  197. package/dist-package/src/TagSelector/TagSelector.js.map +1 -0
  198. package/dist-package/src/TagSelector/index.d.ts +3 -0
  199. package/dist-package/src/TagSelector/index.d.ts.map +1 -0
  200. package/dist-package/src/TagSelector/index.js.map +1 -0
  201. package/{TimePicker → dist-package/src/TimePicker}/TimePicker.d.ts +1 -0
  202. package/dist-package/src/TimePicker/TimePicker.d.ts.map +1 -0
  203. package/dist-package/src/TimePicker/TimePicker.js.map +1 -0
  204. package/{TimePicker → dist-package/src/TimePicker}/index.d.ts +1 -0
  205. package/dist-package/src/TimePicker/index.d.ts.map +1 -0
  206. package/dist-package/src/TimePicker/index.js.map +1 -0
  207. package/{index.d.ts → dist-package/src/index.d.ts} +10 -0
  208. package/dist-package/src/index.d.ts.map +1 -0
  209. package/{index.js → dist-package/src/index.js} +3 -0
  210. package/dist-package/src/index.js.map +1 -0
  211. package/{utils → dist-package/src/utils}/flat-map.d.ts +1 -0
  212. package/dist-package/src/utils/flat-map.d.ts.map +1 -0
  213. package/dist-package/src/utils/flat-map.js.map +1 -0
  214. package/{utils → dist-package/src/utils}/form-values-change-decorator/form-values-change-decorator.d.ts +1 -0
  215. package/dist-package/src/utils/form-values-change-decorator/form-values-change-decorator.d.ts.map +1 -0
  216. package/dist-package/src/utils/form-values-change-decorator/form-values-change-decorator.js.map +1 -0
  217. package/{utils → dist-package/src/utils}/form-values-change-decorator/index.d.ts +1 -0
  218. package/dist-package/src/utils/form-values-change-decorator/index.d.ts.map +1 -0
  219. package/dist-package/src/utils/form-values-change-decorator/index.js.map +1 -0
  220. package/{utils → dist-package/src/utils}/index.d.ts +1 -0
  221. package/dist-package/src/utils/index.d.ts.map +1 -0
  222. package/dist-package/src/utils/index.js.map +1 -0
  223. package/{utils → dist-package/src/utils}/scroll-to-error-decorator.d.ts +1 -0
  224. package/dist-package/src/utils/scroll-to-error-decorator.d.ts.map +1 -0
  225. package/dist-package/src/utils/scroll-to-error-decorator.js.map +1 -0
  226. package/{utils → dist-package/src/utils}/scroll-to.d.ts +1 -0
  227. package/dist-package/src/utils/scroll-to.d.ts.map +1 -0
  228. package/dist-package/src/utils/scroll-to.js.map +1 -0
  229. package/{utils → dist-package/src/utils}/use-field-validation/index.d.ts +1 -0
  230. package/dist-package/src/utils/use-field-validation/index.d.ts.map +1 -0
  231. package/dist-package/src/utils/use-field-validation/index.js.map +1 -0
  232. package/{utils → dist-package/src/utils}/use-field-validation/use-field-validation.d.ts +1 -0
  233. package/dist-package/src/utils/use-field-validation/use-field-validation.d.ts.map +1 -0
  234. package/dist-package/src/utils/use-field-validation/use-field-validation.js.map +1 -0
  235. package/{utils → dist-package/src/utils}/use-form-auto-save/index.d.ts +1 -0
  236. package/dist-package/src/utils/use-form-auto-save/index.d.ts.map +1 -0
  237. package/dist-package/src/utils/use-form-auto-save/index.js.map +1 -0
  238. package/{utils → dist-package/src/utils}/use-form-auto-save/use-form-auto-save.d.ts +1 -0
  239. package/dist-package/src/utils/use-form-auto-save/use-form-auto-save.d.ts.map +1 -0
  240. package/dist-package/src/utils/use-form-auto-save/use-form-auto-save.js.map +1 -0
  241. package/{utils → dist-package/src/utils}/use-form-input-reset/index.d.ts +1 -0
  242. package/dist-package/src/utils/use-form-input-reset/index.d.ts.map +1 -0
  243. package/dist-package/src/utils/use-form-input-reset/index.js.map +1 -0
  244. package/{utils → dist-package/src/utils}/use-form-input-reset/use-form-input-reset.d.ts +1 -0
  245. package/dist-package/src/utils/use-form-input-reset/use-form-input-reset.d.ts.map +1 -0
  246. package/dist-package/src/utils/use-form-input-reset/use-form-input-reset.js.map +1 -0
  247. package/{utils → dist-package/src/utils}/validators.d.ts +1 -0
  248. package/dist-package/src/utils/validators.d.ts.map +1 -0
  249. package/dist-package/src/utils/validators.js.map +1 -0
  250. package/package.json +24 -11
  251. package/src/Autocomplete/Autocomplete.tsx +37 -0
  252. package/src/Autocomplete/index.ts +1 -0
  253. package/src/AvatarUpload/AvatarUpload.tsx +92 -0
  254. package/src/AvatarUpload/index.ts +1 -0
  255. package/src/ButtonCheckbox/ButtonCheckbox.tsx +63 -0
  256. package/src/ButtonCheckbox/index.ts +1 -0
  257. package/src/ButtonRadio/ButtonRadio.tsx +25 -0
  258. package/src/ButtonRadio/index.ts +1 -0
  259. package/src/Checkbox/Checkbox.tsx +79 -0
  260. package/src/Checkbox/__snapshots__/test.tsx.snap +259 -0
  261. package/src/Checkbox/index.ts +2 -0
  262. package/src/Checkbox/test.tsx +92 -0
  263. package/src/CheckboxGroup/CheckboxGroup.tsx +47 -0
  264. package/src/CheckboxGroup/CheckboxGroupContext.ts +3 -0
  265. package/src/CheckboxGroup/index.ts +3 -0
  266. package/src/CheckboxGroup/test.tsx +36 -0
  267. package/src/DatePicker/DatePicker.tsx +40 -0
  268. package/src/DatePicker/index.ts +1 -0
  269. package/src/Dropzone/Dropzone.tsx +102 -0
  270. package/src/Dropzone/index.ts +6 -0
  271. package/src/Field/Field.tsx +196 -0
  272. package/src/Field/index.ts +2 -0
  273. package/src/FieldBase/index.ts +1 -0
  274. package/src/FieldBase/types.ts +23 -0
  275. package/src/FieldLabel/FieldLabel.tsx +64 -0
  276. package/src/FieldLabel/__snapshots__/test.tsx.snap +21 -0
  277. package/src/FieldLabel/index.ts +2 -0
  278. package/src/FieldLabel/test.tsx +52 -0
  279. package/src/FieldWrapper/FieldWrapper.tsx +48 -0
  280. package/src/FieldWrapper/index.ts +6 -0
  281. package/src/FieldWrapper/story/index.jsx +153 -0
  282. package/src/FieldWrapper/test.tsx +32 -0
  283. package/src/FileInput/FileInput.tsx +85 -0
  284. package/src/FileInput/index.ts +1 -0
  285. package/src/Form/Form.tsx +161 -0
  286. package/src/Form/FormContext.ts +38 -0
  287. package/src/Form/FormRenderer.tsx +38 -0
  288. package/src/Form/__snapshots__/test.tsx.snap +140 -0
  289. package/src/Form/index.ts +2 -0
  290. package/src/Form/mutators/index.ts +2 -0
  291. package/src/Form/mutators/set-active-field-touched.ts +16 -0
  292. package/src/Form/mutators/set-has-multiline-counter.ts +16 -0
  293. package/src/Form/story/AutoSave.example.tsx +120 -0
  294. package/src/Form/story/AvatarUpload.example.tsx +81 -0
  295. package/src/Form/story/BackendCommunication.example.tsx +137 -0
  296. package/src/Form/story/CustomFormLevelConfiguration.example.tsx +35 -0
  297. package/src/Form/story/CustomValidator.example.tsx +53 -0
  298. package/src/Form/story/Default.example.tsx +218 -0
  299. package/src/Form/story/Dropzone.example.tsx +42 -0
  300. package/src/Form/story/FieldRequirements.example.tsx +58 -0
  301. package/src/Form/story/FileInput.example.tsx +43 -0
  302. package/src/Form/story/HighlightAutofill.example.tsx +96 -0
  303. package/src/Form/story/Horizontal.example.tsx +281 -0
  304. package/src/Form/story/HorizontalLabelWidth.example.tsx +26 -0
  305. package/src/Form/story/NoScrolling.example.tsx +42 -0
  306. package/src/Form/story/ParseInput.example.tsx +31 -0
  307. package/src/Form/story/RichTextEditor.example.tsx +32 -0
  308. package/src/Form/story/Status.example.tsx +35 -0
  309. package/src/Form/story/TitleCase.example.tsx +194 -0
  310. package/src/Form/story/ValidateOnSubmit.example.tsx +99 -0
  311. package/src/Form/story/index.jsx +289 -0
  312. package/src/Form/test.tsx +202 -0
  313. package/src/FormCompound/index.ts +51 -0
  314. package/src/FormConfig/FormConfig.ts +35 -0
  315. package/src/FormConfig/index.ts +1 -0
  316. package/src/FormConfig/test.tsx +44 -0
  317. package/src/Input/Input.tsx +80 -0
  318. package/src/Input/index.ts +2 -0
  319. package/src/Input/test.tsx +35 -0
  320. package/src/InputField/InputField.tsx +71 -0
  321. package/src/InputField/index.ts +1 -0
  322. package/src/InputField/test.ts +105 -0
  323. package/src/NumberInput/NumberInput.tsx +58 -0
  324. package/src/NumberInput/index.ts +2 -0
  325. package/src/PasswordInput/FieldRenderer.tsx +36 -0
  326. package/src/PasswordInput/PasswordInput.tsx +144 -0
  327. package/src/PasswordInput/index.ts +1 -0
  328. package/src/PasswordInput/test.ts +45 -0
  329. package/src/PasswordInput/validators.ts +28 -0
  330. package/src/Radio/Radio.tsx +25 -0
  331. package/src/Radio/__snapshots__/test.tsx.snap +235 -0
  332. package/src/Radio/index.ts +1 -0
  333. package/src/Radio/test.tsx +49 -0
  334. package/src/RadioGroup/RadioGroup.tsx +53 -0
  335. package/src/RadioGroup/RadioGroupContext.ts +3 -0
  336. package/src/RadioGroup/index.ts +3 -0
  337. package/src/RadioGroup/test.tsx +36 -0
  338. package/src/Rating/Rating.tsx +95 -0
  339. package/src/Rating/__snapshots__/test.tsx.snap +226 -0
  340. package/src/Rating/index.ts +1 -0
  341. package/src/Rating/test.tsx +171 -0
  342. package/src/RichTextEditor/RichTextEditor.tsx +87 -0
  343. package/{RichTextEditor/hooks/index.d.ts → src/RichTextEditor/hooks/index.ts} +1 -1
  344. package/src/RichTextEditor/hooks/use-enforce-highlight-autofill.test.tsx +67 -0
  345. package/src/RichTextEditor/hooks/use-enforce-highlight-autofill.ts +48 -0
  346. package/src/RichTextEditor/index.ts +1 -0
  347. package/src/Select/Select.tsx +55 -0
  348. package/src/Select/index.ts +2 -0
  349. package/src/SubmitButton/SubmitButton.tsx +71 -0
  350. package/src/SubmitButton/index.ts +6 -0
  351. package/src/SubmitButton/story/ButtonTypes.example.tsx +45 -0
  352. package/src/SubmitButton/story/Default.example.tsx +16 -0
  353. package/src/SubmitButton/story/index.jsx +35 -0
  354. package/src/Switch/Switch.tsx +40 -0
  355. package/src/Switch/index.ts +1 -0
  356. package/src/TagSelector/TagSelector.tsx +41 -0
  357. package/src/TagSelector/index.ts +2 -0
  358. package/src/TimePicker/TimePicker.tsx +43 -0
  359. package/src/TimePicker/index.ts +1 -0
  360. package/src/index.ts +86 -0
  361. package/src/story/Deserialization.example.tsx +40 -0
  362. package/src/story/FormSpy.example.tsx +50 -0
  363. package/src/story/index.jsx +39 -0
  364. package/src/utils/flat-map.ts +4 -0
  365. package/src/utils/form-values-change-decorator/form-values-change-decorator.ts +64 -0
  366. package/src/utils/form-values-change-decorator/index.ts +3 -0
  367. package/src/utils/form-values-change-decorator/test.tsx +77 -0
  368. package/src/utils/index.ts +6 -0
  369. package/src/utils/scroll-to-error-decorator.ts +85 -0
  370. package/src/utils/scroll-to.ts +10 -0
  371. package/src/utils/use-field-validation/index.ts +1 -0
  372. package/src/utils/use-field-validation/test.tsx +73 -0
  373. package/src/utils/use-field-validation/use-field-validation.ts +63 -0
  374. package/src/utils/use-form-auto-save/index.ts +1 -0
  375. package/src/utils/use-form-auto-save/use-form-auto-save.ts +59 -0
  376. package/src/utils/use-form-input-reset/index.ts +1 -0
  377. package/src/utils/use-form-input-reset/test.ts +72 -0
  378. package/src/utils/use-form-input-reset/use-form-input-reset.ts +32 -0
  379. package/src/utils/validators.ts +18 -0
  380. package/utils.d.ts +1 -0
  381. package/utils.js +4 -0
  382. package/Autocomplete/Autocomplete.js.map +0 -1
  383. package/Autocomplete/index.js.map +0 -1
  384. package/AvatarUpload/AvatarUpload.js.map +0 -1
  385. package/AvatarUpload/index.js.map +0 -1
  386. package/ButtonCheckbox/ButtonCheckbox.js.map +0 -1
  387. package/ButtonCheckbox/index.js.map +0 -1
  388. package/ButtonRadio/ButtonRadio.js.map +0 -1
  389. package/ButtonRadio/index.js.map +0 -1
  390. package/Checkbox/Checkbox.js.map +0 -1
  391. package/Checkbox/index.d.ts +0 -1
  392. package/Checkbox/index.js.map +0 -1
  393. package/CheckboxGroup/CheckboxGroup.js.map +0 -1
  394. package/CheckboxGroup/CheckboxGroupContext.js.map +0 -1
  395. package/CheckboxGroup/index.js.map +0 -1
  396. package/DatePicker/DatePicker.js.map +0 -1
  397. package/DatePicker/index.js.map +0 -1
  398. package/Dropzone/Dropzone.js.map +0 -1
  399. package/Dropzone/index.js.map +0 -1
  400. package/Field/Field.js.map +0 -1
  401. package/Field/index.js.map +0 -1
  402. package/FieldBase/index.d.ts +0 -1
  403. package/FieldBase/index.js.map +0 -1
  404. package/FieldBase/types.d.ts +0 -8
  405. package/FieldLabel/FieldLabel.js.map +0 -1
  406. package/FieldLabel/index.js.map +0 -1
  407. package/FieldWrapper/FieldWrapper.js.map +0 -1
  408. package/FieldWrapper/index.js.map +0 -1
  409. package/FileInput/FileInput.js.map +0 -1
  410. package/FileInput/index.js.map +0 -1
  411. package/Form/Form.js.map +0 -1
  412. package/Form/FormContext.js.map +0 -1
  413. package/Form/FormRenderer.js.map +0 -1
  414. package/Form/index.js.map +0 -1
  415. package/Form/mutators/index.js.map +0 -1
  416. package/Form/mutators/set-active-field-touched.js.map +0 -1
  417. package/Form/mutators/set-has-multiline-counter.js.map +0 -1
  418. package/FormCompound/index.js.map +0 -1
  419. package/FormConfig/FormConfig.js.map +0 -1
  420. package/FormConfig/index.d.ts +0 -1
  421. package/FormConfig/index.js.map +0 -1
  422. package/Input/Input.js.map +0 -1
  423. package/Input/index.js.map +0 -1
  424. package/InputField/InputField.js.map +0 -1
  425. package/InputField/index.js.map +0 -1
  426. package/LICENSE +0 -20
  427. package/NumberInput/NumberInput.js.map +0 -1
  428. package/NumberInput/index.d.ts +0 -1
  429. package/NumberInput/index.js.map +0 -1
  430. package/PasswordInput/FieldRenderer.js.map +0 -1
  431. package/PasswordInput/PasswordInput.js.map +0 -1
  432. package/PasswordInput/index.js.map +0 -1
  433. package/PasswordInput/validators.js.map +0 -1
  434. package/Radio/Radio.js.map +0 -1
  435. package/Radio/index.js.map +0 -1
  436. package/RadioGroup/RadioGroup.js.map +0 -1
  437. package/RadioGroup/RadioGroupContext.js.map +0 -1
  438. package/RadioGroup/index.js.map +0 -1
  439. package/Rating/Rating.js.map +0 -1
  440. package/Rating/index.js.map +0 -1
  441. package/RichTextEditor/RichTextEditor.js.map +0 -1
  442. package/RichTextEditor/hooks/index.js.map +0 -1
  443. package/RichTextEditor/hooks/use-enforce-highlight-autofill.js.map +0 -1
  444. package/RichTextEditor/hooks/use-enforce-highlight-autofill.test.d.ts +0 -1
  445. package/RichTextEditor/hooks/use-enforce-highlight-autofill.test.js +0 -51
  446. package/RichTextEditor/hooks/use-enforce-highlight-autofill.test.js.map +0 -1
  447. package/RichTextEditor/index.js.map +0 -1
  448. package/Select/Select.js.map +0 -1
  449. package/Select/index.d.ts +0 -1
  450. package/Select/index.js.map +0 -1
  451. package/SubmitButton/SubmitButton.js.map +0 -1
  452. package/SubmitButton/index.js.map +0 -1
  453. package/Switch/Switch.js.map +0 -1
  454. package/Switch/index.js.map +0 -1
  455. package/TagSelector/TagSelector.js.map +0 -1
  456. package/TagSelector/index.d.ts +0 -1
  457. package/TagSelector/index.js.map +0 -1
  458. package/TimePicker/TimePicker.js.map +0 -1
  459. package/TimePicker/index.js.map +0 -1
  460. package/index.js.map +0 -1
  461. package/utils/flat-map.js.map +0 -1
  462. package/utils/form-values-change-decorator/form-values-change-decorator.js.map +0 -1
  463. package/utils/form-values-change-decorator/index.js.map +0 -1
  464. package/utils/index.js.map +0 -1
  465. package/utils/scroll-to-error-decorator.js.map +0 -1
  466. package/utils/scroll-to.js.map +0 -1
  467. package/utils/use-field-validation/index.js.map +0 -1
  468. package/utils/use-field-validation/use-field-validation.js.map +0 -1
  469. package/utils/use-form-auto-save/index.js.map +0 -1
  470. package/utils/use-form-auto-save/use-form-auto-save.js.map +0 -1
  471. package/utils/use-form-input-reset/index.js.map +0 -1
  472. package/utils/use-form-input-reset/use-form-input-reset.js.map +0 -1
  473. package/utils/validators.js.map +0 -1
  474. /package/{Autocomplete → dist-package/src/Autocomplete}/Autocomplete.js +0 -0
  475. /package/{Autocomplete → dist-package/src/Autocomplete}/index.js +0 -0
  476. /package/{AvatarUpload → dist-package/src/AvatarUpload}/AvatarUpload.js +0 -0
  477. /package/{AvatarUpload → dist-package/src/AvatarUpload}/index.js +0 -0
  478. /package/{ButtonCheckbox → dist-package/src/ButtonCheckbox}/ButtonCheckbox.js +0 -0
  479. /package/{ButtonCheckbox → dist-package/src/ButtonCheckbox}/index.js +0 -0
  480. /package/{ButtonRadio → dist-package/src/ButtonRadio}/ButtonRadio.js +0 -0
  481. /package/{ButtonRadio → dist-package/src/ButtonRadio}/index.js +0 -0
  482. /package/{Checkbox → dist-package/src/Checkbox}/Checkbox.js +0 -0
  483. /package/{Checkbox → dist-package/src/Checkbox}/index.js +0 -0
  484. /package/{CheckboxGroup → dist-package/src/CheckboxGroup}/CheckboxGroup.js +0 -0
  485. /package/{CheckboxGroup → dist-package/src/CheckboxGroup}/CheckboxGroupContext.js +0 -0
  486. /package/{CheckboxGroup → dist-package/src/CheckboxGroup}/index.js +0 -0
  487. /package/{DatePicker → dist-package/src/DatePicker}/DatePicker.js +0 -0
  488. /package/{DatePicker → dist-package/src/DatePicker}/index.js +0 -0
  489. /package/{Dropzone → dist-package/src/Dropzone}/Dropzone.js +0 -0
  490. /package/{Dropzone → dist-package/src/Dropzone}/index.js +0 -0
  491. /package/{Field → dist-package/src/Field}/Field.js +0 -0
  492. /package/{Field → dist-package/src/Field}/index.js +0 -0
  493. /package/{FieldBase → dist-package/src/FieldBase}/index.js +0 -0
  494. /package/{FieldBase → dist-package/src/FieldBase}/types.js +0 -0
  495. /package/{FieldLabel → dist-package/src/FieldLabel}/FieldLabel.js +0 -0
  496. /package/{FieldLabel → dist-package/src/FieldLabel}/index.js +0 -0
  497. /package/{FieldWrapper → dist-package/src/FieldWrapper}/FieldWrapper.js +0 -0
  498. /package/{FieldWrapper → dist-package/src/FieldWrapper}/index.js +0 -0
  499. /package/{FileInput → dist-package/src/FileInput}/FileInput.js +0 -0
  500. /package/{FileInput → dist-package/src/FileInput}/index.js +0 -0
  501. /package/{Form → dist-package/src/Form}/FormContext.js +0 -0
  502. /package/{Form → dist-package/src/Form}/FormRenderer.js +0 -0
  503. /package/{Form → dist-package/src/Form}/index.js +0 -0
  504. /package/{Form → dist-package/src/Form}/mutators/index.js +0 -0
  505. /package/{Form → dist-package/src/Form}/mutators/set-active-field-touched.js +0 -0
  506. /package/{Form → dist-package/src/Form}/mutators/set-has-multiline-counter.js +0 -0
  507. /package/{FormCompound → dist-package/src/FormCompound}/index.js +0 -0
  508. /package/{FormConfig → dist-package/src/FormConfig}/FormConfig.js +0 -0
  509. /package/{FormConfig → dist-package/src/FormConfig}/index.js +0 -0
  510. /package/{Input → dist-package/src/Input}/Input.js +0 -0
  511. /package/{Input → dist-package/src/Input}/index.js +0 -0
  512. /package/{InputField → dist-package/src/InputField}/InputField.js +0 -0
  513. /package/{InputField → dist-package/src/InputField}/index.js +0 -0
  514. /package/{NumberInput → dist-package/src/NumberInput}/NumberInput.js +0 -0
  515. /package/{NumberInput → dist-package/src/NumberInput}/index.js +0 -0
  516. /package/{PasswordInput → dist-package/src/PasswordInput}/FieldRenderer.js +0 -0
  517. /package/{PasswordInput → dist-package/src/PasswordInput}/PasswordInput.js +0 -0
  518. /package/{PasswordInput → dist-package/src/PasswordInput}/index.js +0 -0
  519. /package/{PasswordInput → dist-package/src/PasswordInput}/validators.js +0 -0
  520. /package/{Radio → dist-package/src/Radio}/Radio.js +0 -0
  521. /package/{Radio → dist-package/src/Radio}/index.js +0 -0
  522. /package/{RadioGroup → dist-package/src/RadioGroup}/RadioGroup.js +0 -0
  523. /package/{RadioGroup → dist-package/src/RadioGroup}/RadioGroupContext.js +0 -0
  524. /package/{RadioGroup → dist-package/src/RadioGroup}/index.js +0 -0
  525. /package/{Rating → dist-package/src/Rating}/Rating.js +0 -0
  526. /package/{Rating → dist-package/src/Rating}/index.js +0 -0
  527. /package/{RichTextEditor → dist-package/src/RichTextEditor}/RichTextEditor.js +0 -0
  528. /package/{RichTextEditor → dist-package/src/RichTextEditor}/hooks/index.js +0 -0
  529. /package/{RichTextEditor → dist-package/src/RichTextEditor}/hooks/use-enforce-highlight-autofill.js +0 -0
  530. /package/{RichTextEditor → dist-package/src/RichTextEditor}/index.js +0 -0
  531. /package/{Select → dist-package/src/Select}/index.js +0 -0
  532. /package/{SubmitButton → dist-package/src/SubmitButton}/SubmitButton.js +0 -0
  533. /package/{SubmitButton → dist-package/src/SubmitButton}/index.js +0 -0
  534. /package/{Switch → dist-package/src/Switch}/Switch.js +0 -0
  535. /package/{Switch → dist-package/src/Switch}/index.js +0 -0
  536. /package/{TagSelector → dist-package/src/TagSelector}/TagSelector.js +0 -0
  537. /package/{TagSelector → dist-package/src/TagSelector}/index.js +0 -0
  538. /package/{TimePicker → dist-package/src/TimePicker}/TimePicker.js +0 -0
  539. /package/{TimePicker → dist-package/src/TimePicker}/index.js +0 -0
  540. /package/{utils → dist-package/src/utils}/flat-map.js +0 -0
  541. /package/{utils → dist-package/src/utils}/form-values-change-decorator/form-values-change-decorator.js +0 -0
  542. /package/{utils → dist-package/src/utils}/form-values-change-decorator/index.js +0 -0
  543. /package/{utils → dist-package/src/utils}/index.js +0 -0
  544. /package/{utils → dist-package/src/utils}/scroll-to-error-decorator.js +0 -0
  545. /package/{utils → dist-package/src/utils}/scroll-to.js +0 -0
  546. /package/{utils → dist-package/src/utils}/use-field-validation/index.js +0 -0
  547. /package/{utils → dist-package/src/utils}/use-field-validation/use-field-validation.js +0 -0
  548. /package/{utils → dist-package/src/utils}/use-form-auto-save/index.js +0 -0
  549. /package/{utils → dist-package/src/utils}/use-form-auto-save/use-form-auto-save.js +0 -0
  550. /package/{utils → dist-package/src/utils}/use-form-input-reset/index.js +0 -0
  551. /package/{utils → dist-package/src/utils}/use-form-input-reset/use-form-input-reset.js +0 -0
  552. /package/{utils → dist-package/src/utils}/validators.js +0 -0
@@ -0,0 +1,226 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`Rating Thumbs renders default Stars 1`] = `
4
+ <div>
5
+ <div
6
+ class="Picasso-root"
7
+ >
8
+ <div
9
+ class=""
10
+ >
11
+ <form
12
+ class=""
13
+ >
14
+ <div
15
+ class="PicassoFormField-root"
16
+ data-field-has-error="false"
17
+ >
18
+ <div
19
+ class=""
20
+ id="stars"
21
+ type="number"
22
+ >
23
+ <label
24
+ class="PicassoRating-label PicassoRating-clickableLabel"
25
+ for="stars-1"
26
+ >
27
+ <span>
28
+ <svg
29
+ class="PicassoSvgStar16-root PicassoRatingIcon-clickableIcon PicassoSvgStar16-yellow"
30
+ style="min-width: 16px; min-height: 16px;"
31
+ viewBox="0 0 16 16"
32
+ >
33
+ <path
34
+ d="m8 11.5-4.114 2.163.785-4.581-3.328-3.245 4.6-.669L8 1l2.057 4.168 4.6.669-3.328 3.245.785 4.581L8 11.5Zm0-1.13 2.786 1.465-.532-3.103 2.254-2.197-3.115-.453L8 3.26 6.607 6.082l-3.115.453 2.254 2.197-.532 3.103L8 10.37Z"
35
+ />
36
+ </svg>
37
+ </span>
38
+ <input
39
+ class="PicassoRating-radio"
40
+ data-testid="stars-1"
41
+ id="stars-1"
42
+ name="stars"
43
+ type="radio"
44
+ value="1"
45
+ />
46
+ </label>
47
+ <label
48
+ class="PicassoRating-label PicassoRating-clickableLabel"
49
+ for="stars-2"
50
+ >
51
+ <span>
52
+ <svg
53
+ class="PicassoSvgStar16-root PicassoRatingIcon-clickableIcon PicassoSvgStar16-yellow"
54
+ style="min-width: 16px; min-height: 16px;"
55
+ viewBox="0 0 16 16"
56
+ >
57
+ <path
58
+ d="m8 11.5-4.114 2.163.785-4.581-3.328-3.245 4.6-.669L8 1l2.057 4.168 4.6.669-3.328 3.245.785 4.581L8 11.5Zm0-1.13 2.786 1.465-.532-3.103 2.254-2.197-3.115-.453L8 3.26 6.607 6.082l-3.115.453 2.254 2.197-.532 3.103L8 10.37Z"
59
+ />
60
+ </svg>
61
+ </span>
62
+ <input
63
+ class="PicassoRating-radio"
64
+ data-testid="stars-2"
65
+ id="stars-2"
66
+ name="stars"
67
+ type="radio"
68
+ value="2"
69
+ />
70
+ </label>
71
+ <label
72
+ class="PicassoRating-label PicassoRating-clickableLabel"
73
+ for="stars-3"
74
+ >
75
+ <span>
76
+ <svg
77
+ class="PicassoSvgStar16-root PicassoRatingIcon-clickableIcon PicassoSvgStar16-yellow"
78
+ style="min-width: 16px; min-height: 16px;"
79
+ viewBox="0 0 16 16"
80
+ >
81
+ <path
82
+ d="m8 11.5-4.114 2.163.785-4.581-3.328-3.245 4.6-.669L8 1l2.057 4.168 4.6.669-3.328 3.245.785 4.581L8 11.5Zm0-1.13 2.786 1.465-.532-3.103 2.254-2.197-3.115-.453L8 3.26 6.607 6.082l-3.115.453 2.254 2.197-.532 3.103L8 10.37Z"
83
+ />
84
+ </svg>
85
+ </span>
86
+ <input
87
+ class="PicassoRating-radio"
88
+ data-testid="stars-3"
89
+ id="stars-3"
90
+ name="stars"
91
+ type="radio"
92
+ value="3"
93
+ />
94
+ </label>
95
+ <label
96
+ class="PicassoRating-label PicassoRating-clickableLabel"
97
+ for="stars-4"
98
+ >
99
+ <span>
100
+ <svg
101
+ class="PicassoSvgStar16-root PicassoRatingIcon-clickableIcon PicassoSvgStar16-yellow"
102
+ style="min-width: 16px; min-height: 16px;"
103
+ viewBox="0 0 16 16"
104
+ >
105
+ <path
106
+ d="m8 11.5-4.114 2.163.785-4.581-3.328-3.245 4.6-.669L8 1l2.057 4.168 4.6.669-3.328 3.245.785 4.581L8 11.5Zm0-1.13 2.786 1.465-.532-3.103 2.254-2.197-3.115-.453L8 3.26 6.607 6.082l-3.115.453 2.254 2.197-.532 3.103L8 10.37Z"
107
+ />
108
+ </svg>
109
+ </span>
110
+ <input
111
+ class="PicassoRating-radio"
112
+ data-testid="stars-4"
113
+ id="stars-4"
114
+ name="stars"
115
+ type="radio"
116
+ value="4"
117
+ />
118
+ </label>
119
+ <label
120
+ class="PicassoRating-label PicassoRating-clickableLabel"
121
+ for="stars-5"
122
+ >
123
+ <span>
124
+ <svg
125
+ class="PicassoSvgStar16-root PicassoRatingIcon-clickableIcon PicassoSvgStar16-yellow"
126
+ style="min-width: 16px; min-height: 16px;"
127
+ viewBox="0 0 16 16"
128
+ >
129
+ <path
130
+ d="m8 11.5-4.114 2.163.785-4.581-3.328-3.245 4.6-.669L8 1l2.057 4.168 4.6.669-3.328 3.245.785 4.581L8 11.5Zm0-1.13 2.786 1.465-.532-3.103 2.254-2.197-3.115-.453L8 3.26 6.607 6.082l-3.115.453 2.254 2.197-.532 3.103L8 10.37Z"
131
+ />
132
+ </svg>
133
+ </span>
134
+ <input
135
+ class="PicassoRating-radio"
136
+ data-testid="stars-5"
137
+ id="stars-5"
138
+ name="stars"
139
+ type="radio"
140
+ value="5"
141
+ />
142
+ </label>
143
+ <input
144
+ class="PicassoRating-radio"
145
+ id="stars-reset"
146
+ name="stars"
147
+ type="radio"
148
+ value=""
149
+ />
150
+ </div>
151
+ </div>
152
+ </form>
153
+ </div>
154
+ </div>
155
+ </div>
156
+ `;
157
+
158
+ exports[`Rating Thumbs renders default Thumbs 1`] = `
159
+ <div>
160
+ <div
161
+ class="Picasso-root"
162
+ >
163
+ <div
164
+ class=""
165
+ >
166
+ <form
167
+ class=""
168
+ >
169
+ <div
170
+ class="PicassoFormField-root"
171
+ data-field-has-error="false"
172
+ >
173
+ <div
174
+ class=""
175
+ >
176
+ <label
177
+ class="makeStyles-label"
178
+ for="0-posititve"
179
+ >
180
+ <svg
181
+ class="PicassoSvgThumbsUp16-root makeStyles-thumbs makeStyles-interactiveThumbs"
182
+ style="min-width: 16px; min-height: 16px;"
183
+ viewBox="0 0 16 16"
184
+ >
185
+ <path
186
+ d="M8.778.26 9.5.5a1.707 1.707 0 0 1 1.117 2.034l-.642 2.56 1.762-.319a3 3 0 0 1 3.488 3.488l-.628 3.453A4 4 0 0 1 10.662 15H9c-1.664 0-3.33-.333-5-1H2a1 1 0 0 1-1-1V7a1 1 0 0 1 1-1h2.45L7.593.712A1 1 0 0 1 8.778.259Zm-.316.948-.01.015L5.02 7 5 6.999v6.307c1.341.464 2.673.695 4 .694h1.662a3 3 0 0 0 2.951-2.463l.628-3.452a2 2 0 0 0-2.326-2.326l-3.287.596.377-1.503.641-2.56a.707.707 0 0 0-.462-.843l-.722-.241ZM4 13V6.999L2 7v6h2Z"
187
+ />
188
+ </svg>
189
+ <input
190
+ class="makeStyles-radio"
191
+ data-testid="positive-thumb"
192
+ id="0-posititve"
193
+ name="thumbs"
194
+ type="radio"
195
+ value="positive"
196
+ />
197
+ </label>
198
+ <label
199
+ class="makeStyles-label"
200
+ for="0-negative"
201
+ >
202
+ <svg
203
+ class="PicassoSvgThumbsDown16-root makeStyles-thumbs makeStyles-interactiveThumbs"
204
+ style="min-width: 16px; min-height: 16px;"
205
+ viewBox="0 0 16 16"
206
+ >
207
+ <path
208
+ d="M7.003 1c1.664 0 3.33.333 5 1h2a1 1 0 0 1 1 1v6a1 1 0 0 1-1 1h-2.45L8.41 15.288a1 1 0 0 1-1.185.453l-.722-.241a1.707 1.707 0 0 1-1.116-2.034l.641-2.56-1.761.319A3 3 0 0 1 .778 7.737l.628-3.453A4 4 0 0 1 5.342 1h1.661ZM12 9h2.003V3H12L12 9ZM7.003 2H5.342A3 3 0 0 0 2.39 4.463l-.628 3.452a2 2 0 0 0 2.326 2.326l3.287-.596-.377 1.503-.641 2.56a.707.707 0 0 0 .462.843l.723.241.008-.015L10.984 9H11V2.693A12.144 12.144 0 0 0 7.003 2Z"
209
+ />
210
+ </svg>
211
+ <input
212
+ class="makeStyles-radio"
213
+ data-testid="negative-thumb"
214
+ id="0-negative"
215
+ name="thumbs"
216
+ type="radio"
217
+ value="negative"
218
+ />
219
+ </label>
220
+ </div>
221
+ </div>
222
+ </form>
223
+ </div>
224
+ </div>
225
+ </div>
226
+ `;
@@ -0,0 +1 @@
1
+ export { default } from './Rating'
@@ -0,0 +1,171 @@
1
+ import React from 'react'
2
+ import { render, fireEvent, waitFor, act } from '@toptal/picasso-test-utils'
3
+
4
+ import type { RatingThumbsProps } from './Rating'
5
+ import type { Props as FormProps } from '../Form'
6
+ import { FormCompound as Form } from '../FormCompound'
7
+
8
+ let defaultOnSubmit: jest.Mock = jest.fn()
9
+
10
+ enum TestId {
11
+ SUBMIT_BUTTON = 'submit-button',
12
+ POSITIVE_THUMB = 'positive-thumb',
13
+ NEGATIVE_THUMB = 'negative-thumb',
14
+ }
15
+
16
+ const renderThumbsForm = (
17
+ props: {
18
+ form?: Partial<FormProps>
19
+ thumbs?: Partial<RatingThumbsProps>
20
+ } = {}
21
+ ) =>
22
+ render(
23
+ <Form onSubmit={defaultOnSubmit} {...props.form}>
24
+ <Form.Rating.Thumbs
25
+ name='thumbs'
26
+ testIds={{
27
+ positiveInput: TestId.POSITIVE_THUMB,
28
+ negativeInput: TestId.NEGATIVE_THUMB,
29
+ }}
30
+ {...props.thumbs}
31
+ />
32
+
33
+ <button type='submit' data-testid={TestId.SUBMIT_BUTTON}>
34
+ Submit
35
+ </button>
36
+ </Form>
37
+ )
38
+
39
+ describe('Rating', () => {
40
+ beforeEach(() => {
41
+ defaultOnSubmit = jest.fn()
42
+ })
43
+
44
+ describe('Thumbs', () => {
45
+ it('renders default Thumbs', () => {
46
+ const { container } = render(
47
+ <Form onSubmit={defaultOnSubmit}>
48
+ <Form.Rating.Thumbs
49
+ name='thumbs'
50
+ testIds={{
51
+ positiveInput: TestId.POSITIVE_THUMB,
52
+ negativeInput: TestId.NEGATIVE_THUMB,
53
+ }}
54
+ />
55
+ </Form>
56
+ )
57
+
58
+ expect(container).toMatchSnapshot()
59
+ })
60
+
61
+ it('renders default Stars', () => {
62
+ const { container } = render(
63
+ <Form onSubmit={defaultOnSubmit}>
64
+ <Form.Rating.Stars name='stars' />
65
+ </Form>
66
+ )
67
+
68
+ expect(container).toMatchSnapshot()
69
+ })
70
+
71
+ describe('when submitting while required', () => {
72
+ it("don't show a validation error for negative values", async () => {
73
+ const { queryByText, getByTestId } = renderThumbsForm({
74
+ thumbs: { required: true },
75
+ })
76
+
77
+ fireEvent.click(getByTestId(TestId.NEGATIVE_THUMB))
78
+
79
+ await act(() => {
80
+ fireEvent.click(getByTestId(TestId.SUBMIT_BUTTON))
81
+ })
82
+
83
+ expect(
84
+ queryByText('Please complete this field.')
85
+ ).not.toBeInTheDocument()
86
+
87
+ expect(defaultOnSubmit).toHaveBeenCalledWith(
88
+ { thumbs: false },
89
+ expect.anything(),
90
+ expect.anything()
91
+ )
92
+ expect(defaultOnSubmit).toHaveBeenCalledTimes(1)
93
+ })
94
+ })
95
+
96
+ describe('when submitting with custom validation', () => {
97
+ it('validate both required when having a custom validation with preference', async () => {
98
+ const ERROR_MSG = 'Errata'
99
+ const { getByTestId, queryByText } = renderThumbsForm({
100
+ thumbs: { required: true, validate: () => ERROR_MSG },
101
+ })
102
+
103
+ await act(() => {
104
+ fireEvent.click(getByTestId(TestId.SUBMIT_BUTTON))
105
+ })
106
+
107
+ expect(queryByText('Please complete this field.')).toBeInTheDocument()
108
+
109
+ expect(defaultOnSubmit).toHaveBeenCalledTimes(0)
110
+ })
111
+
112
+ it('validate both required and having a custom validation', async () => {
113
+ const ERROR_MSG = 'Errata'
114
+ const { getByTestId, queryByText } = renderThumbsForm({
115
+ thumbs: { required: true, validate: () => ERROR_MSG },
116
+ })
117
+
118
+ fireEvent.click(getByTestId(TestId.NEGATIVE_THUMB))
119
+
120
+ await waitFor(() => {
121
+ fireEvent.click(getByTestId(TestId.SUBMIT_BUTTON))
122
+ })
123
+
124
+ expect(queryByText(ERROR_MSG)).toBeInTheDocument()
125
+
126
+ expect(defaultOnSubmit).toHaveBeenCalledTimes(0)
127
+ })
128
+
129
+ it('validate both required and having a custom validation, everythin ok', async () => {
130
+ const { getByTestId, queryByText } = renderThumbsForm({
131
+ thumbs: { required: true, validate: () => undefined },
132
+ })
133
+
134
+ fireEvent.click(getByTestId(TestId.NEGATIVE_THUMB))
135
+
136
+ await act(() => {
137
+ fireEvent.click(getByTestId(TestId.SUBMIT_BUTTON))
138
+ })
139
+
140
+ expect(
141
+ queryByText('Please complete this field.')
142
+ ).not.toBeInTheDocument()
143
+
144
+ expect(defaultOnSubmit).toHaveBeenCalledWith(
145
+ { thumbs: false },
146
+ expect.anything(),
147
+ expect.anything()
148
+ )
149
+ expect(defaultOnSubmit).toHaveBeenCalledTimes(1)
150
+ })
151
+ })
152
+
153
+ describe('when submitting with requiredPositive true', () => {
154
+ it("don't allow a negative value", async () => {
155
+ const { getByTestId, queryByText } = renderThumbsForm({
156
+ thumbs: { requirePositive: true },
157
+ })
158
+
159
+ fireEvent.click(getByTestId(TestId.NEGATIVE_THUMB))
160
+
161
+ await act(() => {
162
+ fireEvent.click(getByTestId(TestId.SUBMIT_BUTTON))
163
+ })
164
+
165
+ expect(queryByText('Please complete this field.')).toBeInTheDocument()
166
+
167
+ expect(defaultOnSubmit).toHaveBeenCalledTimes(0)
168
+ })
169
+ })
170
+ })
171
+ })
@@ -0,0 +1,87 @@
1
+ import type {
2
+ ASTType,
3
+ RichTextEditorProps,
4
+ } from '@toptal/picasso-rich-text-editor'
5
+ import { RichTextEditor as PicassoRichTextEditor } from '@toptal/picasso-rich-text-editor'
6
+ import React, { useCallback, useState } from 'react'
7
+ import type { Except } from 'type-fest/source/except'
8
+ import { useForm } from 'react-final-form'
9
+
10
+ import type { FieldProps } from '../FieldWrapper'
11
+ import InputField from '../InputField'
12
+ import FieldLabel from '../FieldLabel'
13
+ import { useEnforceHighlightAutofill } from './hooks'
14
+
15
+ type OverriddenProps = {
16
+ defaultValue?: ASTType
17
+ value?: never
18
+ initialValue?: never
19
+ }
20
+
21
+ export type Props = RichTextEditorProps &
22
+ Except<FieldProps<string>, keyof OverriddenProps> &
23
+ OverriddenProps
24
+
25
+ type InternalProps = RichTextEditorProps & { value: string }
26
+
27
+ export const RichTextEditor = (props: Props) => {
28
+ const { onChange, onFocus, defaultValue, label, titleCase, ...rest } = props
29
+
30
+ const { enforceHighlightAutofill, registerChangeOrFocus } =
31
+ useEnforceHighlightAutofill()
32
+ const [value, setValue] = useState('')
33
+ const {
34
+ mutators: { setHasMultilineCounter },
35
+ } = useForm()
36
+
37
+ // Because RichTextEditor doesn't have an value input we need to implement this
38
+ // as an compatibility layer between final-form
39
+ const handleOnChange = useCallback(
40
+ (newVal: string) => {
41
+ registerChangeOrFocus()
42
+ setValue(newVal)
43
+ onChange?.(newVal)
44
+ },
45
+ [onChange, setValue, registerChangeOrFocus]
46
+ )
47
+
48
+ const handleOnFocus = useCallback(() => {
49
+ registerChangeOrFocus()
50
+
51
+ onFocus?.()
52
+ }, [onFocus, registerChangeOrFocus])
53
+
54
+ const hiddenInputId = `${props.id}-hidden-input`
55
+
56
+ return (
57
+ <InputField<InternalProps>
58
+ value={value}
59
+ onChange={handleOnChange}
60
+ onFocus={handleOnFocus}
61
+ label={
62
+ label ? (
63
+ <FieldLabel
64
+ name={hiddenInputId}
65
+ required={props.required}
66
+ label={label}
67
+ titleCase={titleCase}
68
+ alignment='top'
69
+ />
70
+ ) : null
71
+ }
72
+ setHasMultilineCounter={setHasMultilineCounter}
73
+ {...rest}
74
+ >
75
+ {(inputProps: RichTextEditorProps) => (
76
+ <PicassoRichTextEditor
77
+ defaultValue={defaultValue}
78
+ hiddenInputId={hiddenInputId}
79
+ highlight={enforceHighlightAutofill ? 'autofill' : undefined}
80
+ {...inputProps}
81
+ />
82
+ )}
83
+ </InputField>
84
+ )
85
+ }
86
+
87
+ export default RichTextEditor
@@ -1 +1 @@
1
- export { useEnforceHighlightAutofill } from './use-enforce-highlight-autofill';
1
+ export { useEnforceHighlightAutofill } from './use-enforce-highlight-autofill'
@@ -0,0 +1,67 @@
1
+ import React from 'react'
2
+ import { render, fireEvent } from '@toptal/picasso-test-utils'
3
+
4
+ import { useEnforceHighlightAutofill } from './use-enforce-highlight-autofill'
5
+ import { useFormConfig } from '../../FormConfig'
6
+
7
+ jest.mock('../../FormConfig', () => ({
8
+ useFormConfig: jest.fn(),
9
+ }))
10
+
11
+ const mockedUseFormConfig = useFormConfig as jest.MockedFunction<
12
+ typeof useFormConfig
13
+ >
14
+
15
+ const TestComponent = () => {
16
+ const { enforceHighlightAutofill, registerChangeOrFocus } =
17
+ useEnforceHighlightAutofill()
18
+
19
+ return (
20
+ <>
21
+ <button onClick={registerChangeOrFocus}>trigger</button>
22
+ <div data-testid='enforce-highlight-autofill-status'>
23
+ {enforceHighlightAutofill ? 'true' : 'false'}
24
+ </div>
25
+ </>
26
+ )
27
+ }
28
+
29
+ describe('useEnforceHighlightAutofill', () => {
30
+ describe('when form does not highlight autofilled fields', () => {
31
+ it('does not enforce highlighting', () => {
32
+ mockedUseFormConfig.mockReturnValue({ highlightAutofill: false })
33
+ const { getByText, getByTestId } = render(<TestComponent />)
34
+ const button = getByText('trigger')
35
+ const autofillStatusContainer = getByTestId(
36
+ 'enforce-highlight-autofill-status'
37
+ )
38
+
39
+ fireEvent.click(button)
40
+
41
+ // After first update
42
+ expect(autofillStatusContainer).toHaveTextContent('false')
43
+ })
44
+ })
45
+
46
+ describe('when form highlights autofilled fields', () => {
47
+ it('highlighting is enforced after first update and not enforced after following updates', async () => {
48
+ mockedUseFormConfig.mockReturnValue({ highlightAutofill: true })
49
+ const { getByText, getByTestId } = render(<TestComponent />)
50
+
51
+ const button = getByText('trigger')
52
+ const autofillStatusContainer = getByTestId(
53
+ 'enforce-highlight-autofill-status'
54
+ )
55
+
56
+ fireEvent.click(button)
57
+
58
+ // After first update
59
+ expect(autofillStatusContainer).toHaveTextContent('true')
60
+
61
+ fireEvent.click(button)
62
+
63
+ // After second update
64
+ expect(autofillStatusContainer).toHaveTextContent('false')
65
+ })
66
+ })
67
+ })
@@ -0,0 +1,48 @@
1
+ import { useCallback, useMemo, useState } from 'react'
2
+
3
+ import { useFormConfig } from '../../FormConfig'
4
+
5
+ /**
6
+ * This hook keeps the highlighted state for Rich Text Editor form fields after
7
+ * first `onChange` callback which is triggered by editor itself when initial value is
8
+ * provided. Starting from second `onChange` or first `onFocus` invocation (which are
9
+ * triggered by user) the field is no longer highlighted.
10
+ *
11
+ * Editor triggers the very first onChange callback by itself only when initial value
12
+ * is provided in order to propagate the value to wrapping form.
13
+ */
14
+
15
+ /**
16
+ * After first two editor changes are tracked (the initial one and the one originated
17
+ * from user), hook stops responding due to performance reasons.
18
+ */
19
+ const TRACKED_EVENTS_LIMIT = 2
20
+
21
+ export const useEnforceHighlightAutofill = () => {
22
+ const { highlightAutofill } = useFormConfig()
23
+ const [timesChangeOrFocusTriggered, setTimesChangeOrFocusTriggered] =
24
+ useState(0)
25
+
26
+ const enforceHighlightAutofill = useMemo(() => {
27
+ if (!highlightAutofill) {
28
+ return false
29
+ }
30
+
31
+ return timesChangeOrFocusTriggered < 2
32
+ }, [highlightAutofill, timesChangeOrFocusTriggered])
33
+
34
+ const registerChangeOrFocus = useCallback(() => {
35
+ if (!highlightAutofill) {
36
+ return
37
+ }
38
+
39
+ if (timesChangeOrFocusTriggered <= TRACKED_EVENTS_LIMIT) {
40
+ setTimesChangeOrFocusTriggered(timesChangeOrFocusTriggered + 1)
41
+ }
42
+ }, [highlightAutofill, timesChangeOrFocusTriggered])
43
+
44
+ return {
45
+ enforceHighlightAutofill,
46
+ registerChangeOrFocus,
47
+ }
48
+ }
@@ -0,0 +1 @@
1
+ export { default } from './RichTextEditor'
@@ -0,0 +1,55 @@
1
+ import React from 'react'
2
+ import type { SelectProps, SelectValueType } from '@toptal/picasso'
3
+ import { Select as PicassoSelect } from '@toptal/picasso'
4
+ import { generateRandomStringOrGetEmptyInTest } from '@toptal/picasso-utils'
5
+
6
+ import type { FieldProps } from '../Field'
7
+ import InputField from '../InputField'
8
+ import FieldLabel from '../FieldLabel'
9
+
10
+ export type Props<
11
+ T extends SelectValueType,
12
+ M extends boolean = false
13
+ > = SelectProps<T, M> & FieldProps<SelectProps<T, M>['value']>
14
+
15
+ export const Select = <T extends SelectValueType, M extends boolean = false>(
16
+ props: Props<T, M>
17
+ ) => {
18
+ const { name, id = name, label, titleCase, ...rest } = props
19
+ const randomizedId = id ? generateRandomStringOrGetEmptyInTest(id) : undefined
20
+
21
+ return (
22
+ <InputField<SelectProps<any, any>>
23
+ {...rest}
24
+ name={name}
25
+ id={randomizedId}
26
+ label={
27
+ label ? (
28
+ <FieldLabel
29
+ name={randomizedId}
30
+ required={rest.required}
31
+ label={label}
32
+ titleCase={titleCase}
33
+ />
34
+ ) : null
35
+ }
36
+ >
37
+ {(selectProps: SelectProps) => {
38
+ return (
39
+ <PicassoSelect
40
+ {...selectProps}
41
+ id={randomizedId}
42
+ // if `id` is specified, we have to provide a not correct value for autoComplete, e.g. `none` to trick google chrome
43
+ autoComplete={id ? 'none' : rest.autoComplete || 'off'}
44
+ />
45
+ )
46
+ }}
47
+ </InputField>
48
+ )
49
+ }
50
+
51
+ Select.defaultProps = {}
52
+
53
+ Select.displayName = 'Select'
54
+
55
+ export default Select
@@ -0,0 +1,2 @@
1
+ export { default } from './Select'
2
+ export type { Props } from './Select'