@transferwise/components 46.78.0 → 46.79.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 (388) hide show
  1. package/build/accordion/AccordionItem/AccordionItem.js +22 -3
  2. package/build/accordion/AccordionItem/AccordionItem.js.map +1 -1
  3. package/build/accordion/AccordionItem/AccordionItem.mjs +22 -3
  4. package/build/accordion/AccordionItem/AccordionItem.mjs.map +1 -1
  5. package/build/actionButton/ActionButton.js +22 -1
  6. package/build/actionButton/ActionButton.js.map +1 -1
  7. package/build/actionButton/ActionButton.mjs +22 -1
  8. package/build/actionButton/ActionButton.mjs.map +1 -1
  9. package/build/actionOption/ActionOption.js +24 -2
  10. package/build/actionOption/ActionOption.js.map +1 -1
  11. package/build/actionOption/ActionOption.mjs +24 -2
  12. package/build/actionOption/ActionOption.mjs.map +1 -1
  13. package/build/alert/Alert.js +22 -6
  14. package/build/alert/Alert.js.map +1 -1
  15. package/build/alert/Alert.mjs +22 -6
  16. package/build/alert/Alert.mjs.map +1 -1
  17. package/build/alert/inlineMarkdown/InlineMarkdown.js +25 -2
  18. package/build/alert/inlineMarkdown/InlineMarkdown.js.map +1 -1
  19. package/build/alert/inlineMarkdown/InlineMarkdown.mjs +25 -2
  20. package/build/alert/inlineMarkdown/InlineMarkdown.mjs.map +1 -1
  21. package/build/avatar/Avatar.js +23 -2
  22. package/build/avatar/Avatar.js.map +1 -1
  23. package/build/avatar/Avatar.mjs +23 -2
  24. package/build/avatar/Avatar.mjs.map +1 -1
  25. package/build/avatarWrapper/AvatarWrapper.js +23 -3
  26. package/build/avatarWrapper/AvatarWrapper.js.map +1 -1
  27. package/build/avatarWrapper/AvatarWrapper.mjs +23 -3
  28. package/build/avatarWrapper/AvatarWrapper.mjs.map +1 -1
  29. package/build/badge/Badge.js +23 -2
  30. package/build/badge/Badge.js.map +1 -1
  31. package/build/badge/Badge.mjs +23 -2
  32. package/build/badge/Badge.mjs.map +1 -1
  33. package/build/button/Button.js +22 -6
  34. package/build/button/Button.js.map +1 -1
  35. package/build/button/Button.messages.js.map +1 -1
  36. package/build/button/Button.messages.mjs.map +1 -1
  37. package/build/button/Button.mjs +22 -6
  38. package/build/button/Button.mjs.map +1 -1
  39. package/build/button/classMap.js +24 -0
  40. package/build/button/classMap.js.map +1 -1
  41. package/build/button/classMap.mjs +24 -0
  42. package/build/button/classMap.mjs.map +1 -1
  43. package/build/button/legacyUtils/legacyUtils.js +30 -7
  44. package/build/button/legacyUtils/legacyUtils.js.map +1 -1
  45. package/build/button/legacyUtils/legacyUtils.mjs +30 -7
  46. package/build/button/legacyUtils/legacyUtils.mjs.map +1 -1
  47. package/build/card/Card.js +23 -3
  48. package/build/card/Card.js.map +1 -1
  49. package/build/card/Card.mjs +23 -3
  50. package/build/card/Card.mjs.map +1 -1
  51. package/build/checkbox/Checkbox.js +23 -1
  52. package/build/checkbox/Checkbox.js.map +1 -1
  53. package/build/checkbox/Checkbox.mjs +23 -1
  54. package/build/checkbox/Checkbox.mjs.map +1 -1
  55. package/build/checkboxOption/CheckboxOption.js +1 -1
  56. package/build/checkboxOption/CheckboxOption.mjs +1 -1
  57. package/build/chevron/Chevron.js +21 -1
  58. package/build/chevron/Chevron.js.map +1 -1
  59. package/build/chevron/Chevron.mjs +21 -1
  60. package/build/chevron/Chevron.mjs.map +1 -1
  61. package/build/chips/Chip.js +19 -1
  62. package/build/chips/Chip.js.map +1 -1
  63. package/build/chips/Chip.mjs +19 -1
  64. package/build/chips/Chip.mjs.map +1 -1
  65. package/build/circularButton/CircularButton.js +23 -4
  66. package/build/circularButton/CircularButton.js.map +1 -1
  67. package/build/circularButton/CircularButton.mjs +23 -4
  68. package/build/circularButton/CircularButton.mjs.map +1 -1
  69. package/build/common/bottomSheet/BottomSheet.js +3 -2
  70. package/build/common/bottomSheet/BottomSheet.js.map +1 -1
  71. package/build/common/bottomSheet/BottomSheet.mjs +3 -2
  72. package/build/common/bottomSheet/BottomSheet.mjs.map +1 -1
  73. package/build/common/hooks/useHasIntersected/useHasIntersected.js +10 -10
  74. package/build/common/hooks/useHasIntersected/useHasIntersected.js.map +1 -1
  75. package/build/common/hooks/useHasIntersected/useHasIntersected.mjs +10 -10
  76. package/build/common/hooks/useHasIntersected/useHasIntersected.mjs.map +1 -1
  77. package/build/common/locale/index.js +24 -0
  78. package/build/common/locale/index.js.map +1 -1
  79. package/build/common/locale/index.mjs +24 -0
  80. package/build/common/locale/index.mjs.map +1 -1
  81. package/build/common/panel/Panel.js +23 -2
  82. package/build/common/panel/Panel.js.map +1 -1
  83. package/build/common/panel/Panel.mjs +23 -2
  84. package/build/common/panel/Panel.mjs.map +1 -1
  85. package/build/common/responsivePanel/ResponsivePanel.js +27 -3
  86. package/build/common/responsivePanel/ResponsivePanel.js.map +1 -1
  87. package/build/common/responsivePanel/ResponsivePanel.mjs +27 -3
  88. package/build/common/responsivePanel/ResponsivePanel.mjs.map +1 -1
  89. package/build/criticalBanner/CriticalCommsBanner.js +22 -3
  90. package/build/criticalBanner/CriticalCommsBanner.js.map +1 -1
  91. package/build/criticalBanner/CriticalCommsBanner.mjs +22 -3
  92. package/build/criticalBanner/CriticalCommsBanner.mjs.map +1 -1
  93. package/build/dateInput/DateInput.js +22 -5
  94. package/build/dateInput/DateInput.js.map +1 -1
  95. package/build/dateInput/DateInput.mjs +22 -5
  96. package/build/dateInput/DateInput.mjs.map +1 -1
  97. package/build/dateLookup/DateLookup.js +24 -6
  98. package/build/dateLookup/DateLookup.js.map +1 -1
  99. package/build/dateLookup/DateLookup.mjs +24 -6
  100. package/build/dateLookup/DateLookup.mjs.map +1 -1
  101. package/build/dateLookup/dateHeader/DateHeader.js +26 -5
  102. package/build/dateLookup/dateHeader/DateHeader.js.map +1 -1
  103. package/build/dateLookup/dateHeader/DateHeader.mjs +26 -5
  104. package/build/dateLookup/dateHeader/DateHeader.mjs.map +1 -1
  105. package/build/dateLookup/dateTrigger/DateTrigger.js +19 -3
  106. package/build/dateLookup/dateTrigger/DateTrigger.js.map +1 -1
  107. package/build/dateLookup/dateTrigger/DateTrigger.mjs +19 -3
  108. package/build/dateLookup/dateTrigger/DateTrigger.mjs.map +1 -1
  109. package/build/decision/Decision.js +24 -3
  110. package/build/decision/Decision.js.map +1 -1
  111. package/build/decision/Decision.mjs +24 -3
  112. package/build/decision/Decision.mjs.map +1 -1
  113. package/build/definitionList/DefinitionList.js +23 -1
  114. package/build/definitionList/DefinitionList.js.map +1 -1
  115. package/build/definitionList/DefinitionList.mjs +23 -1
  116. package/build/definitionList/DefinitionList.mjs.map +1 -1
  117. package/build/dimmer/Dimmer.js +24 -2
  118. package/build/dimmer/Dimmer.js.map +1 -1
  119. package/build/dimmer/Dimmer.mjs +24 -2
  120. package/build/dimmer/Dimmer.mjs.map +1 -1
  121. package/build/display/Display.js +23 -1
  122. package/build/display/Display.js.map +1 -1
  123. package/build/display/Display.mjs +23 -1
  124. package/build/display/Display.mjs.map +1 -1
  125. package/build/drawer/Drawer.js +23 -4
  126. package/build/drawer/Drawer.js.map +1 -1
  127. package/build/drawer/Drawer.mjs +23 -4
  128. package/build/drawer/Drawer.mjs.map +1 -1
  129. package/build/field/Field.js +23 -2
  130. package/build/field/Field.js.map +1 -1
  131. package/build/field/Field.mjs +23 -2
  132. package/build/field/Field.mjs.map +1 -1
  133. package/build/flowNavigation/FlowNavigation.js +19 -2
  134. package/build/flowNavigation/FlowNavigation.js.map +1 -1
  135. package/build/flowNavigation/FlowNavigation.mjs +19 -2
  136. package/build/flowNavigation/FlowNavigation.mjs.map +1 -1
  137. package/build/header/Header.js +24 -2
  138. package/build/header/Header.js.map +1 -1
  139. package/build/header/Header.mjs +24 -2
  140. package/build/header/Header.mjs.map +1 -1
  141. package/build/image/Image.js +4 -1
  142. package/build/image/Image.js.map +1 -1
  143. package/build/image/Image.mjs +4 -1
  144. package/build/image/Image.mjs.map +1 -1
  145. package/build/index.js +69 -62
  146. package/build/index.js.map +1 -1
  147. package/build/index.mjs +27 -20
  148. package/build/index.mjs.map +1 -1
  149. package/build/info/Info.js +21 -3
  150. package/build/info/Info.js.map +1 -1
  151. package/build/info/Info.mjs +21 -3
  152. package/build/info/Info.mjs.map +1 -1
  153. package/build/inlineAlert/InlineAlert.js +24 -3
  154. package/build/inlineAlert/InlineAlert.js.map +1 -1
  155. package/build/inlineAlert/InlineAlert.mjs +24 -3
  156. package/build/inlineAlert/InlineAlert.mjs.map +1 -1
  157. package/build/inputs/SearchInput.js +23 -2
  158. package/build/inputs/SearchInput.js.map +1 -1
  159. package/build/inputs/SearchInput.mjs +23 -2
  160. package/build/inputs/SearchInput.mjs.map +1 -1
  161. package/build/instructionsList/InstructionsList.js +22 -1
  162. package/build/instructionsList/InstructionsList.js.map +1 -1
  163. package/build/instructionsList/InstructionsList.mjs +22 -1
  164. package/build/instructionsList/InstructionsList.mjs.map +1 -1
  165. package/build/loader/Loader.js +22 -1
  166. package/build/loader/Loader.js.map +1 -1
  167. package/build/loader/Loader.mjs +22 -1
  168. package/build/loader/Loader.mjs.map +1 -1
  169. package/build/markdown/Markdown.js +24 -1
  170. package/build/markdown/Markdown.js.map +1 -1
  171. package/build/markdown/Markdown.mjs +24 -1
  172. package/build/markdown/Markdown.mjs.map +1 -1
  173. package/build/modal/Modal.js +22 -5
  174. package/build/modal/Modal.js.map +1 -1
  175. package/build/modal/Modal.mjs +22 -5
  176. package/build/modal/Modal.mjs.map +1 -1
  177. package/build/moneyInput/MoneyInput.js +22 -3
  178. package/build/moneyInput/MoneyInput.js.map +1 -1
  179. package/build/moneyInput/MoneyInput.mjs +22 -3
  180. package/build/moneyInput/MoneyInput.mjs.map +1 -1
  181. package/build/navigationOption/NavigationOption.js +23 -2
  182. package/build/navigationOption/NavigationOption.js.map +1 -1
  183. package/build/navigationOption/NavigationOption.mjs +23 -2
  184. package/build/navigationOption/NavigationOption.mjs.map +1 -1
  185. package/build/nudge/Nudge.js +19 -1
  186. package/build/nudge/Nudge.js.map +1 -1
  187. package/build/nudge/Nudge.mjs +19 -1
  188. package/build/nudge/Nudge.mjs.map +1 -1
  189. package/build/overlayHeader/OverlayHeader.js +19 -1
  190. package/build/overlayHeader/OverlayHeader.js.map +1 -1
  191. package/build/overlayHeader/OverlayHeader.mjs +19 -1
  192. package/build/overlayHeader/OverlayHeader.mjs.map +1 -1
  193. package/build/phoneNumberInput/PhoneNumberInput.js +23 -2
  194. package/build/phoneNumberInput/PhoneNumberInput.js.map +1 -1
  195. package/build/phoneNumberInput/PhoneNumberInput.mjs +23 -2
  196. package/build/phoneNumberInput/PhoneNumberInput.mjs.map +1 -1
  197. package/build/popover/Popover.js +24 -4
  198. package/build/popover/Popover.js.map +1 -1
  199. package/build/popover/Popover.mjs +24 -4
  200. package/build/popover/Popover.mjs.map +1 -1
  201. package/build/processIndicator/ProcessIndicator.js +22 -1
  202. package/build/processIndicator/ProcessIndicator.js.map +1 -1
  203. package/build/processIndicator/ProcessIndicator.mjs +22 -1
  204. package/build/processIndicator/ProcessIndicator.mjs.map +1 -1
  205. package/build/progressBar/ProgressBar.js +24 -2
  206. package/build/progressBar/ProgressBar.js.map +1 -1
  207. package/build/progressBar/ProgressBar.mjs +24 -2
  208. package/build/progressBar/ProgressBar.mjs.map +1 -1
  209. package/build/promoCard/PromoCard.js +22 -2
  210. package/build/promoCard/PromoCard.js.map +1 -1
  211. package/build/promoCard/PromoCard.mjs +22 -2
  212. package/build/promoCard/PromoCard.mjs.map +1 -1
  213. package/build/promoCard/PromoCardIndicator.js +22 -1
  214. package/build/promoCard/PromoCardIndicator.js.map +1 -1
  215. package/build/promoCard/PromoCardIndicator.mjs +22 -1
  216. package/build/promoCard/PromoCardIndicator.mjs.map +1 -1
  217. package/build/provider/Provider.js +25 -2
  218. package/build/provider/Provider.js.map +1 -1
  219. package/build/provider/Provider.mjs +25 -2
  220. package/build/provider/Provider.mjs.map +1 -1
  221. package/build/radio/Radio.js +24 -2
  222. package/build/radio/Radio.js.map +1 -1
  223. package/build/radio/Radio.mjs +24 -2
  224. package/build/radio/Radio.mjs.map +1 -1
  225. package/build/segmentedControl/SegmentedControl.js +22 -1
  226. package/build/segmentedControl/SegmentedControl.js.map +1 -1
  227. package/build/segmentedControl/SegmentedControl.mjs +22 -1
  228. package/build/segmentedControl/SegmentedControl.mjs.map +1 -1
  229. package/build/select/Select.js +26 -4
  230. package/build/select/Select.js.map +1 -1
  231. package/build/select/Select.mjs +26 -4
  232. package/build/select/Select.mjs.map +1 -1
  233. package/build/select/option/Option.js +22 -1
  234. package/build/select/option/Option.js.map +1 -1
  235. package/build/select/option/Option.mjs +22 -1
  236. package/build/select/option/Option.mjs.map +1 -1
  237. package/build/selectOption/SelectOption.js +24 -6
  238. package/build/selectOption/SelectOption.js.map +1 -1
  239. package/build/selectOption/SelectOption.mjs +24 -6
  240. package/build/selectOption/SelectOption.mjs.map +1 -1
  241. package/build/statusIcon/StatusIcon.js +22 -4
  242. package/build/statusIcon/StatusIcon.js.map +1 -1
  243. package/build/statusIcon/StatusIcon.mjs +22 -4
  244. package/build/statusIcon/StatusIcon.mjs.map +1 -1
  245. package/build/stepper/Stepper.js +25 -3
  246. package/build/stepper/Stepper.js.map +1 -1
  247. package/build/stepper/Stepper.mjs +25 -3
  248. package/build/stepper/Stepper.mjs.map +1 -1
  249. package/build/stepper/deviceDetection.js +2 -3
  250. package/build/stepper/deviceDetection.js.map +1 -1
  251. package/build/stepper/deviceDetection.mjs +2 -3
  252. package/build/stepper/deviceDetection.mjs.map +1 -1
  253. package/build/sticky/Sticky.js +25 -2
  254. package/build/sticky/Sticky.js.map +1 -1
  255. package/build/sticky/Sticky.mjs +25 -2
  256. package/build/sticky/Sticky.mjs.map +1 -1
  257. package/build/summary/Summary.js +21 -5
  258. package/build/summary/Summary.js.map +1 -1
  259. package/build/summary/Summary.mjs +21 -5
  260. package/build/summary/Summary.mjs.map +1 -1
  261. package/build/tabs/Tabs.js +23 -3
  262. package/build/tabs/Tabs.js.map +1 -1
  263. package/build/tabs/Tabs.mjs +23 -3
  264. package/build/tabs/Tabs.mjs.map +1 -1
  265. package/build/tile/Tile.js +24 -2
  266. package/build/tile/Tile.js.map +1 -1
  267. package/build/tile/Tile.mjs +24 -2
  268. package/build/tile/Tile.mjs.map +1 -1
  269. package/build/title/Title.js +23 -1
  270. package/build/title/Title.js.map +1 -1
  271. package/build/title/Title.mjs +23 -1
  272. package/build/title/Title.mjs.map +1 -1
  273. package/build/tooltip/Tooltip.js +22 -1
  274. package/build/tooltip/Tooltip.js.map +1 -1
  275. package/build/tooltip/Tooltip.mjs +22 -1
  276. package/build/tooltip/Tooltip.mjs.map +1 -1
  277. package/build/typeahead/Typeahead.js +22 -4
  278. package/build/typeahead/Typeahead.js.map +1 -1
  279. package/build/typeahead/Typeahead.mjs +22 -4
  280. package/build/typeahead/Typeahead.mjs.map +1 -1
  281. package/build/types/button/Button.d.ts.map +1 -1
  282. package/build/types/button/Button.messages.d.ts +7 -7
  283. package/build/types/button/Button.messages.d.ts.map +1 -1
  284. package/build/types/button/classMap.d.ts +10 -10
  285. package/build/types/button/classMap.d.ts.map +1 -1
  286. package/build/types/button/legacyUtils/index.d.ts +1 -1
  287. package/build/types/button/legacyUtils/index.d.ts.map +1 -1
  288. package/build/types/button/legacyUtils/legacyUtils.d.ts +20 -6
  289. package/build/types/button/legacyUtils/legacyUtils.d.ts.map +1 -1
  290. package/build/types/checkboxButton/index.d.ts +1 -1
  291. package/build/types/checkboxButton/index.d.ts.map +1 -1
  292. package/build/types/common/fakeEvents.d.ts +23 -0
  293. package/build/types/common/fakeEvents.d.ts.map +1 -0
  294. package/build/types/common/hooks/index.d.ts +4 -4
  295. package/build/types/common/hooks/index.d.ts.map +1 -1
  296. package/build/types/common/hooks/useConditionalListener/index.d.ts +1 -1
  297. package/build/types/common/hooks/useConditionalListener/index.d.ts.map +1 -1
  298. package/build/types/common/hooks/useDirection/index.d.ts +1 -1
  299. package/build/types/common/hooks/useDirection/index.d.ts.map +1 -1
  300. package/build/types/common/hooks/useHasIntersected/index.d.ts +1 -1
  301. package/build/types/common/hooks/useHasIntersected/index.d.ts.map +1 -1
  302. package/build/types/common/hooks/useHasIntersected/useHasIntersected.d.ts +15 -4
  303. package/build/types/common/hooks/useHasIntersected/useHasIntersected.d.ts.map +1 -1
  304. package/build/types/common/index.d.ts +28 -28
  305. package/build/types/common/index.d.ts.map +1 -1
  306. package/build/types/common/responsivePanel/index.d.ts +1 -1
  307. package/build/types/common/responsivePanel/index.d.ts.map +1 -1
  308. package/build/types/index.d.ts +1 -0
  309. package/build/types/index.d.ts.map +1 -1
  310. package/build/types/navigationOption/NavigationOption.d.ts +1 -0
  311. package/build/types/navigationOption/NavigationOption.d.ts.map +1 -1
  312. package/build/types/stepper/deviceDetection.d.ts +1 -1
  313. package/build/types/stepper/deviceDetection.d.ts.map +1 -1
  314. package/build/types/test-utils/style-mock.d.ts +1 -0
  315. package/build/types/test-utils/style-mock.d.ts.map +1 -0
  316. package/build/types/utilities/deprecatedProperty/deprecatedProperty.d.ts +8 -6
  317. package/build/types/utilities/deprecatedProperty/deprecatedProperty.d.ts.map +1 -1
  318. package/build/types/utilities/deprecatedProperty/index.d.ts +1 -1
  319. package/build/types/utilities/deprecatedProperty/index.d.ts.map +1 -1
  320. package/build/types/utilities/index.d.ts +2 -2
  321. package/build/types/utilities/index.d.ts.map +1 -1
  322. package/build/types/utilities/logActionRequired.d.ts +2 -2
  323. package/build/types/utilities/logActionRequired.d.ts.map +1 -1
  324. package/build/upload/Upload.js +21 -2
  325. package/build/upload/Upload.js.map +1 -1
  326. package/build/upload/Upload.mjs +21 -2
  327. package/build/upload/Upload.mjs.map +1 -1
  328. package/build/upload/steps/processingStep/processingStep.js +25 -3
  329. package/build/upload/steps/processingStep/processingStep.js.map +1 -1
  330. package/build/upload/steps/processingStep/processingStep.mjs +25 -3
  331. package/build/upload/steps/processingStep/processingStep.mjs.map +1 -1
  332. package/build/upload/steps/uploadImageStep/uploadImageStep.js +23 -3
  333. package/build/upload/steps/uploadImageStep/uploadImageStep.js.map +1 -1
  334. package/build/upload/steps/uploadImageStep/uploadImageStep.mjs +23 -3
  335. package/build/upload/steps/uploadImageStep/uploadImageStep.mjs.map +1 -1
  336. package/build/uploadInput/UploadInput.js +22 -3
  337. package/build/uploadInput/UploadInput.js.map +1 -1
  338. package/build/uploadInput/UploadInput.mjs +22 -3
  339. package/build/uploadInput/UploadInput.mjs.map +1 -1
  340. package/build/uploadInput/uploadButton/UploadButton.js +21 -2
  341. package/build/uploadInput/uploadButton/UploadButton.js.map +1 -1
  342. package/build/uploadInput/uploadButton/UploadButton.mjs +21 -2
  343. package/build/uploadInput/uploadButton/UploadButton.mjs.map +1 -1
  344. package/build/uploadInput/uploadButton/defaults.js +24 -0
  345. package/build/uploadInput/uploadButton/defaults.js.map +1 -1
  346. package/build/uploadInput/uploadButton/defaults.mjs +24 -0
  347. package/build/uploadInput/uploadButton/defaults.mjs.map +1 -1
  348. package/build/uploadInput/uploadItem/UploadItem.js +21 -4
  349. package/build/uploadInput/uploadItem/UploadItem.js.map +1 -1
  350. package/build/uploadInput/uploadItem/UploadItem.mjs +21 -4
  351. package/build/uploadInput/uploadItem/UploadItem.mjs.map +1 -1
  352. package/build/utilities/logActionRequired.js.map +1 -1
  353. package/build/utilities/logActionRequired.mjs.map +1 -1
  354. package/build/withDisplayFormat/WithDisplayFormat.js +25 -1
  355. package/build/withDisplayFormat/WithDisplayFormat.js.map +1 -1
  356. package/build/withDisplayFormat/WithDisplayFormat.mjs +25 -1
  357. package/build/withDisplayFormat/WithDisplayFormat.mjs.map +1 -1
  358. package/package.json +2 -2
  359. package/src/button/Button.tsx +0 -3
  360. package/src/button/legacyUtils/legacyUtils.ts +74 -0
  361. package/src/common/{fakeEvents.js → fakeEvents.ts} +1 -1
  362. package/src/common/hooks/useHasIntersected/{useHasIntersected.js → useHasIntersected.ts} +20 -11
  363. package/src/flowNavigation/{FlowNavigation.story.js → FlowNavigation.story.tsx} +34 -16
  364. package/src/index.ts +1 -0
  365. package/src/inputWithDisplayFormat/InputWithDisplayFormat.story.tsx +78 -0
  366. package/src/navigationOption/{NavigationOption.story.js → NavigationOption.story.tsx} +23 -5
  367. package/src/navigationOption/NavigationOption.tsx +1 -1
  368. package/src/select/{Select.story.js → Select.story.tsx} +97 -47
  369. package/src/stepper/{deviceDetection.js → deviceDetection.ts} +2 -6
  370. package/src/utilities/deprecatedProperty/{deprecatedProperty.spec.js → deprecatedProperty.spec.ts} +7 -13
  371. package/src/utilities/deprecatedProperty/{deprecatedProperty.js → deprecatedProperty.ts} +23 -4
  372. package/src/utilities/{logActionRequired.js → logActionRequired.ts} +2 -2
  373. package/src/button/legacyUtils/legacyUtils.js +0 -54
  374. package/src/common/requirements.js +0 -440
  375. package/src/inputWithDisplayFormat/InputWithDisplayFormat.story.js +0 -85
  376. /package/src/button/{Button.messages.js → Button.messages.ts} +0 -0
  377. /package/src/button/{classMap.js → classMap.ts} +0 -0
  378. /package/src/button/legacyUtils/{index.js → index.ts} +0 -0
  379. /package/src/checkboxButton/{index.js → index.ts} +0 -0
  380. /package/src/common/hooks/{index.js → index.ts} +0 -0
  381. /package/src/common/hooks/useConditionalListener/{index.js → index.ts} +0 -0
  382. /package/src/common/hooks/useDirection/{index.js → index.ts} +0 -0
  383. /package/src/common/hooks/useHasIntersected/{index.js → index.ts} +0 -0
  384. /package/src/common/{index.js → index.ts} +0 -0
  385. /package/src/common/responsivePanel/{index.js → index.ts} +0 -0
  386. /package/src/test-utils/{style-mock.js → style-mock.ts} +0 -0
  387. /package/src/utilities/deprecatedProperty/{index.js → index.ts} +0 -0
  388. /package/src/utilities/{index.js → index.ts} +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"WithDisplayFormat.mjs","sources":["../../src/withDisplayFormat/WithDisplayFormat.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport { HistoryNavigator } from '../common';\nimport {\n formatWithPattern,\n getCountOfSymbolsInSelection,\n getCursorPositionAfterKeystroke,\n unformatWithPattern,\n getDistanceToPreviousSymbol,\n getDistanceToNextSymbol,\n} from '../common/textFormat';\nimport { InputProps } from '../inputs/Input';\nimport { TextAreaProps } from '../inputs/TextArea';\n\ntype HTMLTextElement = HTMLInputElement | HTMLTextAreaElement;\ntype TextElementProps = InputProps | TextAreaProps;\n\nexport type EventType =\n | 'KeyDown'\n | 'Paste'\n | 'Cut'\n | 'Undo'\n | 'Redo'\n | 'Backspace'\n | 'Delete'\n | 'Initial';\n\ninterface WithDisplayFormatState {\n value: string;\n historyNavigator: HistoryNavigator;\n prevDisplayPattern: string;\n triggerType: EventType;\n triggerEvent: React.KeyboardEvent<HTMLTextElement> | null;\n pastedLength: number;\n selectionStart: number;\n selectionEnd: number;\n}\n\nexport interface WithDisplayFormatProps<T extends TextElementProps = TextElementProps>\n extends Pick<\n TextElementProps,\n | 'className'\n | 'disabled'\n | 'id'\n | 'maxLength'\n | 'minLength'\n | 'name'\n | 'placeholder'\n | 'readOnly'\n | 'required'\n | 'inputMode'\n > {\n value?: string;\n displayPattern: string;\n /**\n * autocomplete hides our form help so we need to disable it when help text\n * is present. Chrome ignores autocomplete=off, the only way to disable it is\n * to provide an 'invalid' value, for which 'disabled' serves.\n */\n autoComplete?: TextElementProps['autoComplete'] | 'disabled';\n onChange?: (value: string) => void;\n onBlur?: (value: string) => void;\n onFocus?: (value: string) => void;\n render: (renderProps: T) => React.JSX.Element;\n}\n\nclass WithDisplayFormat<T extends TextElementProps> extends React.Component<\n WithDisplayFormatProps<T>,\n WithDisplayFormatState\n> {\n declare props: WithDisplayFormatProps<T> &\n Required<Pick<WithDisplayFormatProps<T>, keyof typeof WithDisplayFormat.defaultProps>>;\n static defaultProps = {\n autoComplete: 'off',\n displayPattern: '',\n value: '',\n };\n\n constructor(props: WithDisplayFormatProps) {\n super(props);\n const unformattedValue = unformatWithPattern(props.value ?? '', props.displayPattern);\n this.state = {\n value: formatWithPattern(unformattedValue, props.displayPattern),\n historyNavigator: new HistoryNavigator(),\n prevDisplayPattern: props.displayPattern,\n triggerType: 'Initial',\n triggerEvent: null,\n selectionStart: 0,\n selectionEnd: 0,\n pastedLength: 0,\n };\n }\n\n static getDerivedStateFromProps(\n { displayPattern }: WithDisplayFormatProps,\n { prevDisplayPattern = displayPattern, value, historyNavigator }: WithDisplayFormatState,\n ) {\n if (prevDisplayPattern !== displayPattern) {\n const unFormattedValue = unformatWithPattern(value, prevDisplayPattern);\n historyNavigator.reset();\n\n return {\n prevDisplayPattern: displayPattern,\n value: formatWithPattern(unFormattedValue, displayPattern),\n triggerType: null,\n triggerEvent: null,\n pastedLength: 0,\n };\n }\n return null;\n }\n\n getUserAction = (unformattedValue: string): EventType | string => {\n const { triggerEvent, triggerType, value } = this.state;\n const { displayPattern } = this.props;\n\n if (triggerEvent) {\n const charCode = String.fromCharCode(triggerEvent.which).toLowerCase();\n\n if (triggerType === 'Paste' || triggerType === 'Cut') {\n return triggerType;\n }\n\n if ((triggerEvent.ctrlKey || triggerEvent.metaKey) && charCode === 'z') {\n return triggerEvent.shiftKey ? 'Redo' : 'Undo';\n }\n // Detect mouse event redo\n if (triggerEvent.ctrlKey && charCode === 'd') {\n return 'Delete';\n }\n\n // Android Fix.\n if (\n typeof triggerEvent.key === 'undefined' &&\n unformattedValue.length <= unformatWithPattern(value, displayPattern).length\n ) {\n return 'Backspace';\n }\n return triggerEvent.key;\n }\n // triggerEvent can be null only in case of \"autofilling\" (via password manager extension or browser build-in one) events\n return 'Paste';\n };\n\n resetEvent = () => {\n this.setState({\n triggerType: 'Initial',\n triggerEvent: null,\n pastedLength: 0,\n });\n };\n\n detectUndoRedo = (event: React.KeyboardEvent<HTMLTextElement>) => {\n const charCode = String.fromCharCode(event.which).toLowerCase();\n if ((event.ctrlKey || event.metaKey) && charCode === 'z') {\n return event.shiftKey ? 'Redo' : 'Undo';\n }\n return null;\n };\n\n handleOnKeyDown: React.KeyboardEventHandler<HTMLTextElement> = (event) => {\n event.persist();\n const { selectionStart, selectionEnd } = event.currentTarget;\n const { historyNavigator } = this.state;\n const { displayPattern } = this.props;\n\n // Unfortunately Undo and Redo don't trigger OnChange event so we need to handle some value logic here.\n let newFormattedValue = '';\n\n if (this.detectUndoRedo(event) === 'Undo') {\n newFormattedValue = formatWithPattern(historyNavigator.undo().toString(), displayPattern);\n this.setState({ value: newFormattedValue, triggerType: 'Undo' });\n } else if (this.detectUndoRedo(event) === 'Redo') {\n newFormattedValue = formatWithPattern(historyNavigator.redo().toString(), displayPattern);\n this.setState({ value: newFormattedValue, triggerType: 'Redo' });\n } else {\n this.setState({\n triggerEvent: event,\n triggerType: 'KeyDown',\n selectionStart: selectionStart ?? 0,\n selectionEnd: selectionEnd ?? 0,\n });\n }\n };\n\n handleOnPaste: React.ClipboardEventHandler<HTMLTextElement> = (event) => {\n const { displayPattern } = this.props;\n const pastedLength = unformatWithPattern(\n event.clipboardData.getData('Text'),\n displayPattern,\n ).length;\n\n this.setState({ triggerType: 'Paste', pastedLength });\n };\n\n handleOnCut: React.ClipboardEventHandler<HTMLTextElement> = () => {\n this.setState({ triggerType: 'Cut' });\n };\n\n isKeyAllowed = (action: EventType | string) => {\n const { displayPattern } = this.props;\n const symbolsInPattern = displayPattern.split('').filter((character) => character !== '*');\n\n return !symbolsInPattern.includes(action);\n };\n\n handleOnChange: React.ChangeEventHandler<HTMLTextElement> = (event) => {\n const { historyNavigator, triggerType } = this.state;\n const { displayPattern, onChange } = this.props;\n const { value } = event.target;\n let unformattedValue = unformatWithPattern(value, displayPattern);\n const action = this.getUserAction(unformattedValue);\n if (!this.isKeyAllowed(action) || triggerType === 'Undo' || triggerType === 'Redo') {\n return;\n }\n\n if (action === 'Backspace' || action === 'Delete') {\n unformattedValue = this.handleDelete(unformattedValue, action);\n }\n\n const newFormattedValue = formatWithPattern(unformattedValue, displayPattern);\n historyNavigator.add(unformattedValue);\n\n this.handleCursorPositioning(action);\n\n this.setState({ value: newFormattedValue }, () => {\n this.resetEvent();\n if (onChange) {\n const broadcastValue = unformatWithPattern(newFormattedValue, displayPattern);\n onChange(broadcastValue);\n }\n });\n };\n\n handleOnBlur: React.FocusEventHandler<HTMLTextElement> = (event) => {\n this.props.onBlur?.(unformatWithPattern(event.target.value, this.props.displayPattern));\n };\n\n handleOnFocus: React.FocusEventHandler<HTMLTextElement> = (event) => {\n const { displayPattern, onFocus } = this.props;\n if (onFocus) {\n this.handleOnChange(event);\n onFocus(unformatWithPattern(event.target.value, displayPattern));\n }\n };\n\n handleDelete = (unformattedValue: string, action: EventType) => {\n const { displayPattern } = this.props;\n const { selectionStart, selectionEnd } = this.state;\n const newStack = [...unformattedValue];\n if (selectionStart === selectionEnd) {\n let startPosition =\n selectionStart - getCountOfSymbolsInSelection(0, selectionStart, displayPattern);\n let toDelete = 0;\n\n let count = getDistanceToNextSymbol(selectionStart, displayPattern);\n if (action === 'Backspace') {\n startPosition -= 1;\n count = getDistanceToPreviousSymbol(selectionStart, displayPattern);\n }\n\n if (startPosition >= 0 && count) {\n toDelete = 1;\n }\n\n newStack.splice(startPosition, toDelete);\n }\n\n return newStack.join('');\n };\n\n handleCursorPositioning = (action: string) => {\n const { displayPattern } = this.props;\n const { triggerEvent, selectionStart, selectionEnd, pastedLength } = this.state;\n const target = triggerEvent?.currentTarget;\n\n const cursorPosition = getCursorPositionAfterKeystroke(\n action,\n selectionStart,\n selectionEnd,\n displayPattern,\n pastedLength,\n );\n\n setTimeout(() => {\n target?.setSelectionRange(cursorPosition, cursorPosition);\n this.setState({ selectionStart: cursorPosition, selectionEnd: cursorPosition });\n }, 0);\n };\n\n render() {\n const {\n inputMode,\n className,\n id,\n name,\n placeholder,\n readOnly,\n required,\n minLength,\n maxLength,\n disabled,\n autoComplete,\n } = this.props;\n const { value } = this.state;\n const renderProps: TextElementProps = {\n inputMode,\n className,\n id,\n name,\n placeholder,\n readOnly,\n required,\n minLength,\n maxLength,\n disabled,\n autoComplete,\n value,\n onFocus: this.handleOnFocus,\n onBlur: this.handleOnBlur,\n onPaste: this.handleOnPaste,\n onKeyDown: this.handleOnKeyDown,\n onChange: this.handleOnChange,\n onCut: this.handleOnCut,\n };\n return this.props.render(renderProps as T);\n }\n}\n\nexport default WithDisplayFormat;\n"],"names":["WithDisplayFormat","React","Component","defaultProps","autoComplete","displayPattern","value","constructor","props","unformattedValue","unformatWithPattern","state","formatWithPattern","historyNavigator","HistoryNavigator","prevDisplayPattern","triggerType","triggerEvent","selectionStart","selectionEnd","pastedLength","getDerivedStateFromProps","unFormattedValue","reset","getUserAction","charCode","String","fromCharCode","which","toLowerCase","ctrlKey","metaKey","shiftKey","key","length","resetEvent","setState","detectUndoRedo","event","handleOnKeyDown","persist","currentTarget","newFormattedValue","undo","toString","redo","handleOnPaste","clipboardData","getData","handleOnCut","isKeyAllowed","action","symbolsInPattern","split","filter","character","includes","handleOnChange","onChange","target","handleDelete","add","handleCursorPositioning","broadcastValue","handleOnBlur","onBlur","handleOnFocus","onFocus","newStack","startPosition","getCountOfSymbolsInSelection","toDelete","count","getDistanceToNextSymbol","getDistanceToPreviousSymbol","splice","join","cursorPosition","getCursorPositionAfterKeystroke","setTimeout","setSelectionRange","render","inputMode","className","id","name","placeholder","readOnly","required","minLength","maxLength","disabled","renderProps","onPaste","onKeyDown","onCut"],"mappings":"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"}
