@transferwise/components 46.130.2 → 46.131.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 (610) hide show
  1. package/build/dateInput/DateInput.js +12 -5
  2. package/build/dateInput/DateInput.js.map +1 -1
  3. package/build/dateInput/DateInput.mjs +11 -4
  4. package/build/dateInput/DateInput.mjs.map +1 -1
  5. package/build/expressiveMoneyInput/currencySelector/CurrencySelector.js +16 -8
  6. package/build/expressiveMoneyInput/currencySelector/CurrencySelector.js.map +1 -1
  7. package/build/expressiveMoneyInput/currencySelector/CurrencySelector.mjs +14 -6
  8. package/build/expressiveMoneyInput/currencySelector/CurrencySelector.mjs.map +1 -1
  9. package/build/index.js +12 -7
  10. package/build/index.js.map +1 -1
  11. package/build/index.mjs +9 -3
  12. package/build/index.mjs.map +1 -1
  13. package/build/inputs/{_BottomSheet.js → SelectInput/BottomSheet/SelectInputBottomSheet.js} +7 -7
  14. package/build/inputs/SelectInput/BottomSheet/SelectInputBottomSheet.js.map +1 -0
  15. package/build/inputs/{_BottomSheet.mjs → SelectInput/BottomSheet/SelectInputBottomSheet.mjs} +7 -7
  16. package/build/inputs/SelectInput/BottomSheet/SelectInputBottomSheet.mjs.map +1 -0
  17. package/build/inputs/{_ButtonInput.js → SelectInput/ButtonInput/SelectInputButtonInput.js} +5 -5
  18. package/build/inputs/SelectInput/ButtonInput/SelectInputButtonInput.js.map +1 -0
  19. package/build/inputs/{_ButtonInput.mjs → SelectInput/ButtonInput/SelectInputButtonInput.mjs} +5 -5
  20. package/build/inputs/SelectInput/ButtonInput/SelectInputButtonInput.mjs.map +1 -0
  21. package/build/inputs/SelectInput/ClearButton/SelectInputClearButton.js +26 -0
  22. package/build/inputs/SelectInput/ClearButton/SelectInputClearButton.js.map +1 -0
  23. package/build/inputs/SelectInput/ClearButton/SelectInputClearButton.mjs +24 -0
  24. package/build/inputs/SelectInput/ClearButton/SelectInputClearButton.mjs.map +1 -0
  25. package/build/inputs/SelectInput/DefaultRenderTrigger/SelectInputDefaultRenderTrigger.js +59 -0
  26. package/build/inputs/SelectInput/DefaultRenderTrigger/SelectInputDefaultRenderTrigger.js.map +1 -0
  27. package/build/inputs/SelectInput/DefaultRenderTrigger/SelectInputDefaultRenderTrigger.mjs +56 -0
  28. package/build/inputs/SelectInput/DefaultRenderTrigger/SelectInputDefaultRenderTrigger.mjs.map +1 -0
  29. package/build/inputs/SelectInput/ItemView/GroupItemView/SelectInputGroupItemView.js +50 -0
  30. package/build/inputs/SelectInput/ItemView/GroupItemView/SelectInputGroupItemView.js.map +1 -0
  31. package/build/inputs/SelectInput/ItemView/GroupItemView/SelectInputGroupItemView.mjs +48 -0
  32. package/build/inputs/SelectInput/ItemView/GroupItemView/SelectInputGroupItemView.mjs.map +1 -0
  33. package/build/inputs/SelectInput/ItemView/SelectInputItemView.js +47 -0
  34. package/build/inputs/SelectInput/ItemView/SelectInputItemView.js.map +1 -0
  35. package/build/inputs/SelectInput/ItemView/SelectInputItemView.mjs +45 -0
  36. package/build/inputs/SelectInput/ItemView/SelectInputItemView.mjs.map +1 -0
  37. package/build/inputs/SelectInput/Option/SelectInputOption.js +42 -0
  38. package/build/inputs/SelectInput/Option/SelectInputOption.js.map +1 -0
  39. package/build/inputs/SelectInput/Option/SelectInputOption.mjs +40 -0
  40. package/build/inputs/SelectInput/Option/SelectInputOption.mjs.map +1 -0
  41. package/build/inputs/SelectInput/OptionContent/SelectInputOptionContent.js +40 -0
  42. package/build/inputs/SelectInput/OptionContent/SelectInputOptionContent.js.map +1 -0
  43. package/build/inputs/SelectInput/OptionContent/SelectInputOptionContent.mjs +38 -0
  44. package/build/inputs/SelectInput/OptionContent/SelectInputOptionContent.mjs.map +1 -0
  45. package/build/inputs/SelectInput/Options/OptionsContainer/SelectInputOptionsContainer.js +48 -0
  46. package/build/inputs/SelectInput/Options/OptionsContainer/SelectInputOptionsContainer.js.map +1 -0
  47. package/build/inputs/SelectInput/Options/OptionsContainer/SelectInputOptionsContainer.mjs +46 -0
  48. package/build/inputs/SelectInput/Options/OptionsContainer/SelectInputOptionsContainer.mjs.map +1 -0
  49. package/build/inputs/SelectInput/Options/SelectInputOptions.js +300 -0
  50. package/build/inputs/SelectInput/Options/SelectInputOptions.js.map +1 -0
  51. package/build/inputs/SelectInput/Options/SelectInputOptions.mjs +298 -0
  52. package/build/inputs/SelectInput/Options/SelectInputOptions.mjs.map +1 -0
  53. package/build/inputs/{_Popover.js → SelectInput/Popover/SelectInputPopover.js} +7 -7
  54. package/build/inputs/SelectInput/Popover/SelectInputPopover.js.map +1 -0
  55. package/build/inputs/{_Popover.mjs → SelectInput/Popover/SelectInputPopover.mjs} +7 -7
  56. package/build/inputs/SelectInput/Popover/SelectInputPopover.mjs.map +1 -0
  57. package/build/inputs/SelectInput/SelectInput.contexts.js +29 -0
  58. package/build/inputs/SelectInput/SelectInput.contexts.js.map +1 -0
  59. package/build/inputs/SelectInput/SelectInput.contexts.mjs +24 -0
  60. package/build/inputs/SelectInput/SelectInput.contexts.mjs.map +1 -0
  61. package/build/inputs/SelectInput/SelectInput.js +222 -0
  62. package/build/inputs/SelectInput/SelectInput.js.map +1 -0
  63. package/build/inputs/SelectInput/SelectInput.messages.js.map +1 -0
  64. package/build/inputs/SelectInput/SelectInput.messages.mjs.map +1 -0
  65. package/build/inputs/SelectInput/SelectInput.mjs +216 -0
  66. package/build/inputs/SelectInput/SelectInput.mjs.map +1 -0
  67. package/build/inputs/SelectInput/SelectInput.utils.js +164 -0
  68. package/build/inputs/SelectInput/SelectInput.utils.js.map +1 -0
  69. package/build/inputs/SelectInput/SelectInput.utils.mjs +154 -0
  70. package/build/inputs/SelectInput/SelectInput.utils.mjs.map +1 -0
  71. package/build/inputs/SelectInput/TriggerButton/SelectInputTriggerButton.js +42 -0
  72. package/build/inputs/SelectInput/TriggerButton/SelectInputTriggerButton.js.map +1 -0
  73. package/build/inputs/SelectInput/TriggerButton/SelectInputTriggerButton.mjs +36 -0
  74. package/build/inputs/SelectInput/TriggerButton/SelectInputTriggerButton.mjs.map +1 -0
  75. package/build/main.css +27094 -97
  76. package/build/moneyInput/MoneyInput.js +9 -2
  77. package/build/moneyInput/MoneyInput.js.map +1 -1
  78. package/build/moneyInput/MoneyInput.mjs +8 -1
  79. package/build/moneyInput/MoneyInput.mjs.map +1 -1
  80. package/build/phoneNumberInput/PhoneNumberInput.js +10 -3
  81. package/build/phoneNumberInput/PhoneNumberInput.js.map +1 -1
  82. package/build/phoneNumberInput/PhoneNumberInput.mjs +9 -2
  83. package/build/phoneNumberInput/PhoneNumberInput.mjs.map +1 -1
  84. package/build/styles/css/accordion.css +255 -0
  85. package/build/styles/css/alerts.css +751 -0
  86. package/build/styles/css/background.css +20 -0
  87. package/build/styles/css/badge.css +90 -0
  88. package/build/styles/css/border-radius.css +3 -0
  89. package/build/styles/css/breadcrumbs.css +20 -0
  90. package/build/styles/css/button-groups.css +495 -0
  91. package/build/styles/css/buttons.css +1390 -0
  92. package/build/styles/css/chevron.css +35 -0
  93. package/build/styles/css/circles.css +248 -0
  94. package/build/styles/css/close.css +47 -0
  95. package/build/styles/css/column-layout.css +164 -0
  96. package/build/styles/css/currency-flags.css +46 -0
  97. package/build/styles/css/decision.css +136 -0
  98. package/build/styles/css/dropdowns.css +472 -0
  99. package/build/styles/css/droppable.css +221 -0
  100. package/build/styles/css/flex.css +598 -0
  101. package/build/styles/css/footer.css +129 -0
  102. package/build/styles/css/grid.css +2369 -0
  103. package/build/styles/css/input-groups.css +2740 -0
  104. package/build/styles/css/link-callout.css +20 -0
  105. package/build/styles/css/list-group.css +350 -0
  106. package/build/styles/css/loaders.css +76 -0
  107. package/build/styles/css/media.css +74 -0
  108. package/build/styles/css/modals.css +185 -0
  109. package/build/styles/css/navbar.css +2406 -0
  110. package/build/styles/css/navs.css +296 -0
  111. package/build/styles/css/neptune-social-media.css +144 -0
  112. package/build/styles/css/neptune.css +25724 -0
  113. package/build/styles/css/panels.css +528 -0
  114. package/build/styles/css/popovers.css +661 -0
  115. package/build/styles/css/process.css +483 -0
  116. package/build/styles/css/progress-bars.css +64 -0
  117. package/build/styles/css/ring.css +55 -0
  118. package/build/styles/css/select.css +99 -0
  119. package/build/styles/css/sequences.css +855 -0
  120. package/build/styles/css/table.css +446 -0
  121. package/build/styles/css/tick.css +32 -0
  122. package/build/styles/css/tooltip.css +160 -0
  123. package/build/styles/css/utilities.css +145 -0
  124. package/build/styles/css/wells.css +74 -0
  125. package/build/styles/fonts/TW-Averta-Bold.woff +0 -0
  126. package/build/styles/fonts/TW-Averta-Bold.woff2 +0 -0
  127. package/build/styles/fonts/TW-Averta-Regular.woff +0 -0
  128. package/build/styles/fonts/TW-Averta-Regular.woff2 +0 -0
  129. package/build/styles/fonts/TW-Averta-Semibold.woff +0 -0
  130. package/build/styles/fonts/TW-Averta-Semibold.woff2 +0 -0
  131. package/build/styles/fonts/TransferWise-IconFont.svg +81 -0
  132. package/build/styles/fonts/TransferWise-IconFont.woff +0 -0
  133. package/build/styles/fonts/WiseSans-Heavy.woff2 +0 -0
  134. package/build/styles/fonts/inter-cyrillic-ext-variable-wghtOnly-normal.woff2 +0 -0
  135. package/build/styles/fonts/inter-cyrillic-variable-wghtOnly-normal.woff2 +0 -0
  136. package/build/styles/fonts/inter-greek-ext-variable-wghtOnly-normal.woff2 +0 -0
  137. package/build/styles/fonts/inter-greek-variable-wghtOnly-normal.woff2 +0 -0
  138. package/build/styles/fonts/inter-latin-ext-variable-wghtOnly-normal.woff2 +0 -0
  139. package/build/styles/fonts/inter-latin-variable-wghtOnly-normal.woff2 +0 -0
  140. package/build/styles/fonts/inter-vietnamese-variable-wghtOnly-normal.woff2 +0 -0
  141. package/build/styles/img/bg-dark.svg +31 -0
  142. package/build/styles/img/bg-light.svg +26 -0
  143. package/build/styles/inputs/SelectInput/BottomSheet/SelectInputBottomSheet.css +96 -0
  144. package/build/styles/inputs/SelectInput/ButtonInput/SelectInputButtonInput.css +16 -0
  145. package/build/styles/inputs/SelectInput/ClearButton/SelectInputClearButton.css +46 -0
  146. package/build/styles/inputs/SelectInput/ItemView/SelectInputItemView.css +16 -0
  147. package/build/styles/inputs/SelectInput/Option/SelectInputOption.css +33 -0
  148. package/build/styles/inputs/SelectInput/OptionContent/SelectInputOptionContent.css +37 -0
  149. package/build/styles/inputs/SelectInput/Options/SelectInputOptions.css +81 -0
  150. package/build/styles/inputs/SelectInput/Popover/SelectInputPopover.css +46 -0
  151. package/build/styles/less/legacy-variables.css +0 -0
  152. package/build/styles/less/legacy-variables.less +1299 -0
  153. package/build/styles/less/neptune-tokens.css +0 -0
  154. package/build/styles/less/neptune-tokens.less +275 -0
  155. package/build/styles/less/zindex.css +0 -0
  156. package/build/styles/less/zindex.less +17 -0
  157. package/build/styles/main.css +27094 -97
  158. package/build/styles/props/custom-media.css +11 -0
  159. package/build/styles/props/legacy-custom-props.css +69 -0
  160. package/build/styles/props/neptune-tokens.css +152 -0
  161. package/build/styles/styles/less/accordion.css +255 -0
  162. package/build/styles/styles/less/alerts.css +751 -0
  163. package/build/styles/styles/less/background.css +20 -0
  164. package/build/styles/styles/less/badge.css +90 -0
  165. package/build/styles/styles/less/border-radius.css +3 -0
  166. package/build/styles/styles/less/breadcrumbs.css +20 -0
  167. package/build/styles/styles/less/button-groups.css +495 -0
  168. package/build/styles/styles/less/buttons.css +1390 -0
  169. package/build/styles/styles/less/chevron.css +35 -0
  170. package/build/styles/styles/less/circles.css +248 -0
  171. package/build/styles/styles/less/close.css +47 -0
  172. package/build/styles/styles/less/column-layout.css +164 -0
  173. package/build/styles/styles/less/core/viewport-themes.css +59 -0
  174. package/build/styles/styles/less/currency-flags.css +46 -0
  175. package/build/styles/styles/less/decision.css +136 -0
  176. package/build/styles/styles/less/dropdowns.css +472 -0
  177. package/build/styles/styles/less/droppable.css +221 -0
  178. package/build/styles/styles/less/flex.css +598 -0
  179. package/build/styles/styles/less/footer.css +129 -0
  180. package/build/styles/styles/less/forms/bootstrap-forms.css +2277 -0
  181. package/build/styles/styles/less/forms/checkbox-radio.css +367 -0
  182. package/build/styles/styles/less/grid.css +2369 -0
  183. package/build/styles/styles/less/input-groups.css +2740 -0
  184. package/build/styles/styles/less/link-callout.css +20 -0
  185. package/build/styles/styles/less/list-group.css +350 -0
  186. package/build/styles/styles/less/loaders.css +76 -0
  187. package/build/styles/styles/less/media.css +74 -0
  188. package/build/styles/styles/less/modals.css +185 -0
  189. package/build/styles/styles/less/navbar.css +2406 -0
  190. package/build/styles/styles/less/navs.css +296 -0
  191. package/build/styles/styles/less/neptune-social-media.css +144 -0
  192. package/build/styles/styles/less/neptune.css +25724 -0
  193. package/build/styles/styles/less/panels.css +528 -0
  194. package/build/styles/styles/less/popovers.css +661 -0
  195. package/build/styles/styles/less/process.css +483 -0
  196. package/build/styles/styles/less/progress-bars.css +64 -0
  197. package/build/styles/styles/less/ring.css +55 -0
  198. package/build/styles/styles/less/select.css +99 -0
  199. package/build/styles/styles/less/sequences.css +855 -0
  200. package/build/styles/styles/less/table.css +446 -0
  201. package/build/styles/styles/less/tick.css +32 -0
  202. package/build/styles/styles/less/tooltip.css +160 -0
  203. package/build/styles/styles/less/utilities.css +145 -0
  204. package/build/styles/styles/less/wells.css +74 -0
  205. package/build/styles/styles/props/custom-media.css +11 -0
  206. package/build/styles/styles/props/legacy-custom-props.css +69 -0
  207. package/build/styles/styles/props/neptune-tokens.css +11 -0
  208. package/build/styles/styles/variables/legacy-variables.css +0 -0
  209. package/build/styles/styles/variables/neptune-tokens.css +0 -0
  210. package/build/styles/styles/variables/zindex.css +0 -0
  211. package/build/types/index.d.ts +1 -1
  212. package/build/types/index.d.ts.map +1 -1
  213. package/build/types/inputs/{_BottomSheet.d.ts → SelectInput/BottomSheet/SelectInputBottomSheet.d.ts} +3 -3
  214. package/build/types/inputs/SelectInput/BottomSheet/SelectInputBottomSheet.d.ts.map +1 -0
  215. package/build/types/inputs/SelectInput/BottomSheet/index.d.ts +3 -0
  216. package/build/types/inputs/SelectInput/BottomSheet/index.d.ts.map +1 -0
  217. package/build/types/inputs/SelectInput/ButtonInput/SelectInputButtonInput.d.ts +5 -0
  218. package/build/types/inputs/SelectInput/ButtonInput/SelectInputButtonInput.d.ts.map +1 -0
  219. package/build/types/inputs/SelectInput/ButtonInput/index.d.ts +3 -0
  220. package/build/types/inputs/SelectInput/ButtonInput/index.d.ts.map +1 -0
  221. package/build/types/inputs/SelectInput/ClearButton/SelectInputClearButton.d.ts +7 -0
  222. package/build/types/inputs/SelectInput/ClearButton/SelectInputClearButton.d.ts.map +1 -0
  223. package/build/types/inputs/SelectInput/ClearButton/index.d.ts +3 -0
  224. package/build/types/inputs/SelectInput/ClearButton/index.d.ts.map +1 -0
  225. package/build/types/inputs/SelectInput/DefaultRenderTrigger/SelectInputDefaultRenderTrigger.d.ts +16 -0
  226. package/build/types/inputs/SelectInput/DefaultRenderTrigger/SelectInputDefaultRenderTrigger.d.ts.map +1 -0
  227. package/build/types/inputs/SelectInput/DefaultRenderTrigger/index.d.ts +2 -0
  228. package/build/types/inputs/SelectInput/DefaultRenderTrigger/index.d.ts.map +1 -0
  229. package/build/types/inputs/SelectInput/ItemView/GroupItemView/SelectInputGroupItemView.d.ts +9 -0
  230. package/build/types/inputs/SelectInput/ItemView/GroupItemView/SelectInputGroupItemView.d.ts.map +1 -0
  231. package/build/types/inputs/SelectInput/ItemView/GroupItemView/index.d.ts +3 -0
  232. package/build/types/inputs/SelectInput/ItemView/GroupItemView/index.d.ts.map +1 -0
  233. package/build/types/inputs/SelectInput/ItemView/SelectInputItemView.d.ts +11 -0
  234. package/build/types/inputs/SelectInput/ItemView/SelectInputItemView.d.ts.map +1 -0
  235. package/build/types/inputs/SelectInput/ItemView/index.d.ts +4 -0
  236. package/build/types/inputs/SelectInput/ItemView/index.d.ts.map +1 -0
  237. package/build/types/inputs/SelectInput/Option/SelectInputOption.d.ts +11 -0
  238. package/build/types/inputs/SelectInput/Option/SelectInputOption.d.ts.map +1 -0
  239. package/build/types/inputs/SelectInput/Option/index.d.ts +3 -0
  240. package/build/types/inputs/SelectInput/Option/index.d.ts.map +1 -0
  241. package/build/types/inputs/SelectInput/OptionContent/SelectInputOptionContent.d.ts +13 -0
  242. package/build/types/inputs/SelectInput/OptionContent/SelectInputOptionContent.d.ts.map +1 -0
  243. package/build/types/inputs/SelectInput/OptionContent/index.d.ts +3 -0
  244. package/build/types/inputs/SelectInput/OptionContent/index.d.ts.map +1 -0
  245. package/build/types/inputs/SelectInput/Options/OptionsContainer/SelectInputOptionsContainer.d.ts +9 -0
  246. package/build/types/inputs/SelectInput/Options/OptionsContainer/SelectInputOptionsContainer.d.ts.map +1 -0
  247. package/build/types/inputs/SelectInput/Options/OptionsContainer/index.d.ts +3 -0
  248. package/build/types/inputs/SelectInput/Options/OptionsContainer/index.d.ts.map +1 -0
  249. package/build/types/inputs/SelectInput/Options/SelectInputOptions.d.ts +21 -0
  250. package/build/types/inputs/SelectInput/Options/SelectInputOptions.d.ts.map +1 -0
  251. package/build/types/inputs/SelectInput/Options/index.d.ts +4 -0
  252. package/build/types/inputs/SelectInput/Options/index.d.ts.map +1 -0
  253. package/build/types/inputs/{_Popover.d.ts → SelectInput/Popover/SelectInputPopover.d.ts} +3 -3
  254. package/build/types/inputs/SelectInput/Popover/SelectInputPopover.d.ts.map +1 -0
  255. package/build/types/inputs/SelectInput/Popover/index.d.ts +3 -0
  256. package/build/types/inputs/SelectInput/Popover/index.d.ts.map +1 -0
  257. package/build/types/inputs/SelectInput/SelectInput.contexts.d.ts +33 -0
  258. package/build/types/inputs/SelectInput/SelectInput.contexts.d.ts.map +1 -0
  259. package/build/types/inputs/SelectInput/SelectInput.d.ts +10 -0
  260. package/build/types/inputs/SelectInput/SelectInput.d.ts.map +1 -0
  261. package/build/types/inputs/SelectInput/SelectInput.messages.d.ts.map +1 -0
  262. package/build/types/inputs/{SelectInput.d.ts → SelectInput/SelectInput.types.d.ts} +12 -38
  263. package/build/types/inputs/SelectInput/SelectInput.types.d.ts.map +1 -0
  264. package/build/types/inputs/SelectInput/SelectInput.utils.d.ts +60 -0
  265. package/build/types/inputs/SelectInput/SelectInput.utils.d.ts.map +1 -0
  266. package/build/types/inputs/SelectInput/TriggerButton/SelectInputTriggerButton.d.ts +12 -0
  267. package/build/types/inputs/SelectInput/TriggerButton/SelectInputTriggerButton.d.ts.map +1 -0
  268. package/build/types/inputs/SelectInput/TriggerButton/index.d.ts +3 -0
  269. package/build/types/inputs/SelectInput/TriggerButton/index.d.ts.map +1 -0
  270. package/build/types/inputs/SelectInput/components.d.ts +10 -0
  271. package/build/types/inputs/SelectInput/components.d.ts.map +1 -0
  272. package/build/types/inputs/SelectInput/index.d.ts +10 -0
  273. package/build/types/inputs/SelectInput/index.d.ts.map +1 -0
  274. package/package.json +9 -5
  275. package/src/{DisabledComponents.story.tsx → DisabledComponents.test.story.tsx} +1 -1
  276. package/src/accordion/Accordion.less +3 -3
  277. package/src/actionButton/ActionButton.less +1 -1
  278. package/src/actionButton/ActionButton.story.tsx +11 -7
  279. package/src/actionButton/ActionButton.test.story.tsx +49 -0
  280. package/src/avatar/Avatar.less +3 -3
  281. package/src/avatarLayout/AvatarLayout.story.tsx +1 -105
  282. package/src/avatarLayout/AvatarLayout.test.story.tsx +117 -0
  283. package/src/avatarView/AvatarView.story.tsx +1 -104
  284. package/src/avatarView/AvatarView.test.story.tsx +114 -0
  285. package/src/badge/Badge.less +1 -1
  286. package/src/button/LegacyButton.less +1 -1
  287. package/src/button/LegacyButton.story.tsx +1 -26
  288. package/src/button/LegacyButton.test.story.tsx +37 -0
  289. package/src/button/_stories/Button.story.tsx +17 -41
  290. package/src/button/_stories/Button.test.story.tsx +30 -0
  291. package/src/card/Card.less +3 -3
  292. package/src/checkbox/Checkbox.story.tsx +1 -6
  293. package/src/checkbox/Checkbox.test.story.tsx +33 -0
  294. package/src/checkboxButton/CheckboxButton.less +2 -2
  295. package/src/chips/Chip.less +3 -3
  296. package/src/circularButton/CircularButton.story.tsx +0 -6
  297. package/src/circularButton/CircularButton.test.story.tsx +62 -1
  298. package/src/common/Option/Option.less +2 -2
  299. package/src/common/bottomSheet/BottomSheet.less +1 -1
  300. package/src/common/bottomSheet/BottomSheet.story.tsx +0 -55
  301. package/src/common/bottomSheet/BottomSheet.test.story.tsx +118 -2
  302. package/src/common/closeButton/CloseButton.less +1 -1
  303. package/src/common/panel/Panel.less +1 -1
  304. package/src/criticalBanner/CriticalCommsBanner.test.story.tsx +1 -1
  305. package/src/dateLookup/DateLookup.less +1 -1
  306. package/src/dateLookup/DateLookup.story.tsx +0 -18
  307. package/src/dateLookup/DateLookup.test.story.tsx +51 -1
  308. package/src/dateLookup/dateTrigger/DateTrigger.less +2 -2
  309. package/src/decision/Decision.less +1 -1
  310. package/src/definitionList/DefinitionList.less +1 -1
  311. package/src/dimmer/Dimmer.less +2 -2
  312. package/src/divider/Divider.story.tsx +0 -1
  313. package/src/expressiveMoneyInput/ExpressiveMoneyInput.autofocus.docs.mdx +1 -1
  314. package/src/expressiveMoneyInput/ExpressiveMoneyInput.story.tsx +0 -9
  315. package/src/expressiveMoneyInput/ExpressiveMoneyInput.test.story.tsx +23 -0
  316. package/src/field/Field.story.tsx +1 -34
  317. package/src/field/Field.test.story.tsx +56 -0
  318. package/src/flowNavigation/FlowNavigation.less +1 -1
  319. package/src/flowNavigation/animatedLabel/AnimatedLabel.less +2 -2
  320. package/src/header/Header.test.story.tsx +1 -1
  321. package/src/index.ts +0 -1
  322. package/src/info/Info.less +1 -1
  323. package/src/info/Info.story.tsx +1 -34
  324. package/src/info/Info.test.story.tsx +53 -0
  325. package/src/inputWithDisplayFormat/InputWithDisplayFormat.story.tsx +0 -12
  326. package/src/inputWithDisplayFormat/InputWithDisplayFormat.test.story.tsx +33 -0
  327. package/src/inputs/SelectInput/BottomSheet/SelectInputBottomSheet.css +96 -0
  328. package/src/inputs/{_BottomSheet.tsx → SelectInput/BottomSheet/SelectInputBottomSheet.tsx} +7 -7
  329. package/src/inputs/SelectInput/BottomSheet/index.ts +2 -0
  330. package/src/inputs/SelectInput/ButtonInput/SelectInputButtonInput.css +16 -0
  331. package/src/inputs/{_ButtonInput.tsx → SelectInput/ButtonInput/SelectInputButtonInput.tsx} +5 -5
  332. package/src/inputs/SelectInput/ButtonInput/index.ts +2 -0
  333. package/src/inputs/SelectInput/ClearButton/SelectInputClearButton.css +46 -0
  334. package/src/inputs/SelectInput/ClearButton/SelectInputClearButton.less +39 -0
  335. package/src/inputs/SelectInput/ClearButton/SelectInputClearButton.tsx +27 -0
  336. package/src/inputs/SelectInput/ClearButton/index.ts +2 -0
  337. package/src/inputs/SelectInput/DefaultRenderTrigger/SelectInputDefaultRenderTrigger.tsx +74 -0
  338. package/src/inputs/SelectInput/DefaultRenderTrigger/index.ts +5 -0
  339. package/src/inputs/SelectInput/ItemView/GroupItemView/SelectInputGroupItemView.tsx +61 -0
  340. package/src/inputs/SelectInput/ItemView/GroupItemView/index.ts +2 -0
  341. package/src/inputs/SelectInput/ItemView/SelectInputItemView.css +16 -0
  342. package/src/inputs/SelectInput/ItemView/SelectInputItemView.less +17 -0
  343. package/src/inputs/SelectInput/ItemView/SelectInputItemView.tsx +48 -0
  344. package/src/inputs/SelectInput/ItemView/index.ts +3 -0
  345. package/src/inputs/SelectInput/Option/SelectInputOption.css +33 -0
  346. package/src/inputs/SelectInput/Option/SelectInputOption.less +32 -0
  347. package/src/inputs/SelectInput/Option/SelectInputOption.tsx +57 -0
  348. package/src/inputs/SelectInput/Option/index.ts +2 -0
  349. package/src/inputs/SelectInput/OptionContent/SelectInputOptionContent.css +37 -0
  350. package/src/inputs/SelectInput/OptionContent/SelectInputOptionContent.less +38 -0
  351. package/src/inputs/SelectInput/OptionContent/SelectInputOptionContent.tsx +72 -0
  352. package/src/inputs/SelectInput/OptionContent/index.ts +2 -0
  353. package/src/inputs/SelectInput/Options/OptionsContainer/SelectInputOptionsContainer.tsx +59 -0
  354. package/src/inputs/SelectInput/Options/OptionsContainer/index.ts +2 -0
  355. package/src/inputs/SelectInput/Options/SelectInputOptions.css +81 -0
  356. package/src/inputs/SelectInput/Options/SelectInputOptions.less +77 -0
  357. package/src/inputs/SelectInput/Options/SelectInputOptions.tsx +411 -0
  358. package/src/inputs/SelectInput/Options/index.ts +3 -0
  359. package/src/inputs/SelectInput/Popover/SelectInputPopover.css +46 -0
  360. package/src/inputs/{_Popover.tsx → SelectInput/Popover/SelectInputPopover.tsx} +7 -7
  361. package/src/inputs/SelectInput/Popover/index.ts +2 -0
  362. package/src/inputs/SelectInput/SelectInput.contexts.tsx +40 -0
  363. package/src/inputs/SelectInput/SelectInput.less +22 -0
  364. package/src/inputs/{SelectInput.test.tsx → SelectInput/SelectInput.test.tsx} +9 -11
  365. package/src/inputs/SelectInput/SelectInput.tsx +257 -0
  366. package/src/inputs/SelectInput/SelectInput.types.ts +113 -0
  367. package/src/inputs/SelectInput/SelectInput.utils.ts +205 -0
  368. package/src/inputs/SelectInput/TriggerButton/SelectInputTriggerButton.tsx +36 -0
  369. package/src/inputs/SelectInput/TriggerButton/index.ts +5 -0
  370. package/src/inputs/{SelectInput.docs.mdx → SelectInput/_stories/SelectInput.docs.mdx} +0 -1
  371. package/src/inputs/{SelectInput.story.tsx → SelectInput/_stories/SelectInput.story.tsx} +11 -8
  372. package/src/inputs/{SelectInput.test.story.tsx → SelectInput/_stories/SelectInput.test.story.tsx} +6 -10
  373. package/src/inputs/SelectInput/components.ts +10 -0
  374. package/src/inputs/SelectInput/index.ts +12 -0
  375. package/src/inputs/_common.less +1 -1
  376. package/src/legacylistItem/LegacyListItem.test.story.tsx +1 -1
  377. package/src/link/Link.less +2 -2
  378. package/src/listItem/ListItem.less +1 -1
  379. package/src/listItem/_stories/Breakpoints/ListItem.noMedia.test.story.tsx +1 -1
  380. package/src/listItem/_stories/Breakpoints/ListItem.sideMedia.test.story.tsx +1 -1
  381. package/src/listItem/_stories/Breakpoints/ListItem.stackedMedia.test.story.tsx +1 -1
  382. package/src/listItem/_stories/ListItem.focus.test.story.tsx +1 -1
  383. package/src/listItem/_stories/ListItem.layout.test.story.tsx +1 -1
  384. package/src/listItem/_stories/variants/ListItem.brightGreen.test.story.tsx +1 -1
  385. package/src/listItem/_stories/variants/ListItem.dark.test.story.tsx +1 -1
  386. package/src/listItem/_stories/variants/ListItem.forestGreen.test.story.tsx +1 -1
  387. package/src/listItem/_stories/variants/ListItem.medium.test.story.tsx +1 -1
  388. package/src/listItem/_stories/variants/ListItem.neutral.test.story.tsx +1 -1
  389. package/src/listItem/_stories/variants/ListItem.personal.test.story.tsx +1 -1
  390. package/src/listItem/_stories/variants/ListItem.rtl.test.story.tsx +1 -1
  391. package/src/listItem/_stories/variants/ListItem.small.test.story.tsx +1 -1
  392. package/src/logo/Logo.story.tsx +0 -6
  393. package/src/logo/Logo.test.story.tsx +20 -0
  394. package/src/main.css +27094 -97
  395. package/src/main.less +3 -1
  396. package/src/modal/Modal.story.tsx +0 -26
  397. package/src/modal/Modal.test.story.tsx +125 -0
  398. package/src/moneyInput/MoneyInput.less +2 -2
  399. package/src/moneyInput/MoneyInput.test.story.tsx +1 -1
  400. package/src/navigationOption/NavigationOption.less +3 -3
  401. package/src/navigationOptionsList/NavigationOptionsList.less +1 -1
  402. package/src/overlayHeader/OverlayHeader.less +1 -1
  403. package/src/phoneNumberInput/PhoneNumberInput.less +1 -1
  404. package/src/popover/Popover.less +1 -1
  405. package/src/prompt/ActionPrompt/ActionPrompt.story.tsx +0 -43
  406. package/src/prompt/ActionPrompt/ActionPrompt.test.story.tsx +45 -1
  407. package/src/radioGroup/RadioGroup.test.story.tsx +1 -1
  408. package/src/select/Select.less +5 -5
  409. package/src/slidingPanel/SlidingPanel.less +2 -2
  410. package/src/snackbar/Snackbar.less +3 -3
  411. package/src/stepper/Stepper.less +3 -3
  412. package/src/stepper/Stepper.test.story.tsx +1 -1
  413. package/src/styles/fonts/TW-Averta-Bold.woff +0 -0
  414. package/src/styles/fonts/TW-Averta-Bold.woff2 +0 -0
  415. package/src/styles/fonts/TW-Averta-Regular.woff +0 -0
  416. package/src/styles/fonts/TW-Averta-Regular.woff2 +0 -0
  417. package/src/styles/fonts/TW-Averta-Semibold.woff +0 -0
  418. package/src/styles/fonts/TW-Averta-Semibold.woff2 +0 -0
  419. package/src/styles/fonts/TransferWise-IconFont.svg +81 -0
  420. package/src/styles/fonts/TransferWise-IconFont.woff +0 -0
  421. package/src/styles/fonts/WiseSans-Heavy.woff2 +0 -0
  422. package/src/styles/fonts/inter-cyrillic-ext-variable-wghtOnly-normal.woff2 +0 -0
  423. package/src/styles/fonts/inter-cyrillic-variable-wghtOnly-normal.woff2 +0 -0
  424. package/src/styles/fonts/inter-greek-ext-variable-wghtOnly-normal.woff2 +0 -0
  425. package/src/styles/fonts/inter-greek-variable-wghtOnly-normal.woff2 +0 -0
  426. package/src/styles/fonts/inter-latin-ext-variable-wghtOnly-normal.woff2 +0 -0
  427. package/src/styles/fonts/inter-latin-variable-wghtOnly-normal.woff2 +0 -0
  428. package/src/styles/fonts/inter-vietnamese-variable-wghtOnly-normal.woff2 +0 -0
  429. package/src/styles/img/bg-dark.svg +31 -0
  430. package/src/styles/img/bg-light.svg +26 -0
  431. package/src/styles/less/accordion.css +255 -0
  432. package/src/styles/less/accordion.less +15 -0
  433. package/src/styles/less/addons/_background-utilities.less +82 -0
  434. package/src/styles/less/addons/_border.less +3 -0
  435. package/src/styles/less/addons/_display-utilities.less +159 -0
  436. package/src/styles/less/addons/_spacing-utilities.less +73 -0
  437. package/src/styles/less/addons/_utilities.less +147 -0
  438. package/src/styles/less/alerts.css +751 -0
  439. package/src/styles/less/alerts.less +252 -0
  440. package/src/styles/less/background.css +20 -0
  441. package/src/styles/less/background.less +24 -0
  442. package/src/styles/less/badge.css +90 -0
  443. package/src/styles/less/badge.less +85 -0
  444. package/src/styles/less/border-radius.css +3 -0
  445. package/src/styles/less/border-radius.less +3 -0
  446. package/src/styles/less/breadcrumbs.css +20 -0
  447. package/src/styles/less/breadcrumbs.less +27 -0
  448. package/src/styles/less/button-groups.css +495 -0
  449. package/src/styles/less/button-groups.less +424 -0
  450. package/src/styles/less/buttons.css +1390 -0
  451. package/src/styles/less/buttons.less +738 -0
  452. package/src/styles/less/chevron.css +35 -0
  453. package/src/styles/less/chevron.less +39 -0
  454. package/src/styles/less/circles.css +248 -0
  455. package/src/styles/less/circles.less +233 -0
  456. package/src/styles/less/close.css +47 -0
  457. package/src/styles/less/close.less +48 -0
  458. package/src/styles/less/column-layout.css +164 -0
  459. package/src/styles/less/column-layout.less +167 -0
  460. package/src/styles/less/components/_component-animations.less +43 -0
  461. package/src/styles/less/core/_fonts.less +97 -0
  462. package/src/styles/less/core/_scaffolding.less +380 -0
  463. package/src/styles/less/core/_typography-utilities.less +255 -0
  464. package/src/styles/less/core/_typography.less +575 -0
  465. package/src/styles/less/core/viewport-themes.css +59 -0
  466. package/src/styles/less/core/viewport-themes.less +65 -0
  467. package/src/styles/less/currency-flags.css +46 -0
  468. package/src/styles/less/currency-flags.less +42 -0
  469. package/src/styles/less/decision.css +136 -0
  470. package/src/styles/less/decision.less +98 -0
  471. package/src/styles/less/dropdowns.css +472 -0
  472. package/src/styles/less/dropdowns.less +365 -0
  473. package/src/styles/less/droppable.css +221 -0
  474. package/src/styles/less/droppable.less +213 -0
  475. package/src/styles/less/flex.css +598 -0
  476. package/src/styles/less/flex.less +113 -0
  477. package/src/styles/less/footer.css +129 -0
  478. package/src/styles/less/footer.less +113 -0
  479. package/src/styles/less/forms/bootstrap-forms.css +2277 -0
  480. package/src/styles/less/forms/bootstrap-forms.less +1218 -0
  481. package/src/styles/less/forms/checkbox-radio.css +367 -0
  482. package/src/styles/less/forms/checkbox-radio.less +330 -0
  483. package/src/styles/less/grid.css +2369 -0
  484. package/src/styles/less/grid.less +187 -0
  485. package/src/styles/less/input-groups.css +2740 -0
  486. package/src/styles/less/input-groups.less +298 -0
  487. package/src/styles/less/link-callout.css +20 -0
  488. package/src/styles/less/link-callout.less +17 -0
  489. package/src/styles/less/list-group.css +350 -0
  490. package/src/styles/less/list-group.less +260 -0
  491. package/src/styles/less/loaders.css +76 -0
  492. package/src/styles/less/loaders.less +91 -0
  493. package/src/styles/less/media.css +74 -0
  494. package/src/styles/less/media.less +68 -0
  495. package/src/styles/less/mixins/_alerts.less +39 -0
  496. package/src/styles/less/mixins/_arrows.less +52 -0
  497. package/src/styles/less/mixins/_border-radius.less +11 -0
  498. package/src/styles/less/mixins/_buttons.less +82 -0
  499. package/src/styles/less/mixins/_center-block.less +7 -0
  500. package/src/styles/less/mixins/_clearfix.less +23 -0
  501. package/src/styles/less/mixins/_flex.less +105 -0
  502. package/src/styles/less/mixins/_forms.less +130 -0
  503. package/src/styles/less/mixins/_grid-framework.less +104 -0
  504. package/src/styles/less/mixins/_grid.less +158 -0
  505. package/src/styles/less/mixins/_hide-text.less +20 -0
  506. package/src/styles/less/mixins/_links.less +7 -0
  507. package/src/styles/less/mixins/_list-group.less +23 -0
  508. package/src/styles/less/mixins/_logical-properties-IE-friendly.less +381 -0
  509. package/src/styles/less/mixins/_logical-properties-modern-browsers.less +226 -0
  510. package/src/styles/less/mixins/_logical-properties.less +5 -0
  511. package/src/styles/less/mixins/_nav-divider.less +10 -0
  512. package/src/styles/less/mixins/_nav-vertical-align.less +10 -0
  513. package/src/styles/less/mixins/_panels.less +23 -0
  514. package/src/styles/less/mixins/_physical-properties.less +110 -0
  515. package/src/styles/less/mixins/_reset-text.less +22 -0
  516. package/src/styles/less/mixins/_sequence.less +203 -0
  517. package/src/styles/less/mixins/_spacing.less +122 -0
  518. package/src/styles/less/mixins/_tab-focus.less +5 -0
  519. package/src/styles/less/mixins/_table-row.less +47 -0
  520. package/src/styles/less/mixins/_text-emphasis.less +39 -0
  521. package/src/styles/less/mixins/_text-overflow.less +8 -0
  522. package/src/styles/less/mixins/_theming.less +7 -0
  523. package/src/styles/less/modals.css +185 -0
  524. package/src/styles/less/modals.less +239 -0
  525. package/src/styles/less/navbar.css +2406 -0
  526. package/src/styles/less/navbar.less +1442 -0
  527. package/src/styles/less/navs.css +296 -0
  528. package/src/styles/less/navs.less +339 -0
  529. package/src/styles/less/neptune-social-media.css +144 -0
  530. package/src/styles/less/neptune-social-media.less +84 -0
  531. package/src/styles/less/neptune.bundle.less +63 -0
  532. package/src/styles/less/neptune.css +25724 -0
  533. package/src/styles/less/panels.css +528 -0
  534. package/src/styles/less/panels.less +410 -0
  535. package/src/styles/less/popovers.css +661 -0
  536. package/src/styles/less/popovers.less +379 -0
  537. package/src/styles/less/process.css +483 -0
  538. package/src/styles/less/process.less +426 -0
  539. package/src/styles/less/progress-bars.css +64 -0
  540. package/src/styles/less/progress-bars.less +55 -0
  541. package/src/styles/less/ring.css +55 -0
  542. package/src/styles/less/ring.less +51 -0
  543. package/src/styles/less/select.css +99 -0
  544. package/src/styles/less/select.less +88 -0
  545. package/src/styles/less/sequences.css +855 -0
  546. package/src/styles/less/sequences.less +511 -0
  547. package/src/styles/less/table.css +446 -0
  548. package/src/styles/less/table.less +385 -0
  549. package/src/styles/less/tick.css +32 -0
  550. package/src/styles/less/tick.less +37 -0
  551. package/src/styles/less/tooltip.css +160 -0
  552. package/src/styles/less/tooltip.less +130 -0
  553. package/src/styles/less/utilities.css +145 -0
  554. package/src/styles/less/utilities.less +153 -0
  555. package/src/styles/less/wells.css +74 -0
  556. package/src/styles/less/wells.less +37 -0
  557. package/src/styles/props/custom-media.css +11 -0
  558. package/src/styles/props/legacy-custom-props.css +69 -0
  559. package/src/styles/props/neptune-tokens.css +11 -0
  560. package/src/styles/variables/legacy-variables.css +0 -0
  561. package/src/styles/variables/legacy-variables.less +1299 -0
  562. package/src/styles/variables/neptune-tokens.css +0 -0
  563. package/src/styles/variables/neptune-tokens.less +12 -0
  564. package/src/styles/variables/zindex.css +0 -0
  565. package/src/styles/variables/zindex.less +17 -0
  566. package/src/summary/Summary.less +1 -1
  567. package/src/summary/Summary.test.story.tsx +1 -1
  568. package/src/switch/Switch.less +4 -4
  569. package/src/table/Table.less +1 -1
  570. package/src/tabs/Tabs.less +4 -4
  571. package/src/tile/Tile.less +1 -1
  572. package/src/tooltip/Tooltip.less +1 -1
  573. package/src/tooltip/Tooltip.story.tsx +0 -21
  574. package/src/tooltip/Tooltip.test.story.tsx +42 -0
  575. package/src/typeahead/Typeahead.less +2 -2
  576. package/src/typeahead/Typeahead.story.tsx +0 -52
  577. package/src/typeahead/Typeahead.test.story.tsx +73 -0
  578. package/src/typeahead/typeaheadOption/TypeaheadOption.less +1 -1
  579. package/src/upload/Upload.less +1 -1
  580. package/src/uploadInput/UploadInput.less +2 -2
  581. package/src/uploadInput/uploadItem/UploadItem.less +1 -1
  582. package/build/inputs/SelectInput.js +0 -890
  583. package/build/inputs/SelectInput.js.map +0 -1
  584. package/build/inputs/SelectInput.messages.js.map +0 -1
  585. package/build/inputs/SelectInput.messages.mjs.map +0 -1
  586. package/build/inputs/SelectInput.mjs +0 -881
  587. package/build/inputs/SelectInput.mjs.map +0 -1
  588. package/build/inputs/_BottomSheet.js.map +0 -1
  589. package/build/inputs/_BottomSheet.mjs.map +0 -1
  590. package/build/inputs/_ButtonInput.js.map +0 -1
  591. package/build/inputs/_ButtonInput.mjs.map +0 -1
  592. package/build/inputs/_Popover.js.map +0 -1
  593. package/build/inputs/_Popover.mjs.map +0 -1
  594. package/build/types/inputs/SelectInput.d.ts.map +0 -1
  595. package/build/types/inputs/SelectInput.messages.d.ts.map +0 -1
  596. package/build/types/inputs/_BottomSheet.d.ts.map +0 -1
  597. package/build/types/inputs/_ButtonInput.d.ts +0 -5
  598. package/build/types/inputs/_ButtonInput.d.ts.map +0 -1
  599. package/build/types/inputs/_Popover.d.ts.map +0 -1
  600. package/src/inputs/SelectInput.less +0 -219
  601. package/src/inputs/SelectInput.tsx +0 -1269
  602. package/build/inputs/{SelectInput.messages.js → SelectInput/SelectInput.messages.js} +0 -0
  603. package/build/inputs/{SelectInput.messages.mjs → SelectInput/SelectInput.messages.mjs} +0 -0
  604. package/build/styles/inputs/{SelectInput.css → SelectInput/SelectInput.css} +90 -90
  605. package/build/types/inputs/{SelectInput.messages.d.ts → SelectInput/SelectInput.messages.d.ts} +0 -0
  606. package/src/inputs/{_BottomSheet.less → SelectInput/BottomSheet/SelectInputBottomSheet.less} +0 -0
  607. package/src/inputs/{_ButtonInput.less → SelectInput/ButtonInput/SelectInputButtonInput.less} +0 -0
  608. package/src/inputs/{_Popover.less → SelectInput/Popover/SelectInputPopover.less} +0 -0
  609. package/src/inputs/{SelectInput.css → SelectInput/SelectInput.css} +90 -90
  610. /package/src/inputs/{SelectInput.messages.ts → SelectInput/SelectInput.messages.ts} +0 -0
