@webiny/ui 0.0.0-unstable.40876133bb → 0.0.0-unstable.496cf268ac

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 (394) hide show
  1. package/Accordion/Accordion.d.ts +1 -1
  2. package/Accordion/Accordion.js +5 -19
  3. package/Accordion/Accordion.js.map +1 -1
  4. package/Accordion/Accordion.stories.js +0 -8
  5. package/Accordion/Accordion.stories.js.map +1 -1
  6. package/Accordion/AccordionItem.d.ts +21 -2
  7. package/Accordion/AccordionItem.js +49 -71
  8. package/Accordion/AccordionItem.js.map +1 -1
  9. package/Accordion/AccordionItemActions.d.ts +8 -0
  10. package/Accordion/AccordionItemActions.js +28 -0
  11. package/Accordion/AccordionItemActions.js.map +1 -0
  12. package/Accordion/index.js +0 -4
  13. package/Accordion/index.js.map +1 -1
  14. package/Alert/Alert.d.ts +1 -1
  15. package/Alert/Alert.js +4 -11
  16. package/Alert/Alert.js.map +1 -1
  17. package/Alert/Alert.stories.js +0 -6
  18. package/Alert/Alert.stories.js.map +1 -1
  19. package/Alert/index.js +0 -2
  20. package/Alert/index.js.map +1 -1
  21. package/AutoComplete/AutoComplete.js +38 -88
  22. package/AutoComplete/AutoComplete.js.map +1 -1
  23. package/AutoComplete/AutoComplete.stories.js +0 -7
  24. package/AutoComplete/AutoComplete.stories.js.map +1 -1
  25. package/AutoComplete/MultiAutoComplete.js +52 -128
  26. package/AutoComplete/MultiAutoComplete.js.map +1 -1
  27. package/AutoComplete/MultiAutoComplete.stories.js +0 -8
  28. package/AutoComplete/MultiAutoComplete.stories.js.map +1 -1
  29. package/AutoComplete/index.js +0 -4
  30. package/AutoComplete/index.js.map +1 -1
  31. package/AutoComplete/styles.js +0 -2
  32. package/AutoComplete/styles.js.map +1 -1
  33. package/AutoComplete/utils.js +0 -8
  34. package/AutoComplete/utils.js.map +1 -1
  35. package/Avatar/Avatar.js +7 -18
  36. package/Avatar/Avatar.js.map +1 -1
  37. package/Avatar/Avatar.stories.js +0 -6
  38. package/Avatar/Avatar.stories.js.map +1 -1
  39. package/Avatar/index.js +0 -2
  40. package/Avatar/index.js.map +1 -1
  41. package/Button/Button.d.ts +30 -1
  42. package/Button/Button.js +39 -63
  43. package/Button/Button.js.map +1 -1
  44. package/Button/Button.stories.js +0 -10
  45. package/Button/Button.stories.js.map +1 -1
  46. package/Button/Button.styles.js +0 -2
  47. package/Button/Button.styles.js.map +1 -1
  48. package/Button/CopyButton/CopyButton.js +2 -12
  49. package/Button/CopyButton/CopyButton.js.map +1 -1
  50. package/Button/CopyButton/CopyButton.stories.js +0 -7
  51. package/Button/CopyButton/CopyButton.stories.js.map +1 -1
  52. package/Button/IconButton/IconButton.js +6 -12
  53. package/Button/IconButton/IconButton.js.map +1 -1
  54. package/Button/IconButton/IconButton.stories.js +0 -9
  55. package/Button/IconButton/IconButton.stories.js.map +1 -1
  56. package/Button/index.js +0 -6
  57. package/Button/index.js.map +1 -1
  58. package/Carousel/Carousel.js +0 -14
  59. package/Carousel/Carousel.js.map +1 -1
  60. package/Carousel/Carouser.stories.js +0 -7
  61. package/Carousel/Carouser.stories.js.map +1 -1
  62. package/Carousel/index.js +0 -2
  63. package/Carousel/index.js.map +1 -1
  64. package/Checkbox/Checkbox.d.ts +1 -0
  65. package/Checkbox/Checkbox.js +13 -31
  66. package/Checkbox/Checkbox.js.map +1 -1
  67. package/Checkbox/Checkbox.stories.js +0 -8
  68. package/Checkbox/Checkbox.stories.js.map +1 -1
  69. package/Checkbox/Checkbox.styles.js +0 -2
  70. package/Checkbox/Checkbox.styles.js.map +1 -1
  71. package/Checkbox/CheckboxGroup.js +7 -24
  72. package/Checkbox/CheckboxGroup.js.map +1 -1
  73. package/Checkbox/CheckboxGroup.stories.js +2 -10
  74. package/Checkbox/CheckboxGroup.stories.js.map +1 -1
  75. package/Checkbox/index.js +0 -3
  76. package/Checkbox/index.js.map +1 -1
  77. package/Chips/Chip.js +1 -8
  78. package/Chips/Chip.js.map +1 -1
  79. package/Chips/Chips.js +3 -13
  80. package/Chips/Chips.js.map +1 -1
  81. package/Chips/Chips.stories.js +0 -8
  82. package/Chips/Chips.stories.js.map +1 -1
  83. package/Chips/index.js +0 -4
  84. package/Chips/index.js.map +1 -1
  85. package/Chips/styles.js +0 -2
  86. package/Chips/styles.js.map +1 -1
  87. package/CodeEditor/CodeEditor.js +8 -36
  88. package/CodeEditor/CodeEditor.js.map +1 -1
  89. package/CodeEditor/CodeEditor.stories.js +0 -10
  90. package/CodeEditor/CodeEditor.stories.js.map +1 -1
  91. package/CodeEditor/index.js +0 -2
  92. package/CodeEditor/index.js.map +1 -1
  93. package/ColorPicker/ColorPicker.js +7 -31
  94. package/ColorPicker/ColorPicker.js.map +1 -1
  95. package/ColorPicker/ColorPicker.stories.js +0 -8
  96. package/ColorPicker/ColorPicker.stories.js.map +1 -1
  97. package/ColorPicker/index.js +0 -2
  98. package/ColorPicker/index.js.map +1 -1
  99. package/ConfirmationDialog/ConfirmationDialog.js +33 -65
  100. package/ConfirmationDialog/ConfirmationDialog.js.map +1 -1
  101. package/ConfirmationDialog/ConfirmationDialog.stories.js +0 -7
  102. package/ConfirmationDialog/ConfirmationDialog.stories.js.map +1 -1
  103. package/ConfirmationDialog/index.js +0 -4
  104. package/ConfirmationDialog/index.js.map +1 -1
  105. package/ConfirmationDialog/withConfirmation.js +0 -5
  106. package/ConfirmationDialog/withConfirmation.js.map +1 -1
  107. package/DataTable/DataTable.d.ts +16 -1
  108. package/DataTable/DataTable.js +62 -42
  109. package/DataTable/DataTable.js.map +1 -1
  110. package/DataTable/DataTable.stories.js +0 -6
  111. package/DataTable/DataTable.stories.js.map +1 -1
  112. package/DataTable/index.js +0 -2
  113. package/DataTable/index.js.map +1 -1
  114. package/DataTable/styled.d.ts +30 -1
  115. package/DataTable/styled.js +25 -7
  116. package/DataTable/styled.js.map +1 -1
  117. package/DelayedOnChange/DelayedOnChange.js +19 -35
  118. package/DelayedOnChange/DelayedOnChange.js.map +1 -1
  119. package/DelayedOnChange/index.js +0 -3
  120. package/DelayedOnChange/index.js.map +1 -1
  121. package/DelayedOnChange/withDelayedOnChange.js +3 -9
  122. package/DelayedOnChange/withDelayedOnChange.js.map +1 -1
  123. package/Dialog/Dialog.js +7 -39
  124. package/Dialog/Dialog.js.map +1 -1
  125. package/Dialog/Dialog.stories.js +0 -7
  126. package/Dialog/Dialog.stories.js.map +1 -1
  127. package/Dialog/index.js +0 -2
  128. package/Dialog/index.js.map +1 -1
  129. package/Drawer/Drawer.js +0 -9
  130. package/Drawer/Drawer.js.map +1 -1
  131. package/Drawer/Drawer.stories.js +0 -8
  132. package/Drawer/Drawer.stories.js.map +1 -1
  133. package/Drawer/index.js +0 -2
  134. package/Drawer/index.js.map +1 -1
  135. package/DynamicFieldset/Fieldset.js +7 -34
  136. package/DynamicFieldset/Fieldset.js.map +1 -1
  137. package/DynamicFieldset/index.js +0 -2
  138. package/DynamicFieldset/index.js.map +1 -1
  139. package/Elevation/Elevation.js +0 -5
  140. package/Elevation/Elevation.js.map +1 -1
  141. package/Elevation/Elevation.stories.js +0 -8
  142. package/Elevation/Elevation.stories.js.map +1 -1
  143. package/Elevation/index.js +0 -2
  144. package/Elevation/index.js.map +1 -1
  145. package/FormElementMessage/FormElementMessage.js +0 -5
  146. package/FormElementMessage/FormElementMessage.js.map +1 -1
  147. package/FormElementMessage/index.js +0 -1
  148. package/FormElementMessage/index.js.map +1 -1
  149. package/FullName/FullName.js +0 -7
  150. package/FullName/FullName.js.map +1 -1
  151. package/FullName/index.js +0 -2
  152. package/FullName/index.js.map +1 -1
  153. package/Grid/Grid.js +1 -9
  154. package/Grid/Grid.js.map +1 -1
  155. package/Grid/Grid.stories.js +0 -6
  156. package/Grid/Grid.stories.js.map +1 -1
  157. package/Grid/index.js +0 -2
  158. package/Grid/index.js.map +1 -1
  159. package/Helpers/ClassNames.js +0 -9
  160. package/Helpers/ClassNames.js.map +1 -1
  161. package/Helpers/index.js +0 -1
  162. package/Helpers/index.js.map +1 -1
  163. package/Icon/Icon.js +1 -7
  164. package/Icon/Icon.js.map +1 -1
  165. package/Icon/Icon.stories.js +0 -10
  166. package/Icon/Icon.stories.js.map +1 -1
  167. package/Icon/index.js +0 -2
  168. package/Icon/index.js.map +1 -1
  169. package/Image/Image.js +0 -8
  170. package/Image/Image.js.map +1 -1
  171. package/Image/Image.stories.js +0 -7
  172. package/Image/Image.stories.js.map +1 -1
  173. package/Image/index.js +0 -2
  174. package/Image/index.js.map +1 -1
  175. package/ImageEditor/ImageEditor.js +46 -107
  176. package/ImageEditor/ImageEditor.js.map +1 -1
  177. package/ImageEditor/index.js +0 -2
  178. package/ImageEditor/index.js.map +1 -1
  179. package/ImageEditor/toolbar/crop.js +1 -16
  180. package/ImageEditor/toolbar/crop.js.map +1 -1
  181. package/ImageEditor/toolbar/filter.js +11 -36
  182. package/ImageEditor/toolbar/filter.js.map +1 -1
  183. package/ImageEditor/toolbar/flip.js +0 -17
  184. package/ImageEditor/toolbar/flip.js.map +1 -1
  185. package/ImageEditor/toolbar/icons/index.js +0 -8
  186. package/ImageEditor/toolbar/icons/index.js.map +1 -1
  187. package/ImageEditor/toolbar/index.js +0 -5
  188. package/ImageEditor/toolbar/index.js.map +1 -1
  189. package/ImageEditor/toolbar/rotate.js +8 -43
  190. package/ImageEditor/toolbar/rotate.js.map +1 -1
  191. package/ImageUpload/Image.js +10 -34
  192. package/ImageUpload/Image.js.map +1 -1
  193. package/ImageUpload/ImageEditorDialog.js +11 -33
  194. package/ImageUpload/ImageEditorDialog.js.map +1 -1
  195. package/ImageUpload/MultiImageUpload.js +111 -175
  196. package/ImageUpload/MultiImageUpload.js.map +1 -1
  197. package/ImageUpload/MultiImageUpload.stories.js +0 -8
  198. package/ImageUpload/MultiImageUpload.stories.js.map +1 -1
  199. package/ImageUpload/SingleImageUpload.js +38 -79
  200. package/ImageUpload/SingleImageUpload.js.map +1 -1
  201. package/ImageUpload/SingleImageUpload.stories.js +0 -8
  202. package/ImageUpload/SingleImageUpload.stories.js.map +1 -1
  203. package/ImageUpload/index.js +0 -5
  204. package/ImageUpload/index.js.map +1 -1
  205. package/ImageUpload/styled.d.ts +27 -17
  206. package/ImageUpload/styled.js +0 -5
  207. package/ImageUpload/styled.js.map +1 -1
  208. package/Input/Input.d.ts +2 -12
  209. package/Input/Input.js +86 -149
  210. package/Input/Input.js.map +1 -1
  211. package/Input/Input.stories.js +0 -13
  212. package/Input/Input.stories.js.map +1 -1
  213. package/Input/__tests__/Input.test.js +4 -30
  214. package/Input/__tests__/Input.test.js.map +1 -1
  215. package/Input/index.js +0 -2
  216. package/Input/index.js.map +1 -1
  217. package/List/CollapsibleList/CollapsibleList.stories.js +0 -8
  218. package/List/CollapsibleList/CollapsibleList.stories.js.map +1 -1
  219. package/List/CollapsibleList/index.js +0 -6
  220. package/List/CollapsibleList/index.js.map +1 -1
  221. package/List/DataList/DataList.js +18 -97
  222. package/List/DataList/DataList.js.map +1 -1
  223. package/List/DataList/DataList.stories.js +2 -10
  224. package/List/DataList/DataList.stories.js.map +1 -1
  225. package/List/DataList/DataListModalOverlay/DataListModalOverlay.d.ts +8 -6
  226. package/List/DataList/DataListModalOverlay/DataListModalOverlay.js +5 -16
  227. package/List/DataList/DataListModalOverlay/DataListModalOverlay.js.map +1 -1
  228. package/List/DataList/DataListModalOverlay/DataListModalOverlayAction.js +3 -14
  229. package/List/DataList/DataListModalOverlay/DataListModalOverlayAction.js.map +1 -1
  230. package/List/DataList/DataListModalOverlay/DataListModalOverlayContext.js +3 -12
  231. package/List/DataList/DataListModalOverlay/DataListModalOverlayContext.js.map +1 -1
  232. package/List/DataList/DataListModalOverlay/index.js +0 -3
  233. package/List/DataList/DataListModalOverlay/index.js.map +1 -1
  234. package/List/DataList/DataListWithSections.js +4 -48
  235. package/List/DataList/DataListWithSections.js.map +1 -1
  236. package/List/DataList/Loader.js +0 -7
  237. package/List/DataList/Loader.js.map +1 -1
  238. package/List/DataList/NoData.js +0 -7
  239. package/List/DataList/NoData.js.map +1 -1
  240. package/List/DataList/icons/index.js +0 -29
  241. package/List/DataList/icons/index.js.map +1 -1
  242. package/List/DataList/index.js +0 -6
  243. package/List/DataList/index.js.map +1 -1
  244. package/List/List.js +0 -39
  245. package/List/List.js.map +1 -1
  246. package/List/List.stories.js +0 -12
  247. package/List/List.stories.js.map +1 -1
  248. package/List/icons/index.js +0 -3
  249. package/List/icons/index.js.map +1 -1
  250. package/List/index.js +0 -4
  251. package/List/index.js.map +1 -1
  252. package/Menu/Menu.js +2 -28
  253. package/Menu/Menu.js.map +1 -1
  254. package/Menu/Menu.stories.js +0 -7
  255. package/Menu/Menu.stories.js.map +1 -1
  256. package/Menu/index.js +0 -2
  257. package/Menu/index.js.map +1 -1
  258. package/Mosaic/Mosaic.js +3 -7
  259. package/Mosaic/Mosaic.js.map +1 -1
  260. package/Mosaic/Mosaic.stories.js +0 -6
  261. package/Mosaic/Mosaic.stories.js.map +1 -1
  262. package/Mosaic/index.js +0 -2
  263. package/Mosaic/index.js.map +1 -1
  264. package/Progress/CircularProgress.js +6 -14
  265. package/Progress/CircularProgress.js.map +1 -1
  266. package/Progress/index.js +0 -2
  267. package/Progress/index.js.map +1 -1
  268. package/Radio/Radio.js +9 -28
  269. package/Radio/Radio.js.map +1 -1
  270. package/Radio/Radio.styles.js +0 -2
  271. package/Radio/Radio.styles.js.map +1 -1
  272. package/Radio/RadioGroup.js +5 -21
  273. package/Radio/RadioGroup.js.map +1 -1
  274. package/Radio/RadioGroup.stories.js +2 -10
  275. package/Radio/RadioGroup.stories.js.map +1 -1
  276. package/Radio/index.js +0 -3
  277. package/Radio/index.js.map +1 -1
  278. package/RichTextEditor/RichTextEditor.js +30 -64
  279. package/RichTextEditor/RichTextEditor.js.map +1 -1
  280. package/RichTextEditor/RichTextEditor.stories.js +0 -7
  281. package/RichTextEditor/RichTextEditor.stories.js.map +1 -1
  282. package/RichTextEditor/createPropsFromConfig.js +0 -4
  283. package/RichTextEditor/createPropsFromConfig.js.map +1 -1
  284. package/RichTextEditor/index.js +0 -3
  285. package/RichTextEditor/index.js.map +1 -1
  286. package/Ripple/Ripple.js +0 -6
  287. package/Ripple/Ripple.js.map +1 -1
  288. package/Ripple/Ripple.stories.js +0 -12
  289. package/Ripple/Ripple.stories.js.map +1 -1
  290. package/Ripple/index.js +0 -2
  291. package/Ripple/index.js.map +1 -1
  292. package/Scrollbar/Scrollbar.js +0 -5
  293. package/Scrollbar/Scrollbar.js.map +1 -1
  294. package/Scrollbar/Scrollbar.stories.js +0 -6
  295. package/Scrollbar/Scrollbar.stories.js.map +1 -1
  296. package/Scrollbar/index.js +0 -2
  297. package/Scrollbar/index.js.map +1 -1
  298. package/Section/Section.stories.js +0 -7
  299. package/Section/Section.stories.js.map +1 -1
  300. package/Section/index.js +2 -12
  301. package/Section/index.js.map +1 -1
  302. package/Select/Select.js +9 -32
  303. package/Select/Select.js.map +1 -1
  304. package/Select/Select.stories.js +0 -8
  305. package/Select/Select.stories.js.map +1 -1
  306. package/Select/index.js +0 -2
  307. package/Select/index.js.map +1 -1
  308. package/Skeleton/Skeleton.d.ts +6 -2
  309. package/Skeleton/Skeleton.js +8 -11
  310. package/Skeleton/Skeleton.js.map +1 -1
  311. package/Skeleton/Skeleton.stories.js +0 -6
  312. package/Skeleton/Skeleton.stories.js.map +1 -1
  313. package/Skeleton/index.js +0 -2
  314. package/Skeleton/index.js.map +1 -1
  315. package/Slider/Slider.js +7 -29
  316. package/Slider/Slider.js.map +1 -1
  317. package/Slider/Slider.stories.js +1 -9
  318. package/Slider/Slider.stories.js.map +1 -1
  319. package/Slider/index.js +0 -2
  320. package/Slider/index.js.map +1 -1
  321. package/Snackbar/Snackbar.js +0 -19
  322. package/Snackbar/Snackbar.js.map +1 -1
  323. package/Snackbar/Snackbar.stories.js +0 -23
  324. package/Snackbar/Snackbar.stories.js.map +1 -1
  325. package/Snackbar/index.js +0 -1
  326. package/Snackbar/index.js.map +1 -1
  327. package/Switch/Switch.d.ts +1 -1
  328. package/Switch/Switch.js +5 -28
  329. package/Switch/Switch.js.map +1 -1
  330. package/Switch/Switch.stories.js +0 -8
  331. package/Switch/Switch.stories.js.map +1 -1
  332. package/Switch/index.js +0 -2
  333. package/Switch/index.js.map +1 -1
  334. package/Tabs/Tab.d.ts +1 -0
  335. package/Tabs/Tab.js +3 -9
  336. package/Tabs/Tab.js.map +1 -1
  337. package/Tabs/Tabs.d.ts +1 -0
  338. package/Tabs/Tabs.js +15 -28
  339. package/Tabs/Tabs.js.map +1 -1
  340. package/Tabs/Tabs.stories.js +0 -10
  341. package/Tabs/Tabs.stories.js.map +1 -1
  342. package/Tabs/index.js +0 -4
  343. package/Tabs/index.js.map +1 -1
  344. package/Tags/Tags.d.ts +8 -15
  345. package/Tags/Tags.js +77 -130
  346. package/Tags/Tags.js.map +1 -1
  347. package/Tags/Tags.stories.js +0 -8
  348. package/Tags/Tags.stories.js.map +1 -1
  349. package/Tags/index.js +0 -2
  350. package/Tags/index.js.map +1 -1
  351. package/Tooltip/Tooltip.js +0 -19
  352. package/Tooltip/Tooltip.js.map +1 -1
  353. package/Tooltip/Tooltip.stories.js +0 -6
  354. package/Tooltip/Tooltip.stories.js.map +1 -1
  355. package/Tooltip/index.js +0 -2
  356. package/Tooltip/index.js.map +1 -1
  357. package/TopAppBar/TopAppBar.js +1 -8
  358. package/TopAppBar/TopAppBar.js.map +1 -1
  359. package/TopAppBar/TopAppBar.stories.js +3 -16
  360. package/TopAppBar/TopAppBar.stories.js.map +1 -1
  361. package/TopAppBar/TopAppBarActionItem.js +0 -5
  362. package/TopAppBar/TopAppBarActionItem.js.map +1 -1
  363. package/TopAppBar/TopAppBarNavigationIcon.js +0 -5
  364. package/TopAppBar/TopAppBarNavigationIcon.js.map +1 -1
  365. package/TopAppBar/TopAppBarPrimary.js +1 -8
  366. package/TopAppBar/TopAppBarPrimary.js.map +1 -1
  367. package/TopAppBar/TopAppBarSecondary.js +3 -10
  368. package/TopAppBar/TopAppBarSecondary.js.map +1 -1
  369. package/TopAppBar/TopAppBarSection.js +1 -8
  370. package/TopAppBar/TopAppBarSection.js.map +1 -1
  371. package/TopAppBar/TopAppBarTitle.js +1 -8
  372. package/TopAppBar/TopAppBarTitle.js.map +1 -1
  373. package/TopAppBar/index.js +0 -14
  374. package/TopAppBar/index.js.map +1 -1
  375. package/TopProgressBar/TopProgressBar.js +0 -5
  376. package/TopProgressBar/TopProgressBar.js.map +1 -1
  377. package/TopProgressBar/TopProgressBar.stories.js +1 -8
  378. package/TopProgressBar/TopProgressBar.stories.js.map +1 -1
  379. package/TopProgressBar/hoc/index.js +0 -2
  380. package/TopProgressBar/hoc/index.js.map +1 -1
  381. package/TopProgressBar/hoc/withTopProgressBar.js +2 -8
  382. package/TopProgressBar/hoc/withTopProgressBar.js.map +1 -1
  383. package/TopProgressBar/index.js +0 -2
  384. package/TopProgressBar/index.js.map +1 -1
  385. package/Typography/Typography.d.ts +2 -2
  386. package/Typography/Typography.js +0 -5
  387. package/Typography/Typography.js.map +1 -1
  388. package/Typography/Typography.stories.js +0 -6
  389. package/Typography/Typography.stories.js.map +1 -1
  390. package/Typography/index.js +0 -2
  391. package/Typography/index.js.map +1 -1
  392. package/package.json +17 -15
  393. package/types.d.ts +3 -3
  394. package/types.js.map +1 -1
