@transferwise/components 46.36.1 → 46.38.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 (351) hide show
  1. package/README.md +1 -1
  2. package/build/index.js +169 -348
  3. package/build/index.js.map +1 -1
  4. package/build/index.mjs +164 -342
  5. package/build/index.mjs.map +1 -1
  6. package/build/main.css +127 -108
  7. package/build/styles/main.css +127 -108
  8. package/build/styles/uploadInput/UploadInput.css +25 -27
  9. package/build/styles/uploadInput/uploadButton/UploadButton.css +24 -38
  10. package/build/styles/uploadInput/uploadItem/UploadItem.css +81 -46
  11. package/build/types/accordion/AccordionItem/AccordionItem.d.ts.map +1 -1
  12. package/build/types/actionButton/ActionButton.d.ts +2 -2
  13. package/build/types/actionButton/ActionButton.d.ts.map +1 -1
  14. package/build/types/actionOption/ActionOption.d.ts +4 -5
  15. package/build/types/actionOption/ActionOption.d.ts.map +1 -1
  16. package/build/types/alert/Alert.d.ts +1 -2
  17. package/build/types/alert/Alert.d.ts.map +1 -1
  18. package/build/types/alert/inlineMarkdown/InlineMarkdown.d.ts +4 -11
  19. package/build/types/alert/inlineMarkdown/InlineMarkdown.d.ts.map +1 -1
  20. package/build/types/alert/inlineMarkdown/index.d.ts +2 -1
  21. package/build/types/alert/inlineMarkdown/index.d.ts.map +1 -1
  22. package/build/types/avatar/Avatar.d.ts +0 -1
  23. package/build/types/avatar/Avatar.d.ts.map +1 -1
  24. package/build/types/avatar/colors/colors.d.ts.map +1 -1
  25. package/build/types/avatarWrapper/AvatarWrapper.d.ts +0 -1
  26. package/build/types/avatarWrapper/AvatarWrapper.d.ts.map +1 -1
  27. package/build/types/body/Body.d.ts +3 -3
  28. package/build/types/body/Body.d.ts.map +1 -1
  29. package/build/types/button/Button.d.ts +0 -1
  30. package/build/types/button/Button.d.ts.map +1 -1
  31. package/build/types/button/Button.messages.d.ts +3 -3
  32. package/build/types/button/classMap.d.ts +6 -6
  33. package/build/types/card/Card.d.ts +16 -20
  34. package/build/types/card/Card.d.ts.map +1 -1
  35. package/build/types/card/index.d.ts +2 -1
  36. package/build/types/card/index.d.ts.map +1 -1
  37. package/build/types/checkbox/Checkbox.d.ts +15 -20
  38. package/build/types/checkbox/Checkbox.d.ts.map +1 -1
  39. package/build/types/checkbox/index.d.ts +2 -2
  40. package/build/types/checkbox/index.d.ts.map +1 -1
  41. package/build/types/checkboxOption/CheckboxOption.d.ts +2 -3
  42. package/build/types/checkboxOption/CheckboxOption.d.ts.map +1 -1
  43. package/build/types/chevron/Chevron.d.ts +0 -1
  44. package/build/types/chevron/Chevron.d.ts.map +1 -1
  45. package/build/types/chips/Chip.d.ts +1 -2
  46. package/build/types/chips/Chip.d.ts.map +1 -1
  47. package/build/types/chips/Chips.d.ts +1 -2
  48. package/build/types/chips/Chips.d.ts.map +1 -1
  49. package/build/types/circularButton/CircularButton.d.ts +0 -1
  50. package/build/types/circularButton/CircularButton.d.ts.map +1 -1
  51. package/build/types/common/RadioButton/RadioButton.d.ts +0 -1
  52. package/build/types/common/RadioButton/RadioButton.d.ts.map +1 -1
  53. package/build/types/common/action/Action.d.ts +0 -1
  54. package/build/types/common/action/Action.d.ts.map +1 -1
  55. package/build/types/common/bottomSheet/BottomSheet.d.ts +2 -2
  56. package/build/types/common/bottomSheet/BottomSheet.d.ts.map +1 -1
  57. package/build/types/common/closeButton/CloseButton.d.ts +5 -6
  58. package/build/types/common/closeButton/CloseButton.d.ts.map +1 -1
  59. package/build/types/common/commonProps.d.ts +0 -1
  60. package/build/types/common/commonProps.d.ts.map +1 -1
  61. package/build/types/common/dateUtils/getMonthNames/getMonthNames.d.ts +1 -1
  62. package/build/types/common/dateUtils/getMonthNames/getMonthNames.d.ts.map +1 -1
  63. package/build/types/common/flowHeader/FlowHeader.d.ts +1 -1
  64. package/build/types/common/flowHeader/FlowHeader.d.ts.map +1 -1
  65. package/build/types/common/focusBoundary/FocusBoundary.d.ts +0 -1
  66. package/build/types/common/focusBoundary/FocusBoundary.d.ts.map +1 -1
  67. package/build/types/common/hooks/useDirection/useDirection.d.ts.map +1 -1
  68. package/build/types/common/hooks/useResizeObserver.d.ts +1 -2
  69. package/build/types/common/hooks/useResizeObserver.d.ts.map +1 -1
  70. package/build/types/common/panel/Panel.d.ts +11 -11
  71. package/build/types/common/panel/Panel.d.ts.map +1 -1
  72. package/build/types/common/polymorphicWithOverrides/PolymorphicWithOverrides.d.ts +1 -2
  73. package/build/types/common/polymorphicWithOverrides/PolymorphicWithOverrides.d.ts.map +1 -1
  74. package/build/types/common/responsivePanel/ResponsivePanel.d.ts +9 -10
  75. package/build/types/common/responsivePanel/ResponsivePanel.d.ts.map +1 -1
  76. package/build/types/criticalBanner/CriticalCommsBanner.d.ts +0 -1
  77. package/build/types/criticalBanner/CriticalCommsBanner.d.ts.map +1 -1
  78. package/build/types/dateInput/DateInput.d.ts +0 -1
  79. package/build/types/dateInput/DateInput.d.ts.map +1 -1
  80. package/build/types/dateLookup/DateLookup.d.ts +1 -1
  81. package/build/types/dateLookup/DateLookup.d.ts.map +1 -1
  82. package/build/types/dateLookup/dateHeader/DateHeader.d.ts +0 -1
  83. package/build/types/dateLookup/dateHeader/DateHeader.d.ts.map +1 -1
  84. package/build/types/dateLookup/dateTrigger/DateTrigger.d.ts +0 -1
  85. package/build/types/dateLookup/dateTrigger/DateTrigger.d.ts.map +1 -1
  86. package/build/types/dateLookup/dayCalendar/DayCalendar.d.ts +0 -1
  87. package/build/types/dateLookup/dayCalendar/DayCalendar.d.ts.map +1 -1
  88. package/build/types/dateLookup/dayCalendar/table/DayCalendarTable.d.ts +0 -1
  89. package/build/types/dateLookup/dayCalendar/table/DayCalendarTable.d.ts.map +1 -1
  90. package/build/types/dateLookup/monthCalendar/MonthCalendar.d.ts +0 -1
  91. package/build/types/dateLookup/monthCalendar/MonthCalendar.d.ts.map +1 -1
  92. package/build/types/dateLookup/monthCalendar/table/MonthCalendarTable.d.ts +0 -1
  93. package/build/types/dateLookup/monthCalendar/table/MonthCalendarTable.d.ts.map +1 -1
  94. package/build/types/dateLookup/tableLink/TableLink.d.ts +0 -1
  95. package/build/types/dateLookup/tableLink/TableLink.d.ts.map +1 -1
  96. package/build/types/dateLookup/yearCalendar/YearCalendar.d.ts +0 -1
  97. package/build/types/dateLookup/yearCalendar/YearCalendar.d.ts.map +1 -1
  98. package/build/types/dateLookup/yearCalendar/table/YearCalendarTable.d.ts +0 -1
  99. package/build/types/dateLookup/yearCalendar/table/YearCalendarTable.d.ts.map +1 -1
  100. package/build/types/decision/Decision.d.ts +1 -2
  101. package/build/types/decision/Decision.d.ts.map +1 -1
  102. package/build/types/definitionList/DefinitionList.d.ts +19 -24
  103. package/build/types/definitionList/DefinitionList.d.ts.map +1 -1
  104. package/build/types/definitionList/index.d.ts +2 -1
  105. package/build/types/definitionList/index.d.ts.map +1 -1
  106. package/build/types/dimmer/Dimmer.d.ts +3 -3
  107. package/build/types/dimmer/Dimmer.d.ts.map +1 -1
  108. package/build/types/drawer/Drawer.d.ts +18 -36
  109. package/build/types/drawer/Drawer.d.ts.map +1 -1
  110. package/build/types/drawer/index.d.ts +2 -1
  111. package/build/types/drawer/index.d.ts.map +1 -1
  112. package/build/types/dropFade/DropFade.d.ts.map +1 -1
  113. package/build/types/emphasis/Emphasis.d.ts +1 -2
  114. package/build/types/emphasis/Emphasis.d.ts.map +1 -1
  115. package/build/types/field/Field.d.ts +0 -1
  116. package/build/types/field/Field.d.ts.map +1 -1
  117. package/build/types/flowNavigation/FlowNavigation.d.ts +0 -1
  118. package/build/types/flowNavigation/FlowNavigation.d.ts.map +1 -1
  119. package/build/types/flowNavigation/backButton/BackButton.d.ts +3 -3
  120. package/build/types/flowNavigation/backButton/index.d.ts +1 -1
  121. package/build/types/flowNavigation/backButton/index.d.ts.map +1 -1
  122. package/build/types/header/Header.d.ts +0 -1
  123. package/build/types/header/Header.d.ts.map +1 -1
  124. package/build/types/image/Image.d.ts +0 -1
  125. package/build/types/image/Image.d.ts.map +1 -1
  126. package/build/types/index.d.ts +4 -0
  127. package/build/types/index.d.ts.map +1 -1
  128. package/build/types/info/Info.d.ts +0 -1
  129. package/build/types/info/Info.d.ts.map +1 -1
  130. package/build/types/inputWithDisplayFormat/InputWithDisplayFormat.d.ts +0 -1
  131. package/build/types/inputWithDisplayFormat/InputWithDisplayFormat.d.ts.map +1 -1
  132. package/build/types/inputs/Input.d.ts +1 -2
  133. package/build/types/inputs/Input.d.ts.map +1 -1
  134. package/build/types/inputs/InputGroup.d.ts +0 -1
  135. package/build/types/inputs/InputGroup.d.ts.map +1 -1
  136. package/build/types/inputs/SearchInput.d.ts +1 -2
  137. package/build/types/inputs/SearchInput.d.ts.map +1 -1
  138. package/build/types/inputs/SelectInput.d.ts +0 -1
  139. package/build/types/inputs/SelectInput.d.ts.map +1 -1
  140. package/build/types/inputs/TextArea.d.ts +1 -2
  141. package/build/types/inputs/TextArea.d.ts.map +1 -1
  142. package/build/types/inputs/_BottomSheet.d.ts +1 -2
  143. package/build/types/inputs/_BottomSheet.d.ts.map +1 -1
  144. package/build/types/inputs/_ButtonInput.d.ts +1 -2
  145. package/build/types/inputs/_ButtonInput.d.ts.map +1 -1
  146. package/build/types/inputs/_Popover.d.ts +0 -1
  147. package/build/types/inputs/_Popover.d.ts.map +1 -1
  148. package/build/types/inputs/contexts.d.ts +0 -1
  149. package/build/types/inputs/contexts.d.ts.map +1 -1
  150. package/build/types/label/Label.d.ts +0 -1
  151. package/build/types/label/Label.d.ts.map +1 -1
  152. package/build/types/loader/Loader.d.ts +0 -1
  153. package/build/types/loader/Loader.d.ts.map +1 -1
  154. package/build/types/logo/Logo.d.ts +15 -23
  155. package/build/types/logo/Logo.d.ts.map +1 -1
  156. package/build/types/logo/index.d.ts +1 -2
  157. package/build/types/logo/index.d.ts.map +1 -1
  158. package/build/types/markdown/Markdown.d.ts +0 -1
  159. package/build/types/markdown/Markdown.d.ts.map +1 -1
  160. package/build/types/money/Money.d.ts +0 -1
  161. package/build/types/money/Money.d.ts.map +1 -1
  162. package/build/types/moneyInput/MoneyInput.d.ts +0 -1
  163. package/build/types/moneyInput/MoneyInput.d.ts.map +1 -1
  164. package/build/types/navigationOption/NavigationOption.d.ts +0 -1
  165. package/build/types/navigationOption/NavigationOption.d.ts.map +1 -1
  166. package/build/types/phoneNumberInput/PhoneNumberInput.d.ts +0 -1
  167. package/build/types/phoneNumberInput/PhoneNumberInput.d.ts.map +1 -1
  168. package/build/types/popover/Popover.d.ts +0 -1
  169. package/build/types/popover/Popover.d.ts.map +1 -1
  170. package/build/types/progress/Progress.d.ts +1 -2
  171. package/build/types/progress/Progress.d.ts.map +1 -1
  172. package/build/types/progressBar/ProgressBar.d.ts +1 -2
  173. package/build/types/progressBar/ProgressBar.d.ts.map +1 -1
  174. package/build/types/promoCard/PromoCard.d.ts +1 -1
  175. package/build/types/promoCard/PromoCard.d.ts.map +1 -1
  176. package/build/types/provider/Provider.d.ts +0 -1
  177. package/build/types/provider/Provider.d.ts.map +1 -1
  178. package/build/types/provider/direction/DirectionProvider.d.ts +2 -2
  179. package/build/types/provider/direction/DirectionProvider.d.ts.map +1 -1
  180. package/build/types/provider/language/LanguageProvider.d.ts +2 -2
  181. package/build/types/provider/language/LanguageProvider.d.ts.map +1 -1
  182. package/build/types/radio/Radio.d.ts +0 -1
  183. package/build/types/radio/Radio.d.ts.map +1 -1
  184. package/build/types/radioGroup/RadioGroup.d.ts +0 -1
  185. package/build/types/radioGroup/RadioGroup.d.ts.map +1 -1
  186. package/build/types/radioOption/RadioOption.d.ts +0 -1
  187. package/build/types/radioOption/RadioOption.d.ts.map +1 -1
  188. package/build/types/segmentedControl/SegmentedControl.d.ts +0 -1
  189. package/build/types/segmentedControl/SegmentedControl.d.ts.map +1 -1
  190. package/build/types/select/index.d.ts +1 -1
  191. package/build/types/select/index.d.ts.map +1 -1
  192. package/build/types/select/option/Option.d.ts +2 -1
  193. package/build/types/select/option/Option.d.ts.map +1 -1
  194. package/build/types/select/option/index.d.ts +1 -1
  195. package/build/types/select/option/index.d.ts.map +1 -1
  196. package/build/types/select/searchBox/SearchBox.d.ts +3 -3
  197. package/build/types/select/searchBox/SearchBox.d.ts.map +1 -1
  198. package/build/types/slidingPanel/SlidingPanel.d.ts +2 -2
  199. package/build/types/slidingPanel/SlidingPanel.d.ts.map +1 -1
  200. package/build/types/snackbar/Snackbar.d.ts +2 -1
  201. package/build/types/snackbar/Snackbar.d.ts.map +1 -1
  202. package/build/types/snackbar/SnackbarContext.d.ts +0 -1
  203. package/build/types/snackbar/SnackbarContext.d.ts.map +1 -1
  204. package/build/types/snackbar/SnackbarProvider.d.ts +0 -1
  205. package/build/types/snackbar/SnackbarProvider.d.ts.map +1 -1
  206. package/build/types/statusIcon/StatusIcon.d.ts +0 -1
  207. package/build/types/statusIcon/StatusIcon.d.ts.map +1 -1
  208. package/build/types/sticky/Sticky.d.ts +32 -4
  209. package/build/types/sticky/Sticky.d.ts.map +1 -1
  210. package/build/types/switchOption/SwitchOption.d.ts +3 -4
  211. package/build/types/switchOption/SwitchOption.d.ts.map +1 -1
  212. package/build/types/tabs/TabList.d.ts +1 -1
  213. package/build/types/tabs/TabPanel.d.ts +4 -4
  214. package/build/types/tabs/Tabs.d.ts +1 -1
  215. package/build/types/tabs/Tabs.d.ts.map +1 -1
  216. package/build/types/test-utils/story-config.d.ts +8 -0
  217. package/build/types/test-utils/story-config.d.ts.map +1 -1
  218. package/build/types/textareaWithDisplayFormat/TextareaWithDisplayFormat.d.ts +0 -1
  219. package/build/types/textareaWithDisplayFormat/TextareaWithDisplayFormat.d.ts.map +1 -1
  220. package/build/types/tile/Tile.d.ts +16 -37
  221. package/build/types/tile/Tile.d.ts.map +1 -1
  222. package/build/types/tile/index.d.ts +1 -1
  223. package/build/types/tile/index.d.ts.map +1 -1
  224. package/build/types/tooltip/Tooltip.d.ts.map +1 -1
  225. package/build/types/typeahead/Typeahead.d.ts.map +1 -1
  226. package/build/types/typeahead/typeaheadOption/TypeaheadOption.d.ts +0 -1
  227. package/build/types/typeahead/typeaheadOption/TypeaheadOption.d.ts.map +1 -1
  228. package/build/types/typeahead/util/highlight.d.ts +0 -1
  229. package/build/types/typeahead/util/highlight.d.ts.map +1 -1
  230. package/build/types/upload/Upload.d.ts.map +1 -1
  231. package/build/types/upload/Upload.messages.d.ts +20 -20
  232. package/build/types/upload/steps/completeStep/completeStep.d.ts +10 -10
  233. package/build/types/upload/steps/mediaUploadStep/mediaUploadStep.d.ts +8 -8
  234. package/build/types/upload/steps/processingStep/processingStep.d.ts +8 -8
  235. package/build/types/upload/steps/uploadImageStep/uploadImageStep.d.ts +9 -9
  236. package/build/types/upload/steps/uploadImageStep/uploadImageStep.d.ts.map +1 -1
  237. package/build/types/uploadInput/UploadInput.d.ts +1 -2
  238. package/build/types/uploadInput/UploadInput.d.ts.map +1 -1
  239. package/build/types/uploadInput/types.d.ts +9 -1
  240. package/build/types/uploadInput/types.d.ts.map +1 -1
  241. package/build/types/uploadInput/uploadButton/UploadButton.d.ts +1 -6
  242. package/build/types/uploadInput/uploadButton/UploadButton.d.ts.map +1 -1
  243. package/build/types/uploadInput/uploadItem/UploadItem.d.ts +0 -1
  244. package/build/types/uploadInput/uploadItem/UploadItem.d.ts.map +1 -1
  245. package/build/types/withDisplayFormat/WithDisplayFormat.d.ts +4 -4
  246. package/build/types/withDisplayFormat/WithDisplayFormat.d.ts.map +1 -1
  247. package/build/types/withNextPortal/withNextPortal.d.ts +0 -1
  248. package/build/types/withNextPortal/withNextPortal.d.ts.map +1 -1
  249. package/package.json +3 -4
  250. package/src/accordion/AccordionItem/AccordionItem.tsx +5 -2
  251. package/src/actionOption/ActionOption.tsx +4 -5
  252. package/src/alert/Alert.tsx +1 -1
  253. package/src/alert/inlineMarkdown/InlineMarkdown.tsx +13 -0
  254. package/src/alert/inlineMarkdown/index.ts +2 -0
  255. package/src/body/Body.tsx +4 -3
  256. package/src/card/{Card.story.js → Card.story.tsx} +6 -15
  257. package/src/card/{Card.js → Card.tsx} +23 -34
  258. package/src/card/index.ts +2 -0
  259. package/src/checkbox/{Checkbox.spec.js → Checkbox.spec.tsx} +5 -5
  260. package/src/checkbox/{Checkbox.js → Checkbox.tsx} +19 -41
  261. package/src/checkbox/index.ts +2 -0
  262. package/src/chips/Chip.tsx +5 -6
  263. package/src/chips/Chips.tsx +1 -2
  264. package/src/common/bottomSheet/BottomSheet.tsx +2 -9
  265. package/src/common/closeButton/CloseButton.tsx +1 -1
  266. package/src/common/flowHeader/FlowHeader.tsx +1 -1
  267. package/src/common/hooks/useResizeObserver.ts +1 -1
  268. package/src/common/panel/Panel.spec.tsx +1 -1
  269. package/src/common/panel/Panel.tsx +7 -7
  270. package/src/common/polymorphicWithOverrides/PolymorphicWithOverrides.tsx +1 -1
  271. package/src/decision/Decision.tsx +1 -1
  272. package/src/definitionList/{DefinitionList.story.js → DefinitionList.story.tsx} +22 -2
  273. package/src/definitionList/DefinitionList.tsx +95 -0
  274. package/src/definitionList/index.ts +2 -0
  275. package/src/dimmer/Dimmer.tsx +2 -10
  276. package/src/drawer/{Drawer.rtl.spec.js → Drawer.rtl.spec.tsx} +4 -2
  277. package/src/drawer/{Drawer.story.js → Drawer.story.tsx} +20 -28
  278. package/src/drawer/{Drawer.js → Drawer.tsx} +26 -31
  279. package/src/drawer/index.ts +2 -0
  280. package/src/emphasis/Emphasis.tsx +1 -3
  281. package/src/index.ts +4 -0
  282. package/src/inputs/Input.tsx +1 -1
  283. package/src/inputs/SearchInput.tsx +1 -1
  284. package/src/inputs/SelectInput.tsx +4 -4
  285. package/src/inputs/TextArea.tsx +1 -1
  286. package/src/inputs/_BottomSheet.tsx +1 -1
  287. package/src/inputs/_ButtonInput.tsx +1 -1
  288. package/src/logo/Logo.story.tsx +3 -6
  289. package/src/logo/{Logo.js → Logo.tsx} +25 -35
  290. package/src/logo/index.ts +1 -0
  291. package/src/main.css +127 -108
  292. package/src/progress/Progress.tsx +3 -15
  293. package/src/progressBar/ProgressBar.tsx +1 -2
  294. package/src/promoCard/PromoCard.tsx +2 -2
  295. package/src/promoCard/PromoCardContext.spec.tsx +1 -1
  296. package/src/provider/direction/DirectionProvider.tsx +2 -5
  297. package/src/provider/language/LanguageProvider.tsx +2 -2
  298. package/src/section/Section.story.tsx +0 -2
  299. package/src/segmentedControl/SegmentedControl.tsx +2 -2
  300. package/src/select/option/Option.tsx +6 -18
  301. package/src/slidingPanel/SlidingPanel.spec.js +2 -1
  302. package/src/slidingPanel/SlidingPanel.tsx +4 -1
  303. package/src/snackbar/Snackbar.story.tsx +20 -100
  304. package/src/snackbar/Snackbar.tests.story.tsx +281 -0
  305. package/src/snackbar/Snackbar.tsx +8 -12
  306. package/src/ssr.spec.js +6 -0
  307. package/src/sticky/Sticky.spec.tsx +71 -0
  308. package/src/sticky/Sticky.story.tsx +72 -15
  309. package/src/sticky/Sticky.tsx +49 -5
  310. package/src/switchOption/SwitchOption.tsx +5 -7
  311. package/src/tabs/Tabs.js +3 -3
  312. package/src/test-utils/Parameters.d.ts +8 -0
  313. package/src/test-utils/story-config.ts +5 -0
  314. package/src/tile/{Tile.spec.js → Tile.spec.tsx} +1 -1
  315. package/src/tile/{Tile.js → Tile.tsx} +24 -35
  316. package/src/tooltip/Tooltip.tsx +2 -1
  317. package/src/uploadInput/UploadInput.css +25 -27
  318. package/src/uploadInput/UploadInput.less +24 -23
  319. package/src/uploadInput/UploadInput.story.tsx +60 -10
  320. package/src/uploadInput/UploadInput.tsx +3 -6
  321. package/src/uploadInput/types.ts +11 -1
  322. package/src/uploadInput/uploadButton/UploadButton.css +24 -38
  323. package/src/uploadInput/uploadButton/UploadButton.less +27 -40
  324. package/src/uploadInput/uploadButton/UploadButton.spec.tsx +0 -1
  325. package/src/uploadInput/uploadButton/UploadButton.tsx +12 -37
  326. package/src/uploadInput/uploadItem/UploadItem.css +81 -46
  327. package/src/uploadInput/uploadItem/UploadItem.less +75 -40
  328. package/src/uploadInput/uploadItem/UploadItem.tsx +33 -29
  329. package/src/uploadInput/uploadItem/UploadItemBody.tsx +1 -1
  330. package/src/withDisplayFormat/WithDisplayFormat.tsx +3 -3
  331. package/build/types/logo/logoTypes.d.ts +0 -6
  332. package/build/types/logo/logoTypes.d.ts.map +0 -1
  333. package/src/alert/inlineMarkdown/InlineMarkdown.js +0 -21
  334. package/src/alert/inlineMarkdown/index.js +0 -1
  335. package/src/card/index.js +0 -1
  336. package/src/checkbox/index.js +0 -3
  337. package/src/definitionList/DefinitionList.js +0 -100
  338. package/src/definitionList/index.js +0 -1
  339. package/src/drawer/index.js +0 -1
  340. package/src/logo/index.js +0 -2
  341. package/src/logo/logoTypes.ts +0 -6
  342. package/src/snackbar/Snackbar.spec.js +0 -112
  343. package/src/sticky/Sticky.spec.js +0 -34
  344. /package/src/card/{Card.spec.js → Card.spec.tsx} +0 -0
  345. /package/src/checkbox/__snapshots__/{Checkbox.spec.js.snap → Checkbox.spec.tsx.snap} +0 -0
  346. /package/src/drawer/__snapshots__/{Drawer.rtl.spec.js.snap → Drawer.rtl.spec.tsx.snap} +0 -0
  347. /package/src/logo/{Logo.spec.js → Logo.spec.tsx} +0 -0
  348. /package/src/logo/__snapshots__/{Logo.spec.js.snap → Logo.spec.tsx.snap} +0 -0
  349. /package/src/tile/{Tile.story.js → Tile.story.tsx} +0 -0
  350. /package/src/tile/__snapshots__/{Tile.spec.js.snap → Tile.spec.tsx.snap} +0 -0
  351. /package/src/tile/{index.js → index.ts} +0 -0