@@ -0,0 +1,257 @@
1
+ import mergeProps from 'merge-props';
2
+ import { useEffect, useRef, useState, useDeferredValue } from 'react';
3
+ import { Listbox as ListboxBase } from '@headlessui/react';
4
+ import { useScreenSize } from '../../common/hooks/useScreenSize';
5
+ import { Breakpoint } from '../../common/propsValues/breakpoint';
6
+ import { useEffectEvent } from '../../common/hooks/useEffectEvent';
7
+ import { useInputAttributes } from '../contexts';
8
+
9
+ import { SelectInputBottomSheet } from './BottomSheet';
10
+ import { SelectInputPopover } from './Popover';
11
+ import { SelectInputOptions } from './Options';
12
+ import { DefaultRenderTrigger } from './DefaultRenderTrigger';
13
+
14
+ import {
15
+ SelectInputOptionContentWithinTriggerContext,
16
+ SelectInputTriggerButtonPropsContext,
17
+ } from './SelectInput.contexts';
18
+ import { searchableString, sortByRelevance } from './SelectInput.utils';
19
+ import { SelectInputProps } from './SelectInput.types';
20
+
21
+ const noop = () => {};
22
+
23
+ /**
24
+ * SelectInput component allows users to select an option from a dropdown list.
25
+ * Supports filtering, multiple selection, and customization.
26
+ */
27
+ export function SelectInput<T = string, M extends boolean = false>({
28
+ id: idProp,
29
+ parentId,
30
+ name,
31
+ multiple,
32
+ placeholder,
33
+ autocomplete,
34
+ items,
35
+ defaultValue,
36
+ value: controlledValue,
37
+ compareValues,
38
+ renderValue = String,
39
+ renderFooter,
40
+ renderTrigger = DefaultRenderTrigger,
41
+ filterable,
42
+ filterPlaceholder,
43
+ sortFilteredOptions,
44
+ disabled,
45
+ size = 'md',
46
+ className,
47
+ UNSAFE_triggerButtonProps,
48
+ triggerRef: externalTriggerRef,
49
+ onFilterChange = noop,
50
+ onChange,
51
+ onOpen,
52
+ onClose,
53
+ onClear,
54
+ }: SelectInputProps<T, M>) {
55
+ const inputAttributes = useInputAttributes({ nonLabelable: true });
56
+ const id = idProp ?? inputAttributes.id;
57
+
58
+ const [open, setOpen] = useState(false);
59
+
60
+ const initialized = useRef(false);
61
+ const handleClose = useEffectEvent(onClose ?? (() => {}));
62
+ const handleOpen = useEffectEvent(onOpen ?? (() => {}));
63
+ useEffect(() => {
64
+ if (initialized.current) {
65
+ if (open) {
66
+ handleOpen?.();
67
+ } else {
68
+ handleClose?.();
69
+ }
70
+ } else {
71
+ initialized.current = true;
72
+ }
73
+ }, [handleClose, handleOpen, open]);
74
+
75
+ const [filterQuery, _setFilterQuery] = useState('');
76
+ const deferredFilterQuery = useDeferredValue(filterQuery);
77
+ const setFilterQuery = useEffectEvent((query: string) => {
78
+ _setFilterQuery(query);
79
+ if (query !== filterQuery) {
80
+ onFilterChange({
81
+ query,
82
+ queryNormalized: query ? searchableString(query) : null,
83
+ });
84
+ }
85
+ });
86
+
87
+ const internalTriggerRef = useRef<HTMLButtonElement | null>(null);
88
+
89
+ const screenSm = useScreenSize(Breakpoint.SMALL);
90
+ const OptionsOverlay = screenSm ? SelectInputPopover : SelectInputBottomSheet;
91
+
92
+ const searchInputRef = useRef<HTMLInputElement>(null);
93
+ const listboxRef = useRef<HTMLDivElement>(null);
94
+ const controllerRef = filterable ? searchInputRef : listboxRef;
95
+
96
+ /**
97
+ * Attempts to resolve the `listbox` label
98
+ * @see https://storybook.wise.design/?path=/docs/forms-selectinput-accessibility--docs#labelling
99
+ */
100
+ const getListBoxLabelProps = (): {
101
+ listBoxLabel?: string;
102
+ listBoxLabelledBy?: string;
103
+ } => {
104
+ if (UNSAFE_triggerButtonProps?.['aria-label']) {
105
+ return {
106
+ listBoxLabel: UNSAFE_triggerButtonProps['aria-label'],
107
+ };
108
+ }
109
+
110
+ if (UNSAFE_triggerButtonProps?.['aria-labelledby']) {
111
+ return {
112
+ listBoxLabelledBy: UNSAFE_triggerButtonProps['aria-labelledby'],
113
+ };
114
+ }
115
+
116
+ if (inputAttributes['aria-labelledby']) {
117
+ return {
118
+ listBoxLabelledBy: inputAttributes['aria-labelledby'],
119
+ };
120
+ }
121
+
122
+ return {};
123
+ };
124
+
125
+ return (
126
+ <ListboxBase
127
+ name={name}
128
+ multiple={multiple}
129
+ defaultValue={defaultValue as M extends true ? T[] : T}
130
+ value={controlledValue as M extends true ? T[] : T}
131
+ by={compareValues}
132
+ disabled={disabled}
133
+ onChange={
134
+ ((value) => {
135
+ if (!multiple) {
136
+ setOpen(false);
137
+ }
138
+ onChange?.(value);
139
+ }) satisfies SelectInputProps<T, M>['onChange']
140
+ }
141
+ >
142
+ {({ disabled: uiDisabled, value }) => {
143
+ const placeholderShown =
144
+ multiple && Array.isArray(value) ? value.length === 0 : value == null;
145
+ return (
146
+ <OptionsOverlay
147
+ placement="bottom-start"
148
+ open={open}
149
+ renderTrigger={({ ref, getInteractionProps }) => (
150
+ <SelectInputTriggerButtonPropsContext.Provider
151
+ // eslint-disable-next-line react/jsx-no-constructed-context-values
152
+ value={{
153
+ ref: (node) => {
154
+ ref(node);
155
+ if (externalTriggerRef) {
156
+ // eslint-disable-next-line no-param-reassign
157
+ externalTriggerRef.current = node;
158
+ } else {
159
+ internalTriggerRef.current = node;
160
+ }
161
+ },
162
+ size,
163
+ ...inputAttributes,
164
+ ...UNSAFE_triggerButtonProps,
165
+ id,
166
+ ...mergeProps(
167
+ {
168
+ onClick: () => {
169
+ setOpen((prev) => !prev);
170
+ },
171
+ onKeyDown: (event: React.KeyboardEvent) => {
172
+ if (
173
+ event.key === ' ' ||
174
+ event.key === 'Enter' ||
175
+ event.key === 'ArrowDown' ||
176
+ event.key === 'ArrowUp'
177
+ ) {
178
+ setOpen((prev) => !prev);
179
+ }
180
+ },
181
+ },
182
+ getInteractionProps(),
183
+ ),
184
+ }}
185
+ >
186
+ {renderTrigger({
187
+ content: !placeholderShown ? (
188
+ <SelectInputOptionContentWithinTriggerContext.Provider value>
189
+ {multiple && Array.isArray(value)
190
+ ? (value as readonly NonNullable<T>[])
191
+ .map((option) => renderValue(option, true))
192
+ .filter((node) => node != null)
193
+ .join(', ')
194
+ : renderValue(value as NonNullable<T>, true)}
195
+ </SelectInputOptionContentWithinTriggerContext.Provider>
196
+ ) : (
197
+ placeholder
198
+ ),
199
+ placeholderShown,
200
+ clear:
201
+ onClear != null
202
+ ? () => {
203
+ onClear();
204
+ (externalTriggerRef?.current ?? internalTriggerRef.current)?.focus({
205
+ preventScroll: true,
206
+ });
207
+ }
208
+ : undefined,
209
+ disabled: uiDisabled,
210
+ size,
211
+ className,
212
+ })}
213
+ </SelectInputTriggerButtonPropsContext.Provider>
214
+ )}
215
+ initialFocusRef={controllerRef}
216
+ size={filterable ? 'lg' : 'md'}
217
+ padding="none"
218
+ onClose={() => {
219
+ setOpen(false);
220
+ }}
221
+ onCloseEnd={() => {
222
+ setFilterQuery('');
223
+ }}
224
+ >
225
+ <SelectInputOptions
226
+ id={id ? `${id}Search` : undefined}
227
+ parentId={parentId}
228
+ items={items}
229
+ compareValues={compareValues}
230
+ renderValue={renderValue}
231
+ renderFooter={renderFooter}
232
+ filterable={filterable}
233
+ filterPlaceholder={filterPlaceholder}
234
+ sortFilteredOptions={sortFilteredOptions}
235
+ searchInputRef={searchInputRef}
236
+ listboxRef={listboxRef}
237
+ filterQuery={deferredFilterQuery}
238
+ autocomplete={autocomplete}
239
+ name={name}
240
+ onFilterChange={setFilterQuery}
241
+ onAutocompleteSelect={(matchedValue) => {
242
+ onChange?.(matchedValue as M extends true ? T[] : T);
243
+ if (!multiple) {
244
+ setOpen(false);
245
+ }
246
+ }}
247
+ {...getListBoxLabelProps()}
248
+ />
249
+ </OptionsOverlay>
250
+ );
251
+ }}
252
+ </ListboxBase>
253
+ );
254
+ }
255
+
256
+ // Attach sortByRelevance to the component for convenience
257
+ SelectInput.sortByRelevance = sortByRelevance;
@@ -0,0 +1,113 @@
1
+ import React, { ReactNode } from 'react';
2
+ import { ButtonProps } from '../../button/Button.types';
3
+ import { WithInputAttributesProps } from './SelectInput.contexts';
4
+
5
+ // Item interfaces
6
+ export interface SelectInputOptionItem<T = string> {
7
+ type: 'option';
8
+ value: T;
9
+ filterMatchers?: readonly string[];
10
+ disabled?: boolean;
11
+ }
12
+
13
+ export interface SelectInputGroupItem<T = string> {
14
+ type: 'group';
15
+ label: ReactNode;
16
+ options: readonly SelectInputOptionItem<T>[];
17
+ action?: {
18
+ label: string;
19
+ onClick: ButtonProps['onClick'];
20
+ };
21
+ }
22
+
23
+ export interface SelectInputSeparatorItem {
24
+ type: 'separator';
25
+ }
26
+
27
+ export type SelectInputItem<T = string> =
28
+ | SelectInputOptionItem<T>
29
+ | SelectInputGroupItem<T>
30
+ | SelectInputSeparatorItem;
31
+
32
+ // Main component props
33
+ export interface SelectInputProps<T = string, M extends boolean = false> {
34
+ id?: string;
35
+ /**
36
+ * Sets the `data-wds-parent` attribute on the listbox container, which is needed for complex components like DateInput to correctly manage event handling.
37
+ * @internal
38
+ */
39
+ parentId?: string;
40
+ name?: string;
41
+ multiple?: M;
42
+ placeholder?: string;
43
+ items: readonly SelectInputItem<NonNullable<T>>[];
44
+ /**
45
+ * Enables browser autocomplete integration through the search input.
46
+ * Accepts standard HTML autocomplete values (e.g., "country-name", "address-level1").
47
+ *
48
+ * Requires `filterable={true}` to enable the search input.
49
+ *
50
+ * @example
51
+ * <SelectInput
52
+ * name="country"
53
+ * autocomplete="country-name"
54
+ * filterable={true}
55
+ * items={[{
56
+ * type: 'option',
57
+ * value: 'GB',
58
+ * filterMatchers: ['United Kingdom', 'UK']
59
+ * }]}
60
+ * />
61
+ */
62
+ autocomplete?: string;
63
+ defaultValue?: M extends true ? readonly T[] : T;
64
+ value?: M extends true ? readonly T[] : T;
65
+ compareValues?:
66
+ | (keyof NonNullable<T> & string)
67
+ | ((a: T | undefined, b: T | undefined) => boolean);
68
+ renderValue?: (value: NonNullable<T>, withinTrigger: boolean) => React.ReactNode;
69
+ renderFooter?: (args: {
70
+ resultsEmpty: boolean;
71
+ queryNormalized: string | null | undefined;
72
+ }) => React.ReactNode;
73
+ renderTrigger?: (args: {
74
+ content: React.ReactNode;
75
+ placeholderShown: boolean;
76
+ clear: (() => void) | undefined;
77
+ disabled: boolean;
78
+ size: 'sm' | 'md' | 'lg';
79
+ className: string | undefined;
80
+ }) => React.ReactNode;
81
+ filterable?: boolean;
82
+ filterPlaceholder?: string;
83
+ sortFilteredOptions?: (
84
+ a: SelectInputOptionItem<NonNullable<T>>,
85
+ b: SelectInputOptionItem<NonNullable<T>>,
86
+ searchQuery: string,
87
+ ) => number;
88
+ disabled?: boolean;
89
+ size?: 'sm' | 'md' | 'lg';
90
+ className?: string;
91
+ UNSAFE_triggerButtonProps?: WithInputAttributesProps['inputAttributes'] & {
92
+ 'aria-label'?: string;
93
+ };
94
+ /** Ref to the select trigger button element. */
95
+ triggerRef?: React.MutableRefObject<HTMLButtonElement | null>;
96
+ onFilterChange?: (args: { query: string; queryNormalized: string | null }) => void;
97
+ onChange?: (value: M extends true ? T[] : T) => void;
98
+ onOpen?: () => void;
99
+ onClose?: () => void;
100
+ onClear?: () => void;
101
+ }
102
+
103
+ export type {
104
+ SelectInputTriggerButtonElementType,
105
+ SelectInputTriggerButtonProps,
106
+ } from './TriggerButton';
107
+ export type { SelectInputClearButtonProps } from './ClearButton';
108
+ export type { SelectInputOptionContentProps } from './OptionContent';
109
+ export type { SelectInputOptionProps } from './Option';
110
+ export type { SelectInputItemViewProps } from './ItemView';
111
+ export type { SelectInputGroupItemViewProps } from './ItemView/GroupItemView';
112
+ export type { SelectInputOptionsProps } from './Options';
113
+ export type { SelectInputOptionsContainerProps } from './Options/OptionsContainer';
@@ -0,0 +1,205 @@
1
+ import { SelectInputItem, SelectInputOptionItem } from './SelectInput.types';
2
+
3
+ export const MAX_ITEMS_WITHOUT_VIRTUALIZATION = 50;
4
+
5
+ /**
6
+ * Converts a string to a normalized, searchable format by:
7
+ * - Trimming whitespace
8
+ * - Normalizing whitespace (convert multiple spaces to single space)
9
+ * - Converting to NFD normalization form to handle diacritics
10
+ * - Removing combining diacritical marks
11
+ * - Converting to lowercase
12
+ */
13
+ export function searchableString(value: string) {
14
+ return (
15
+ value
16
+ .trim()
17
+ .replace(/\s+/gu, ' ')
18
+ // NFD converts an Å to A + ̊ (and other special characters)
19
+ .normalize('NFD')
20
+ // and then this replaces the ̊ with nothing (and other special characters)
21
+ .replace(/[\u0300-\u036f]/g, '')
22
+ .toLowerCase()
23
+ );
24
+ }
25
+
26
+ /**
27
+ * Extracts searchable strings from a value.
28
+ * - If the value is a string, returns a normalized version.
29
+ * - If the value is an object, extracts all string values and normalizes them.
30
+ * - Otherwise returns an empty array.
31
+ */
32
+ export function inferSearchableStrings(value: unknown) {
33
+ if (typeof value === 'string') {
34
+ return [searchableString(value)];
35
+ }
36
+
37
+ if (typeof value === 'object' && value != null) {
38
+ return Object.values(value)
39
+ .filter((innerValue) => typeof innerValue === 'string')
40
+ .map((innerValue) => searchableString(innerValue));
41
+ }
42
+
43
+ return [];
44
+ }
45
+
46
+ /**
47
+ * Sets the value of a duplicate option item to undefined, effectively hiding it when rendered.
48
+ */
49
+ export function dedupeSelectInputOptionItem<T>(
50
+ item: SelectInputOptionItem<T>,
51
+ existingValues: Set<T>,
52
+ compareValues?: (a: T, b: T) => boolean,
53
+ ): SelectInputOptionItem<T | undefined> {
54
+ const isDuplicate = compareValues
55
+ ? Array.from(existingValues).some((existingValue) => compareValues(item.value, existingValue))
56
+ : existingValues.has(item.value);
57
+
58
+ if (!isDuplicate) {
59
+ existingValues.add(item.value);
60
+ return item;
61
+ }
62
+ return { ...item, value: undefined };
63
+ }
64
+
65
+ /**
66
+ * Sets the `value` of duplicate option items to `undefined`, hiding them when
67
+ * rendered. Indexes are kept intact within groups to preserve the active item
68
+ * between filter changes when possible.
69
+ */
70
+ export function dedupeSelectInputItems<T>(
71
+ items: readonly SelectInputItem<T>[],
72
+ compareValues?: (a: T, b: T) => boolean,
73
+ ): SelectInputItem<T | undefined>[] {
74
+ const existingValues = new Set<T>();
75
+
76
+ return items.map((item) => {
77
+ switch (item.type) {
78
+ case 'option': {
79
+ return dedupeSelectInputOptionItem(item, existingValues, compareValues);
80
+ }
81
+ case 'group': {
82
+ return {
83
+ ...item,
84
+ options: item.options.map((option) =>
85
+ dedupeSelectInputOptionItem(option, existingValues, compareValues),
86
+ ),
87
+ };
88
+ }
89
+ default:
90
+ }
91
+ return item;
92
+ });
93
+ }
94
+
95
+ /**
96
+ * Checks if a SelectInputOptionItem matches the search needle.
97
+ */
98
+ export function selectInputOptionItemIncludesNeedle<T>(
99
+ item: SelectInputOptionItem<T>,
100
+ needle: string,
101
+ ) {
102
+ return inferSearchableStrings(item.filterMatchers ?? item.value).some((haystack) =>
103
+ haystack.includes(needle),
104
+ );
105
+ }
106
+
107
+ /**
108
+ * Filters SelectInputItems based on the provided predicate function.
109
+ * For group items, it checks if any of their options match the predicate.
110
+ */
111
+ export function filterSelectInputItems<T>(
112
+ items: readonly SelectInputItem<T>[],
113
+ predicate: (item: SelectInputOptionItem<T>) => boolean,
114
+ ) {
115
+ return items.filter((item) => {
116
+ switch (item.type) {
117
+ case 'option': {
118
+ return predicate(item);
119
+ }
120
+ case 'group': {
121
+ return item.options.some((option) => predicate(option));
122
+ }
123
+ default:
124
+ }
125
+ return false;
126
+ });
127
+ }
128
+
129
+ /**
130
+ * Flattens and sorts filtered options using the provided comparator.
131
+ * Extracts all options from groups, filters out undefined values (deduplicated items),
132
+ * sorts them, and returns as a flat list of option items.
133
+ */
134
+ export function sortSelectInputItems<T>(
135
+ items: readonly SelectInputItem<T | undefined>[],
136
+ compareFn: (
137
+ a: SelectInputOptionItem<NonNullable<T>>,
138
+ b: SelectInputOptionItem<NonNullable<T>>,
139
+ searchQuery: string,
140
+ ) => number,
141
+ searchQuery: string,
142
+ ): SelectInputItem<NonNullable<T>>[] {
143
+ const flattenedOption = items.flatMap((item) => {
144
+ if (item.type === 'option') {
145
+ return item.value !== undefined ? [item as SelectInputOptionItem<NonNullable<T>>] : [];
146
+ }
147
+
148
+ if (item.type === 'group') {
149
+ return item.options.filter(
150
+ (option): option is SelectInputOptionItem<NonNullable<T>> => option.value !== undefined,
151
+ );
152
+ }
153
+
154
+ return [];
155
+ });
156
+
157
+ // eslint-disable-next-line functional/immutable-data
158
+ return flattenedOption.sort((a, b) => compareFn(a, b, searchQuery));
159
+ }
160
+
161
+ /**
162
+ * A prebuilt sort function for `sortFilteredOptions` that sorts options by relevance to the search query.
163
+ * Prioritizes: exact matches > starts with > contains > alphabetical.
164
+ *
165
+ * @param getLabel - Function to extract the label string from the option value. Defaults to using `title` property.
166
+ *
167
+ * @example
168
+ * ```tsx
169
+ * <SelectInput
170
+ * filterable
171
+ * sortFilteredOptions={sortByRelevance((value) => value.name)}
172
+ * // ...
173
+ * />
174
+ * ```
175
+ */
176
+ export function sortByRelevance<T>(
177
+ getLabel: (value: T) => string = (value) => (value as { title: string }).title,
178
+ ): (a: SelectInputOptionItem<T>, b: SelectInputOptionItem<T>, searchQuery: string) => number {
179
+ return (a, b, searchQuery) => {
180
+ const normalizedQuery = searchQuery.toLowerCase();
181
+ const labelA = getLabel(a.value).toLowerCase();
182
+ const labelB = getLabel(b.value).toLowerCase();
183
+
184
+ // Prioritize exact matches
185
+ const aExactMatch = labelA === normalizedQuery;
186
+ const bExactMatch = labelB === normalizedQuery;
187
+ if (aExactMatch && !bExactMatch) return -1;
188
+ if (!aExactMatch && bExactMatch) return 1;
189
+
190
+ // Then prioritize options where label starts with the search query
191
+ const aStartsWith = labelA.startsWith(normalizedQuery);
192
+ const bStartsWith = labelB.startsWith(normalizedQuery);
193
+ if (aStartsWith && !bStartsWith) return -1;
194
+ if (!aStartsWith && bStartsWith) return 1;
195
+
196
+ // Then prioritize options where label contains the search query
197
+ const aContains = labelA.includes(normalizedQuery);
198
+ const bContains = labelB.includes(normalizedQuery);
199
+ if (aContains && !bContains) return -1;
200
+ if (!aContains && bContains) return 1;
201
+
202
+ // Finally sort alphabetically
203
+ return labelA.localeCompare(labelB);
204
+ };
205
+ }
@@ -0,0 +1,36 @@
1
+ import { ListboxButton } from '@headlessui/react';
2
+ import mergeProps from 'merge-props';
3
+ import { useContext } from 'react';
4
+ import { PolymorphicWithOverrides } from '../../../common/polymorphicWithOverrides/PolymorphicWithOverrides';
5
+ import { Merge } from '../../../utils';
6
+ import { SelectInputTriggerButtonPropsContext } from '../SelectInput.contexts';
7
+
8
+ export type SelectInputTriggerButtonElementType = 'button' | React.ComponentType;
9
+
10
+ export type SelectInputTriggerButtonProps<
11
+ T extends SelectInputTriggerButtonElementType = 'button',
12
+ > = Merge<React.ComponentPropsWithoutRef<T>, { as?: T }>;
13
+
14
+ /**
15
+ * The trigger button component for SelectInput.
16
+ * Uses Headless UI's ListboxButton with polymorphic support to allow
17
+ * rendering as different element types.
18
+ */
19
+ export function SelectInputTriggerButton<T extends SelectInputTriggerButtonElementType = 'button'>({
20
+ as = 'button' as T,
21
+ ...restProps
22
+ }: SelectInputTriggerButtonProps<T>) {
23
+ const { ref, onClick, onKeyDown, size, ...interactionProps } = useContext(
24
+ SelectInputTriggerButtonPropsContext,
25
+ );
26
+
27
+ return (
28
+ <ListboxButton
29
+ ref={ref}
30
+ as={PolymorphicWithOverrides}
31
+ role="combobox"
32
+ __overrides={{ as, size, ...interactionProps } as Record<string, unknown>}
33
+ {...mergeProps({ onClick, onKeyDown }, restProps)}
34
+ />
35
+ );
36
+ }
@@ -0,0 +1,5 @@
1
+ export { SelectInputTriggerButton } from './SelectInputTriggerButton';
2
+ export type {
3
+ SelectInputTriggerButtonElementType,
4
+ SelectInputTriggerButtonProps,
5
+ } from './SelectInputTriggerButton';
@@ -1,5 +1,4 @@
1
1
  import { Meta } from '@storybook/addon-docs/blocks';