package/Input/Input.js CHANGED
@@ -1,181 +1,118 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
-
4
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
8
  exports.Input = void 0;
9
-
10
9
  var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
11
-
12
10
  var _regeneratorRuntime2 = _interopRequireDefault(require("@babel/runtime/helpers/regeneratorRuntime"));
13
-
14
11
  var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
15
-
16
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
17
-
18
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
19
-
20
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
21
-
22
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
23
-
24
- var _createSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/createSuper"));
25
-
26
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
27
-
28
- var _react = _interopRequireDefault(require("react"));
29
-
12
+ var _react = _interopRequireWildcard(require("react"));
30
13
  var _textfield = require("@rmwc/textfield");
31
-
32
14
  var _FormElementMessage = require("../FormElementMessage");
33
-
34
15
  var _pick = _interopRequireDefault(require("lodash/pick"));
35
-
36
16
  var _emotion = require("emotion");
37
-
38
17
  var _classnames = _interopRequireDefault(require("classnames"));
39
-
40
18
  var _excluded = ["autoFocus", "value", "label", "description", "placeholder", "rows", "validation", "icon", "trailingIcon", "onEnter"];
41
-
42
19
  /**
43
20
  * fix label position when autofilled
44
21
  * @type {string}
45
22
  */
46
- var webinyInputStyles = /*#__PURE__*/(0, _emotion.css)(".mdc-text-field__input:-webkit-autofill + .mdc-floating-label{transform:translateY(-106%) scale(0.75);}}label:webinyInputStyles;");
23
+ var webinyInputStyles = /*#__PURE__*/(0, _emotion.css)(".mdc-text-field__input:-webkit-autofill + .mdc-floating-label{transform:translateY(-106%) scale(0.75);}label:webinyInputStyles;");
24
+
47
25
  /**
48
26
  * Use Input component to store short string values, like first name, last name, e-mail etc.
49
27
  * Additionally, with rows prop, it can also be turned into a text area, to store longer strings.
50
28
  */