@@ -1,17 +1,29 @@
1
1
  import classNames from 'classnames';
2
- import PropTypes from 'prop-types';
3
2
  import { forwardRef } from 'react';
4
- import requiredIf from 'react-required-if';
5
3
 
6
4
  import Body from '../body';
7
5
  import Chevron from '../chevron';
8
6
  import { Position, Typography } from '../common';
9
7
  import Option from '../common/Option';
10
8
 
11
- const Card = forwardRef((props, reference) => {
12
- const {
9
+ export interface CardProps {
10
+ 'aria-label'?: string;
11
+ as?: React.ElementType;
12
+ isExpanded?: boolean;
13
+ title: React.ReactNode;
14
+ details: React.ReactNode;
15
+ icon?: React.ReactNode;
16
+ children?: React.ReactNode;
17
+ id?: string;
18
+ className?: string;
19
+ 'data-testid'?: string;
20
+ onClick?: (nextIsExpanded: boolean) => void;
21
+ }
22
+
23
+ const Card = forwardRef(function Card(
24
+ {
13
25
  'aria-label': ariaLabel,
14
- as: Element,
26
+ as: Element = 'div',
15
27
  isExpanded,
16
28
  title,
17
29
  details,
@@ -20,8 +32,10 @@ const Card = forwardRef((props, reference) => {
20
32
  icon,
21
33
  id,
22
34
  className,
23
- ...rest
24
- } = props;
35
+ 'data-testid': dataTestId,
36
+ }: CardProps,
37
+ reference,
38
+ ) {
25
39
  const isOpen = !!(isExpanded && children);
26
40
 
27
41
  return (
@@ -33,7 +47,7 @@ const Card = forwardRef((props, reference) => {
33
47
  'np-card--has-icon': !!icon,
34
48
  })}
35
49
  id={id}
36
- data-testid={rest['data-testid']}
50
+ data-testid={dataTestId}
37
51
  >
38
52
  <Option
39
53
  aria-label={ariaLabel}
@@ -44,7 +58,7 @@ const Card = forwardRef((props, reference) => {
44
58
  content={details}
45
59
  showMediaAtAllSizes
46
60
  button={children && <Chevron orientation={isOpen ? Position.TOP : Position.BOTTOM} />}
47
- onClick={() => children && onClick(!isExpanded)}
61
+ onClick={children ? () => onClick?.(!isExpanded) : undefined}
48
62
  />
49
63
  <div
50
64
  className={classNames('np-card__divider', {
@@ -60,29 +74,4 @@ const Card = forwardRef((props, reference) => {
60
74
  );
61
75
  });
62
76
 
63
- const hasChildren = ({ children }) => children;
64
-
65
- Card.propTypes = {
66
- 'aria-label': PropTypes.string,
67
- as: PropTypes.string,
68
- isExpanded: requiredIf(PropTypes.bool, hasChildren),
69
- title: PropTypes.node.isRequired,
70
- details: PropTypes.node.isRequired,
71
- onClick: requiredIf(PropTypes.func, hasChildren),
72
- icon: PropTypes.node,
73
- children: PropTypes.node,
74
- id: PropTypes.string,
75
- className: PropTypes.string,
76
- 'data-testid': PropTypes.string,
77
- };
78
-
79
- Card.defaultProps = {
80
- 'aria-label': undefined,
81
- as: 'div',
82
- children: null,
83
- id: null,
84
- className: null,
85
- 'data-testid': null,
86
- };
87
-
88
77
  export default Card;
@@ -0,0 +1,2 @@
1
+ export { default } from './Card';
2
+ export type { CardProps } from './Card';
@@ -2,10 +2,10 @@ import '@testing-library/jest-dom';
2
2
 
3
3
  import { render, fireEvent, screen } from '@testing-library/react';
4
4
 
5
- import Checkbox from '.';
5
+ import Checkbox, { CheckboxProps } from '.';
6
6
 
7
7
  describe('Checkbox', () => {
8
- let props;
8
+ let props: CheckboxProps;
9
9
 
10
10
  beforeEach(() => {
11
11
  props = {
@@ -68,7 +68,7 @@ describe('Checkbox', () => {
68
68
 
69
69
  it('has disabled class when the disabled prop is true', () => {
70
70
  const { container } = render(<Checkbox {...props} disabled />);
71
- expect(getCheckboxContainer(container).firstChild).toHaveClass('disabled');
71
+ expect(getCheckboxContainer(container)?.firstChild).toHaveClass('disabled');
72
72
  });
73
73
 
74
74
  it('passes required to checkbox button', () => {
@@ -117,7 +117,7 @@ describe('Checkbox', () => {
117
117
  expect(getCheckboxContainer(container)).toHaveClass('checkbox-lg');
118
118
  });
119
119
 
120
- const getCheckboxContainer = (container) => container.querySelector('.np-checkbox');
121
- const getLabel = () => screen.getByText('hello').parentElement;
120
+ const getCheckboxContainer = (container: HTMLElement) => container.querySelector('.np-checkbox');
121
+ const getLabel = () => screen.getByText('hello').parentElement!;
122
122
  const getCheckbox = () => screen.getByRole('checkbox');
123
123
  });
@@ -1,12 +1,24 @@
1
- import { useTheme } from '@wise/components-theming';
2
1
  import classNames from 'classnames';
3
- import PropTypes from 'prop-types';
4
2
 
5
3
  import Body from '../body/Body';
6
4
  import CheckboxButton from '../checkboxButton';
7
5
  import { Typography } from '../common';
8
6
 
9
- const Checkbox = ({
7
+ export interface CheckboxProps {
8
+ id?: string;
9
+ checked?: boolean;
10
+ required?: boolean;
11
+ disabled?: boolean;
12
+ readOnly?: boolean;
13
+ label: React.ReactNode;
14
+ secondary?: string;
15
+ onFocus?: React.FocusEventHandler<HTMLInputElement>;
16
+ onChange: (checked: boolean) => void;
17
+ onBlur?: React.FocusEventHandler<HTMLInputElement>;
18
+ className?: string;
19
+ }
20
+
21
+ export default function Checkbox({
10
22
  id,
11
23
  checked,
12
24
  required,
@@ -18,15 +30,13 @@ const Checkbox = ({
18
30
  onChange,
19
31
  onFocus,
20
32
  onBlur,
21
- }) => {
22
- const { isModern } = useTheme();
23
-
33
+ }: CheckboxProps) {
24
34
  const classList = classNames(
25
35
  'np-checkbox',
26
36
  {
27
37
  checkbox: true,
28
38
  'checkbox-lg': secondary,
29
- disabled: isModern && disabled,
39
+ disabled,
30
40
  },
31
41
  className,
32
42
  );
@@ -51,41 +61,9 @@ const Checkbox = ({
51
61
  type={secondary ? Typography.BODY_LARGE_BOLD : Typography.BODY_LARGE}
52
62
  >
53
63
  <span className={required ? 'has-required' : undefined}>{label}</span>
54
- {secondary && (
55
- <Body as="span" className={classNames({ secondary: !isModern })}>
56
- {secondary}
57
- </Body>
58
- )}
64
+ {secondary && <Body as="span">{secondary}</Body>}
59
65
  </Body>
60
66
  </label>
61
67
  </div>
62
68
  );
63
- };
64
-
65
- Checkbox.propTypes = {
66
- id: PropTypes.string,
67
- checked: PropTypes.bool,
68
- required: PropTypes.bool,
69
- disabled: PropTypes.bool,
70
- readOnly: PropTypes.bool,
71
- label: PropTypes.node.isRequired,
72
- secondary: PropTypes.string,
73
- onFocus: PropTypes.func,
74
- onChange: PropTypes.func.isRequired,
75
- onBlur: PropTypes.func,
76
- className: PropTypes.string,
77
- };
78
-
79
- Checkbox.defaultProps = {
80
- id: null,
81
- checked: false,
82
- required: false,
83
- disabled: false,
84
- readOnly: false,
85
- secondary: null,
86
- onFocus: null,
87
- onBlur: null,
88
- className: undefined,
89
- };
90
-
91
- export default Checkbox;
69
+ }
@@ -0,0 +1,2 @@
1
+ export { default } from './Checkbox';
2
+ export type { CheckboxProps } from './Checkbox';
@@ -1,10 +1,9 @@
1
1
  import { useTheme } from '@wise/components-theming';
2
2
  import classNames from 'classnames';
3
- import { ReactElement, useEffect, useRef } from 'react';
3
+ import { useEffect, useRef } from 'react';
4
4
 
5
5
  import Body from '../body/Body';
6
- import { AriaLabelProperty, CommonProps } from '../common';
7
- import { Typography } from '../common';
6
+ import { AriaLabelProperty, CommonProps, Typography } from '../common';
8
7
  import { CloseButton } from '../common/closeButton/CloseButton';
9
8
 
10
9
  export type ChipValue = string | number;
@@ -32,7 +31,7 @@ const Chip = ({
32
31
  'aria-checked': ariaChecked,
33
32
  role,
34
33
  closeButton,
35
- }: Props): ReactElement => {
34
+ }: Props) => {
36
35
  const isActionable = onClick || onKeyPress;
37
36
  const defaultRole = isActionable ? 'button' : undefined;
38
37
  const tabIndex = isActionable ? 0 : -1;
@@ -40,7 +39,7 @@ const Chip = ({
40
39
  const { isModern } = useTheme();
41
40
 
42
41
  const closeButtonReference = useRef<HTMLButtonElement>(null);
43
- const previousCloseButtonShown = useRef<boolean>();
42
+ const previousCloseButtonShown = useRef<boolean | undefined>(undefined);
44
43
  useEffect(() => {
45
44
  if (closeButtonReference.current != null && previousCloseButtonShown.current === false) {
46
45
  closeButtonReference.current?.focus();
@@ -78,7 +77,7 @@ const Chip = ({
78
77
  <CloseButton
79
78
  ref={closeButtonReference}
80
79
  className={isModern ? `btn-unstyled` : `btn-unstyled m-l-1`}
81
- aria-label={closeButton && closeButton['aria-label']}
80
+ aria-label={closeButton?.['aria-label']}
82
81
  size="sm"
83
82
  filled={isModern}
84
83
  onClick={onRemove}
@@ -1,5 +1,4 @@
1
1
  import classNames from 'classnames';
2
- import { ReactElement } from 'react';
3
2
  import { useIntl } from 'react-intl';
4
3
 
5
4
  import { CommonProps, AriaLabelProperty } from '../common';
@@ -39,7 +38,7 @@ const Chips = ({
39
38
  'aria-label': ariaLabel,
40
39
  className,
41
40
  multiple,
42
- }: ChipsProps): ReactElement => {
41
+ }: ChipsProps) => {
43
42
  const intl = useIntl();
44
43
 
45
44
  const isSelected = (value: ChipValue) =>
@@ -1,12 +1,5 @@
1
1
  import classNames from 'classnames';
2
- import {
3
- useRef,
4
- useState,
5
- ReactElement,
6
- PropsWithChildren,
7
- CSSProperties,
8
- SyntheticEvent,
9
- } from 'react';
2
+ import { useRef, useState, PropsWithChildren, CSSProperties, SyntheticEvent } from 'react';
10
3
 
11
4
  import Dimmer from '../../dimmer';
12
5
  import Drawer from '../../drawer';
@@ -38,7 +31,7 @@ export type BottomSheetProps = PropsWithChildren<
38
31
  * Neptune Web: https://transferwise.github.io/neptune-web/components/overlays/BottomSheet
39
32
  *
40
33
  */
41
- const BottomSheet = (props: BottomSheetProps): ReactElement => {
34
+ const BottomSheet = (props: BottomSheetProps) => {
42
35
  const bottomSheetReference = useRef<HTMLDivElement>(null);
43
36
  const topBarReference = useRef<HTMLDivElement>(null);
44
37
  const contentReference = useRef<HTMLDivElement>(null);
@@ -27,7 +27,7 @@ export const CloseButton = forwardRef(function CloseButton(
27
27
  isDisabled,
28
28
  testId,
29
29
  }: CloseButtonProps,
30
- reference: React.ForwardedRef<HTMLButtonElement>,
30
+ reference: React.ForwardedRef<HTMLButtonElement | null>,
31
31
  ) {
32
32
  const intl = useIntl();
33
33
  ariaLabel ??= intl.formatMessage(messages.ariaLabel);
@@ -20,7 +20,7 @@ const FlowHeader = React.forwardRef(
20
20
  leftContent,
21
21
  rightContent,
22
22
  }: FlowHeaderProps,
23
- reference: React.ForwardedRef<HTMLDivElement>,
23
+ reference: React.ForwardedRef<HTMLDivElement | null>,
24
24
  ) => {
25
25
  const isVertical = layout === Layout.VERTICAL;
26
26
 
@@ -3,7 +3,7 @@ import { useEffect } from 'react';
3
3
  import { useEffectEvent } from './useEffectEvent';
4
4
 
5
5
  export function useResizeObserver(
6
- ref: React.RefObject<Element>,
6
+ ref: React.MutableRefObject<Element | null>,
7
7
  callback: (entry: ResizeObserverEntry) => void,
8
8
  ) {
9
9
  const handleCallback = useEffectEvent(callback);
@@ -6,7 +6,7 @@ import { render } from '../../test-utils';
6
6
  import Panel from './Panel';
7
7
  import type { PanelProps } from './Panel';
8
8
 
9
- const mockAnchorRef: React.RefObject<HTMLAnchorElement> = {
9
+ const mockAnchorRef: React.MutableRefObject<HTMLAnchorElement | null> = {
10
10
  current: document.createElement('a'),
11
11
  };
12
12
 
@@ -1,13 +1,13 @@
1
1
  import classnames from 'classnames';
2
2
  import {
3
- useState,
4
- forwardRef,
5
- useEffect,
3
+ CSSProperties,
4
+ HTMLAttributes,
5
+ MutableRefObject,
6
6
  PropsWithChildren,
7
- RefObject,
8
7
  SyntheticEvent,
9
- HTMLAttributes,
10
- CSSProperties,
8
+ forwardRef,
9
+ useEffect,
10
+ useState,
11
11
  } from 'react';
12
12
  import { usePopper } from 'react-popper';
13
13
 
@@ -33,7 +33,7 @@ export type PanelProps = PropsWithChildren<{
33
33
  open?: boolean;
34
34
  onClose?: (event: Event | SyntheticEvent) => void;
35
35
  position?: PositionBottom | PositionLeft | PositionRight | PositionTop;
36
- anchorRef: RefObject<Element>;
36
+ anchorRef: MutableRefObject<Element | null>;
37
37
  anchorWidth?: boolean;
38
38
  }> &
39
39
  HTMLAttributes<HTMLDivElement>;
@@ -13,7 +13,7 @@ export interface PolymorphicWithOverridesProps {
13
13
  */
14
14
  export const PolymorphicWithOverrides = forwardRef(function PolymorphicWithOverrides(
15
15
  { __overrides: { as: Element, ...restOverrides }, ...restProps }: PolymorphicWithOverridesProps,
16
- ref: React.ForwardedRef<Element>,
16
+ ref: React.ForwardedRef<Element | null>,
17
17
  ) {
18
18
  return <Element ref={ref} {...restProps} {...restOverrides} />;
19
19
  });
@@ -14,7 +14,7 @@ interface DecisionOption {
14
14
  block: React.ReactNode;
15
15
  list: React.ReactNode;
16
16
  };
17
- onClick?: React.MouseEventHandler<HTMLElement>;
17
+ onClick?: (event?: React.MouseEvent<HTMLElement>) => void;
18
18
  title: React.ReactNode;
19
19
  }
20
20
 
@@ -30,14 +30,34 @@ const definitions = [
30
30
 
31
31
  export const Basic = () => {
32
32
  const muted = boolean('muted', false);
33
- const layout = select('layout', Object.values(Layout), Layout.HORIZONTAL_LEFT_ALIGNED);
33
+ const layout = select(
34
+ 'layout',
35
+ [
36
+ Layout.VERTICAL_TWO_COLUMN,
37
+ Layout.VERTICAL_ONE_COLUMN,
38
+ Layout.HORIZONTAL_JUSTIFIED,
39
+ Layout.HORIZONTAL_LEFT_ALIGNED,
40
+ Layout.HORIZONTAL_RIGHT_ALIGNED,
41
+ ],
42
+ Layout.HORIZONTAL_LEFT_ALIGNED,
43
+ );
34
44
 
35
45
  return <DefinitionList layout={layout} muted={muted} definitions={definitions} />;
36
46
  };
37
47
 
38
48
  export const WithActionButtons = () => {
39
49
  const muted = boolean('muted', false);
40
- const layout = select('layout', Object.values(Layout), Layout.HORIZONTAL_LEFT_ALIGNED);
50
+ const layout = select(
51
+ 'layout',
52
+ [
53
+ Layout.VERTICAL_TWO_COLUMN,
54
+ Layout.VERTICAL_ONE_COLUMN,
55
+ Layout.HORIZONTAL_JUSTIFIED,
56
+ Layout.HORIZONTAL_LEFT_ALIGNED,
57
+ Layout.HORIZONTAL_RIGHT_ALIGNED,
58
+ ],
59
+ Layout.HORIZONTAL_LEFT_ALIGNED,
60
+ );
41
61
 
42
62
  return (
43
63
  <DefinitionList
@@ -0,0 +1,95 @@
1
+ import classNames from 'classnames';
2
+
3
+ import ActionButton from '../actionButton';
4
+ import { Layout } from '../common';
5
+
6
+ interface Definition {
7
+ action?: {
8
+ label: string;
9
+ onClick?: React.MouseEventHandler<HTMLButtonElement>;
10
+ };
11
+ title: React.ReactNode;
12
+ value: React.ReactNode;
13
+ key: string;
14
+ }
15
+
16
+ type DefinitionListLayout =
17
+ `${Layout.VERTICAL_TWO_COLUMN | Layout.VERTICAL_ONE_COLUMN | Layout.HORIZONTAL_JUSTIFIED | Layout.HORIZONTAL_LEFT_ALIGNED | Layout.HORIZONTAL_RIGHT_ALIGNED}`;
18
+
19
+ export interface DefinitionListProps {
20
+ definitions?: Definition[];
21
+ layout?: DefinitionListLayout;
22
+ muted?: boolean;
23
+ }
24
+
25
+ const isLayoutHorizontal = (layout: DefinitionListLayout) =>
26
+ layout === Layout.HORIZONTAL_LEFT_ALIGNED ||
27
+ layout === Layout.HORIZONTAL_RIGHT_ALIGNED ||
28
+ layout === Layout.HORIZONTAL_JUSTIFIED;
29
+
30
+ const getAlignmentClasses = (layout: DefinitionListLayout, action: Definition['action']) => {
31
+ const classes = ['d-flex'];
32
+
33
+ if (action) {
34
+ if (isLayoutHorizontal(layout)) {
35
+ classes.push('align-items-center');
36
+ } else {
37
+ classes.push('align-items-start');
38
+ }
39
+ }
40
+
41
+ if (layout === Layout.HORIZONTAL_RIGHT_ALIGNED) {
42
+ classes.push('text-sm-right tw-definition-list--right-aligned-desktop');
43
+ } else {
44
+ classes.push('justify-content-between');
45
+ }
46
+
47
+ if (layout === Layout.HORIZONTAL_JUSTIFIED) {
48
+ classes.push('text-sm-justify');
49
+ }
50
+
51
+ return classes;
52
+ };
53
+
54
+ const defaultDefinitions = [] satisfies DefinitionListProps['definitions'];
55
+
56
+ export default function DefinitionList({
57
+ definitions = defaultDefinitions,
58
+ layout = 'VERTICAL_TWO_COLUMN',
59
+ muted,
60
+ }: DefinitionListProps) {
61
+ return (
62
+ <dl
63
+ className={classNames('tw-definition-list d-flex ', {
64
+ 'text-muted': muted,
65
+ 'flex-column': layout === Layout.VERTICAL_ONE_COLUMN,
66
+ 'tw-definition-list--columns flex-column flex-row--sm':
67
+ layout === Layout.VERTICAL_TWO_COLUMN,
68
+ 'tw-definition-list--horizontal flex-column': isLayoutHorizontal(layout),
69
+ })}
70
+ >
71
+ {definitions
72
+ .filter((definition) => definition)
73
+ .map(({ action, title, value, key }) => (
74
+ <div key={key} className="tw-definition-list__item">
75
+ <dt>{title}</dt>
76
+ <dd className={classNames(...getAlignmentClasses(layout, action))}>
77
+ <div>{value}</div>
78
+ {action ? (
79
+ <div
80
+ className={classNames(
81
+ isLayoutHorizontal(layout) ? 'p-l-2' : 'p-x-2',
82
+ 'tw-definition-list__action',
83
+ )}
84
+ >
85
+ <ActionButton className="tw-definition-list__button" onClick={action.onClick}>
86
+ {action.label}
87
+ </ActionButton>
88
+ </div>
89
+ ) : null}
90
+ </dd>
91
+ </div>
92
+ ))}
93
+ </dl>
94
+ );
95
+ }
@@ -0,0 +1,2 @@
1
+ export { default } from './DefinitionList';
2
+ export type { DefinitionListProps } from './DefinitionList';
@@ -1,14 +1,6 @@
1
1
  import { ThemeProvider, useTheme } from '@wise/components-theming';
2
2
  import classNames from 'classnames';
3
- import {
4
- MouseEvent,
5
- ReactElement,
6
- ReactNode,
7
- useCallback,
8
- useEffect,
9
- useRef,
10
- useState,
11
- } from 'react';
3
+ import { MouseEvent, ReactNode, useCallback, useEffect, useRef, useState } from 'react';
12
4
  import { CSSTransition } from 'react-transition-group';
13
5
 
14
6
  import {
@@ -203,7 +195,7 @@ export const DimmerContentWrapper = ({
203
195
  children,
204
196
  scrollBody,
205
197
  }: {
206
- children: ReactElement;
198
+ children: React.ReactElement;
207
199
  scrollBody: boolean;
208
200
  }) => {
209
201
  useEffect(() => {
@@ -1,3 +1,5 @@
1
+ import { DimmerProps } from '../dimmer';
2
+ import { SlidingPanelProps } from '../slidingPanel';
1
3
  import { mockMatchMedia, render, screen, userEvent } from '../test-utils';
2
4
 
3
5
  import Drawer from './Drawer';
@@ -7,7 +9,7 @@ mockMatchMedia();
7
9
  jest.mock(
8
10
  '../dimmer',
9
11
  () =>
10
- function ({ open, children }) {
12
+ function Dimmer({ open, children }: DimmerProps) {
11
13
  return open ? <div className="dimmer">{children}</div> : null;
12
14
  },
13
15
  );
@@ -15,7 +17,7 @@ jest.mock(
15
17
  jest.mock(
16
18
  '../slidingPanel',
17
19
  () =>
18
- function ({ open, children }) {
20
+ function SlidingPanel({ open, children }: SlidingPanelProps) {
19
21
  return open ? <div className="sliding-panel">{children}</div> : null;
20
22
  },
21
23
  );
@@ -3,7 +3,6 @@ import { useState } from 'react';
3
3
 
4
4
  import { Section, Button, Input, Modal } from '..';
5
5
  import { Position, Priority } from '../common';
6
- import { storyConfig } from '../test-utils';
7
6
 
8
7
  import Drawer from './Drawer';
9
8
 
@@ -17,18 +16,6 @@ export const Basic = () => {
17
16
  const [openModal, setOpenModal] = useState(false);
18
17
  const position = select('position', [Position.LEFT, Position.RIGHT], Position.RIGHT);
19
18
 
20
- const handleDrawerClose = (event) => {
21
- console.log('drawer close');
22
- event.stopPropagation();
23
- setOpenDrawer(false);
24
- };
25
-
26
- const handleModalClose = (event) => {
27
- console.log('modal close');
28
- event.stopPropagation();
29
- setOpenModal(false);
30
- };
31
-
32
19
  return (
33
20
  <>
34
21
  <Button disabled={false} block={false} onClick={() => setOpenDrawer(true)}>
@@ -48,7 +35,11 @@ export const Basic = () => {
48
35
  </Button>
49
36
  </>
50
37
  }
51
- onClose={handleDrawerClose}
38
+ onClose={(event) => {
39
+ console.log('drawer close');
40
+ event.stopPropagation();
41
+ setOpenDrawer(false);
42
+ }}
52
43
  >
53
44
  <p>
54
45
  I am baby actually poke kickstarter, street art jean shorts bespoke chambray activated
@@ -62,23 +53,24 @@ export const Basic = () => {
62
53
  <Button onClick={() => setOpenModal(true)}>Open Modal</Button>
63
54
  <Modal
64
55
  body={
65
- <>
66
- <p className="m-t-4">
67
- I am baby actually poke kickstarter, street art jean shorts bespoke chambray
68
- activated charcoal ramps marfa shoreditch tumeric tumblr. Mixtape cred palo santo,
69
- cliche lyft marfa ethical waistcoat poke jean shorts. Scenester readymade selvage
70
- disrupt pok pok. La croix stumptown try-hard chartreuse. I am baby actually poke
71
- kickstarter, street art jean shorts bespoke chambray activated charcoal ramps
72
- marfa shoreditch tumeric, I am baby actually poke kickstarter, street art jean
73
- shorts bespoke chambray activated charcoal ramps marfa shoreditch tumeric tumblr.
74
- Mixtape cred palo santo, cliche lyft marfa ethical waistcoat poke jean shorts.
75
- Scenester readymade selvage disrupt pok pok.
76
- </p>
77
- </>
56
+ <p className="m-t-4">
57
+ I am baby actually poke kickstarter, street art jean shorts bespoke chambray
58
+ activated charcoal ramps marfa shoreditch tumeric tumblr. Mixtape cred palo santo,
59
+ cliche lyft marfa ethical waistcoat poke jean shorts. Scenester readymade selvage
60
+ disrupt pok pok. La croix stumptown try-hard chartreuse. I am baby actually poke
61
+ kickstarter, street art jean shorts bespoke chambray activated charcoal ramps marfa
62
+ shoreditch tumeric, I am baby actually poke kickstarter, street art jean shorts
63
+ bespoke chambray activated charcoal ramps marfa shoreditch tumeric tumblr. Mixtape
64
+ cred palo santo, cliche lyft marfa ethical waistcoat poke jean shorts. Scenester
65
+ readymade selvage disrupt pok pok.
66
+ </p>
78
67
  }
79
68
  open={openModal}
80
69
  title="Title"
81
- onClose={handleModalClose}
70
+ onClose={() => {
71
+ console.log('modal close');
72
+ setOpenModal(false);
73
+ }}
82
74
  />
83
75
  </Section>
84
76
  <p>