2
- import { MoneyInput } from '..';
3
2
 
4
3
  <Meta title="Forms/SelectInput/Accessibility" />
5
4
 
@@ -5,19 +5,19 @@ import { Flag } from '@wise/art';
5
5
  import { clsx } from 'clsx';
6
6
  import { useState } from 'react';
7
7
 
8
- import Button from '../button';
9
- import { getMonthNames } from '../common/dateUtils';
10
- import Drawer from '../drawer';
11
- import { Field } from '../field/Field';
12
- import Modal from '../modal';
13
- import { wait } from '../test-utils/wait';
8
+ import Button from '../../../button';
9
+ import { getMonthNames } from '../../../common/dateUtils';
10
+ import Drawer from '../../../drawer';
11
+ import { Field } from '../../../field/Field';
12
+ import Modal from '../../../modal';
13
+ import { wait } from '../../../test-utils/wait';
14
14
  import {
15
15
  SelectInput,
16
16
  type SelectInputItem,
17
17
  SelectInputOptionContent,
18
18
  type SelectInputProps,
19
19
  SelectInputTriggerButton,
20
- } from './SelectInput';
20
+ } from '..';
21
21
 
22
22
  const meta = {
23
23
  title: 'Forms/SelectInput',
@@ -35,7 +35,10 @@ const meta = {
35
35
  },
36
36
  },