1
+ {"version":3,"file":"WithDisplayFormat.mjs","sources":["../../src/withDisplayFormat/WithDisplayFormat.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport { HistoryNavigator } from '../common';\nimport {\n formatWithPattern,\n getCountOfSymbolsInSelection,\n getCursorPositionAfterKeystroke,\n unformatWithPattern,\n getDistanceToPreviousSymbol,\n getDistanceToNextSymbol,\n} from '../common/textFormat';\nimport { InputProps } from '../inputs/Input';\nimport { TextAreaProps } from '../inputs/TextArea';\n\ntype HTMLTextElement = HTMLInputElement | HTMLTextAreaElement;\ntype TextElementProps = InputProps | TextAreaProps;\n\nexport type EventType =\n | 'KeyDown'\n | 'Paste'\n | 'Cut'\n | 'Undo'\n | 'Redo'\n | 'Backspace'\n | 'Delete'\n | 'Initial';\n\ninterface WithDisplayFormatState {\n value: string;\n historyNavigator: HistoryNavigator;\n prevDisplayPattern: string;\n triggerType: EventType;\n triggerEvent: React.KeyboardEvent<HTMLTextElement> | null;\n pastedLength: number;\n selectionStart: number;\n selectionEnd: number;\n}\n\nexport interface WithDisplayFormatProps<T extends TextElementProps = TextElementProps>\n extends Pick<\n TextElementProps,\n | 'className'\n | 'disabled'\n | 'id'\n | 'maxLength'\n | 'minLength'\n | 'name'\n | 'placeholder'\n | 'readOnly'\n | 'required'\n | 'inputMode'\n > {\n value?: string;\n displayPattern: string;\n /**\n * autocomplete hides our form help so we need to disable it when help text\n * is present. Chrome ignores autocomplete=off, the only way to disable it is\n * to provide an 'invalid' value, for which 'disabled' serves.\n */\n autoComplete?: TextElementProps['autoComplete'] | 'disabled';\n onChange?: (value: string) => void;\n onBlur?: (value: string) => void;\n onFocus?: (value: string) => void;\n render: (renderProps: T) => React.JSX.Element;\n}\n\nclass WithDisplayFormat<T extends TextElementProps> extends React.Component<\n WithDisplayFormatProps<T>,\n WithDisplayFormatState\n> {\n declare props: WithDisplayFormatProps<T> &\n Required<Pick<WithDisplayFormatProps<T>, keyof typeof WithDisplayFormat.defaultProps>>;\n static defaultProps = {\n autoComplete: 'off',\n displayPattern: '',\n value: '',\n };\n\n constructor(props: WithDisplayFormatProps) {\n super(props);\n const unformattedValue = unformatWithPattern(props.value ?? '', props.displayPattern);\n this.state = {\n value: formatWithPattern(unformattedValue, props.displayPattern),\n historyNavigator: new HistoryNavigator(),\n prevDisplayPattern: props.displayPattern,\n triggerType: 'Initial',\n triggerEvent: null,\n selectionStart: 0,\n selectionEnd: 0,\n pastedLength: 0,\n };\n }\n\n static getDerivedStateFromProps(\n { displayPattern }: WithDisplayFormatProps,\n { prevDisplayPattern = displayPattern, value, historyNavigator }: WithDisplayFormatState,\n ) {\n if (prevDisplayPattern !== displayPattern) {\n const unFormattedValue = unformatWithPattern(value, prevDisplayPattern);\n historyNavigator.reset();\n\n return {\n prevDisplayPattern: displayPattern,\n value: formatWithPattern(unFormattedValue, displayPattern),\n triggerType: null,\n triggerEvent: null,\n pastedLength: 0,\n };\n }\n return null;\n }\n\n getUserAction = (unformattedValue: string): EventType | string => {\n const { triggerEvent, triggerType, value } = this.state;\n const { displayPattern } = this.props;\n\n if (triggerEvent) {\n const charCode = String.fromCharCode(triggerEvent.which).toLowerCase();\n\n if (triggerType === 'Paste' || triggerType === 'Cut') {\n return triggerType;\n }\n\n if ((triggerEvent.ctrlKey || triggerEvent.metaKey) && charCode === 'z') {\n return triggerEvent.shiftKey ? 'Redo' : 'Undo';\n }\n // Detect mouse event redo\n if (triggerEvent.ctrlKey && charCode === 'd') {\n return 'Delete';\n }\n\n // Android Fix.\n if (\n typeof triggerEvent.key === 'undefined' &&\n unformattedValue.length <= unformatWithPattern(value, displayPattern).length\n ) {\n return 'Backspace';\n }\n return triggerEvent.key;\n }\n // triggerEvent can be null only in case of \"autofilling\" (via password manager extension or browser build-in one) events\n return 'Paste';\n };\n\n resetEvent = () => {\n this.setState({\n triggerType: 'Initial',\n triggerEvent: null,\n pastedLength: 0,\n });\n };\n\n detectUndoRedo = (event: React.KeyboardEvent<HTMLTextElement>) => {\n const charCode = String.fromCharCode(event.which).toLowerCase();\n if ((event.ctrlKey || event.metaKey) && charCode === 'z') {\n return event.shiftKey ? 'Redo' : 'Undo';\n }\n return null;\n };\n\n handleOnKeyDown: React.KeyboardEventHandler<HTMLTextElement> = (event) => {\n event.persist();\n const { selectionStart, selectionEnd } = event.currentTarget;\n const { historyNavigator } = this.state;\n const { displayPattern } = this.props;\n\n // Unfortunately Undo and Redo don't trigger OnChange event so we need to handle some value logic here.\n let newFormattedValue = '';\n\n if (this.detectUndoRedo(event) === 'Undo') {\n newFormattedValue = formatWithPattern(historyNavigator.undo().toString(), displayPattern);\n this.setState({ value: newFormattedValue, triggerType: 'Undo' });\n } else if (this.detectUndoRedo(event) === 'Redo') {\n newFormattedValue = formatWithPattern(historyNavigator.redo().toString(), displayPattern);\n this.setState({ value: newFormattedValue, triggerType: 'Redo' });\n } else {\n this.setState({\n triggerEvent: event,\n triggerType: 'KeyDown',\n selectionStart: selectionStart ?? 0,\n selectionEnd: selectionEnd ?? 0,\n });\n }\n };\n\n handleOnPaste: React.ClipboardEventHandler<HTMLTextElement> = (event) => {\n const { displayPattern } = this.props;\n const pastedLength = unformatWithPattern(\n event.clipboardData.getData('Text'),\n displayPattern,\n ).length;\n\n this.setState({ triggerType: 'Paste', pastedLength });\n };\n\n handleOnCut: React.ClipboardEventHandler<HTMLTextElement> = () => {\n this.setState({ triggerType: 'Cut' });\n };\n\n isKeyAllowed = (action: EventType | string) => {\n const { displayPattern } = this.props;\n const symbolsInPattern = displayPattern.split('').filter((character) => character !== '*');\n\n return !symbolsInPattern.includes(action);\n };\n\n handleOnChange: React.ChangeEventHandler<HTMLTextElement> = (event) => {\n const { historyNavigator, triggerType } = this.state;\n const { displayPattern, onChange } = this.props;\n const { value } = event.target;\n let unformattedValue = unformatWithPattern(value, displayPattern);\n const action = this.getUserAction(unformattedValue);\n if (!this.isKeyAllowed(action) || triggerType === 'Undo' || triggerType === 'Redo') {\n return;\n }\n\n if (action === 'Backspace' || action === 'Delete') {\n unformattedValue = this.handleDelete(unformattedValue, action);\n }\n\n const newFormattedValue = formatWithPattern(unformattedValue, displayPattern);\n historyNavigator.add(unformattedValue);\n\n this.handleCursorPositioning(action);\n\n this.setState({ value: newFormattedValue }, () => {\n this.resetEvent();\n if (onChange) {\n const broadcastValue = unformatWithPattern(newFormattedValue, displayPattern);\n onChange(broadcastValue);\n }\n });\n };\n\n handleOnBlur: React.FocusEventHandler<HTMLTextElement> = (event) => {\n this.props.onBlur?.(unformatWithPattern(event.target.value, this.props.displayPattern));\n };\n\n handleOnFocus: React.FocusEventHandler<HTMLTextElement> = (event) => {\n const { displayPattern, onFocus } = this.props;\n if (onFocus) {\n this.handleOnChange(event);\n onFocus(unformatWithPattern(event.target.value, displayPattern));\n }\n };\n\n handleDelete = (unformattedValue: string, action: EventType) => {\n const { displayPattern } = this.props;\n const { selectionStart, selectionEnd } = this.state;\n const newStack = [...unformattedValue];\n if (selectionStart === selectionEnd) {\n let startPosition =\n selectionStart - getCountOfSymbolsInSelection(0, selectionStart, displayPattern);\n let toDelete = 0;\n\n let count = getDistanceToNextSymbol(selectionStart, displayPattern);\n if (action === 'Backspace') {\n startPosition -= 1;\n count = getDistanceToPreviousSymbol(selectionStart, displayPattern);\n }\n\n if (startPosition >= 0 && count) {\n toDelete = 1;\n }\n\n newStack.splice(startPosition, toDelete);\n }\n\n return newStack.join('');\n };\n\n handleCursorPositioning = (action: string) => {\n const { displayPattern } = this.props;\n const { triggerEvent, selectionStart, selectionEnd, pastedLength } = this.state;\n const target = triggerEvent?.currentTarget;\n\n const cursorPosition = getCursorPositionAfterKeystroke(\n action,\n selectionStart,\n selectionEnd,\n displayPattern,\n pastedLength,\n );\n\n setTimeout(() => {\n target?.setSelectionRange(cursorPosition, cursorPosition);\n this.setState({ selectionStart: cursorPosition, selectionEnd: cursorPosition });\n }, 0);\n };\n\n render() {\n const {\n inputMode,\n className,\n id,\n name,\n placeholder,\n readOnly,\n required,\n minLength,\n maxLength,\n disabled,\n autoComplete,\n } = this.props;\n const { value } = this.state;\n const renderProps: TextElementProps = {\n inputMode,\n className,\n id,\n name,\n placeholder,\n readOnly,\n required,\n minLength,\n maxLength,\n disabled,\n autoComplete,\n value,\n onFocus: this.handleOnFocus,\n onBlur: this.handleOnBlur,\n onPaste: this.handleOnPaste,\n onKeyDown: this.handleOnKeyDown,\n onChange: this.handleOnChange,\n onCut: this.handleOnCut,\n };\n return this.props.render(renderProps as T);\n }\n}\n\nexport default WithDisplayFormat;\n"],"names":["WithDisplayFormat","React","Component","defaultProps","autoComplete","displayPattern","value","constructor","props","unformattedValue","unformatWithPattern","state","formatWithPattern","historyNavigator","HistoryNavigator","prevDisplayPattern","triggerType","triggerEvent","selectionStart","selectionEnd","pastedLength","getDerivedStateFromProps","unFormattedValue","reset","getUserAction","charCode","String","fromCharCode","which","toLowerCase","ctrlKey","metaKey","shiftKey","key","length","resetEvent","setState","detectUndoRedo","event","handleOnKeyDown","persist","currentTarget","newFormattedValue","undo","toString","redo","handleOnPaste","clipboardData","getData","handleOnCut","isKeyAllowed","action","symbolsInPattern","split","filter","character","includes","handleOnChange","onChange","target","handleDelete","add","handleCursorPositioning","broadcastValue","handleOnBlur","onBlur","handleOnFocus","onFocus","newStack","startPosition","getCountOfSymbolsInSelection","toDelete","count","getDistanceToNextSymbol","getDistanceToPreviousSymbol","splice","join","cursorPosition","getCursorPositionAfterKeystroke","setTimeout","setSelectionRange","render","inputMode","className","id","name","placeholder","readOnly","required","minLength","maxLength","disabled","renderProps","onPaste","onKeyDown","onCut"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkEA,MAAMA,iBAA8C,SAAQC,KAAK,CAACC,SAGjE,CAAA;AAGC,EAAA,OAAOC,YAAY,GAAG;AACpBC,IAAAA,YAAY,EAAE,KAAK;AACnBC,IAAAA,cAAc,EAAE,EAAE;AAClBC,IAAAA,KAAK,EAAE,EAAA;GACR,CAAA;EAEDC,WAAAA,CAAYC,KAA6B,EAAA;IACvC,KAAK,CAACA,KAAK,CAAC,CAAA;AACZ,IAAA,MAAMC,gBAAgB,GAAGC,mBAAmB,CAACF,KAAK,CAACF,KAAK,IAAI,EAAE,EAAEE,KAAK,CAACH,cAAc,CAAC,CAAA;IACrF,IAAI,CAACM,KAAK,GAAG;MACXL,KAAK,EAAEM,iBAAiB,CAACH,gBAAgB,EAAED,KAAK,CAACH,cAAc,CAAC;AAChEQ,MAAAA,gBAAgB,EAAE,IAAIC,gBAAgB,EAAE;MACxCC,kBAAkB,EAAEP,KAAK,CAACH,cAAc;AACxCW,MAAAA,WAAW,EAAE,SAAS;AACtBC,MAAAA,YAAY,EAAE,IAAI;AAClBC,MAAAA,cAAc,EAAE,CAAC;AACjBC,MAAAA,YAAY,EAAE,CAAC;AACfC,MAAAA,YAAY,EAAE,CAAA;KACf,CAAA;AACH,GAAA;AAEA,EAAA,OAAOC,wBAAwBA,CAC7B;AAAEhB,IAAAA,cAAAA;AAAwC,GAAA,EAC1C;AAAEU,IAAAA,kBAAkB,GAAGV,cAAc;IAAEC,KAAK;AAAEO,IAAAA,gBAAAA;AAA0C,GAAA,EAAA;IAExF,IAAIE,kBAAkB,KAAKV,cAAc,EAAE;AACzC,MAAA,MAAMiB,gBAAgB,GAAGZ,mBAAmB,CAACJ,KAAK,EAAES,kBAAkB,CAAC,CAAA;MACvEF,gBAAgB,CAACU,KAAK,EAAE,CAAA;MAExB,OAAO;AACLR,QAAAA,kBAAkB,EAAEV,cAAc;AAClCC,QAAAA,KAAK,EAAEM,iBAAiB,CAACU,gBAAgB,EAAEjB,cAAc,CAAC;AAC1DW,QAAAA,WAAW,EAAE,IAAI;AACjBC,QAAAA,YAAY,EAAE,IAAI;AAClBG,QAAAA,YAAY,EAAE,CAAA;OACf,CAAA;AACH,KAAA;AACA,IAAA,OAAO,IAAI,CAAA;AACb,GAAA;EAEAI,aAAa,GAAIf,gBAAwB,IAAwB;IAC/D,MAAM;MAAEQ,YAAY;MAAED,WAAW;AAAEV,MAAAA,KAAAA;KAAO,GAAG,IAAI,CAACK,KAAK,CAAA;IACvD,MAAM;AAAEN,MAAAA,cAAAA;KAAgB,GAAG,IAAI,CAACG,KAAK,CAAA;AAErC,IAAA,IAAIS,YAAY,EAAE;AAChB,MAAA,MAAMQ,QAAQ,GAAGC,MAAM,CAACC,YAAY,CAACV,YAAY,CAACW,KAAK,CAAC,CAACC,WAAW,EAAE,CAAA;AAEtE,MAAA,IAAIb,WAAW,KAAK,OAAO,IAAIA,WAAW,KAAK,KAAK,EAAE;AACpD,QAAA,OAAOA,WAAW,CAAA;AACpB,OAAA;AAEA,MAAA,IAAI,CAACC,YAAY,CAACa,OAAO,IAAIb,YAAY,CAACc,OAAO,KAAKN,QAAQ,KAAK,GAAG,EAAE;AACtE,QAAA,OAAOR,YAAY,CAACe,QAAQ,GAAG,MAAM,GAAG,MAAM,CAAA;AAChD,OAAA;AACA;AACA,MAAA,IAAIf,YAAY,CAACa,OAAO,IAAIL,QAAQ,KAAK,GAAG,EAAE;AAC5C,QAAA,OAAO,QAAQ,CAAA;AACjB,OAAA;AAEA;AACA,MAAA,IACE,OAAOR,YAAY,CAACgB,GAAG,KAAK,WAAW,IACvCxB,gBAAgB,CAACyB,MAAM,IAAIxB,mBAAmB,CAACJ,KAAK,EAAED,cAAc,CAAC,CAAC6B,MAAM,EAC5E;AACA,QAAA,OAAO,WAAW,CAAA;AACpB,OAAA;MACA,OAAOjB,YAAY,CAACgB,GAAG,CAAA;AACzB,KAAA;AACA;AACA,IAAA,OAAO,OAAO,CAAA;GACf,CAAA;EAEDE,UAAU,GAAGA,MAAK;IAChB,IAAI,CAACC,QAAQ,CAAC;AACZpB,MAAAA,WAAW,EAAE,SAAS;AACtBC,MAAAA,YAAY,EAAE,IAAI;AAClBG,MAAAA,YAAY,EAAE,CAAA;AACf,KAAA,CAAC,CAAA;GACH,CAAA;EAEDiB,cAAc,GAAIC,KAA2C,IAAI;AAC/D,IAAA,MAAMb,QAAQ,GAAGC,MAAM,CAACC,YAAY,CAACW,KAAK,CAACV,KAAK,CAAC,CAACC,WAAW,EAAE,CAAA;AAC/D,IAAA,IAAI,CAACS,KAAK,CAACR,OAAO,IAAIQ,KAAK,CAACP,OAAO,KAAKN,QAAQ,KAAK,GAAG,EAAE;AACxD,MAAA,OAAOa,KAAK,CAACN,QAAQ,GAAG,MAAM,GAAG,MAAM,CAAA;AACzC,KAAA;AACA,IAAA,OAAO,IAAI,CAAA;GACZ,CAAA;EAEDO,eAAe,GAAiDD,KAAK,IAAI;IACvEA,KAAK,CAACE,OAAO,EAAE,CAAA;IACf,MAAM;MAAEtB,cAAc;AAAEC,MAAAA,YAAAA;KAAc,GAAGmB,KAAK,CAACG,aAAa,CAAA;IAC5D,MAAM;AAAE5B,MAAAA,gBAAAA;KAAkB,GAAG,IAAI,CAACF,KAAK,CAAA;IACvC,MAAM;AAAEN,MAAAA,cAAAA;KAAgB,GAAG,IAAI,CAACG,KAAK,CAAA;AAErC;IACA,IAAIkC,iBAAiB,GAAG,EAAE,CAAA;IAE1B,IAAI,IAAI,CAACL,cAAc,CAACC,KAAK,CAAC,KAAK,MAAM,EAAE;AACzCI,MAAAA,iBAAiB,GAAG9B,iBAAiB,CAACC,gBAAgB,CAAC8B,IAAI,EAAE,CAACC,QAAQ,EAAE,EAAEvC,cAAc,CAAC,CAAA;MACzF,IAAI,CAAC+B,QAAQ,CAAC;AAAE9B,QAAAA,KAAK,EAAEoC,iBAAiB;AAAE1B,QAAAA,WAAW,EAAE,MAAA;AAAM,OAAE,CAAC,CAAA;KACjE,MAAM,IAAI,IAAI,CAACqB,cAAc,CAACC,KAAK,CAAC,KAAK,MAAM,EAAE;AAChDI,MAAAA,iBAAiB,GAAG9B,iBAAiB,CAACC,gBAAgB,CAACgC,IAAI,EAAE,CAACD,QAAQ,EAAE,EAAEvC,cAAc,CAAC,CAAA;MACzF,IAAI,CAAC+B,QAAQ,CAAC;AAAE9B,QAAAA,KAAK,EAAEoC,iBAAiB;AAAE1B,QAAAA,WAAW,EAAE,MAAA;AAAM,OAAE,CAAC,CAAA;AAClE,KAAC,MAAM;MACL,IAAI,CAACoB,QAAQ,CAAC;AACZnB,QAAAA,YAAY,EAAEqB,KAAK;AACnBtB,QAAAA,WAAW,EAAE,SAAS;QACtBE,cAAc,EAAEA,cAAc,IAAI,CAAC;QACnCC,YAAY,EAAEA,YAAY,IAAI,CAAA;AAC/B,OAAA,CAAC,CAAA;AACJ,KAAA;GACD,CAAA;EAED2B,aAAa,GAAkDR,KAAK,IAAI;IACtE,MAAM;AAAEjC,MAAAA,cAAAA;KAAgB,GAAG,IAAI,CAACG,KAAK,CAAA;AACrC,IAAA,MAAMY,YAAY,GAAGV,mBAAmB,CACtC4B,KAAK,CAACS,aAAa,CAACC,OAAO,CAAC,MAAM,CAAC,EACnC3C,cAAc,CACf,CAAC6B,MAAM,CAAA;IAER,IAAI,CAACE,QAAQ,CAAC;AAAEpB,MAAAA,WAAW,EAAE,OAAO;AAAEI,MAAAA,YAAAA;AAAc,KAAA,CAAC,CAAA;GACtD,CAAA;EAED6B,WAAW,GAAiDA,MAAK;IAC/D,IAAI,CAACb,QAAQ,CAAC;AAAEpB,MAAAA,WAAW,EAAE,KAAA;AAAO,KAAA,CAAC,CAAA;GACtC,CAAA;EAEDkC,YAAY,GAAIC,MAA0B,IAAI;IAC5C,MAAM;AAAE9C,MAAAA,cAAAA;KAAgB,GAAG,IAAI,CAACG,KAAK,CAAA;AACrC,IAAA,MAAM4C,gBAAgB,GAAG/C,cAAc,CAACgD,KAAK,CAAC,EAAE,CAAC,CAACC,MAAM,CAAEC,SAAS,IAAKA,SAAS,KAAK,GAAG,CAAC,CAAA;AAE1F,IAAA,OAAO,CAACH,gBAAgB,CAACI,QAAQ,CAACL,MAAM,CAAC,CAAA;GAC1C,CAAA;EAEDM,cAAc,GAA+CnB,KAAK,IAAI;IACpE,MAAM;MAAEzB,gBAAgB;AAAEG,MAAAA,WAAAA;KAAa,GAAG,IAAI,CAACL,KAAK,CAAA;IACpD,MAAM;MAAEN,cAAc;AAAEqD,MAAAA,QAAAA;KAAU,GAAG,IAAI,CAAClD,KAAK,CAAA;IAC/C,MAAM;AAAEF,MAAAA,KAAAA;KAAO,GAAGgC,KAAK,CAACqB,MAAM,CAAA;AAC9B,IAAA,IAAIlD,gBAAgB,GAAGC,mBAAmB,CAACJ,KAAK,EAAED,cAAc,CAAC,CAAA;AACjE,IAAA,MAAM8C,MAAM,GAAG,IAAI,CAAC3B,aAAa,CAACf,gBAAgB,CAAC,CAAA;AACnD,IAAA,IAAI,CAAC,IAAI,CAACyC,YAAY,CAACC,MAAM,CAAC,IAAInC,WAAW,KAAK,MAAM,IAAIA,WAAW,KAAK,MAAM,EAAE;AAClF,MAAA,OAAA;AACF,KAAA;AAEA,IAAA,IAAImC,MAAM,KAAK,WAAW,IAAIA,MAAM,KAAK,QAAQ,EAAE;MACjD1C,gBAAgB,GAAG,IAAI,CAACmD,YAAY,CAACnD,gBAAgB,EAAE0C,MAAM,CAAC,CAAA;AAChE,KAAA;AAEA,IAAA,MAAMT,iBAAiB,GAAG9B,iBAAiB,CAACH,gBAAgB,EAAEJ,cAAc,CAAC,CAAA;AAC7EQ,IAAAA,gBAAgB,CAACgD,GAAG,CAACpD,gBAAgB,CAAC,CAAA;AAEtC,IAAA,IAAI,CAACqD,uBAAuB,CAACX,MAAM,CAAC,CAAA;IAEpC,IAAI,CAACf,QAAQ,CAAC;AAAE9B,MAAAA,KAAK,EAAEoC,iBAAAA;AAAiB,KAAE,EAAE,MAAK;MAC/C,IAAI,CAACP,UAAU,EAAE,CAAA;AACjB,MAAA,IAAIuB,QAAQ,EAAE;AACZ,QAAA,MAAMK,cAAc,GAAGrD,mBAAmB,CAACgC,iBAAiB,EAAErC,cAAc,CAAC,CAAA;QAC7EqD,QAAQ,CAACK,cAAc,CAAC,CAAA;AAC1B,OAAA;AACF,KAAC,CAAC,CAAA;GACH,CAAA;EAEDC,YAAY,GAA8C1B,KAAK,IAAI;AACjE,IAAA,IAAI,CAAC9B,KAAK,CAACyD,MAAM,GAAGvD,mBAAmB,CAAC4B,KAAK,CAACqB,MAAM,CAACrD,KAAK,EAAE,IAAI,CAACE,KAAK,CAACH,cAAc,CAAC,CAAC,CAAA;GACxF,CAAA;EAED6D,aAAa,GAA8C5B,KAAK,IAAI;IAClE,MAAM;MAAEjC,cAAc;AAAE8D,MAAAA,OAAAA;KAAS,GAAG,IAAI,CAAC3D,KAAK,CAAA;AAC9C,IAAA,IAAI2D,OAAO,EAAE;AACX,MAAA,IAAI,CAACV,cAAc,CAACnB,KAAK,CAAC,CAAA;MAC1B6B,OAAO,CAACzD,mBAAmB,CAAC4B,KAAK,CAACqB,MAAM,CAACrD,KAAK,EAAED,cAAc,CAAC,CAAC,CAAA;AAClE,KAAA;GACD,CAAA;AAEDuD,EAAAA,YAAY,GAAGA,CAACnD,gBAAwB,EAAE0C,MAAiB,KAAI;IAC7D,MAAM;AAAE9C,MAAAA,cAAAA;KAAgB,GAAG,IAAI,CAACG,KAAK,CAAA;IACrC,MAAM;MAAEU,cAAc;AAAEC,MAAAA,YAAAA;KAAc,GAAG,IAAI,CAACR,KAAK,CAAA;AACnD,IAAA,MAAMyD,QAAQ,GAAG,CAAC,GAAG3D,gBAAgB,CAAC,CAAA;IACtC,IAAIS,cAAc,KAAKC,YAAY,EAAE;MACnC,IAAIkD,aAAa,GACfnD,cAAc,GAAGoD,4BAA4B,CAAC,CAAC,EAAEpD,cAAc,EAAEb,cAAc,CAAC,CAAA;MAClF,IAAIkE,QAAQ,GAAG,CAAC,CAAA;AAEhB,MAAA,IAAIC,KAAK,GAAGC,uBAAuB,CAACvD,cAAc,EAAEb,cAAc,CAAC,CAAA;MACnE,IAAI8C,MAAM,KAAK,WAAW,EAAE;AAC1BkB,QAAAA,aAAa,IAAI,CAAC,CAAA;AAClBG,QAAAA,KAAK,GAAGE,2BAA2B,CAACxD,cAAc,EAAEb,cAAc,CAAC,CAAA;AACrE,OAAA;AAEA,MAAA,IAAIgE,aAAa,IAAI,CAAC,IAAIG,KAAK,EAAE;AAC/BD,QAAAA,QAAQ,GAAG,CAAC,CAAA;AACd,OAAA;AAEAH,MAAAA,QAAQ,CAACO,MAAM,CAACN,aAAa,EAAEE,QAAQ,CAAC,CAAA;AAC1C,KAAA;AAEA,IAAA,OAAOH,QAAQ,CAACQ,IAAI,CAAC,EAAE,CAAC,CAAA;GACzB,CAAA;EAEDd,uBAAuB,GAAIX,MAAc,IAAI;IAC3C,MAAM;AAAE9C,MAAAA,cAAAA;KAAgB,GAAG,IAAI,CAACG,KAAK,CAAA;IACrC,MAAM;MAAES,YAAY;MAAEC,cAAc;MAAEC,YAAY;AAAEC,MAAAA,YAAAA;KAAc,GAAG,IAAI,CAACT,KAAK,CAAA;AAC/E,IAAA,MAAMgD,MAAM,GAAG1C,YAAY,EAAEwB,aAAa,CAAA;AAE1C,IAAA,MAAMoC,cAAc,GAAGC,kCAA+B,CACpD3B,MAAM,EACNjC,cAAc,EACdC,YAAY,EACZd,cAAc,EACde,YAAY,CACb,CAAA;AAED2D,IAAAA,UAAU,CAAC,MAAK;AACdpB,MAAAA,MAAM,EAAEqB,iBAAiB,CAACH,cAAc,EAAEA,cAAc,CAAC,CAAA;MACzD,IAAI,CAACzC,QAAQ,CAAC;AAAElB,QAAAA,cAAc,EAAE2D,cAAc;AAAE1D,QAAAA,YAAY,EAAE0D,cAAAA;AAAc,OAAE,CAAC,CAAA;KAChF,EAAE,CAAC,CAAC,CAAA;GACN,CAAA;AAEDI,EAAAA,MAAMA,GAAA;IACJ,MAAM;MACJC,SAAS;MACTC,SAAS;MACTC,EAAE;MACFC,IAAI;MACJC,WAAW;MACXC,QAAQ;MACRC,QAAQ;MACRC,SAAS;MACTC,SAAS;MACTC,QAAQ;AACRvF,MAAAA,YAAAA;KACD,GAAG,IAAI,CAACI,KAAK,CAAA;IACd,MAAM;AAAEF,MAAAA,KAAAA;KAAO,GAAG,IAAI,CAACK,KAAK,CAAA;AAC5B,IAAA,MAAMiF,WAAW,GAAqB;MACpCV,SAAS;MACTC,SAAS;MACTC,EAAE;MACFC,IAAI;MACJC,WAAW;MACXC,QAAQ;MACRC,QAAQ;MACRC,SAAS;MACTC,SAAS;MACTC,QAAQ;MACRvF,YAAY;MACZE,KAAK;MACL6D,OAAO,EAAE,IAAI,CAACD,aAAa;MAC3BD,MAAM,EAAE,IAAI,CAACD,YAAY;MACzB6B,OAAO,EAAE,IAAI,CAAC/C,aAAa;MAC3BgD,SAAS,EAAE,IAAI,CAACvD,eAAe;MAC/BmB,QAAQ,EAAE,IAAI,CAACD,cAAc;MAC7BsC,KAAK,EAAE,IAAI,CAAC9C,WAAAA;KACb,CAAA;AACD,IAAA,OAAO,IAAI,CAACzC,KAAK,CAACyE,MAAM,CAACW,WAAgB,CAAC,CAAA;AAC5C,GAAA;;;;;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@transferwise/components",
3
- "version": "46.78.0",
3
+ "version": "46.79.0",
4
4
  "description": "Neptune React components",
5
5
  "license": "Apache-2.0",
6
6
  "repository": {
@@ -91,8 +91,8 @@
91
91
  "rollup": "^4.18.1",
92
92
  "rollup-preserve-directives": "^1.1.1",
93
93
  "storybook": "^8.2.2",
94
- "@transferwise/less-config": "3.1.0",
95
94
  "@transferwise/neptune-css": "14.19.1",
95
+ "@transferwise/less-config": "3.1.0",
96
96
  "@wise/components-theming": "1.6.1"
97
97
  },
98
98
  "peerDependencies": {
@@ -72,12 +72,9 @@ const Button = forwardRef<ButtonReferenceType, Props>(
72
72
  ) => {
73
73
  const intl = useIntl();
74
74
 
75
- // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
76
75
  logDeprecationNotices({ size, type });
77
76
 
78
- // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
79
77
  const newType = establishNewType(type);
80
- // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment
81
78
  const newPriority = establishNewPriority(priority, type);
82
79
 
83
80
  const classes = clsx(
@@ -0,0 +1,74 @@
1
+ import { ControlType, Priority, Size, Type } from '../../common';
2
+ import { logActionRequired, logActionRequiredIf } from '../../utilities';
3
+
4
+ const deprecatedTypeMap: Record<Type, ControlType> = {
5
+ [Type.PRIMARY]: ControlType.ACCENT,
6
+ [Type.SECONDARY]: ControlType.ACCENT,
7
+ [Type.LINK]: ControlType.ACCENT,
8
+ [Type.PAY]: ControlType.POSITIVE,
9
+ [Type.DANGER]: ControlType.NEGATIVE,
10
+ };
11
+
12
+ type OldTypeKeys = Type.DANGER | Type.LINK | Type.SECONDARY;
13
+ const oldTypePriorityMap: Record<OldTypeKeys, Priority> = {
14
+ [Type.DANGER]: Priority.SECONDARY,
15
+ [Type.LINK]: Priority.TERTIARY,
16
+ [Type.SECONDARY]: Priority.SECONDARY,
17
+ };
18
+
19
+ const deprecatedTypeMapMessage = {
20
+ [Type.DANGER]: 'Type.NEGATIVE',
21
+ [Type.LINK]: 'ControlType.ACCENT with priority Priority.TERTIARY',
22
+ [Type.PAY]: 'ControlType.POSITIVE',
23
+ [Type.PRIMARY]: 'ControlType.ACCENT',
24
+ [Type.SECONDARY]: 'ControlType.ACCENT with priority Priority.SECONDARY',
25
+ };
26
+
27
+ const deprecatedTypes = Object.keys(deprecatedTypeMap);
28
+
29
+ type EstablishNewTypeType = (
30
+ originalType: Type | (string & Record<never, never>) | null,
31
+ ) => `${ControlType}` | string | null;
32
+
33
+ export const establishNewType: EstablishNewTypeType = (originalType) =>
34
+ originalType && originalType in deprecatedTypeMap
35
+ ? deprecatedTypeMap[originalType as Type]
36
+ : originalType;
37
+
38
+ type EstablishNewPriorityType = (
39
+ originalPriority?: Priority | (string & Record<never, never>) | null,
40
+ originalType?: OldTypeKeys | (string & Record<never, never>) | null,
41
+ ) => `${ControlType}` | string | null | undefined;
42
+
43
+ export const establishNewPriority: EstablishNewPriorityType = (originalPriority, originalType) => {
44
+ const type = originalType ? establishNewType(originalType) : '';
45
+
46
+ // The old SECONDARY and LINK types now map to priorities. If they're still using one of
47
+ // these old types, ignore whatever priority they've passed and use this instead.
48
+ if (originalType && originalType in oldTypePriorityMap) {
49
+ return oldTypePriorityMap[originalType as OldTypeKeys];
50
+ }
51
+ // Only ControlType.ACCENT supports tertiary styles
52
+ if (originalPriority === Priority.TERTIARY && type !== ControlType.ACCENT) {
53
+ return Priority.SECONDARY;
54
+ }
55
+ return originalPriority;
56
+ };
57
+
58
+ type DeprecatedTypeMapMessageType = keyof typeof deprecatedTypeMapMessage;
59
+ type LogDeprecationNoticesType = (params: {
60
+ size: `${Size}`;
61
+ type: DeprecatedTypeMapMessageType | (string & Record<never, never>) | null;
62
+ }) => void;
63
+ export const logDeprecationNotices: LogDeprecationNoticesType = ({ size, type }) => {
64
+ logActionRequiredIf(
65
+ 'Button has deprecated the `Size.EXTRA_SMALL` value for the `size` prop. Please use Size.SMALL instead.',
66
+ size === Size.EXTRA_SMALL,
67
+ );
68
+
69
+ if (type && deprecatedTypes.includes(type) && type in deprecatedTypeMapMessage) {
70
+ logActionRequired(
71
+ `Button has deprecated the ${type} value for the \`type\` prop. Please update to ${deprecatedTypeMapMessage[type as DeprecatedTypeMapMessageType]}.`,
72
+ );
73
+ }
74
+ };
@@ -4,7 +4,7 @@ export const fakeEvent = () => ({
4
4
  preventDefault() {},
5
5
  });
6
6
 
7
- export const fakeKeyDownEventForKey = (key) => ({
7
+ export const fakeKeyDownEventForKey = (key: string) => ({
8
8
  ...fakeEvent(),
9
9
  key,
10
10
  });
@@ -1,6 +1,6 @@
1
1
  import { useEffect, useState } from 'react';
2
2
 
3
- const ObserverParams = {
3
+ const ObserverParams: IntersectionObserverInit = {
4
4
  threshold: 0.1,
5
5
  };
6
6
 
@@ -9,13 +9,19 @@ const ObserverParams = {
9
9
  * Use this custom hook to detect when an element has became visible inside the viewport. This hook checks only if the intersection happend.
10
10
  * Once the intersection has happened the hook will not return false even if the element gets out of the viewport.
11
11
  *
12
- * @param elRef.elRef
13
- * @param {object} [elRef] - node object that contains a react reference to the element that needs to be observed.
14
- * @param {strimng} [loading = 'eager'] - string that contains the type of loading.
12
+ * @param {object} params
13
+ * @param {object} [params.elRef] - node object that contains a react reference to the element that needs to be observed.
14
+ * @param {string} [params.loading = 'eager'] - string that contains the type of loading.
15
15
  * @param elRef.loading
16
16
  * @usage `const [hasIntersected] = useHasIntersected({imageRef,loading});`
17
17
  */
18
- export const useHasIntersected = ({ elRef, loading }) => {
18
+ export const useHasIntersected = ({
19
+ elRef,
20
+ loading = 'eager',
21
+ }: {
22
+ elRef: React.RefObject<HTMLElement>;
23
+ loading?: 'eager' | 'lazy';
24
+ }) => {
19
25
  const [hasIntersected, setHasIntersected] = useState(false);
20
26
 
21
27
  const { current } = elRef || {};
@@ -24,29 +30,32 @@ export const useHasIntersected = ({ elRef, loading }) => {
24
30
  return elRef && current;
25
31
  };
26
32
 
27
- const handleOnIntersect = (entries, observer) => {
33
+ const handleOnIntersect: IntersectionObserverCallback = (entries, observer) => {
28
34
  entries.forEach((entry) => {
29
35
  if (entry.isIntersecting) {
30
36
  setHasIntersected(true);
31
- observer.unobserve(current);
37
+
38
+ if (current) {
39
+ observer.unobserve(current);
40
+ }
32
41
  }
33
42
  });
34
43
  };
35
44
 
36
45
  useEffect(() => {
37
- let observer;
46
+ let observer: IntersectionObserver | undefined;
38
47
  let didCancel = false;
39
48
 
40
- // Check if window is define for SSR and Old browsers fallback
49
+ // Check if window is defined for SSR and Old browsers fallback
41
50
  if (typeof window === 'undefined' || !window.IntersectionObserver || !isValidReference()) {
42
51
  setHasIntersected(true);
43
- } else if (!didCancel) {
52
+ } else if (current && !didCancel) {
44
53
  observer = new IntersectionObserver(handleOnIntersect, ObserverParams);
45
54
  observer.observe(current);
46
55
  }
47
56
  return () => {
48
57
  didCancel = true;
49
- if (observer) {
58
+ if (observer && current) {
50
59
  observer.unobserve(current);
51
60
  }
52
61
  };
@@ -24,6 +24,10 @@ const avatarProfiles = {
24
24
  Business: <BriefcaseIcon />,
25
25
  Profile: <ProfileIcon />,
26
26
  };
27
+ type ProfileTypeKeys = keyof typeof ProfileType;
28
+
29
+ const getAvatarProfile = (showAvatar: string) =>
30
+ showAvatar in avatarProfiles ? avatarProfiles[showAvatar as keyof typeof avatarProfiles] : null;
27
31
 
28
32
  export const Variants = () => {
29
33
  const [activeStep, setActiveStep] = useState(2);
@@ -32,7 +36,11 @@ export const Variants = () => {
32
36
  const showCloseButton = boolean('show closeButton', true);
33
37
  const showMobileBackButton = boolean('show mobile backButton', true);
34
38
  const done = boolean('done', false);
35
- const profileType = select('profileType', Object.keys(ProfileType));
39
+ const profileType: ProfileTypeKeys | undefined = select(
40
+ 'profileType',
41
+ Object.keys(ProfileType) as ProfileTypeKeys[],
42
+ undefined,
43
+ );
36
44
  const avatarURL = text(
37
45
  'avatarURL',
38
46
  'https://wise.com/web-art/assets/illustrations/heart-small@2x.webp',
@@ -44,7 +52,7 @@ export const Variants = () => {
44
52
  avatar={
45
53
  !showAvatar ? null : (
46
54
  <Avatar type={AvatarType.ICON} size={Size.MEDIUM}>
47
- {avatarProfiles[showAvatar]}
55
+ {getAvatarProfile(showAvatar)}
48
56
  </Avatar>
49
57
  )
50
58
  }
@@ -70,9 +78,11 @@ export const Variants = () => {
70
78
  onClick: () => setActiveStep(4),
71
79
  },
72
80
  ]}
73
- onClose={showCloseButton && (() => setClosed(true))}
81
+ onClose={showCloseButton ? () => setClosed(true) : undefined}
74
82
  onGoBack={
75
- showMobileBackButton && (() => setActiveStep(activeStep > 0 ? activeStep - 1 : 0))
83
+ showMobileBackButton
84
+ ? () => setActiveStep(activeStep > 0 ? activeStep - 1 : 0)
85
+ : undefined
76
86
  }
77
87
  />
78
88
 
@@ -112,9 +122,11 @@ export const Variants = () => {
112
122
  onClick: () => setActiveStep(4),
113
123
  },
114
124
  ]}
115
- onClose={showCloseButton && (() => setClosed(true))}
125
+ onClose={showCloseButton ? () => setClosed(true) : undefined}
116
126
  onGoBack={
117
- showMobileBackButton && (() => setActiveStep(activeStep - 1 > 0 ? activeStep - 1 : 0))
127
+ showMobileBackButton
128
+ ? () => setActiveStep(activeStep - 1 > 0 ? activeStep - 1 : 0)
129
+ : undefined
118
130
  }
119
131
  />
120
132
 
@@ -155,9 +167,11 @@ export const Variants = () => {
155
167
  onClick: () => setActiveStep(4),
156
168
  },
157
169
  ]}
158
- onClose={showCloseButton && (() => setClosed(true))}
170
+ onClose={showCloseButton ? () => setClosed(true) : undefined}
159
171
  onGoBack={
160
- showMobileBackButton && (() => setActiveStep(activeStep - 1 > 0 ? activeStep - 1 : 0))
172
+ showMobileBackButton
173
+ ? () => setActiveStep(activeStep - 1 > 0 ? activeStep - 1 : 0)
174
+ : undefined
161
175
  }
162
176
  />
163
177
 
@@ -171,9 +185,11 @@ export const Variants = () => {
171
185
  { label: 'Review', hoverLabel: 'Antonio Dozortevo', onClick: () => setActiveStep(1) },
172
186
  { label: 'Pay', hoverLabel: 'Enrico Gusso', onClick: () => setActiveStep(2) },
173
187
  ]}
174
- onClose={showCloseButton && (() => setClosed(true))}
188
+ onClose={showCloseButton ? () => setClosed(true) : undefined}
175
189
  onGoBack={
176
- showMobileBackButton && (() => setActiveStep(activeStep - 1 > 0 ? activeStep - 1 : 0))
190
+ showMobileBackButton
191
+ ? () => setActiveStep(activeStep - 1 > 0 ? activeStep - 1 : 0)
192
+ : undefined
177
193
  }
178
194
  />
179
195
 
@@ -216,7 +232,7 @@ export const SendFlow = () => {
216
232
  ...(activeStep > 3 && { onClick: handleStepClick(3) }),
217
233
  },
218
234
  ];
219
- function handleStepClick(step) {
235
+ function handleStepClick(step: number) {
220
236
  return () => {
221
237
  setActiveStep(step);
222
238
  };
@@ -268,16 +284,18 @@ export const WithOverlayHeaderComparison = () => {
268
284
  avatar={
269
285
  showAvatar ? (
270
286
  <Avatar type={AvatarType.ICON} size={Size.MEDIUM}>
271
- {avatarProfiles[showAvatar]}
287
+ {getAvatarProfile(showAvatar)}
272
288
  </Avatar>
273
289
  ) : null
274
290
  }
275
291
  activeStep={activeStep}
276
292
  done={done}
277
293
  steps={[]}
278
- onClose={showCloseButton && (() => setClosed(true))}
294
+ onClose={showCloseButton ? () => setClosed(true) : undefined}
279
295
  onGoBack={
280
- showMobileBackButton && (() => setActiveStep(activeStep > 0 ? activeStep - 1 : 0))
296
+ showMobileBackButton
297
+ ? () => setActiveStep(activeStep > 0 ? activeStep - 1 : 0)
298
+ : undefined
281
299
  }
282
300
  />
283
301
  </div>
@@ -286,11 +304,11 @@ export const WithOverlayHeaderComparison = () => {
286
304
  avatar={
287
305
  showAvatar ? (
288
306
  <Avatar type={AvatarType.ICON} size={Size.MEDIUM}>
289
- {avatarProfiles[showAvatar]}
307
+ {getAvatarProfile(showAvatar)}
290
308
  </Avatar>
291
309
  ) : null
292
310
  }
293
- onClose={showCloseButton && (() => setClosed(true))}
311
+ onClose={showCloseButton ? () => setClosed(true) : undefined}
294
312
  />
295
313
  </div>
296
314
  </>
package/src/index.ts CHANGED
@@ -59,6 +59,7 @@ export type {
59
59
  MoneyInputProps,
60
60
  } from './moneyInput';
61
61
  export type { NavigationOptionListProps } from './navigationOptionsList';
62
+ export type { NavigationOptionProps } from './navigationOption/NavigationOption';
62
63
  export type { OverlayHeaderProps } from './overlayHeader';
63
64
  export type { PanelProps } from './common/panel';
64
65
  export type { PhoneNumberInputProps } from './phoneNumberInput/PhoneNumberInput';
@@ -0,0 +1,78 @@
1
+ import { userEvent, within, fn } from '@storybook/test';
2
+
3
+ import InputWithDisplayFormat, { InputWithDisplayFormatProps } from '.';
4
+ import { Field, FieldProps } from '../field/Field';
5
+ import { Meta, type StoryObj } from '@storybook/react';
6
+
7
+ type Story = StoryObj<InputWithDisplayFormatProps & { label: string }>;
8
+
9
+ const meta = {
10
+ title: 'Forms/InputWithDisplayFormat',
11
+ component: InputWithDisplayFormat,
12
+ render: function Render({ label, ...args }: InputWithDisplayFormatProps & FieldProps) {
13
+ return (
14
+ <Field label={label} id={args.id}>
15
+ <InputWithDisplayFormat id={args.id} {...args} />
16
+ </Field>
17
+ );
18
+ },
19
+ args: {
20
+ onFocus: fn(),
21
+ onBlur: fn(),
22
+ onChange: fn(),
23
+ },
24
+ } satisfies Meta<typeof InputWithDisplayFormat>;
25
+ export default meta;
26
+
27
+ export const Basic: Story = {
28
+ args: {
29
+ label: 'Sort Code',
30
+ placeholder: '**-**-**',
31
+ displayPattern: '**-**-**',
32
+ },
33
+ };
34
+
35
+ export const CardNumber: Story = {
36
+ args: {
37
+ label: 'Card Number',
38
+ placeholder: '**** **** **** **** ***',
39
+ displayPattern: '**** **** **** **** ***',
40
+ },
41
+ };
42
+
43
+ export const CVC: Story = {
44
+ args: {
45
+ label: 'CVC',
46
+ placeholder: '***',
47
+ displayPattern: '***',
48
+ value: '',
49
+ },
50
+ };
51
+
52
+ export const ExpiryDate: Story = {
53
+ args: {
54
+ label: 'Expiry Date',
55
+ placeholder: '** / **',
56
+ displayPattern: '** / **',
57
+ },
58
+ };
59
+
60
+ export const SecurityPin: Story = {
61
+ args: {
62
+ label: 'Security Pin',
63
+ placeholder: '*-*-*-*-*-*',
64
+ displayPattern: '*-*-*-*-*-*',
65
+ },
66
+ };
67
+
68
+ export const SecurityPinPlay: Story = {
69
+ args: {
70
+ label: 'Security Pin Play',
71
+ placeholder: '*-*-*-*-*-*',
72
+ displayPattern: '*-*-*-*-*-*',
73
+ },
74
+ play: async ({ canvasElement }) => {
75
+ const canvas = within(canvasElement);
76
+ await userEvent.type(canvas.getByPlaceholderText('*-*-*-*-*-*'), '123456');
77
+ },
78
+ };
@@ -1,3 +1,4 @@
1
+ import { ReactNode } from 'react';
1
2
  import { action } from '@storybook/addon-actions';
2
3
  import { text, boolean } from '@storybook/addon-knobs';
3
4
  import {
@@ -19,8 +20,22 @@ export default {
19
20
  tags: ['autodocs'],
20
21
  };
21
22
 
22
- const Template = (props) => {
23
- const href = text('href', props.href);
23
+ type TemplateTypes = {
24
+ href?: string;
25
+ title?: string;
26
+ content?: string;
27
+ complex?: boolean;
28
+ disabled?: boolean;
29
+ showMediaAtAllSizes?: boolean;
30
+ showMediaCircle?: boolean;
31
+ isContainerAligned?: boolean;
32
+ className?: string;
33
+ hasTitleOnly?: boolean;
34
+ media?: ReactNode;
35
+ };
36
+
37
+ const Template = (props: TemplateTypes) => {
38
+ const href = text('href', props.href ?? '');
24
39
  const title = text('title', props.title ?? 'Navigation option');
25
40
  const content = text('content', props.content ?? 'Button and icon are vertically centered.');
26
41
  const complex = boolean('complex', props.complex ?? false);
@@ -28,7 +43,7 @@ const Template = (props) => {
28
43
  const showMediaAtAllSizes = boolean('showMediaAtAllSizes', props.showMediaAtAllSizes ?? false);
29
44
  const showMediaCircle = props.showMediaCircle ?? boolean('showMediaCircle', true);
30
45
  const isContainerAligned = boolean('isContainerAligned', false);
31
- const className = text('className', props.className);
46
+ const className = text('className', props.className ?? '');
32
47
 
33
48
  return (
34
49
  <NavigationOption
@@ -140,7 +155,10 @@ export const Multiple = () => (
140
155
 
141
156
  export const WithIllustration = () => {
142
157
  return (
143
- <Template media={<Illustration name={Assets.GLOBE} disablePadding />} showMediaCircle={false} />
158
+ <Template
159
+ media={<Illustration name={Assets.GLOBE} disablePadding alt="" />}
160
+ showMediaCircle={false}
161
+ />
144
162
  );
145
163
  };
146
164
 
@@ -166,7 +184,7 @@ export const WithContainerContent = () => (
166
184
  </>
167
185
  );
168
186
 
169
- const NavigationOptionTemplate = (props) => {
187
+ const NavigationOptionTemplate = (props: TemplateTypes) => {
170
188
  const {
171
189
  href,
172
190
  title,
@@ -6,7 +6,7 @@ import { Position } from '../common';
6
6
  import Option from '../common/Option';
7
7
  import { OptionProps, ReferenceType } from '../common/Option/Option';
8
8
 
9
- type NavigationOptionProps = OptionProps;
9
+ export type NavigationOptionProps = OptionProps;
10
10
 
11
11
  const NavigationOption = forwardRef<ReferenceType, NavigationOptionProps>(
12
12
  ({ as: component = 'button', disabled = false, onClick, className, ...rest }, reference) => {