51
29
 
52
- var Input = /*#__PURE__*/function (_React$Component) {
53
- (0, _inherits2.default)(Input, _React$Component);
54
-
55
- var _super = (0, _createSuper2.default)(Input);
56
-
57
- function Input() {
58
- var _this;
59
-
60
- (0, _classCallCheck2.default)(this, Input);
61
-
62
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
63
- args[_key] = arguments[_key];
30
+ // IconProps directly passed to RMWC
31
+ var rmwcProps = ["label", "type", "step", "disabled", "readOnly", "placeholder", "outlined", "onKeyDown", "onKeyPress", "onKeyUp", "onFocus", "rootProps", "fullwidth", "inputRef", "className", "maxLength", "characterCount"];
32
+ var Input = function Input(props) {
33
+ var onChange = (0, _react.useCallback)(function (e) {
34
+ var onChange = props.onChange,
35
+ rawOnChange = props.rawOnChange;
36
+ if (!onChange) {
37
+ return;
64
38
  }
65
39
 
66
- _this = _super.call.apply(_super, [this].concat(args));
67
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "onChange", function (e) {
68
- var _this$props = _this.props,
69
- onChange = _this$props.onChange,
70
- rawOnChange = _this$props.rawOnChange;
71
-
72
- if (!onChange) {
73
- return;
74
- } // @ts-ignore
75
-
76
-
77
- onChange(rawOnChange ? e : e.target.value);
78
- });
79
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "onBlur", /*#__PURE__*/function () {
80
- var _ref = (0, _asyncToGenerator2.default)( /*#__PURE__*/(0, _regeneratorRuntime2.default)().mark(function _callee(e) {
81
- var _this$props2, validate, onBlur;
82
-
83
- return (0, _regeneratorRuntime2.default)().wrap(function _callee$(_context) {
84
- while (1) {
85
- switch (_context.prev = _context.next) {
86
- case 0:
87
- _this$props2 = _this.props, validate = _this$props2.validate, onBlur = _this$props2.onBlur;
88
-
89
- if (!validate) {
90
- _context.next = 5;
91
- break;
92
- }
93
-
94
- // Since we are accessing event in an async operation, we need to persist it.
95
- // See https://reactjs.org/docs/events.html#event-pooling.
96
- e.persist();
97
- _context.next = 5;
98
- return validate();
99
-
100
- case 5:
101
- onBlur && onBlur(e);
102
-
103
- case 6:
104
- case "end":
105
- return _context.stop();
40
+ // @ts-ignore
41
+ onChange(rawOnChange ? e : e.target.value);
42
+ }, [props.onChange, props.rawOnChange]);
43
+ var onBlur = (0, _react.useCallback)( /*#__PURE__*/function () {
44
+ var _ref = (0, _asyncToGenerator2.default)( /*#__PURE__*/(0, _regeneratorRuntime2.default)().mark(function _callee(e) {
45
+ var validate, onBlur;
46
+ return (0, _regeneratorRuntime2.default)().wrap(function _callee$(_context) {
47
+ while (1) switch (_context.prev = _context.next) {
48
+ case 0:
49
+ validate = props.validate, onBlur = props.onBlur;
50
+ if (!validate) {
51
+ _context.next = 5;
52
+ break;
106
53
  }
107
- }
108
- }, _callee);
109
- }));
110
-
111
- return function (_x) {
112
- return _ref.apply(this, arguments);
113
- };
114
- }());
115
- return _this;
54
+ // Since we are accessing event in an async operation, we need to persist it.
55
+ // See https://reactjs.org/docs/events.html#event-pooling.
56
+ e.persist();
57
+ _context.next = 5;
58
+ return validate();
59
+ case 5:
60
+ onBlur && onBlur(e);
61
+ case 6:
62
+ case "end":
63
+ return _context.stop();
64
+ }
65
+ }, _callee);
66
+ }));
67
+ return function (_x) {
68
+ return _ref.apply(this, arguments);
69
+ };
70
+ }(), [props.validate, props.onBlur]);
71
+ var autoFocus = props.autoFocus,
72
+ value = props.value,
73
+ label = props.label,
74
+ description = props.description,
75
+ placeholder = props.placeholder,
76
+ rows = props.rows,
77
+ validation = props.validation,
78
+ icon = props.icon,
79
+ trailingIcon = props.trailingIcon,
80
+ onEnter = props.onEnter,
81
+ rest = (0, _objectWithoutProperties2.default)(props, _excluded);
82
+ var inputValue = value;
83
+ if (value === null || typeof value === "undefined") {
84
+ inputValue = "";
116
85
  }
117
-
118
- (0, _createClass2.default)(Input, [{
119
- key: "render",
120
- value: function render() {
121
- var _this$props3 = this.props,
122
- autoFocus = _this$props3.autoFocus,
123
- value = _this$props3.value,
124
- label = _this$props3.label,
125
- description = _this$props3.description,
126
- placeholder = _this$props3.placeholder,
127
- rows = _this$props3.rows,
128
- validation = _this$props3.validation,
129
- icon = _this$props3.icon,
130
- trailingIcon = _this$props3.trailingIcon,
131
- onEnter = _this$props3.onEnter,
132
- props = (0, _objectWithoutProperties2.default)(_this$props3, _excluded);
133
- var inputValue = value;
134
-
135
- if (value === null || typeof value === "undefined") {
136
- inputValue = "";
137
- }
138
-
139
- var _ref2 = validation || {},
140
- validationIsValid = _ref2.isValid,
141
- validationMessage = _ref2.message;
142
-
143
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_textfield.TextField, Object.assign({}, (0, _pick.default)(props, Input.rmwcProps), {
144
- onKeyDown: function onKeyDown(e) {
145
- if (typeof onEnter === "function" && e.key === "Enter") {
146
- onEnter();
147
- }
148
-
149
- if (typeof props.onKeyDown === "function") {
150
- for (var _len2 = arguments.length, rest = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {
151
- rest[_key2 - 1] = arguments[_key2];
152
- }
153
-
154
- return props.onKeyDown.apply(props, [e].concat(rest));
155
- }
156
- },
157
- autoFocus: autoFocus,
158
- textarea: Boolean(rows),
159
- value: inputValue,
160
- onChange: this.onChange,
161
- onBlur: this.onBlur,
162
- label: label,
163
- icon: icon,
164
- placeholder: !label && placeholder || undefined,
165
- trailingIcon: trailingIcon,
166
- rows: this.props.rows,
167
- className: (0, _classnames.default)("webiny-ui-input", webinyInputStyles),
168
- "data-testid": props["data-testid"]
169
- })), validationIsValid === false && /*#__PURE__*/_react.default.createElement(_FormElementMessage.FormElementMessage, {
170
- error: true
171
- }, validationMessage), validationIsValid !== false && description && /*#__PURE__*/_react.default.createElement(_FormElementMessage.FormElementMessage, null, description));
86
+ var _ref2 = validation || {},
87
+ validationIsValid = _ref2.isValid,
88
+ validationMessage = _ref2.message;
89
+ var inputOnKeyDown = (0, _react.useCallback)(function (e) {
90
+ if (typeof onEnter === "function" && e.key === "Enter") {
91
+ onEnter();
172
92
  }
173
- }]);
174
- return Input;
175
- }(_react.default.Component);
176
-
93
+ if (typeof rest.onKeyDown === "function") {
94
+ return rest.onKeyDown(e);
95
+ }
96
+ }, [rest.onKeyDown]);
97
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_textfield.TextField, Object.assign({}, (0, _pick.default)(rest, rmwcProps), {
98
+ onKeyDown: inputOnKeyDown,
99
+ autoFocus: autoFocus,
100
+ textarea: Boolean(rows),
101
+ value: inputValue,
102
+ onChange: onChange,
103
+ onBlur: onBlur,
104
+ label: label,
105
+ icon: icon,
106
+ placeholder: !label && placeholder || undefined,
107
+ trailingIcon: trailingIcon,
108
+ rows: rows,
109
+ className: (0, _classnames.default)("webiny-ui-input", webinyInputStyles),
110
+ "data-testid": props["data-testid"]
111
+ })), validationIsValid === false && /*#__PURE__*/_react.default.createElement(_FormElementMessage.FormElementMessage, {
112
+ error: true
113
+ }, validationMessage), validationIsValid !== false && description && /*#__PURE__*/_react.default.createElement(_FormElementMessage.FormElementMessage, null, description));
114
+ };
177
115
  exports.Input = Input;