37
37
  },
38
- parameters: { actions: { argTypesRegex: '' } },
38
+ parameters: {
39
+ docs: { toc: true },
40
+ actions: { argTypesRegex: '' },
41
+ },
39
42
  } satisfies Meta<typeof SelectInput>;
40
43
  export default meta;
41
44
 
@@ -2,16 +2,12 @@ import type { Meta, StoryObj } from '@storybook/react-webpack5';
2
2
  import { fireEvent, fn, type Mock, screen, userEvent, within } from 'storybook/test';
3
3
  import { useState } from 'react';
4
4
 
5
- import { allModes } from '../../.storybook/modes';
6
- import Body from '../body';
7
- import { Field } from '../field/Field';
8
- import { lorem5, lorem500 } from '../test-utils';
9
- import {
10
- SelectInput,
11
- SelectInputOptionContent,
12
- type SelectInputProps,
13
- sortByRelevance,
14
- } from './SelectInput';
5
+ import { allModes } from '../../../../.storybook/modes';
6
+ import Body from '../../../body';
7
+ import { Field } from '../../../field/Field';
8
+ import { lorem5, lorem500 } from '../../../test-utils';
9
+ import { sortByRelevance } from '../SelectInput.utils';
10
+ import { SelectInput, SelectInputOptionContent, type SelectInputProps } from '..';
15
11
 
16
12
  const meta = {
17
13
  title: 'Forms/SelectInput/Tests',