178
- (0, _defineProperty2.default)(Input, "defaultProps", {
116
+ Input.defaultProps = {
179
117
  rawOnChange: false
180
- });
181
- (0, _defineProperty2.default)(Input, "rmwcProps", ["label", "type", "step", "disabled", "readOnly", "placeholder", "outlined", "onKeyDown", "onKeyPress", "onKeyUp", "onFocus", "rootProps", "fullwidth", "inputRef", "className", "maxLength", "characterCount"]);
118
+ };
@@ -1 +1 @@
1
- {"version":3,"names":["webinyInputStyles","css","Input","e","props","onChange","rawOnChange","target","value","validate","onBlur","persist","autoFocus","label","description","placeholder","rows","validation","icon","trailingIcon","onEnter","inputValue","validationIsValid","isValid","validationMessage","message","pick","rmwcProps","key","onKeyDown","rest","Boolean","undefined","classNames","React","Component"],"sources":["Input.tsx"],"sourcesContent":["import React from \"react\";\nimport { TextField, TextFieldProps } from \"@rmwc/textfield\";\nimport { FormElementMessage } from \"~/FormElementMessage\";\nimport pick from \"lodash/pick\";\nimport { FormComponentProps } from \"~/types\";\nimport { ReactElement } from \"react\";\nimport { css } from \"emotion\";\nimport classNames from \"classnames\";\n\nexport type InputProps = FormComponentProps &\n TextFieldProps & {\n // Should this input be filled with browser values\n autoComplete?: string;\n\n // If true, will pass native `event` to the `onChange` callback\n rawOnChange?: boolean;\n\n // Auto-focus input\n autoFocus?: boolean;\n\n // Input placeholder\n placeholder?: string;\n\n // Description beneath the input.\n description?: string | ReactElement;\n\n // Converts input into a text area with given number of rows.\n rows?: number;\n\n maxLength?: number;\n\n // A callback that is executed when input focus is lost.\n onBlur?: (e: React.SyntheticEvent<HTMLInputElement>) => any;\n\n onKeyDown?: (e: React.SyntheticEvent<HTMLInputElement>) => any;\n\n // A callback that gets triggered when the user presses the \"Enter\" key.\n onEnter?: () => any;\n\n // CSS class name\n className?: string;\n\n // For testing purposes.\n \"data-testid\"?: string;\n };\n\n/**\n * fix label position when autofilled\n * @type {string}\n */\nconst webinyInputStyles = css`\n .mdc-text-field__input:-webkit-autofill + .mdc-floating-label {\n transform: translateY(-106%) scale(0.75);\n }\n }\n`;\n\n/**\n * Use Input component to store short string values, like first name, last name, e-mail etc.\n * Additionally, with rows prop, it can also be turned into a text area, to store longer strings.\n */\n\nexport class Input extends React.Component<InputProps> {\n static defaultProps: InputProps = {\n rawOnChange: false\n };\n\n // IconProps directly passed to RMWC\n static rmwcProps = [\n \"label\",\n \"type\",\n \"step\",\n \"disabled\",\n \"readOnly\",\n \"placeholder\",\n \"outlined\",\n \"onKeyDown\",\n \"onKeyPress\",\n \"onKeyUp\",\n \"onFocus\",\n \"rootProps\",\n \"fullwidth\",\n \"inputRef\",\n \"className\",\n \"maxLength\",\n \"characterCount\"\n ];\n\n onChange = (e: React.SyntheticEvent<HTMLInputElement>) => {\n const { onChange, rawOnChange } = this.props;\n if (!onChange) {\n return;\n }\n\n // @ts-ignore\n onChange(rawOnChange ? e : e.target.value);\n };\n\n onBlur = async (e: React.SyntheticEvent<HTMLInputElement>) => {\n const { validate, onBlur } = this.props;\n if (validate) {\n // Since we are accessing event in an async operation, we need to persist it.\n // See https://reactjs.org/docs/events.html#event-pooling.\n e.persist();\n await validate();\n }\n onBlur && onBlur(e);\n };\n\n public override render() {\n const {\n autoFocus,\n value,\n label,\n description,\n placeholder,\n rows,\n validation,\n icon,\n trailingIcon,\n onEnter,\n ...props\n } = this.props;\n\n let inputValue = value;\n if (value === null || typeof value === \"undefined\") {\n inputValue = \"\";\n }\n\n const { isValid: validationIsValid, message: validationMessage } = validation || {};\n\n return (\n <React.Fragment>\n <TextField\n {...pick(props, Input.rmwcProps)}\n onKeyDown={(e, ...rest) => {\n if (typeof onEnter === \"function\" && e.key === \"Enter\") {\n onEnter();\n }\n\n if (typeof props.onKeyDown === \"function\") {\n return props.onKeyDown(e, ...rest);\n }\n }}\n autoFocus={autoFocus}\n textarea={Boolean(rows)}\n value={inputValue}\n onChange={this.onChange}\n onBlur={this.onBlur}\n label={label}\n icon={icon}\n placeholder={(!label && placeholder) || undefined}\n trailingIcon={trailingIcon}\n rows={this.props.rows}\n className={classNames(\"webiny-ui-input\", webinyInputStyles)}\n data-testid={props[\"data-testid\"]}\n />\n\n {validationIsValid === false && (\n <FormElementMessage error>{validationMessage}</FormElementMessage>\n )}\n {validationIsValid !== false && description && (\n <FormElementMessage>{description}</FormElementMessage>\n )}\n </React.Fragment>\n );\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AAGA;;AACA;;;;AAuCA;AACA;AACA;AACA;AACA,IAAMA,iBAAiB,oBAAGC,YAAH,qIAAvB;AAOA;AACA;AACA;AACA;;IAEaC,K;;;;;;;;;;;;;;;2FA0BE,UAACC,CAAD,EAA+C;MACtD,kBAAkC,MAAKC,KAAvC;MAAA,IAAQC,QAAR,eAAQA,QAAR;MAAA,IAAkBC,WAAlB,eAAkBA,WAAlB;;MACA,IAAI,CAACD,QAAL,EAAe;QACX;MACH,CAJqD,CAMtD;;;MACAA,QAAQ,CAACC,WAAW,GAAGH,CAAH,GAAOA,CAAC,CAACI,MAAF,CAASC,KAA5B,CAAR;IACH,C;;wGAEQ,iBAAOL,CAAP;QAAA;;QAAA;UAAA;YAAA;cAAA;gBAAA,eACwB,MAAKC,KAD7B,EACGK,QADH,gBACGA,QADH,EACaC,MADb,gBACaA,MADb;;gBAAA,KAEDD,QAFC;kBAAA;kBAAA;gBAAA;;gBAGD;gBACA;gBACAN,CAAC,CAACQ,OAAF;gBALC;gBAAA,OAMKF,QAAQ,EANb;;cAAA;gBAQLC,MAAM,IAAIA,MAAM,CAACP,CAAD,CAAhB;;cARK;cAAA;gBAAA;YAAA;UAAA;QAAA;MAAA,C;;;;;;;;;;;WAWT,kBAAyB;MACrB,mBAYI,KAAKC,KAZT;MAAA,IACIQ,SADJ,gBACIA,SADJ;MAAA,IAEIJ,KAFJ,gBAEIA,KAFJ;MAAA,IAGIK,KAHJ,gBAGIA,KAHJ;MAAA,IAIIC,WAJJ,gBAIIA,WAJJ;MAAA,IAKIC,WALJ,gBAKIA,WALJ;MAAA,IAMIC,IANJ,gBAMIA,IANJ;MAAA,IAOIC,UAPJ,gBAOIA,UAPJ;MAAA,IAQIC,IARJ,gBAQIA,IARJ;MAAA,IASIC,YATJ,gBASIA,YATJ;MAAA,IAUIC,OAVJ,gBAUIA,OAVJ;MAAA,IAWOhB,KAXP;MAcA,IAAIiB,UAAU,GAAGb,KAAjB;;MACA,IAAIA,KAAK,KAAK,IAAV,IAAkB,OAAOA,KAAP,KAAiB,WAAvC,EAAoD;QAChDa,UAAU,GAAG,EAAb;MACH;;MAED,YAAmEJ,UAAU,IAAI,EAAjF;MAAA,IAAiBK,iBAAjB,SAAQC,OAAR;MAAA,IAA6CC,iBAA7C,SAAoCC,OAApC;;MAEA,oBACI,6BAAC,cAAD,CAAO,QAAP,qBACI,6BAAC,oBAAD,oBACQ,IAAAC,aAAA,EAAKtB,KAAL,EAAYF,KAAK,CAACyB,SAAlB,CADR;QAEI,SAAS,EAAE,mBAACxB,CAAD,EAAgB;UACvB,IAAI,OAAOiB,OAAP,KAAmB,UAAnB,IAAiCjB,CAAC,CAACyB,GAAF,KAAU,OAA/C,EAAwD;YACpDR,OAAO;UACV;;UAED,IAAI,OAAOhB,KAAK,CAACyB,SAAb,KAA2B,UAA/B,EAA2C;YAAA,mCAL7BC,IAK6B;cAL7BA,IAK6B;YAAA;;YACvC,OAAO1B,KAAK,CAACyB,SAAN,OAAAzB,KAAK,GAAWD,CAAX,SAAiB2B,IAAjB,EAAZ;UACH;QACJ,CAVL;QAWI,SAAS,EAAElB,SAXf;QAYI,QAAQ,EAAEmB,OAAO,CAACf,IAAD,CAZrB;QAaI,KAAK,EAAEK,UAbX;QAcI,QAAQ,EAAE,KAAKhB,QAdnB;QAeI,MAAM,EAAE,KAAKK,MAfjB;QAgBI,KAAK,EAAEG,KAhBX;QAiBI,IAAI,EAAEK,IAjBV;QAkBI,WAAW,EAAG,CAACL,KAAD,IAAUE,WAAX,IAA2BiB,SAlB5C;QAmBI,YAAY,EAAEb,YAnBlB;QAoBI,IAAI,EAAE,KAAKf,KAAL,CAAWY,IApBrB;QAqBI,SAAS,EAAE,IAAAiB,mBAAA,EAAW,iBAAX,EAA8BjC,iBAA9B,CArBf;QAsBI,eAAaI,KAAK,CAAC,aAAD;MAtBtB,GADJ,EA0BKkB,iBAAiB,KAAK,KAAtB,iBACG,6BAAC,sCAAD;QAAoB,KAAK;MAAzB,GAA2BE,iBAA3B,CA3BR,EA6BKF,iBAAiB,KAAK,KAAtB,IAA+BR,WAA/B,iBACG,6BAAC,sCAAD,QAAqBA,WAArB,CA9BR,CADJ;IAmCH;;;EAxGsBoB,cAAA,CAAMC,S;;;8BAApBjC,K,kBACyB;EAC9BI,WAAW,EAAE;AADiB,C;8BADzBJ,K,eAMU,CACf,OADe,EAEf,MAFe,EAGf,MAHe,EAIf,UAJe,EAKf,UALe,EAMf,aANe,EAOf,UAPe,EAQf,WARe,EASf,YATe,EAUf,SAVe,EAWf,SAXe,EAYf,WAZe,EAaf,WAbe,EAcf,UAde,EAef,WAfe,EAgBf,WAhBe,EAiBf,gBAjBe,C"}
1
+ {"version":3,"names":["webinyInputStyles","css","rmwcProps","Input","props","onChange","useCallback","e","rawOnChange","target","value","onBlur","validate","persist","autoFocus","label","description","placeholder","rows","validation","icon","trailingIcon","onEnter","rest","inputValue","validationIsValid","isValid","validationMessage","message","inputOnKeyDown","key","onKeyDown","pick","Boolean","undefined","classNames","defaultProps"],"sources":["Input.tsx"],"sourcesContent":["import React, { useCallback } from \"react\";\nimport { TextField, TextFieldProps } from \"@rmwc/textfield\";\nimport { FormElementMessage } from \"~/FormElementMessage\";\nimport pick from \"lodash/pick\";\nimport { FormComponentProps } from \"~/types\";\nimport { ReactElement } from \"react\";\nimport { css } from \"emotion\";\nimport classNames from \"classnames\";\n\nexport type InputProps<TValue = any> = FormComponentProps<TValue> &\n TextFieldProps & {\n // Should this input be filled with browser values\n autoComplete?: string;\n\n // If true, will pass native `event` to the `onChange` callback\n rawOnChange?: boolean;\n\n // Auto-focus input\n autoFocus?: boolean;\n\n // Input placeholder\n placeholder?: string;\n\n // Description beneath the input.\n description?: string | ReactElement;\n\n // Converts input into a text area with given number of rows.\n rows?: number;\n\n maxLength?: number;\n\n // A callback that is executed when input focus is lost.\n onBlur?: (e: React.SyntheticEvent<HTMLInputElement>) => any;\n\n onKeyDown?: (e: React.SyntheticEvent<HTMLInputElement>) => any;\n\n // A callback that gets triggered when the user presses the \"Enter\" key.\n onEnter?: () => any;\n\n // CSS class name\n className?: string;\n\n // For testing purposes.\n \"data-testid\"?: string;\n };\n\n/**\n * fix label position when autofilled\n * @type {string}\n */\nconst webinyInputStyles = css`\n .mdc-text-field__input:-webkit-autofill + .mdc-floating-label {\n transform: translateY(-106%) scale(0.75);\n }\n`;\n\n/**\n * Use Input component to store short string values, like first name, last name, e-mail etc.\n * Additionally, with rows prop, it can also be turned into a text area, to store longer strings.\n */\n\n// IconProps directly passed to RMWC\nconst rmwcProps = [\n \"label\",\n \"type\",\n \"step\",\n \"disabled\",\n \"readOnly\",\n \"placeholder\",\n \"outlined\",\n \"onKeyDown\",\n \"onKeyPress\",\n \"onKeyUp\",\n \"onFocus\",\n \"rootProps\",\n \"fullwidth\",\n \"inputRef\",\n \"className\",\n \"maxLength\",\n \"characterCount\"\n];\n\nexport const Input: React.FC<InputProps> = props => {\n const onChange = useCallback(\n (e: React.SyntheticEvent<HTMLInputElement>) => {\n const { onChange, rawOnChange } = props;\n if (!onChange) {\n return;\n }\n\n // @ts-ignore\n onChange(rawOnChange ? e : e.target.value);\n },\n [props.onChange, props.rawOnChange]\n );\n\n const onBlur = useCallback(\n async (e: React.SyntheticEvent<HTMLInputElement>) => {\n const { validate, onBlur } = props;\n if (validate) {\n // Since we are accessing event in an async operation, we need to persist it.\n // See https://reactjs.org/docs/events.html#event-pooling.\n e.persist();\n await validate();\n }\n onBlur && onBlur(e);\n },\n [props.validate, props.onBlur]\n );\n\n const {\n autoFocus,\n value,\n label,\n description,\n placeholder,\n rows,\n validation,\n icon,\n trailingIcon,\n onEnter,\n ...rest\n } = props;\n\n let inputValue = value;\n if (value === null || typeof value === \"undefined\") {\n inputValue = \"\";\n }\n\n const { isValid: validationIsValid, message: validationMessage } = validation || {};\n\n const inputOnKeyDown = useCallback(\n e => {\n if (typeof onEnter === \"function\" && e.key === \"Enter\") {\n onEnter();\n }\n\n if (typeof rest.onKeyDown === \"function\") {\n return rest.onKeyDown(e);\n }\n },\n [rest.onKeyDown]\n );\n\n return (\n <React.Fragment>\n <TextField\n {...pick(rest, rmwcProps)}\n onKeyDown={inputOnKeyDown}\n autoFocus={autoFocus}\n textarea={Boolean(rows)}\n value={inputValue}\n onChange={onChange}\n onBlur={onBlur}\n label={label}\n icon={icon}\n placeholder={(!label && placeholder) || undefined}\n trailingIcon={trailingIcon}\n rows={rows}\n className={classNames(\"webiny-ui-input\", webinyInputStyles)}\n data-testid={props[\"data-testid\"]}\n />\n\n {validationIsValid === false && (\n <FormElementMessage error>{validationMessage}</FormElementMessage>\n )}\n {validationIsValid !== false && description && (\n <FormElementMessage>{description}</FormElementMessage>\n )}\n </React.Fragment>\n );\n};\n\nInput.defaultProps = { rawOnChange: false };\n"],"mappings":"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"}
@@ -1,31 +1,18 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
-
5
4
  var _react = _interopRequireDefault(require("react"));
6
-
7
5
  var _react2 = require("@storybook/react");
8
-
9
6
  var _Story = require("@webiny/storybook-utils/Story");
10
-
11
7
  var _addonKnobs = require("@storybook/addon-knobs");
12
-
13
8
  var _README = _interopRequireDefault(require("./../Input/README.md"));
14
-
15
9
  var _baselineAutorenew24px = require("./svg/baseline-autorenew-24px.svg");
16
-
17
10
  var _baselineCloud_done24px = require("./svg/baseline-cloud_done-24px.svg");
18
-
19
11
  var _baselineDelete24px = require("./svg/baseline-delete-24px.svg");
20
-
21
12
  var _baselineDone24px = require("./svg/baseline-done-24px.svg");
22
-
23
13
  var _form = require("@webiny/form");
24
-
25
14
  var _Input = require("./Input");
26
-
27
15
  var _validation = require("@webiny/validation");
28
-
29
16
  var story = (0, _react2.storiesOf)("Components/Input", module);
30
17
  story.addDecorator(_addonKnobs.withKnobs);
31
18
  story.add("usage", function () {
@@ -1 +1 @@
1
- {"version":3,"names":["story","storiesOf","module","addDecorator","withKnobs","add","bindProps","name","validators","validation","create","disabled","boolean","readme","Bind","info","propTables","Input"],"sources":["Input.stories.tsx"],"sourcesContent":["import React from \"react\";\nimport { storiesOf } from \"@storybook/react\";\nimport {\n Story,\n StoryReadme,\n StorySandboxCode,\n StorySandbox,\n StorySandboxExample\n} from \"@webiny/storybook-utils/Story\";\nimport { withKnobs, boolean } from \"@storybook/addon-knobs\";\nimport readme from \"./../Input/README.md\";\nimport { ReactComponent as AutoRenewIcon } from \"./svg/baseline-autorenew-24px.svg\";\nimport { ReactComponent as CloudDoneIcon } from \"./svg/baseline-cloud_done-24px.svg\";\nimport { ReactComponent as BaselineDeleteIcon } from \"./svg/baseline-delete-24px.svg\";\nimport { ReactComponent as BaselineDoneIcon } from \"./svg/baseline-done-24px.svg\";\n\nimport { Form } from \"@webiny/form\";\nimport { Input } from \"./Input\";\nimport { validation } from \"@webiny/validation\";\n\nconst story = storiesOf(\"Components/Input\", module);\nstory.addDecorator(withKnobs);\n\nstory.add(\n \"usage\",\n () => {\n const bindProps = {\n name: \"name\",\n validators: validation.create(\"required,minLength:3\")\n };\n\n const disabled = boolean(\"Disabled\", false);\n\n return (\n <Story>\n <StoryReadme>{readme}</StoryReadme>\n <StorySandbox>\n <StorySandboxExample title={\"Label, description and validation\"}>\n <Form>\n {({ Bind }) => (\n <Bind {...bindProps}>\n <Input\n label={\"Your name\"}\n disabled={disabled}\n description={\"This is your profile name\"}\n />\n </Bind>\n )}\n </Form>\n </StorySandboxExample>\n <StorySandboxCode>\n {`\n <Form>\n {({ Bind }) => (\n <Bind\n name=\"name\"\n validators={validation.create(\"required,minLength:3\")}>\n <Input label={\"Your name\"} disabled={${disabled}} description={\"This is your profile name\"}/>\n </Bind>\n )}\n </Form>\n `}\n </StorySandboxCode>\n </StorySandbox>\n <StorySandbox>\n <StorySandboxExample title={\"With icon (box)\"}>\n <Form>\n {({ Bind }) => (\n <React.Fragment>\n <Bind name=\"phone\">\n <Input\n icon={<AutoRenewIcon />}\n label={\"Your phone number\"}\n description={\"Please enter a real number\"}\n disabled={disabled}\n />\n </Bind>\n <Bind name=\"mobile\">\n <Input\n trailingIcon={<CloudDoneIcon />}\n label={\"Your mobile number\"}\n description={\"An SMS will be sent to this number\"}\n disabled={disabled}\n />\n </Bind>\n </React.Fragment>\n )}\n </Form>\n </StorySandboxExample>\n <StorySandboxCode>\n {`\n <Form>\n {({ Bind }) => (\n <React.Fragment>\n <Bind name=\"phone\">\n <Input\n icon={<AutoRenewIcon />}\n label={\"Your phone number\"}\n description={\"Please enter a real number\"}\n disabled={${disabled}}\n />\n </Bind>\n <Bind name=\"mobile\">\n <Input\n trailingIcon={<CloudDoneIcon />}\n label={\"Your mobile number\"}\n description={\"An SMS will be sent to this number\"}\n disabled={${disabled}}\n />\n </Bind>\n </React.Fragment>\n )}\n </Form>\n `}\n </StorySandboxCode>\n </StorySandbox>\n <StorySandbox>\n <StorySandboxExample title={\"With icon (outlined)\"}>\n <Form>\n {({ Bind }) => (\n <React.Fragment>\n <Bind name=\"phone\">\n <Input\n outlined\n icon={<BaselineDeleteIcon />}\n label={\"Your phone number\"}\n description={\"Please enter a real number\"}\n disabled={disabled}\n />\n </Bind>\n <Bind name=\"mobile\">\n <Input\n outlined\n trailingIcon={<BaselineDoneIcon />}\n label={\"Your mobile number\"}\n description={\"An SMS will be sent to this number\"}\n disabled={disabled}\n />\n </Bind>\n </React.Fragment>\n )}\n </Form>\n </StorySandboxExample>\n <StorySandboxCode>\n {`\n <Form>\n {({ Bind }) => (\n <React.Fragment>\n <Bind name=\"phone\">\n <Input\n outlined\n icon={<BaselineDeleteIcon />}\n label={\"Your phone number\"}\n description={\"Please enter a real number\"}\n disabled={${disabled}}\n />\n </Bind>\n <Bind name=\"mobile\">\n <Input\n outlined\n trailingIcon={<BaselineDoneIcon />}\n label={\"Your mobile number\"}\n description={\"An SMS will be sent to this number\"}\n disabled={${disabled}}\n />\n </Bind>\n </React.Fragment>\n )}\n </Form>\n `}\n </StorySandboxCode>\n </StorySandbox>\n <StorySandbox>\n <StorySandboxExample title={\"Full width\"}>\n <Form>\n {({ Bind }) => (\n <Bind {...bindProps}>\n <Input\n placeholder={\"Your name\"}\n fullwidth\n disabled={disabled}\n />\n </Bind>\n )}\n </Form>\n </StorySandboxExample>\n <StorySandboxCode>\n {`\n <Form>\n {({ Bind }) => (\n <Bind\n name=\"name\"\n validators={validation.create(\"required,minLength:3\")}>\n <Input placeholder={\"Your name\"} fullwidth disabled={${disabled}}/>\n </Bind>\n )}\n </Form>\n `}\n </StorySandboxCode>\n </StorySandbox>\n <StorySandbox>\n <StorySandboxExample title={\"Textarea\"}>\n <Form>\n {({ Bind }) => (\n <React.Fragment>\n <Bind name=\"info\">\n <Input\n rows={6}\n placeholder={\"Tell us something...\"}\n description={\"Just a little bit about yourself.\"}\n disabled={disabled}\n />\n </Bind>\n <Bind name=\"description\">\n <Input\n fullwidth\n rows={6}\n placeholder={\"How's the weather today?\"}\n description={\"We actually need to know.\"}\n disabled={disabled}\n />\n </Bind>\n </React.Fragment>\n )}\n </Form>\n </StorySandboxExample>\n <StorySandboxCode>\n {`\n <Form>\n {({ Bind }) => (\n <React.Fragment>\n <Bind name=\"info\">\n <Input\n rows={6}\n placeholder={\"Tell us something...\"}\n description={\"Just a little bit about yourself.\"}\n disabled={${disabled}}\n />\n </Bind>\n <Bind name=\"description\">\n <Input\n fullwidth\n rows={6}\n placeholder={\"How's the weather today?\"}\n description={\"We actually need to know.\"}\n disabled={${disabled}}\n />\n </Bind>\n </React.Fragment>\n )}\n </Form>\n `}\n </StorySandboxCode>\n </StorySandbox>\n </Story>\n );\n },\n { info: { propTables: [Input] } }\n);\n"],"mappings":"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"}
1
+ {"version":3,"names":["story","storiesOf","module","addDecorator","withKnobs","add","bindProps","name","validators","validation","create","disabled","boolean","readme","Bind","info","propTables","Input"],"sources":["Input.stories.tsx"],"sourcesContent":["import React from \"react\";\nimport { storiesOf } from \"@storybook/react\";\nimport {\n Story,\n StoryReadme,\n StorySandboxCode,\n StorySandbox,\n StorySandboxExample\n} from \"@webiny/storybook-utils/Story\";\nimport { withKnobs, boolean } from \"@storybook/addon-knobs\";\nimport readme from \"./../Input/README.md\";\nimport { ReactComponent as AutoRenewIcon } from \"./svg/baseline-autorenew-24px.svg\";\nimport { ReactComponent as CloudDoneIcon } from \"./svg/baseline-cloud_done-24px.svg\";\nimport { ReactComponent as BaselineDeleteIcon } from \"./svg/baseline-delete-24px.svg\";\nimport { ReactComponent as BaselineDoneIcon } from \"./svg/baseline-done-24px.svg\";\n\nimport { Form } from \"@webiny/form\";\nimport { Input } from \"./Input\";\nimport { validation } from \"@webiny/validation\";\n\nconst story = storiesOf(\"Components/Input\", module);\nstory.addDecorator(withKnobs);\n\nstory.add(\n \"usage\",\n () => {\n const bindProps = {\n name: \"name\",\n validators: validation.create(\"required,minLength:3\")\n };\n\n const disabled = boolean(\"Disabled\", false);\n\n return (\n <Story>\n <StoryReadme>{readme}</StoryReadme>\n <StorySandbox>\n <StorySandboxExample title={\"Label, description and validation\"}>\n <Form>\n {({ Bind }) => (\n <Bind {...bindProps}>\n <Input\n label={\"Your name\"}\n disabled={disabled}\n description={\"This is your profile name\"}\n />\n </Bind>\n )}\n </Form>\n </StorySandboxExample>\n <StorySandboxCode>\n {`\n <Form>\n {({ Bind }) => (\n <Bind\n name=\"name\"\n validators={validation.create(\"required,minLength:3\")}>\n <Input label={\"Your name\"} disabled={${disabled}} description={\"This is your profile name\"}/>\n </Bind>\n )}\n </Form>\n `}\n </StorySandboxCode>\n </StorySandbox>\n <StorySandbox>\n <StorySandboxExample title={\"With icon (box)\"}>\n <Form>\n {({ Bind }) => (\n <React.Fragment>\n <Bind name=\"phone\">\n <Input\n icon={<AutoRenewIcon />}\n label={\"Your phone number\"}\n description={\"Please enter a real number\"}\n disabled={disabled}\n />\n </Bind>\n <Bind name=\"mobile\">\n <Input\n trailingIcon={<CloudDoneIcon />}\n label={\"Your mobile number\"}\n description={\"An SMS will be sent to this number\"}\n disabled={disabled}\n />\n </Bind>\n </React.Fragment>\n )}\n </Form>\n </StorySandboxExample>\n <StorySandboxCode>\n {`\n <Form>\n {({ Bind }) => (\n <React.Fragment>\n <Bind name=\"phone\">\n <Input\n icon={<AutoRenewIcon />}\n label={\"Your phone number\"}\n description={\"Please enter a real number\"}\n disabled={${disabled}}\n />\n </Bind>\n <Bind name=\"mobile\">\n <Input\n trailingIcon={<CloudDoneIcon />}\n label={\"Your mobile number\"}\n description={\"An SMS will be sent to this number\"}\n disabled={${disabled}}\n />\n </Bind>\n </React.Fragment>\n )}\n </Form>\n `}\n </StorySandboxCode>\n </StorySandbox>\n <StorySandbox>\n <StorySandboxExample title={\"With icon (outlined)\"}>\n <Form>\n {({ Bind }) => (\n <React.Fragment>\n <Bind name=\"phone\">\n <Input\n outlined\n icon={<BaselineDeleteIcon />}\n label={\"Your phone number\"}\n description={\"Please enter a real number\"}\n disabled={disabled}\n />\n </Bind>\n <Bind name=\"mobile\">\n <Input\n outlined\n trailingIcon={<BaselineDoneIcon />}\n label={\"Your mobile number\"}\n description={\"An SMS will be sent to this number\"}\n disabled={disabled}\n />\n </Bind>\n </React.Fragment>\n )}\n </Form>\n </StorySandboxExample>\n <StorySandboxCode>\n {`\n <Form>\n {({ Bind }) => (\n <React.Fragment>\n <Bind name=\"phone\">\n <Input\n outlined\n icon={<BaselineDeleteIcon />}\n label={\"Your phone number\"}\n description={\"Please enter a real number\"}\n disabled={${disabled}}\n />\n </Bind>\n <Bind name=\"mobile\">\n <Input\n outlined\n trailingIcon={<BaselineDoneIcon />}\n label={\"Your mobile number\"}\n description={\"An SMS will be sent to this number\"}\n disabled={${disabled}}\n />\n </Bind>\n </React.Fragment>\n )}\n </Form>\n `}\n </StorySandboxCode>\n </StorySandbox>\n <StorySandbox>\n <StorySandboxExample title={\"Full width\"}>\n <Form>\n {({ Bind }) => (\n <Bind {...bindProps}>\n <Input\n placeholder={\"Your name\"}\n fullwidth\n disabled={disabled}\n />\n </Bind>\n )}\n </Form>\n </StorySandboxExample>\n <StorySandboxCode>\n {`\n <Form>\n {({ Bind }) => (\n <Bind\n name=\"name\"\n validators={validation.create(\"required,minLength:3\")}>\n <Input placeholder={\"Your name\"} fullwidth disabled={${disabled}}/>\n </Bind>\n )}\n </Form>\n `}\n </StorySandboxCode>\n </StorySandbox>\n <StorySandbox>\n <StorySandboxExample title={\"Textarea\"}>\n <Form>\n {({ Bind }) => (\n <React.Fragment>\n <Bind name=\"info\">\n <Input\n rows={6}\n placeholder={\"Tell us something...\"}\n description={\"Just a little bit about yourself.\"}\n disabled={disabled}\n />\n </Bind>\n <Bind name=\"description\">\n <Input\n fullwidth\n rows={6}\n placeholder={\"How's the weather today?\"}\n description={\"We actually need to know.\"}\n disabled={disabled}\n />\n </Bind>\n </React.Fragment>\n )}\n </Form>\n </StorySandboxExample>\n <StorySandboxCode>\n {`\n <Form>\n {({ Bind }) => (\n <React.Fragment>\n <Bind name=\"info\">\n <Input\n rows={6}\n placeholder={\"Tell us something...\"}\n description={\"Just a little bit about yourself.\"}\n disabled={${disabled}}\n />\n </Bind>\n <Bind name=\"description\">\n <Input\n fullwidth\n rows={6}\n placeholder={\"How's the weather today?\"}\n description={\"We actually need to know.\"}\n disabled={${disabled}}\n />\n </Bind>\n </React.Fragment>\n )}\n </Form>\n `}\n </StorySandboxCode>\n </StorySandbox>\n </Story>\n );\n },\n { info: { propTables: [Input] } }\n);\n"],"mappings":"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"}
@@ -1,31 +1,18 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
-
5
4
  var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
6
-
7
5
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
8
-
9
6
  var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
10
-
11
7
  var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
12
-
13
8
  var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
14
-
15
9
  var _createSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/createSuper"));
16
-
17
10
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
18
-
19
11
  var _react = _interopRequireDefault(require("react"));
20
-
21
12
  var _index = require("../index");
22
-
23
13
  require("jest-dom/extend-expect");
24
-
25
14
  var _react2 = require("@testing-library/react");
26
-
27
15
  afterEach(_react2.cleanup);
28
-
29
16
  function setup() {
30
17
  var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
31
18
  var renderArg = {
@@ -40,21 +27,15 @@ function setup() {
40
27
  var onChange = props.onChange ? props.onChange : function () {
41
28
  return void 0;
42
29
  };
43
-
44
30
  var Test = /*#__PURE__*/function (_React$Component) {
45
31
  (0, _inherits2.default)(Test, _React$Component);
46
-
47
32
  var _super = (0, _createSuper2.default)(Test);
48
-
49
33
  function Test() {
50
34
  var _this;
51
-
52
35
  (0, _classCallCheck2.default)(this, Test);
53
-
54
36
  for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
55
37
  args[_key] = arguments[_key];
56
38
  }
57
-
58
39
  _this = _super.call.apply(_super, [this].concat(args));
59
40
  (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "state", {
60
41
  value: "init-value"
@@ -66,7 +47,6 @@ function setup() {
66
47
  });
67
48
  return _this;
68
49
  }
69
-
70
50
  (0, _createClass2.default)(Test, [{
71
51
  key: "render",
72
52
  value: function render() {
@@ -78,12 +58,12 @@ function setup() {
78
58
  }]);
79
59
  return Test;
80
60
  }(_react.default.Component);
81
-
82
61
  var utils = (0, _react2.render)( /*#__PURE__*/_react.default.createElement(Test, null));
83
62
  return (0, _objectSpread2.default)({
84
63
  renderArg: renderArg
85
64
  }, utils);
86
65
  }
66
+
87
67
  /**
88
68
  * This return a function that will call all the given functions with
89
69
  * the arguments with which it's called. It does a null-check before
@@ -91,36 +71,30 @@ function setup() {
91
71
  * @param {...Function} fns the functions to call
92
72
  * @return {Function} the function that calls all the functions
93
73
  */
94
-
95
-
96
74
  function callAll() {
97
75
  for (var _len2 = arguments.length, fns = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
98
76
  fns[_key2] = arguments[_key2];
99
77
  }
100
-
101
78
  return function () {
102
79
  for (var _len3 = arguments.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {
103
80
  args[_key3] = arguments[_key3];
104
81
  }
105
-
106
82
  fns.forEach(function (fn) {
107
83
  fn && fn.apply(void 0, args);
108
84
  });
109
85
  };
110
86
  }
111
-
112
87
  describe("Input tests", function () {
113
88
  test("passes expected props to render prop", function () {
114
89
  var _setup = setup(),
115
- renderArg = _setup.renderArg; // @ts-ignore
116
-
90
+ renderArg = _setup.renderArg;
117
91
 
92
+ // @ts-ignore
118
93
  expect(renderArg).toContainKeys(["value", "validation", "onChange", "onBlur"]);
119
94
  });
120
95
  test("updates value via onChange", function () {
121
96
  var _setup2 = setup(),
122
- renderArg = _setup2.renderArg;
123
-
97
+ renderArg = _setup2.renderArg;
124
98
  expect(renderArg.value).toBe("init-value");
125
99
  renderArg.onChange("new-value");
126
100
  expect(renderArg.value).toBe("new-value");
@@ -1 +1 @@
1
- {"version":3,"names":["afterEach","cleanup","setup","props","renderArg","onChange","_","value","renderProp","jest","fn","controllerArg","Object","assign","Test","setState","state","callAll","React","Component","utils","render","fns","args","forEach","describe","test","expect","toContainKeys","toBe"],"sources":["Input.test.tsx"],"sourcesContent":["import React from \"react\";\nimport { Input } from \"../index\";\nimport \"jest-dom/extend-expect\";\nimport { render, cleanup } from \"@testing-library/react\";\n\nafterEach(cleanup);\n\ninterface SetupProps {\n onChange?: () => void;\n}\nfunction setup(props: SetupProps = {}) {\n const renderArg = {\n // eslint-disable-next-line\n onChange: (_: string) => {},\n value: null\n };\n const renderProp = jest.fn(controllerArg => {\n Object.assign(renderArg, controllerArg);\n return null;\n });\n\n const onChange = props.onChange\n ? props.onChange\n : () => {\n return void 0;\n };\n\n class Test extends React.Component {\n public override state = { value: \"init-value\" };\n\n onChange = (value: string) => {\n this.setState({ value });\n };\n\n public override render() {\n return (\n <Input\n {...props}\n value={this.state.value}\n onChange={callAll(onChange, this.onChange)}\n >\n {renderProp}\n </Input>\n );\n }\n }\n\n const utils = render(<Test />);\n\n return { renderArg, ...utils };\n}\n\n/**\n * This return a function that will call all the given functions with\n * the arguments with which it's called. It does a null-check before\n * attempting to call the functions and can take any number of functions.\n * @param {...Function} fns the functions to call\n * @return {Function} the function that calls all the functions\n */\nfunction callAll(...fns: Function[]) {\n return (...args: any) => {\n fns.forEach(fn => {\n fn && fn(...args);\n });\n };\n}\n\ndescribe(\"Input tests\", () => {\n test(\"passes expected props to render prop\", () => {\n const { renderArg } = setup();\n\n // @ts-ignore\n expect(renderArg).toContainKeys([\"value\", \"validation\", \"onChange\", \"onBlur\"]);\n });\n\n test(\"updates value via onChange\", () => {\n const { renderArg } = setup();\n expect(renderArg.value).toBe(\"init-value\");\n renderArg.onChange(\"new-value\");\n expect(renderArg.value).toBe(\"new-value\");\n renderArg.onChange(\"third-value\");\n expect(renderArg.value).toBe(\"third-value\");\n });\n});\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AAEAA,SAAS,CAACC,eAAD,CAAT;;AAKA,SAASC,KAAT,GAAuC;EAAA,IAAxBC,KAAwB,uEAAJ,EAAI;EACnC,IAAMC,SAAS,GAAG;IACd;IACAC,QAAQ,EAAE,kBAACC,CAAD,EAAe,CAAE,CAFb;IAGdC,KAAK,EAAE;EAHO,CAAlB;EAKA,IAAMC,UAAU,GAAGC,IAAI,CAACC,EAAL,CAAQ,UAAAC,aAAa,EAAI;IACxCC,MAAM,CAACC,MAAP,CAAcT,SAAd,EAAyBO,aAAzB;IACA,OAAO,IAAP;EACH,CAHkB,CAAnB;EAKA,IAAMN,QAAQ,GAAGF,KAAK,CAACE,QAAN,GACXF,KAAK,CAACE,QADK,GAEX,YAAM;IACF,OAAO,KAAK,CAAZ;EACH,CAJP;;EAXmC,IAiB7BS,IAjB6B;IAAA;;IAAA;;IAAA;MAAA;;MAAA;;MAAA;QAAA;MAAA;;MAAA;MAAA,oFAkBP;QAAEP,KAAK,EAAE;MAAT,CAlBO;MAAA,uFAoBpB,UAACA,KAAD,EAAmB;QAC1B,MAAKQ,QAAL,CAAc;UAAER,KAAK,EAALA;QAAF,CAAd;MACH,CAtB8B;MAAA;IAAA;;IAAA;MAAA;MAAA,OAwB/B,kBAAyB;QACrB,oBACI,6BAAC,YAAD,oBACQJ,KADR;UAEI,KAAK,EAAE,KAAKa,KAAL,CAAWT,KAFtB;UAGI,QAAQ,EAAEU,OAAO,CAACZ,QAAD,EAAW,KAAKA,QAAhB;QAHrB,IAKKG,UALL,CADJ;MASH;IAlC8B;IAAA;EAAA,EAiBhBU,cAAA,CAAMC,SAjBU;;EAqCnC,IAAMC,KAAK,GAAG,IAAAC,cAAA,gBAAO,6BAAC,IAAD,OAAP,CAAd;EAEA;IAASjB,SAAS,EAATA;EAAT,GAAuBgB,KAAvB;AACH;AAED;AACA;AACA;AACA;AACA;AACA;AACA;;;AACA,SAASH,OAAT,GAAqC;EAAA,mCAAjBK,GAAiB;IAAjBA,GAAiB;EAAA;;EACjC,OAAO,YAAkB;IAAA,mCAAdC,IAAc;MAAdA,IAAc;IAAA;;IACrBD,GAAG,CAACE,OAAJ,CAAY,UAAAd,EAAE,EAAI;MACdA,EAAE,IAAIA,EAAE,MAAF,SAAMa,IAAN,CAAN;IACH,CAFD;EAGH,CAJD;AAKH;;AAEDE,QAAQ,CAAC,aAAD,EAAgB,YAAM;EAC1BC,IAAI,CAAC,sCAAD,EAAyC,YAAM;IAC/C,aAAsBxB,KAAK,EAA3B;IAAA,IAAQE,SAAR,UAAQA,SAAR,CAD+C,CAG/C;;;IACAuB,MAAM,CAACvB,SAAD,CAAN,CAAkBwB,aAAlB,CAAgC,CAAC,OAAD,EAAU,YAAV,EAAwB,UAAxB,EAAoC,QAApC,CAAhC;EACH,CALG,CAAJ;EAOAF,IAAI,CAAC,4BAAD,EAA+B,YAAM;IACrC,cAAsBxB,KAAK,EAA3B;IAAA,IAAQE,SAAR,WAAQA,SAAR;;IACAuB,MAAM,CAACvB,SAAS,CAACG,KAAX,CAAN,CAAwBsB,IAAxB,CAA6B,YAA7B;IACAzB,SAAS,CAACC,QAAV,CAAmB,WAAnB;IACAsB,MAAM,CAACvB,SAAS,CAACG,KAAX,CAAN,CAAwBsB,IAAxB,CAA6B,WAA7B;IACAzB,SAAS,CAACC,QAAV,CAAmB,aAAnB;IACAsB,MAAM,CAACvB,SAAS,CAACG,KAAX,CAAN,CAAwBsB,IAAxB,CAA6B,aAA7B;EACH,CAPG,CAAJ;AAQH,CAhBO,CAAR"}
1
+ {"version":3,"names":["afterEach","cleanup","setup","props","renderArg","onChange","_","value","renderProp","jest","fn","controllerArg","Object","assign","Test","setState","state","callAll","React","Component","utils","render","fns","args","forEach","describe","test","expect","toContainKeys","toBe"],"sources":["Input.test.tsx"],"sourcesContent":["import React from \"react\";\nimport { Input } from \"../index\";\nimport \"jest-dom/extend-expect\";\nimport { render, cleanup } from \"@testing-library/react\";\n\nafterEach(cleanup);\n\ninterface SetupProps {\n onChange?: () => void;\n}\nfunction setup(props: SetupProps = {}) {\n const renderArg = {\n // eslint-disable-next-line\n onChange: (_: string) => {},\n value: null\n };\n const renderProp = jest.fn(controllerArg => {\n Object.assign(renderArg, controllerArg);\n return null;\n });\n\n const onChange = props.onChange\n ? props.onChange\n : () => {\n return void 0;\n };\n\n class Test extends React.Component {\n public override state = { value: \"init-value\" };\n\n onChange = (value: string) => {\n this.setState({ value });\n };\n\n public override render() {\n return (\n <Input\n {...props}\n value={this.state.value}\n onChange={callAll(onChange, this.onChange)}\n >\n {renderProp}\n </Input>\n );\n }\n }\n\n const utils = render(<Test />);\n\n return { renderArg, ...utils };\n}\n\n/**\n * This return a function that will call all the given functions with\n * the arguments with which it's called. It does a null-check before\n * attempting to call the functions and can take any number of functions.\n * @param {...Function} fns the functions to call\n * @return {Function} the function that calls all the functions\n */\nfunction callAll(...fns: Function[]) {\n return (...args: any) => {\n fns.forEach(fn => {\n fn && fn(...args);\n });\n };\n}\n\ndescribe(\"Input tests\", () => {\n test(\"passes expected props to render prop\", () => {\n const { renderArg } = setup();\n\n // @ts-ignore\n expect(renderArg).toContainKeys([\"value\", \"validation\", \"onChange\", \"onBlur\"]);\n });\n\n test(\"updates value via onChange\", () => {\n const { renderArg } = setup();\n expect(renderArg.value).toBe(\"init-value\");\n renderArg.onChange(\"new-value\");\n expect(renderArg.value).toBe(\"new-value\");\n renderArg.onChange(\"third-value\");\n expect(renderArg.value).toBe(\"third-value\");\n });\n});\n"],"mappings":";;;;;;;;;;AAAA;AACA;AACA;AACA;AAEAA,SAAS,CAACC,eAAO,CAAC;AAKlB,SAASC,KAAK,GAAyB;EAAA,IAAxBC,KAAiB,uEAAG,CAAC,CAAC;EACjC,IAAMC,SAAS,GAAG;IACd;IACAC,QAAQ,EAAE,kBAACC,CAAS,EAAK,CAAC,CAAC;IAC3BC,KAAK,EAAE;EACX,CAAC;EACD,IAAMC,UAAU,GAAGC,IAAI,CAACC,EAAE,CAAC,UAAAC,aAAa,EAAI;IACxCC,MAAM,CAACC,MAAM,CAACT,SAAS,EAAEO,aAAa,CAAC;IACvC,OAAO,IAAI;EACf,CAAC,CAAC;EAEF,IAAMN,QAAQ,GAAGF,KAAK,CAACE,QAAQ,GACzBF,KAAK,CAACE,QAAQ,GACd,YAAM;IACF,OAAO,KAAK,CAAC;EACjB,CAAC;EAAC,IAEFS,IAAI;IAAA;IAAA;IAAA;MAAA;MAAA;MAAA;QAAA;MAAA;MAAA;MAAA,oFACkB;QAAEP,KAAK,EAAE;MAAa,CAAC;MAAA,uFAEpC,UAACA,KAAa,EAAK;QAC1B,MAAKQ,QAAQ,CAAC;UAAER,KAAK,EAALA;QAAM,CAAC,CAAC;MAC5B,CAAC;MAAA;IAAA;IAAA;MAAA;MAAA,OAED,kBAAyB;QACrB,oBACI,6BAAC,YAAK,oBACEJ,KAAK;UACT,KAAK,EAAE,IAAI,CAACa,KAAK,CAACT,KAAM;UACxB,QAAQ,EAAEU,OAAO,CAACZ,QAAQ,EAAE,IAAI,CAACA,QAAQ;QAAE,IAE1CG,UAAU,CACP;MAEhB;IAAC;IAAA;EAAA,EAjBcU,cAAK,CAACC,SAAS;EAoBlC,IAAMC,KAAK,GAAG,IAAAC,cAAM,gBAAC,6BAAC,IAAI,OAAG,CAAC;EAE9B;IAASjB,SAAS,EAATA;EAAS,GAAKgB,KAAK;AAChC;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAASH,OAAO,GAAqB;EAAA,mCAAjBK,GAAG;IAAHA,GAAG;EAAA;EACnB,OAAO,YAAkB;IAAA,mCAAdC,IAAI;MAAJA,IAAI;IAAA;IACXD,GAAG,CAACE,OAAO,CAAC,UAAAd,EAAE,EAAI;MACdA,EAAE,IAAIA,EAAE,eAAIa,IAAI,CAAC;IACrB,CAAC,CAAC;EACN,CAAC;AACL;AAEAE,QAAQ,CAAC,aAAa,EAAE,YAAM;EAC1BC,IAAI,CAAC,sCAAsC,EAAE,YAAM;IAC/C,aAAsBxB,KAAK,EAAE;MAArBE,SAAS,UAATA,SAAS;;IAEjB;IACAuB,MAAM,CAACvB,SAAS,CAAC,CAACwB,aAAa,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;EAClF,CAAC,CAAC;EAEFF,IAAI,CAAC,4BAA4B,EAAE,YAAM;IACrC,cAAsBxB,KAAK,EAAE;MAArBE,SAAS,WAATA,SAAS;IACjBuB,MAAM,CAACvB,SAAS,CAACG,KAAK,CAAC,CAACsB,IAAI,CAAC,YAAY,CAAC;IAC1CzB,SAAS,CAACC,QAAQ,CAAC,WAAW,CAAC;IAC/BsB,MAAM,CAACvB,SAAS,CAACG,KAAK,CAAC,CAACsB,IAAI,CAAC,WAAW,CAAC;IACzCzB,SAAS,CAACC,QAAQ,CAAC,aAAa,CAAC;IACjCsB,MAAM,CAACvB,SAAS,CAACG,KAAK,CAAC,CAACsB,IAAI,CAAC,aAAa,CAAC;EAC/C,CAAC,CAAC;AACN,CAAC,CAAC"}
package/Input/index.js CHANGED
@@ -3,9 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
-
7
6
  var _Input = require("./Input");
8
-
9
7
  Object.keys(_Input).forEach(function (key) {
10
8
  if (key === "default" || key === "__esModule") return;
11
9
  if (key in exports && exports[key] === _Input[key]) return;
@@ -1 +1 @@
1
- {"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Input\";\n"],"mappings":";;;;;;AAAA;;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA"}
1
+ {"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Input\";\n"],"mappings":";;;;;AAAA;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA"}
@@ -1,21 +1,13 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
-
5
4
  var _react = _interopRequireDefault(require("react"));
6
-
7
5
  var _react2 = require("@storybook/react");
8
-
9
6
  var _Story = require("@webiny/storybook-utils/Story");
10
-
11
7
  var _README = _interopRequireDefault(require("./README.md"));
12
-
13
8
  var _addonKnobs = require("@storybook/addon-knobs");
14
-
15
9
  var _index = require("./index");
16
-
17
10
  var _List = require("./../List");
18
-
19
11
  var story = (0, _react2.storiesOf)("Components/List", module);
20
12
  story.addDecorator(_addonKnobs.withKnobs);
21
13
  story.add("collapsible list", function () {