@simplybusiness/mobius 3.4.4 → 3.5.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 (575) hide show
  1. package/CHANGELOG.md +27 -4
  2. package/dist/cjs/components/Accordion/Accordion.js +2 -1
  3. package/dist/cjs/components/Accordion/Accordion.js.map +1 -1
  4. package/dist/cjs/components/Accordion/Accordion.test.js +1 -1
  5. package/dist/cjs/components/Alert/Alert.js +6 -2
  6. package/dist/cjs/components/Alert/Alert.js.map +1 -1
  7. package/dist/cjs/components/Alert/Alert.test.js +1 -1
  8. package/dist/cjs/components/Box/Box.js +1 -1
  9. package/dist/cjs/components/Box/Box.test.js +1 -1
  10. package/dist/cjs/components/Breadcrumbs/BreadcrumbItem.js +2 -1
  11. package/dist/cjs/components/Breadcrumbs/BreadcrumbItem.js.map +1 -1
  12. package/dist/cjs/components/Breadcrumbs/Breadcrumbs.js +2 -1
  13. package/dist/cjs/components/Breadcrumbs/Breadcrumbs.js.map +1 -1
  14. package/dist/cjs/components/Breadcrumbs/Breadcrumbs.test.js +1 -1
  15. package/dist/cjs/components/Button/Button.js +2 -1
  16. package/dist/cjs/components/Button/Button.js.map +1 -1
  17. package/dist/cjs/components/Button/Button.test.js +1 -1
  18. package/dist/cjs/components/Button/Loading.d.ts +2 -1
  19. package/dist/cjs/components/Button/Loading.js +1 -1
  20. package/dist/cjs/components/Checkbox/Checkbox.js +1 -1
  21. package/dist/cjs/components/Checkbox/Checkbox.test.js +1 -1
  22. package/dist/cjs/components/Checkbox/CheckboxContext.js +1 -0
  23. package/dist/cjs/components/Checkbox/CheckboxContext.js.map +1 -1
  24. package/dist/cjs/components/Checkbox/CheckboxGroup.js +2 -1
  25. package/dist/cjs/components/Checkbox/CheckboxGroup.js.map +1 -1
  26. package/dist/cjs/components/Checkbox/CheckboxGroup.test.js +1 -1
  27. package/dist/cjs/components/Checkbox/CheckboxGroupItem.js +2 -1
  28. package/dist/cjs/components/Checkbox/CheckboxGroupItem.js.map +1 -1
  29. package/dist/cjs/components/Checkbox/CheckboxItem.js +2 -1
  30. package/dist/cjs/components/Checkbox/CheckboxItem.js.map +1 -1
  31. package/dist/cjs/components/Chopin/Actions/Actions.js +1 -1
  32. package/dist/cjs/components/Chopin/Actions/Actions.test.js +1 -1
  33. package/dist/cjs/components/Chopin/Actions/LinkOrButton.d.ts +2 -1
  34. package/dist/cjs/components/Chopin/Actions/LinkOrButton.js +1 -1
  35. package/dist/cjs/components/Chopin/Actions/LinkOrButton.test.js +1 -1
  36. package/dist/cjs/components/Chopin/Footer/Address.js +1 -1
  37. package/dist/cjs/components/Chopin/Footer/Copyright.js +1 -1
  38. package/dist/cjs/components/Chopin/Footer/Footer.js +1 -1
  39. package/dist/cjs/components/Chopin/Footer/Footer.test.js +1 -1
  40. package/dist/cjs/components/Chopin/Footer/Legal.js +1 -1
  41. package/dist/cjs/components/Chopin/Header/ContactDetails.js +1 -1
  42. package/dist/cjs/components/Chopin/Header/Header.js +1 -1
  43. package/dist/cjs/components/Chopin/Header/Header.test.js +1 -1
  44. package/dist/cjs/components/Chopin/Header/Logo.js +1 -1
  45. package/dist/cjs/components/Chopin/PercentageTotalsQuestion/PercentageItem.d.ts +2 -1
  46. package/dist/cjs/components/Chopin/PercentageTotalsQuestion/PercentageItem.js +2 -1
  47. package/dist/cjs/components/Chopin/PercentageTotalsQuestion/PercentageItem.js.map +1 -1
  48. package/dist/cjs/components/Chopin/PercentageTotalsQuestion/PercentageTotalsQuestion.d.ts +2 -1
  49. package/dist/cjs/components/Chopin/PercentageTotalsQuestion/PercentageTotalsQuestion.js +2 -1
  50. package/dist/cjs/components/Chopin/PercentageTotalsQuestion/PercentageTotalsQuestion.js.map +1 -1
  51. package/dist/cjs/components/Chopin/PercentageTotalsQuestion/PercentageTotalsQuestion.test.js +1 -1
  52. package/dist/cjs/components/Chopin/Question/Question.d.ts +1 -1
  53. package/dist/cjs/components/Chopin/Question/Question.js +2 -1
  54. package/dist/cjs/components/Chopin/Question/Question.js.map +1 -1
  55. package/dist/cjs/components/Chopin/Question/Question.test.js +1 -1
  56. package/dist/cjs/components/Chopin/QuestionGroup/QuestionGroup.js +2 -1
  57. package/dist/cjs/components/Chopin/QuestionGroup/QuestionGroup.js.map +1 -1
  58. package/dist/cjs/components/Chopin/QuestionGroup/QuestionGroup.test.js +1 -1
  59. package/dist/cjs/components/Chopin/QuestionHelp/QuestionHelp.d.ts +1 -1
  60. package/dist/cjs/components/Chopin/QuestionHelp/QuestionHelp.js +2 -1
  61. package/dist/cjs/components/Chopin/QuestionHelp/QuestionHelp.js.map +1 -1
  62. package/dist/cjs/components/Chopin/QuestionHelp/QuestionHelp.test.js +1 -1
  63. package/dist/cjs/components/Chopin/Section/Section.js +1 -1
  64. package/dist/cjs/components/Chopin/Section/Section.test.js +1 -1
  65. package/dist/cjs/components/Chopin/Steps/StepItem.js +6 -2
  66. package/dist/cjs/components/Chopin/Steps/StepItem.js.map +1 -1
  67. package/dist/cjs/components/Chopin/Steps/Steps.js +1 -1
  68. package/dist/cjs/components/Chopin/Steps/Steps.test.js +1 -1
  69. package/dist/cjs/components/Chopin/Testimonial/Testimonial.js +1 -1
  70. package/dist/cjs/components/Chopin/Testimonial/Testimonial.test.js +1 -1
  71. package/dist/cjs/components/Chopin/TradeSelector/Header/Header.d.ts +1 -1
  72. package/dist/cjs/components/Chopin/TradeSelector/Header/Header.js +1 -1
  73. package/dist/cjs/components/Chopin/TradeSelector/Listing/Listing.d.ts +1 -1
  74. package/dist/cjs/components/Chopin/TradeSelector/Listing/Listing.js +1 -1
  75. package/dist/cjs/components/Chopin/TradeSelector/Listing/Listing.test.js +1 -1
  76. package/dist/cjs/components/Chopin/TradeSelector/Listing/ListingItem.js +2 -1
  77. package/dist/cjs/components/Chopin/TradeSelector/Listing/ListingItem.js.map +1 -1
  78. package/dist/cjs/components/Chopin/TradeSelector/Listing/ListingItem.test.js +1 -1
  79. package/dist/cjs/components/Chopin/TradeSelector/SearchResults/SearchResults.d.ts +1 -1
  80. package/dist/cjs/components/Chopin/TradeSelector/SearchResults/SearchResults.js +2 -1
  81. package/dist/cjs/components/Chopin/TradeSelector/SearchResults/SearchResults.js.map +1 -1
  82. package/dist/cjs/components/Chopin/TradeSelector/SearchResults/SearchResults.test.js +1 -1
  83. package/dist/cjs/components/Chopin/TradeSelector/TradeInput/TradeInput.d.ts +1 -1
  84. package/dist/cjs/components/Chopin/TradeSelector/TradeInput/TradeInput.js +2 -1
  85. package/dist/cjs/components/Chopin/TradeSelector/TradeInput/TradeInput.js.map +1 -1
  86. package/dist/cjs/components/Chopin/TradeSelector/TradeInput/TradeInput.test.js +1 -1
  87. package/dist/cjs/components/Chopin/TradeSelector/TradeSelector.js +2 -1
  88. package/dist/cjs/components/Chopin/TradeSelector/TradeSelector.js.map +1 -1
  89. package/dist/cjs/components/Chopin/TradeSelector/TradeSelector.test.js +1 -1
  90. package/dist/cjs/components/Chopin/TradeSelector/types.d.ts +1 -0
  91. package/dist/cjs/components/Chopin/TradeSelector/useFetchTrades/useFetchTrades.js +1 -0
  92. package/dist/cjs/components/Chopin/TradeSelector/useFetchTrades/useFetchTrades.js.map +1 -1
  93. package/dist/cjs/components/Container/Container.js +1 -1
  94. package/dist/cjs/components/Container/Container.test.js +1 -1
  95. package/dist/cjs/components/DataTable/DataTable.js +1 -1
  96. package/dist/cjs/components/DataTable/DataTable.test.js +1 -1
  97. package/dist/cjs/components/DataTable/FlexLayout.js +1 -1
  98. package/dist/cjs/components/DataTable/SortIcon.d.ts +2 -1
  99. package/dist/cjs/components/DataTable/SortIcon.js +1 -1
  100. package/dist/cjs/components/DataTable/TableLayout.js +1 -1
  101. package/dist/cjs/components/DatePicker/Calendar.d.ts +2 -1
  102. package/dist/cjs/components/DatePicker/Calendar.js +2 -1
  103. package/dist/cjs/components/DatePicker/Calendar.js.map +1 -1
  104. package/dist/cjs/components/DatePicker/CalendarButton.js +2 -1
  105. package/dist/cjs/components/DatePicker/CalendarButton.js.map +1 -1
  106. package/dist/cjs/components/DatePicker/CalendarCell.d.ts +2 -1
  107. package/dist/cjs/components/DatePicker/CalendarCell.js +2 -1
  108. package/dist/cjs/components/DatePicker/CalendarCell.js.map +1 -1
  109. package/dist/cjs/components/DatePicker/CalendarGrid.d.ts +2 -1
  110. package/dist/cjs/components/DatePicker/CalendarGrid.js +2 -1
  111. package/dist/cjs/components/DatePicker/CalendarGrid.js.map +1 -1
  112. package/dist/cjs/components/DatePicker/DateField.d.ts +2 -1
  113. package/dist/cjs/components/DatePicker/DateField.js +2 -1
  114. package/dist/cjs/components/DatePicker/DateField.js.map +1 -1
  115. package/dist/cjs/components/DatePicker/DatePicker.d.ts +2 -1
  116. package/dist/cjs/components/DatePicker/DatePicker.js +3 -2
  117. package/dist/cjs/components/DatePicker/DatePicker.js.map +1 -1
  118. package/dist/cjs/components/DatePicker/DateSegment.d.ts +2 -1
  119. package/dist/cjs/components/DatePicker/DateSegment.js +2 -1
  120. package/dist/cjs/components/DatePicker/DateSegment.js.map +1 -1
  121. package/dist/cjs/components/DatePicker/Popover.d.ts +1 -1
  122. package/dist/cjs/components/DatePicker/Popover.js +3 -2
  123. package/dist/cjs/components/DatePicker/Popover.js.map +1 -1
  124. package/dist/cjs/components/Divider/Divider.d.ts +2 -1
  125. package/dist/cjs/components/Divider/Divider.js +2 -1
  126. package/dist/cjs/components/Divider/Divider.js.map +1 -1
  127. package/dist/cjs/components/DropdownMenu/DropdownMenu.js +2 -1
  128. package/dist/cjs/components/DropdownMenu/DropdownMenu.js.map +1 -1
  129. package/dist/cjs/components/DropdownMenu/DropdownMenu.test.js +1 -1
  130. package/dist/cjs/components/DropdownMenu/Item.js +1 -1
  131. package/dist/cjs/components/ErrorMessage/ErrorMessage.d.ts +2 -1
  132. package/dist/cjs/components/ErrorMessage/ErrorMessage.js +1 -1
  133. package/dist/cjs/components/ErrorMessage/ErrorMessage.test.js +1 -1
  134. package/dist/cjs/components/Fieldset/Fieldset.js +2 -1
  135. package/dist/cjs/components/Fieldset/Fieldset.js.map +1 -1
  136. package/dist/cjs/components/Fieldset/Fieldset.test.js +1 -1
  137. package/dist/cjs/components/Fieldset/stories/StyledLegend.d.ts +5 -2
  138. package/dist/cjs/components/Fieldset/stories/StyledLegend.js +9 -7
  139. package/dist/cjs/components/Fieldset/stories/StyledLegend.js.map +1 -1
  140. package/dist/cjs/components/Flex/Flex.js +2 -2
  141. package/dist/cjs/components/Flex/Flex.js.map +1 -1
  142. package/dist/cjs/components/Flex/Flex.test.js +1 -1
  143. package/dist/cjs/components/Grid/Grid.js +2 -2
  144. package/dist/cjs/components/Grid/Grid.js.map +1 -1
  145. package/dist/cjs/components/Grid/Grid.test.js +1 -1
  146. package/dist/cjs/components/Grid/Item.js +4 -2
  147. package/dist/cjs/components/Grid/Item.js.map +1 -1
  148. package/dist/cjs/components/Icon/Icon.js +1 -1
  149. package/dist/cjs/components/Icon/Icon.test.js +1 -1
  150. package/dist/cjs/components/Icon/IconFromName.js +1 -1
  151. package/dist/cjs/components/Icon/IconFromObject.js +2 -2
  152. package/dist/cjs/components/Icon/IconFromObject.js.map +1 -1
  153. package/dist/cjs/components/Image/Image.js +1 -1
  154. package/dist/cjs/components/Image/Image.test.js +1 -1
  155. package/dist/cjs/components/Label/Label.js +1 -1
  156. package/dist/cjs/components/Label/Label.test.js +1 -1
  157. package/dist/cjs/components/Link/Link.js +2 -1
  158. package/dist/cjs/components/Link/Link.js.map +1 -1
  159. package/dist/cjs/components/Link/Link.test.js +1 -1
  160. package/dist/cjs/components/LinkButton/LinkButton.d.ts +1 -1
  161. package/dist/cjs/components/LinkButton/LinkButton.js +1 -1
  162. package/dist/cjs/components/LinkButton/LinkButton.test.js +1 -1
  163. package/dist/cjs/components/List/List.js +1 -1
  164. package/dist/cjs/components/List/List.test.js +1 -1
  165. package/dist/cjs/components/List/ListItem.js +1 -1
  166. package/dist/cjs/components/LoadingIndicator/LoadingIndicator.js +1 -1
  167. package/dist/cjs/components/LoadingIndicator/LoadingIndicator.test.js +1 -1
  168. package/dist/cjs/components/MaskedField/MaskedField.d.ts +11 -0
  169. package/dist/cjs/components/MaskedField/MaskedField.js +46 -0
  170. package/dist/cjs/components/MaskedField/MaskedField.js.map +1 -0
  171. package/dist/cjs/components/MaskedField/MaskedField.test.d.ts +1 -0
  172. package/dist/cjs/components/MaskedField/MaskedField.test.js +69 -0
  173. package/dist/cjs/components/MaskedField/MaskedField.test.js.map +1 -0
  174. package/dist/cjs/components/MaskedField/index.d.ts +1 -0
  175. package/dist/cjs/components/MaskedField/index.js +18 -0
  176. package/dist/cjs/components/MaskedField/index.js.map +1 -0
  177. package/dist/cjs/components/MaskedField/inputFormatters.d.ts +10 -0
  178. package/dist/cjs/components/MaskedField/inputFormatters.js +39 -0
  179. package/dist/cjs/components/MaskedField/inputFormatters.js.map +1 -0
  180. package/dist/cjs/components/Modal/Content.js +1 -1
  181. package/dist/cjs/components/Modal/Header.js +1 -1
  182. package/dist/cjs/components/Modal/Modal.d.ts +1 -1
  183. package/dist/cjs/components/Modal/Modal.js +2 -1
  184. package/dist/cjs/components/Modal/Modal.js.map +1 -1
  185. package/dist/cjs/components/Modal/Modal.test.js +1 -1
  186. package/dist/cjs/components/Modal/index.d.ts +1 -1
  187. package/dist/cjs/components/NumberField/NumberField.js +2 -1
  188. package/dist/cjs/components/NumberField/NumberField.js.map +1 -1
  189. package/dist/cjs/components/NumberField/NumberField.test.js +1 -1
  190. package/dist/cjs/components/NumberField/NumberFieldButton.d.ts +2 -1
  191. package/dist/cjs/components/NumberField/NumberFieldButton.js +2 -1
  192. package/dist/cjs/components/NumberField/NumberFieldButton.js.map +1 -1
  193. package/dist/cjs/components/Option/Option.js +1 -1
  194. package/dist/cjs/components/PasswordField/PasswordField.d.ts +1 -1
  195. package/dist/cjs/components/PasswordField/PasswordField.js +2 -1
  196. package/dist/cjs/components/PasswordField/PasswordField.js.map +1 -1
  197. package/dist/cjs/components/PasswordField/PasswordField.test.js +1 -1
  198. package/dist/cjs/components/PasswordField/ShowHideButton.d.ts +2 -1
  199. package/dist/cjs/components/PasswordField/ShowHideButton.js +1 -1
  200. package/dist/cjs/components/Progress/Progress.js +3 -2
  201. package/dist/cjs/components/Progress/Progress.js.map +1 -1
  202. package/dist/cjs/components/Progress/Progress.test.js +1 -1
  203. package/dist/cjs/components/Radio/Radio.js +8 -2
  204. package/dist/cjs/components/Radio/Radio.js.map +1 -1
  205. package/dist/cjs/components/Radio/Radio.test.js +1 -1
  206. package/dist/cjs/components/Radio/RadioButton.js +8 -2
  207. package/dist/cjs/components/Radio/RadioButton.js.map +1 -1
  208. package/dist/cjs/components/Radio/RadioButton.test.js +1 -1
  209. package/dist/cjs/components/Radio/RadioContext.js +1 -0
  210. package/dist/cjs/components/Radio/RadioContext.js.map +1 -1
  211. package/dist/cjs/components/Radio/RadioGroup.js +2 -1
  212. package/dist/cjs/components/Radio/RadioGroup.js.map +1 -1
  213. package/dist/cjs/components/SVG/SVG.d.ts +1 -0
  214. package/dist/cjs/components/SVG/SVG.js +1 -1
  215. package/dist/cjs/components/SVG/SVG.js.map +1 -1
  216. package/dist/cjs/components/SVG/SVG.test.js +5 -5
  217. package/dist/cjs/components/SVG/SVG.test.js.map +1 -1
  218. package/dist/cjs/components/Segment/Segment.d.ts +1 -1
  219. package/dist/cjs/components/Segment/Segment.js +1 -1
  220. package/dist/cjs/components/Segment/SegmentGroup.d.ts +1 -1
  221. package/dist/cjs/components/Segment/SegmentGroup.js +1 -1
  222. package/dist/cjs/components/Select/Select.d.ts +1 -0
  223. package/dist/cjs/components/Select/Select.js +7 -2
  224. package/dist/cjs/components/Select/Select.js.map +1 -1
  225. package/dist/cjs/components/Select/Select.test.js +1 -1
  226. package/dist/cjs/components/Slider/Slider.d.ts +2 -1
  227. package/dist/cjs/components/Slider/Slider.js +23 -14
  228. package/dist/cjs/components/Slider/Slider.js.map +1 -1
  229. package/dist/cjs/components/Slider/Slider.test.js +1 -1
  230. package/dist/cjs/components/Slider/Thumb.d.ts +1 -1
  231. package/dist/cjs/components/Slider/Thumb.js +9 -5
  232. package/dist/cjs/components/Slider/Thumb.js.map +1 -1
  233. package/dist/cjs/components/Table/Body.js +1 -1
  234. package/dist/cjs/components/Table/Cell.js +1 -1
  235. package/dist/cjs/components/Table/Foot.js +1 -1
  236. package/dist/cjs/components/Table/Head.js +1 -1
  237. package/dist/cjs/components/Table/HeaderCell.js +1 -1
  238. package/dist/cjs/components/Table/Row.js +1 -1
  239. package/dist/cjs/components/Table/Table.js +1 -1
  240. package/dist/cjs/components/Table/Table.test.js +1 -1
  241. package/dist/cjs/components/Text/Text.js +1 -1
  242. package/dist/cjs/components/Text/Text.test.js +1 -1
  243. package/dist/cjs/components/TextArea/TextArea.js +7 -2
  244. package/dist/cjs/components/TextArea/TextArea.js.map +1 -1
  245. package/dist/cjs/components/TextArea/TextArea.test.js +1 -1
  246. package/dist/cjs/components/TextAreaInput/TextAreaInput.js +1 -1
  247. package/dist/cjs/components/TextAreaInput/TextAreaInput.test.js +1 -1
  248. package/dist/cjs/components/TextField/TextField.js +7 -2
  249. package/dist/cjs/components/TextField/TextField.js.map +1 -1
  250. package/dist/cjs/components/TextField/TextField.test.js +1 -1
  251. package/dist/cjs/components/Title/Title.js +1 -1
  252. package/dist/cjs/components/Title/Title.test.js +1 -1
  253. package/dist/cjs/components/VisuallyHidden/index.js +1 -0
  254. package/dist/cjs/components/VisuallyHidden/index.js.map +1 -1
  255. package/dist/cjs/components/index.d.ts +6 -5
  256. package/dist/cjs/components/index.js +6 -5
  257. package/dist/cjs/components/index.js.map +1 -1
  258. package/dist/cjs/contexts/ThemeContext/ThemeContext.d.ts +1 -1
  259. package/dist/cjs/contexts/ThemeContext/ThemeContext.js +2 -1
  260. package/dist/cjs/contexts/ThemeContext/ThemeContext.js.map +1 -1
  261. package/dist/cjs/contexts/ThemeContext/ThemeContext.test.js +1 -1
  262. package/dist/cjs/hooks/useBreakpoint/useBreakpoint.js +1 -0
  263. package/dist/cjs/hooks/useBreakpoint/useBreakpoint.js.map +1 -1
  264. package/dist/cjs/hooks/useBreakpoint/useBreakpoint.test.js +1 -1
  265. package/dist/cjs/hooks/useHideColumns/useHideColumns.js +1 -0
  266. package/dist/cjs/hooks/useHideColumns/useHideColumns.js.map +1 -1
  267. package/dist/cjs/hooks/useOnClickOutside/useOnClickOutside.js +1 -0
  268. package/dist/cjs/hooks/useOnClickOutside/useOnClickOutside.js.map +1 -1
  269. package/dist/cjs/hooks/useWindowEvent/useWindowEvent.js +1 -0
  270. package/dist/cjs/hooks/useWindowEvent/useWindowEvent.js.map +1 -1
  271. package/dist/cjs/index.js +1 -0
  272. package/dist/cjs/index.js.map +1 -1
  273. package/dist/cjs/tsconfig.tsbuildinfo +1 -0
  274. package/dist/esm/components/Accordion/Accordion.js +2 -1
  275. package/dist/esm/components/Accordion/Accordion.js.map +1 -1
  276. package/dist/esm/components/Accordion/Accordion.test.js +1 -1
  277. package/dist/esm/components/Alert/Alert.js +6 -2
  278. package/dist/esm/components/Alert/Alert.js.map +1 -1
  279. package/dist/esm/components/Alert/Alert.test.js +1 -1
  280. package/dist/esm/components/Box/Box.js +1 -1
  281. package/dist/esm/components/Box/Box.test.js +1 -1
  282. package/dist/esm/components/Breadcrumbs/BreadcrumbItem.js +2 -1
  283. package/dist/esm/components/Breadcrumbs/BreadcrumbItem.js.map +1 -1
  284. package/dist/esm/components/Breadcrumbs/Breadcrumbs.js +2 -1
  285. package/dist/esm/components/Breadcrumbs/Breadcrumbs.js.map +1 -1
  286. package/dist/esm/components/Breadcrumbs/Breadcrumbs.test.js +1 -1
  287. package/dist/esm/components/Button/Button.js +2 -1
  288. package/dist/esm/components/Button/Button.js.map +1 -1
  289. package/dist/esm/components/Button/Button.test.js +1 -1
  290. package/dist/esm/components/Button/Loading.js +1 -1
  291. package/dist/esm/components/Checkbox/Checkbox.js +1 -1
  292. package/dist/esm/components/Checkbox/Checkbox.test.js +1 -1
  293. package/dist/esm/components/Checkbox/CheckboxContext.js +1 -0
  294. package/dist/esm/components/Checkbox/CheckboxContext.js.map +1 -1
  295. package/dist/esm/components/Checkbox/CheckboxGroup.js +2 -1
  296. package/dist/esm/components/Checkbox/CheckboxGroup.js.map +1 -1
  297. package/dist/esm/components/Checkbox/CheckboxGroup.test.js +1 -1
  298. package/dist/esm/components/Checkbox/CheckboxGroupItem.js +2 -1
  299. package/dist/esm/components/Checkbox/CheckboxGroupItem.js.map +1 -1
  300. package/dist/esm/components/Checkbox/CheckboxItem.js +2 -1
  301. package/dist/esm/components/Checkbox/CheckboxItem.js.map +1 -1
  302. package/dist/esm/components/Chopin/Actions/Actions.js +1 -1
  303. package/dist/esm/components/Chopin/Actions/Actions.test.js +1 -1
  304. package/dist/esm/components/Chopin/Actions/LinkOrButton.js +1 -1
  305. package/dist/esm/components/Chopin/Actions/LinkOrButton.test.js +1 -1
  306. package/dist/esm/components/Chopin/Footer/Address.js +1 -1
  307. package/dist/esm/components/Chopin/Footer/Copyright.js +1 -1
  308. package/dist/esm/components/Chopin/Footer/Footer.js +1 -1
  309. package/dist/esm/components/Chopin/Footer/Footer.test.js +1 -1
  310. package/dist/esm/components/Chopin/Footer/Legal.js +1 -1
  311. package/dist/esm/components/Chopin/Header/ContactDetails.js +1 -1
  312. package/dist/esm/components/Chopin/Header/Header.js +1 -1
  313. package/dist/esm/components/Chopin/Header/Header.test.js +1 -1
  314. package/dist/esm/components/Chopin/Header/Logo.js +1 -1
  315. package/dist/esm/components/Chopin/PercentageTotalsQuestion/PercentageItem.js +2 -1
  316. package/dist/esm/components/Chopin/PercentageTotalsQuestion/PercentageItem.js.map +1 -1
  317. package/dist/esm/components/Chopin/PercentageTotalsQuestion/PercentageTotalsQuestion.js +2 -1
  318. package/dist/esm/components/Chopin/PercentageTotalsQuestion/PercentageTotalsQuestion.js.map +1 -1
  319. package/dist/esm/components/Chopin/PercentageTotalsQuestion/PercentageTotalsQuestion.test.js +1 -1
  320. package/dist/esm/components/Chopin/Question/Question.js +2 -1
  321. package/dist/esm/components/Chopin/Question/Question.js.map +1 -1
  322. package/dist/esm/components/Chopin/Question/Question.test.js +1 -1
  323. package/dist/esm/components/Chopin/QuestionGroup/QuestionGroup.js +2 -1
  324. package/dist/esm/components/Chopin/QuestionGroup/QuestionGroup.js.map +1 -1
  325. package/dist/esm/components/Chopin/QuestionGroup/QuestionGroup.test.js +1 -1
  326. package/dist/esm/components/Chopin/QuestionHelp/QuestionHelp.js +2 -1
  327. package/dist/esm/components/Chopin/QuestionHelp/QuestionHelp.js.map +1 -1
  328. package/dist/esm/components/Chopin/QuestionHelp/QuestionHelp.test.js +1 -1
  329. package/dist/esm/components/Chopin/Section/Section.js +1 -1
  330. package/dist/esm/components/Chopin/Section/Section.test.js +1 -1
  331. package/dist/esm/components/Chopin/Steps/StepItem.js +6 -2
  332. package/dist/esm/components/Chopin/Steps/StepItem.js.map +1 -1
  333. package/dist/esm/components/Chopin/Steps/Steps.js +1 -1
  334. package/dist/esm/components/Chopin/Steps/Steps.test.js +1 -1
  335. package/dist/esm/components/Chopin/Testimonial/Testimonial.js +1 -1
  336. package/dist/esm/components/Chopin/Testimonial/Testimonial.test.js +1 -1
  337. package/dist/esm/components/Chopin/TradeSelector/Header/Header.js +1 -1
  338. package/dist/esm/components/Chopin/TradeSelector/Listing/Listing.js +1 -1
  339. package/dist/esm/components/Chopin/TradeSelector/Listing/Listing.test.js +1 -1
  340. package/dist/esm/components/Chopin/TradeSelector/Listing/ListingItem.js +2 -1
  341. package/dist/esm/components/Chopin/TradeSelector/Listing/ListingItem.js.map +1 -1
  342. package/dist/esm/components/Chopin/TradeSelector/Listing/ListingItem.test.js +1 -1
  343. package/dist/esm/components/Chopin/TradeSelector/SearchResults/SearchResults.js +2 -1
  344. package/dist/esm/components/Chopin/TradeSelector/SearchResults/SearchResults.js.map +1 -1
  345. package/dist/esm/components/Chopin/TradeSelector/SearchResults/SearchResults.test.js +1 -1
  346. package/dist/esm/components/Chopin/TradeSelector/TradeInput/TradeInput.js +2 -1
  347. package/dist/esm/components/Chopin/TradeSelector/TradeInput/TradeInput.js.map +1 -1
  348. package/dist/esm/components/Chopin/TradeSelector/TradeInput/TradeInput.test.js +1 -1
  349. package/dist/esm/components/Chopin/TradeSelector/TradeSelector.js +2 -1
  350. package/dist/esm/components/Chopin/TradeSelector/TradeSelector.js.map +1 -1
  351. package/dist/esm/components/Chopin/TradeSelector/TradeSelector.test.js +1 -1
  352. package/dist/esm/components/Chopin/TradeSelector/useFetchTrades/useFetchTrades.js +1 -0
  353. package/dist/esm/components/Chopin/TradeSelector/useFetchTrades/useFetchTrades.js.map +1 -1
  354. package/dist/esm/components/Container/Container.js +1 -1
  355. package/dist/esm/components/Container/Container.test.js +1 -1
  356. package/dist/esm/components/DataTable/DataTable.js +1 -1
  357. package/dist/esm/components/DataTable/DataTable.test.js +1 -1
  358. package/dist/esm/components/DataTable/FlexLayout.js +1 -1
  359. package/dist/esm/components/DataTable/SortIcon.js +1 -1
  360. package/dist/esm/components/DataTable/TableLayout.js +1 -1
  361. package/dist/esm/components/DatePicker/Calendar.js +2 -1
  362. package/dist/esm/components/DatePicker/Calendar.js.map +1 -1
  363. package/dist/esm/components/DatePicker/CalendarButton.js +2 -1
  364. package/dist/esm/components/DatePicker/CalendarButton.js.map +1 -1
  365. package/dist/esm/components/DatePicker/CalendarCell.js +2 -1
  366. package/dist/esm/components/DatePicker/CalendarCell.js.map +1 -1
  367. package/dist/esm/components/DatePicker/CalendarGrid.js +2 -1
  368. package/dist/esm/components/DatePicker/CalendarGrid.js.map +1 -1
  369. package/dist/esm/components/DatePicker/DateField.js +2 -1
  370. package/dist/esm/components/DatePicker/DateField.js.map +1 -1
  371. package/dist/esm/components/DatePicker/DatePicker.js +3 -2
  372. package/dist/esm/components/DatePicker/DatePicker.js.map +1 -1
  373. package/dist/esm/components/DatePicker/DateSegment.js +2 -1
  374. package/dist/esm/components/DatePicker/DateSegment.js.map +1 -1
  375. package/dist/esm/components/DatePicker/Popover.js +3 -2
  376. package/dist/esm/components/DatePicker/Popover.js.map +1 -1
  377. package/dist/esm/components/Divider/Divider.js +2 -1
  378. package/dist/esm/components/Divider/Divider.js.map +1 -1
  379. package/dist/esm/components/DropdownMenu/DropdownMenu.js +2 -1
  380. package/dist/esm/components/DropdownMenu/DropdownMenu.js.map +1 -1
  381. package/dist/esm/components/DropdownMenu/DropdownMenu.test.js +1 -1
  382. package/dist/esm/components/DropdownMenu/Item.js +1 -1
  383. package/dist/esm/components/ErrorMessage/ErrorMessage.js +1 -1
  384. package/dist/esm/components/ErrorMessage/ErrorMessage.test.js +1 -1
  385. package/dist/esm/components/Fieldset/Fieldset.js +2 -1
  386. package/dist/esm/components/Fieldset/Fieldset.js.map +1 -1
  387. package/dist/esm/components/Fieldset/Fieldset.test.js +1 -1
  388. package/dist/esm/components/Fieldset/stories/StyledLegend.js +6 -6
  389. package/dist/esm/components/Fieldset/stories/StyledLegend.js.map +1 -1
  390. package/dist/esm/components/Flex/Flex.js +2 -2
  391. package/dist/esm/components/Flex/Flex.js.map +1 -1
  392. package/dist/esm/components/Flex/Flex.test.js +1 -1
  393. package/dist/esm/components/Grid/Grid.js +2 -2
  394. package/dist/esm/components/Grid/Grid.js.map +1 -1
  395. package/dist/esm/components/Grid/Grid.test.js +1 -1
  396. package/dist/esm/components/Grid/Item.js +4 -2
  397. package/dist/esm/components/Grid/Item.js.map +1 -1
  398. package/dist/esm/components/Icon/Icon.js +1 -1
  399. package/dist/esm/components/Icon/Icon.test.js +1 -1
  400. package/dist/esm/components/Icon/IconFromName.js +1 -1
  401. package/dist/esm/components/Icon/IconFromObject.js +2 -2
  402. package/dist/esm/components/Icon/IconFromObject.js.map +1 -1
  403. package/dist/esm/components/Image/Image.js +1 -1
  404. package/dist/esm/components/Image/Image.test.js +1 -1
  405. package/dist/esm/components/Label/Label.js +1 -1
  406. package/dist/esm/components/Label/Label.test.js +1 -1
  407. package/dist/esm/components/Link/Link.js +2 -1
  408. package/dist/esm/components/Link/Link.js.map +1 -1
  409. package/dist/esm/components/Link/Link.test.js +1 -1
  410. package/dist/esm/components/LinkButton/LinkButton.js +1 -1
  411. package/dist/esm/components/LinkButton/LinkButton.test.js +1 -1
  412. package/dist/esm/components/List/List.js +1 -1
  413. package/dist/esm/components/List/List.test.js +1 -1
  414. package/dist/esm/components/List/ListItem.js +1 -1
  415. package/dist/esm/components/LoadingIndicator/LoadingIndicator.js +1 -1
  416. package/dist/esm/components/LoadingIndicator/LoadingIndicator.test.js +1 -1
  417. package/dist/esm/components/MaskedField/MaskedField.js +40 -0
  418. package/dist/esm/components/MaskedField/MaskedField.js.map +1 -0
  419. package/dist/esm/components/MaskedField/MaskedField.test.js +64 -0
  420. package/dist/esm/components/MaskedField/MaskedField.test.js.map +1 -0
  421. package/dist/esm/components/MaskedField/index.js +2 -0
  422. package/dist/esm/components/MaskedField/index.js.map +1 -0
  423. package/dist/esm/components/MaskedField/inputFormatters.js +36 -0
  424. package/dist/esm/components/MaskedField/inputFormatters.js.map +1 -0
  425. package/dist/esm/components/Modal/Content.js +1 -1
  426. package/dist/esm/components/Modal/Header.js +1 -1
  427. package/dist/esm/components/Modal/Modal.js +2 -1
  428. package/dist/esm/components/Modal/Modal.js.map +1 -1
  429. package/dist/esm/components/Modal/Modal.test.js +1 -1
  430. package/dist/esm/components/NumberField/NumberField.js +2 -1
  431. package/dist/esm/components/NumberField/NumberField.js.map +1 -1
  432. package/dist/esm/components/NumberField/NumberField.test.js +1 -1
  433. package/dist/esm/components/NumberField/NumberFieldButton.js +2 -1
  434. package/dist/esm/components/NumberField/NumberFieldButton.js.map +1 -1
  435. package/dist/esm/components/Option/Option.js +1 -1
  436. package/dist/esm/components/PasswordField/PasswordField.js +2 -1
  437. package/dist/esm/components/PasswordField/PasswordField.js.map +1 -1
  438. package/dist/esm/components/PasswordField/PasswordField.test.js +1 -1
  439. package/dist/esm/components/PasswordField/ShowHideButton.js +1 -1
  440. package/dist/esm/components/Progress/Progress.js +3 -2
  441. package/dist/esm/components/Progress/Progress.js.map +1 -1
  442. package/dist/esm/components/Progress/Progress.test.js +1 -1
  443. package/dist/esm/components/Radio/Radio.js +8 -2
  444. package/dist/esm/components/Radio/Radio.js.map +1 -1
  445. package/dist/esm/components/Radio/Radio.test.js +1 -1
  446. package/dist/esm/components/Radio/RadioButton.js +8 -2
  447. package/dist/esm/components/Radio/RadioButton.js.map +1 -1
  448. package/dist/esm/components/Radio/RadioButton.test.js +1 -1
  449. package/dist/esm/components/Radio/RadioContext.js +1 -0
  450. package/dist/esm/components/Radio/RadioContext.js.map +1 -1
  451. package/dist/esm/components/Radio/RadioGroup.js +2 -1
  452. package/dist/esm/components/Radio/RadioGroup.js.map +1 -1
  453. package/dist/esm/components/SVG/SVG.js +1 -1
  454. package/dist/esm/components/SVG/SVG.js.map +1 -1
  455. package/dist/esm/components/SVG/SVG.test.js +5 -5
  456. package/dist/esm/components/SVG/SVG.test.js.map +1 -1
  457. package/dist/esm/components/Segment/Segment.js +1 -1
  458. package/dist/esm/components/Segment/SegmentGroup.js +1 -1
  459. package/dist/esm/components/Select/Select.js +7 -2
  460. package/dist/esm/components/Select/Select.js.map +1 -1
  461. package/dist/esm/components/Select/Select.test.js +1 -1
  462. package/dist/esm/components/Slider/Slider.js +23 -14
  463. package/dist/esm/components/Slider/Slider.js.map +1 -1
  464. package/dist/esm/components/Slider/Slider.test.js +1 -1
  465. package/dist/esm/components/Slider/Thumb.js +9 -5
  466. package/dist/esm/components/Slider/Thumb.js.map +1 -1
  467. package/dist/esm/components/Table/Body.js +1 -1
  468. package/dist/esm/components/Table/Cell.js +1 -1
  469. package/dist/esm/components/Table/Foot.js +1 -1
  470. package/dist/esm/components/Table/Head.js +1 -1
  471. package/dist/esm/components/Table/HeaderCell.js +1 -1
  472. package/dist/esm/components/Table/Row.js +1 -1
  473. package/dist/esm/components/Table/Table.js +1 -1
  474. package/dist/esm/components/Table/Table.test.js +1 -1
  475. package/dist/esm/components/Text/Text.js +1 -1
  476. package/dist/esm/components/Text/Text.test.js +1 -1
  477. package/dist/esm/components/TextArea/TextArea.js +7 -2
  478. package/dist/esm/components/TextArea/TextArea.js.map +1 -1
  479. package/dist/esm/components/TextArea/TextArea.test.js +1 -1
  480. package/dist/esm/components/TextAreaInput/TextAreaInput.js +1 -1
  481. package/dist/esm/components/TextAreaInput/TextAreaInput.test.js +1 -1
  482. package/dist/esm/components/TextField/TextField.js +7 -2
  483. package/dist/esm/components/TextField/TextField.js.map +1 -1
  484. package/dist/esm/components/TextField/TextField.test.js +1 -1
  485. package/dist/esm/components/Title/Title.js +1 -1
  486. package/dist/esm/components/Title/Title.test.js +1 -1
  487. package/dist/esm/components/VisuallyHidden/index.js +1 -0
  488. package/dist/esm/components/VisuallyHidden/index.js.map +1 -1
  489. package/dist/esm/components/index.js +6 -5
  490. package/dist/esm/components/index.js.map +1 -1
  491. package/dist/esm/contexts/ThemeContext/ThemeContext.js +2 -1
  492. package/dist/esm/contexts/ThemeContext/ThemeContext.js.map +1 -1
  493. package/dist/esm/contexts/ThemeContext/ThemeContext.test.js +1 -1
  494. package/dist/esm/hooks/useBreakpoint/useBreakpoint.js +1 -0
  495. package/dist/esm/hooks/useBreakpoint/useBreakpoint.js.map +1 -1
  496. package/dist/esm/hooks/useBreakpoint/useBreakpoint.test.js +1 -1
  497. package/dist/esm/hooks/useHideColumns/useHideColumns.js +1 -0
  498. package/dist/esm/hooks/useHideColumns/useHideColumns.js.map +1 -1
  499. package/dist/esm/hooks/useOnClickOutside/useOnClickOutside.js +1 -0
  500. package/dist/esm/hooks/useOnClickOutside/useOnClickOutside.js.map +1 -1
  501. package/dist/esm/hooks/useWindowEvent/useWindowEvent.js +1 -0
  502. package/dist/esm/hooks/useWindowEvent/useWindowEvent.js.map +1 -1
  503. package/dist/esm/index.js +1 -0
  504. package/dist/esm/index.js.map +1 -1
  505. package/dist/esm/tsconfig.esm.tsbuildinfo +1 -0
  506. package/dist/mobius.d.ts +25 -13
  507. package/package.json +5 -5
  508. package/src/components/Accordion/Accordion.tsx +2 -0
  509. package/src/components/Alert/Alert.tsx +6 -1
  510. package/src/components/Breadcrumbs/BreadcrumbItem.tsx +2 -0
  511. package/src/components/Breadcrumbs/Breadcrumbs.tsx +2 -0
  512. package/src/components/Button/Button.tsx +2 -0
  513. package/src/components/Checkbox/CheckboxContext.tsx +2 -0
  514. package/src/components/Checkbox/CheckboxGroup.tsx +2 -0
  515. package/src/components/Checkbox/CheckboxGroupItem.tsx +2 -0
  516. package/src/components/Checkbox/CheckboxItem.tsx +2 -0
  517. package/src/components/Chopin/PercentageTotalsQuestion/PercentageItem.tsx +2 -0
  518. package/src/components/Chopin/PercentageTotalsQuestion/PercentageTotalsQuestion.tsx +2 -0
  519. package/src/components/Chopin/Question/Question.tsx +2 -0
  520. package/src/components/Chopin/QuestionGroup/QuestionGroup.tsx +2 -0
  521. package/src/components/Chopin/QuestionHelp/QuestionHelp.tsx +2 -0
  522. package/src/components/Chopin/Steps/StepItem.tsx +6 -1
  523. package/src/components/Chopin/TradeSelector/Listing/ListingItem.tsx +2 -0
  524. package/src/components/Chopin/TradeSelector/SearchResults/SearchResults.tsx +2 -0
  525. package/src/components/Chopin/TradeSelector/TradeInput/TradeInput.tsx +2 -0
  526. package/src/components/Chopin/TradeSelector/TradeSelector.tsx +2 -0
  527. package/src/components/Chopin/TradeSelector/types.ts +1 -0
  528. package/src/components/Chopin/TradeSelector/useFetchTrades/useFetchTrades.ts +2 -0
  529. package/src/components/DatePicker/Calendar.tsx +2 -0
  530. package/src/components/DatePicker/CalendarButton.tsx +2 -0
  531. package/src/components/DatePicker/CalendarCell.tsx +2 -0
  532. package/src/components/DatePicker/CalendarGrid.tsx +2 -0
  533. package/src/components/DatePicker/DateField.tsx +2 -0
  534. package/src/components/DatePicker/DatePicker.tsx +3 -1
  535. package/src/components/DatePicker/DateSegment.tsx +2 -0
  536. package/src/components/DatePicker/Popover.tsx +3 -1
  537. package/src/components/Divider/Divider.tsx +2 -0
  538. package/src/components/DropdownMenu/DropdownMenu.tsx +2 -0
  539. package/src/components/Fieldset/Fieldset.tsx +2 -0
  540. package/src/components/Fieldset/stories/StyledLegend.tsx +6 -11
  541. package/src/components/Flex/Flex.tsx +1 -1
  542. package/src/components/Grid/Grid.tsx +3 -4
  543. package/src/components/Grid/Item.tsx +6 -4
  544. package/src/components/Icon/IconFromObject.tsx +1 -1
  545. package/src/components/Link/Link.tsx +2 -0
  546. package/src/components/MaskedField/MaskedField.story.mdx +58 -0
  547. package/src/components/MaskedField/MaskedField.test.tsx +91 -0
  548. package/src/components/MaskedField/MaskedField.tsx +58 -0
  549. package/src/components/MaskedField/index.tsx +1 -0
  550. package/src/components/MaskedField/inputFormatters.ts +42 -0
  551. package/src/components/Modal/Modal.tsx +2 -0
  552. package/src/components/NumberField/NumberField.tsx +2 -0
  553. package/src/components/NumberField/NumberFieldButton.tsx +2 -0
  554. package/src/components/NumberField/__snapshots__/NumberField.test.tsx.snap +4 -2
  555. package/src/components/PasswordField/PasswordField.tsx +2 -0
  556. package/src/components/Progress/Progress.tsx +3 -1
  557. package/src/components/Radio/Radio.tsx +10 -3
  558. package/src/components/Radio/RadioButton.tsx +11 -4
  559. package/src/components/Radio/RadioContext.tsx +2 -0
  560. package/src/components/Radio/RadioGroup.tsx +2 -0
  561. package/src/components/SVG/SVG.test.tsx +3 -4
  562. package/src/components/SVG/SVG.tsx +1 -0
  563. package/src/components/Select/Select.tsx +10 -3
  564. package/src/components/Slider/Slider.tsx +33 -22
  565. package/src/components/Slider/Thumb.tsx +12 -6
  566. package/src/components/TextArea/TextArea.tsx +9 -3
  567. package/src/components/TextField/TextField.tsx +9 -3
  568. package/src/components/VisuallyHidden/index.tsx +2 -0
  569. package/src/components/index.tsx +6 -5
  570. package/src/contexts/ThemeContext/ThemeContext.tsx +2 -0
  571. package/src/hooks/useBreakpoint/useBreakpoint.tsx +2 -0
  572. package/src/hooks/useHideColumns/useHideColumns.ts +2 -0
  573. package/src/hooks/useOnClickOutside/useOnClickOutside.ts +2 -0
  574. package/src/hooks/useWindowEvent/useWindowEvent.tsx +2 -0
  575. package/src/index.tsx +2 -0
@@ -0,0 +1,91 @@
1
+ import { render } from "@testing-library/react";
2
+ import userEvent from "@testing-library/user-event";
3
+ import { MaskedField } from ".";
4
+
5
+ describe("MaskedField", () => {
6
+ const LABEL = "MaskedField";
7
+
8
+ describe("given Social Security Number (SSN) pattern", () => {
9
+ it("should render user input to match the pattern", async () => {
10
+ const { getByLabelText } = render(
11
+ <MaskedField label={LABEL} pattern="ssn" />,
12
+ );
13
+ const inputField = getByLabelText(LABEL);
14
+ const inputValue = "1234567890";
15
+ const expectedUnformatted = "123456789";
16
+ const expectedFormatted = "123-45-6789";
17
+
18
+ await userEvent.tab();
19
+ await userEvent.type(inputField, inputValue);
20
+
21
+ expect(inputField).toHaveValue(expectedUnformatted);
22
+
23
+ await userEvent.tab();
24
+
25
+ expect(inputField).toHaveValue(expectedFormatted);
26
+ });
27
+
28
+ describe("given a numerical and non-numerical input", () => {
29
+ it("should only render numerical input", async () => {
30
+ const { getByLabelText } = render(
31
+ <MaskedField label={LABEL} pattern="ssn" />,
32
+ );
33
+ const inputField = getByLabelText(LABEL);
34
+ const inputValue = "abc1234567890efg";
35
+ const expectedUnformatted = "123456789";
36
+ const expectedFormatted = "123-45-6789";
37
+
38
+ await userEvent.tab();
39
+ await userEvent.type(inputField, inputValue);
40
+
41
+ expect(inputField).toHaveValue(expectedUnformatted);
42
+
43
+ await userEvent.tab();
44
+
45
+ expect(inputField).toHaveValue(expectedFormatted);
46
+ });
47
+ });
48
+ });
49
+
50
+ describe("given Federal Employer Identification Number (FEIN) pattern", () => {
51
+ it("should render user input to match the pattern", async () => {
52
+ const { getByLabelText } = render(
53
+ <MaskedField label={LABEL} pattern="fein" />,
54
+ );
55
+ const inputField = getByLabelText(LABEL);
56
+ const inputValue = "1234567890";
57
+ const expectedUnformatted = "123456789";
58
+ const expectedFormatted = "12-3456789";
59
+
60
+ await userEvent.tab();
61
+ await userEvent.type(inputField, inputValue);
62
+
63
+ expect(inputField).toHaveValue(expectedUnformatted);
64
+
65
+ await userEvent.tab();
66
+
67
+ expect(inputField).toHaveValue(expectedFormatted);
68
+ });
69
+
70
+ describe("given a numerical and non-numerical input", () => {
71
+ it("should only render numerical input", async () => {
72
+ const { getByLabelText } = render(
73
+ <MaskedField label={LABEL} pattern="fein" />,
74
+ );
75
+ const inputField = getByLabelText(LABEL);
76
+ const inputValue = "abc1234567890efg";
77
+ const expectedUnformatted = "123456789";
78
+ const expectedFormatted = "12-3456789";
79
+
80
+ await userEvent.tab();
81
+ await userEvent.type(inputField, inputValue);
82
+
83
+ expect(inputField).toHaveValue(expectedUnformatted);
84
+
85
+ await userEvent.tab();
86
+
87
+ expect(inputField).toHaveValue(expectedFormatted);
88
+ });
89
+ });
90
+ });
91
+ });
@@ -0,0 +1,58 @@
1
+ "use client";
2
+
3
+ import { Ref, forwardRef, useState, useEffect } from "react";
4
+ import { DOMProps } from "@react-types/shared";
5
+ import clsx from "clsx";
6
+ import { ForwardedRefComponent } from "../../types/components";
7
+ import { TextField, TextFieldElementType, TextFieldProps } from "../TextField";
8
+ import { INPUT_FORMATTERS } from "./inputFormatters";
9
+
10
+ export type MaskedFieldElementType = HTMLInputElement;
11
+
12
+ export interface MaskedFieldProps extends TextFieldProps, DOMProps {
13
+ pattern: "ssn" | "fein";
14
+ }
15
+
16
+ export type MaskedFieldRef = Ref<MaskedFieldElementType>;
17
+
18
+ const MaskedField: ForwardedRefComponent<
19
+ MaskedFieldProps,
20
+ TextFieldElementType
21
+ > = forwardRef((props: MaskedFieldProps, ref: MaskedFieldRef) => {
22
+ const { pattern, ...otherProps } = props;
23
+ const [isEditable, setIsEditable] = useState<boolean>(false);
24
+ const [unformatted, setUnformatted] = useState<string>("");
25
+ const [formatted, setFormatted] = useState<string>("");
26
+ const inputValue = isEditable ? unformatted : formatted;
27
+
28
+ const handleChange = (value: string) => {
29
+ const trimmedValue = INPUT_FORMATTERS[pattern].clean(value);
30
+ setUnformatted(trimmedValue);
31
+ };
32
+
33
+ const toggleEditable = () => {
34
+ setIsEditable(!isEditable);
35
+ };
36
+
37
+ useEffect(() => {
38
+ const formattedValue = INPUT_FORMATTERS[pattern].transform(unformatted);
39
+ setFormatted(formattedValue);
40
+ }, [pattern, unformatted]);
41
+
42
+ const classes = clsx("mobius", "mobius/MaskedField", otherProps.className);
43
+
44
+ return (
45
+ <TextField
46
+ onChange={handleChange}
47
+ value={inputValue}
48
+ className={classes}
49
+ ref={ref}
50
+ onFocus={toggleEditable}
51
+ onBlur={toggleEditable}
52
+ {...otherProps}
53
+ />
54
+ );
55
+ });
56
+
57
+ MaskedField.displayName = "MaskedField";
58
+ export { MaskedField };
@@ -0,0 +1 @@
1
+ export * from "./MaskedField";
@@ -0,0 +1,42 @@
1
+ // SSN - Social Security Number. Format: XXX-XX-XXXX
2
+ // FEIN - Federal Employer Identification Number. Format: XX-XXXXXXX
3
+
4
+ const SSN_LENGTH = 9;
5
+ const FEIN_LENGTH = 9;
6
+
7
+ export const INPUT_FORMATTERS = {
8
+ ssn: {
9
+ clean: (value: string) => value.replace(/\D/g, "").slice(0, SSN_LENGTH),
10
+ transform: (value: string) => {
11
+ const startLength = 3;
12
+ const middleLength = 2;
13
+ const start = value.slice(0, 3);
14
+ const middle = value.slice(3, 5);
15
+ const end = value.slice(5, SSN_LENGTH);
16
+
17
+ if (value.length > startLength + middleLength) {
18
+ return `${start}-${middle}-${end}`;
19
+ }
20
+
21
+ if (value.length > startLength) {
22
+ return `${start}-${middle}`;
23
+ }
24
+
25
+ return start;
26
+ },
27
+ },
28
+ fein: {
29
+ clean: (value: string) => value.replace(/\D/g, "").slice(0, FEIN_LENGTH),
30
+ transform: (value: string) => {
31
+ const startLength = 2;
32
+ const start = value.slice(0, 2);
33
+ const end = value.slice(2, FEIN_LENGTH);
34
+
35
+ if (value.length > startLength) {
36
+ return `${start}-${end}`;
37
+ }
38
+
39
+ return start;
40
+ },
41
+ },
42
+ };
@@ -1,3 +1,5 @@
1
+ "use client";
2
+
1
3
  import {
2
4
  Children,
3
5
  isValidElement,
@@ -1,3 +1,5 @@
1
+ "use client";
2
+
1
3
  import { Ref, forwardRef, RefAttributes, ReactNode, useRef } from "react";
2
4
  import { DOMProps } from "@react-types/shared";
3
5
  import {
@@ -1,3 +1,5 @@
1
+ "use client";
2
+
1
3
  import { useButton } from "@react-aria/button";
2
4
  import { useFocusRing } from "@react-aria/focus";
3
5
  import { useHover } from "@react-aria/interactions";
@@ -37,9 +37,10 @@ exports[`NumberField should match snapshot 1`] = `
37
37
  >
38
38
  <svg
39
39
  aria-hidden="true"
40
- class="mobius mobius/Icon css-jnky18"
40
+ class="mobius mobius/Icon"
41
41
  focusable="false"
42
42
  role="img"
43
+ style="height: 1em; vertical-align: -0.2em; transform-origin: center;"
43
44
  viewBox="0 0 24 24"
44
45
  xmlns="http://www.w3.org/2000/svg"
45
46
  >
@@ -58,9 +59,10 @@ exports[`NumberField should match snapshot 1`] = `
58
59
  >
59
60
  <svg
60
61
  aria-hidden="true"
61
- class="mobius mobius/Icon css-jnky18"
62
+ class="mobius mobius/Icon"
62
63
  focusable="false"
63
64
  role="img"
65
+ style="height: 1em; vertical-align: -0.2em; transform-origin: center;"
64
66
  viewBox="0 0 16 16"
65
67
  xmlns="http://www.w3.org/2000/svg"
66
68
  >
@@ -1,3 +1,5 @@
1
+ "use client";
2
+
1
3
  import clsx from "clsx";
2
4
  import { forwardRef, useState, useRef } from "react";
3
5
  import { mergeRefs } from "../../utils/mergeRefs";
@@ -1,3 +1,5 @@
1
+ "use client";
2
+
1
3
  /* eslint no-console: "off" */
2
4
  import { Ref, forwardRef, RefAttributes, ReactNode } from "react";
3
5
  import { DOMProps } from "@react-types/shared";
@@ -118,7 +120,7 @@ const Progress: ForwardedRefComponent<ProgressProps, ProgressElementType> =
118
120
  </Label>
119
121
  )}
120
122
  <div className="mobius/ProgressTrack">
121
- <div className="mobius/ProgressBar" css={{ width: barWidth }} />
123
+ <div className="mobius/ProgressBar" style={{ width: barWidth }} />
122
124
  </div>
123
125
  {showValueLabel && (
124
126
  <Label data-testid="value-label">
@@ -1,3 +1,5 @@
1
+ "use client";
2
+
1
3
  import { forwardRef, ReactNode, useContext, Ref, RefAttributes } from "react";
2
4
  import { useRadio } from "@react-aria/radio";
3
5
  import { AriaRadioProps } from "@react-types/radio";
@@ -5,6 +7,7 @@ import { useFocusRing } from "@react-aria/focus";
5
7
  import { useHover, HoverProps } from "@react-aria/interactions";
6
8
  import { DOMProps } from "@react-types/shared";
7
9
  import clsx from "clsx";
10
+ import styled from '@emotion/styled';
8
11
  import { RadioContext } from "./RadioContext";
9
12
  import { ForwardedRefComponent } from "../../types/components";
10
13
  import { ErrorMessage } from "../ErrorMessage";
@@ -25,6 +28,11 @@ export interface RadioProps
25
28
 
26
29
  export type RadioRef = Ref<RadioElementType>;
27
30
 
31
+ const StyledLabel = styled(Label)`
32
+ display: flex;
33
+ align-items: center;
34
+ `;
35
+
28
36
  const Radio: ForwardedRefComponent<RadioProps, RadioElementType> = forwardRef(
29
37
  (props: RadioProps, ref: RadioRef) => {
30
38
  const radioContext = useContext(RadioContext);
@@ -83,8 +91,7 @@ const Radio: ForwardedRefComponent<RadioProps, RadioElementType> = forwardRef(
83
91
 
84
92
  return (
85
93
  <>
86
- <Label
87
- css={{ display: "flex", alignItems: "center" }}
94
+ <StyledLabel
88
95
  {...hoverProps}
89
96
  className={containerClasses}
90
97
  >
@@ -105,7 +112,7 @@ const Radio: ForwardedRefComponent<RadioProps, RadioElementType> = forwardRef(
105
112
  ) : (
106
113
  <div className="mobius/RadioContent">{label || children}</div>
107
114
  )}
108
- </Label>
115
+ </StyledLabel>
109
116
  {errorMessage && <ErrorMessage errorMessage={errorMessage} />}
110
117
  </>
111
118
  );
@@ -1,3 +1,5 @@
1
+ "use client";
2
+
1
3
  import {
2
4
  forwardRef,
3
5
  ReactNode,
@@ -12,6 +14,7 @@ import { useFocusRing } from "@react-aria/focus";
12
14
  import { useHover, HoverProps } from "@react-aria/interactions";
13
15
  import { DOMProps } from "@react-types/shared";
14
16
  import clsx from "clsx";
17
+ import styled from '@emotion/styled';
15
18
  import { RadioContext } from "./RadioContext";
16
19
  import { ForwardedRefComponent } from "../../types/components";
17
20
 
@@ -29,6 +32,11 @@ export interface RadioButtonProps
29
32
 
30
33
  export type RadioButtonRef = Ref<RadioButtonElementType>;
31
34
 
35
+ const StyledLabel = styled.label`
36
+ display: flex;
37
+ align-items: center;
38
+ `;
39
+
32
40
  const RadioButton: ForwardedRefComponent<
33
41
  RadioButtonProps,
34
42
  RadioButtonElementType
@@ -89,7 +97,7 @@ const RadioButton: ForwardedRefComponent<
89
97
 
90
98
  if (children) {
91
99
  // Determine type of children (label or icon) and map to relevant HTML span
92
- const childMap = { label };
100
+ const childMap: any = { label };
93
101
 
94
102
  Children.map(children, child => {
95
103
  const childType =
@@ -110,14 +118,13 @@ const RadioButton: ForwardedRefComponent<
110
118
  }
111
119
 
112
120
  return (
113
- <label
114
- css={{ display: "flex", alignItems: "center" }}
121
+ <StyledLabel
115
122
  className={containerClasses}
116
123
  {...hoverProps}
117
124
  >
118
125
  {nativeInput}
119
126
  {content}
120
- </label>
127
+ </StyledLabel>
121
128
  );
122
129
  });
123
130
 
@@ -1,3 +1,5 @@
1
+ "use client";
2
+
1
3
  import { RadioGroupState } from "@react-stately/radio";
2
4
  import { createContext, Context } from "react";
3
5
 
@@ -1,3 +1,5 @@
1
+ "use client";
2
+
1
3
  import {
2
4
  Children,
3
5
  Ref,
@@ -11,13 +11,13 @@ const SvgImage = (
11
11
 
12
12
  describe("Test for SVG", () => {
13
13
  it("should render without errors", () => {
14
- render(<SVG css={{ fill: "primary", width: "size-100" }}>{SvgImage}</SVG>);
14
+ render(<SVG>{SvgImage}</SVG>);
15
15
  });
16
16
 
17
17
  describe("uses correct class names", () => {
18
18
  it("uses Mobius class", () => {
19
19
  render(
20
- <SVG css={{ fill: "primary", width: "size-100" }} data-testid="test">
20
+ <SVG data-testid="test">
21
21
  {SvgImage}
22
22
  </SVG>,
23
23
  );
@@ -26,7 +26,7 @@ describe("Test for SVG", () => {
26
26
 
27
27
  it("uses base Mobius class", () => {
28
28
  render(
29
- <SVG css={{ fill: "primary", width: "size-100" }} data-testid="test">
29
+ <SVG data-testid="test">
30
30
  {SvgImage}
31
31
  </SVG>,
32
32
  );
@@ -36,7 +36,6 @@ describe("Test for SVG", () => {
36
36
  it("includes custom class name", () => {
37
37
  render(
38
38
  <SVG
39
- css={{ fill: "primary", width: "size-100" }}
40
39
  data-testid="test"
41
40
  className="my-class"
42
41
  >
@@ -6,6 +6,7 @@ import { ForwardedRefComponent } from "../../types/components";
6
6
  export interface SVGProps extends DOMProps, RefAttributes<SVGSVGElement> {
7
7
  children: React.ReactElement<React.SVGProps<SVGSVGElement>>;
8
8
  className?: string;
9
+ style?: React.CSSProperties;
9
10
  }
10
11
 
11
12
  export type SVGRef = Ref<SVGSVGElement>;
@@ -1,3 +1,5 @@
1
+ "use client";
2
+
1
3
  import {
2
4
  forwardRef,
3
5
  ReactElement,
@@ -11,6 +13,7 @@ import clsx from "clsx";
11
13
  import { useFocusRing } from "@react-aria/focus";
12
14
  import { HoverProps, useHover } from "@react-aria/interactions";
13
15
  import { useSlotId } from "@react-aria/utils";
16
+ import styled from '@emotion/styled';
14
17
  import { ForwardedRefComponent } from "../../types/components";
15
18
  import { Flex } from "../Flex";
16
19
  import { ErrorMessage } from "../ErrorMessage";
@@ -32,10 +35,15 @@ export interface SelectProps
32
35
  className?: string;
33
36
  errorMessage?: string;
34
37
  children?: ReactElement<OptionProps>[] | ReactElement<OptionProps>;
38
+ "aria-describedby"?: string;
35
39
  }
36
40
 
37
41
  export type SelectRef = Ref<SelectElementType>;
38
42
 
43
+ const ColumnFlex = styled(Flex)`
44
+ flex-direction: column;
45
+ `;
46
+
39
47
  const Select: ForwardedRefComponent<SelectProps, SelectElementType> =
40
48
  forwardRef((props: SelectProps, ref: SelectRef) => {
41
49
  const {
@@ -94,9 +102,8 @@ const Select: ForwardedRefComponent<SelectProps, SelectElementType> =
94
102
  ]);
95
103
 
96
104
  return (
97
- <Flex
105
+ <ColumnFlex
98
106
  className="mobius mobius/SelectOuter"
99
- css={{ flexDirection: "column" }}
100
107
  >
101
108
  {label && (
102
109
  <Label {...labelProps} className={labelClasses}>
@@ -124,7 +131,7 @@ const Select: ForwardedRefComponent<SelectProps, SelectElementType> =
124
131
  <span className={iconClasses} />
125
132
  </div>
126
133
  <ErrorMessage id={errorMessageId} errorMessage={errorMessage} />
127
- </Flex>
134
+ </ColumnFlex>
128
135
  );
129
136
  });
130
137
 
@@ -1,3 +1,5 @@
1
+ "use client";
2
+
1
3
  import { useRef } from "react";
2
4
  import { useSlider } from "@react-aria/slider";
3
5
  import { SliderProps as SpectrumSliderProps } from "@react-types/slider";
@@ -5,6 +7,7 @@ import { useSliderState } from "@react-stately/slider";
5
7
  import { useNumberFormatter } from "@react-aria/i18n";
6
8
  import clsx from "clsx";
7
9
  import { DOMProps } from "@react-types/shared";
10
+ import styled from '@emotion/styled';
8
11
  import { SliderThumb } from "./Thumb";
9
12
  import { Label } from "../Label";
10
13
  import { useUnwrappedHandler, useWrappedValue } from "./helpers";
@@ -19,6 +22,29 @@ export interface SliderProps extends SpectrumSliderProps<number>, DOMProps {
19
22
  formatOptions?: Intl.NumberFormatOptions;
20
23
  }
21
24
 
25
+ const SliderWrapper = styled.div`
26
+ position: relative;
27
+ display: flex;
28
+ flex-direction: column;
29
+ align-items: center;
30
+ touch-action: none;
31
+ `;
32
+
33
+ const SliderLabelWrapper = styled.div`
34
+ display: flex;
35
+ align-self: stretch;
36
+ `;
37
+
38
+ const SliderTrackWrapper = styled.div`
39
+ position: relative;
40
+ width: 100%;
41
+ `;
42
+
43
+ const SliderTrack = styled.div`
44
+ position: absolute;
45
+ width: 100%;
46
+ `;
47
+
22
48
  export function Slider(props: SliderProps) {
23
49
  const {
24
50
  className,
@@ -70,19 +96,12 @@ export function Slider(props: SliderProps) {
70
96
  });
71
97
 
72
98
  return (
73
- <div
99
+ <SliderWrapper
74
100
  {...groupProps}
75
- css={{
76
- position: "relative",
77
- display: "flex",
78
- flexDirection: "column",
79
- alignItems: "center",
80
- touchAction: "none",
81
- }}
82
101
  className={classes}
83
102
  >
84
103
  {/* Create a flex container for the label and output element. */}
85
- <div css={{ display: "flex", alignSelf: "stretch" }}>
104
+ <SliderLabelWrapper>
86
105
  {label && <Label {...labelProps}>{label}</Label>}
87
106
  {label && (
88
107
  <output
@@ -92,26 +111,18 @@ export function Slider(props: SliderProps) {
92
111
  {state.getThumbValueLabel(0)}
93
112
  </output>
94
113
  )}
95
- </div>
114
+ </SliderLabelWrapper>
96
115
  {/* The track element holds the visible track line and the thumb. */}
97
- <div
116
+ <SliderTrackWrapper
98
117
  {...trackProps}
99
118
  ref={trackRef}
100
119
  className="mobius mobius/SliderTrackWrapper"
101
- css={{
102
- position: "relative",
103
- width: "100%",
104
- }}
105
120
  >
106
- <div
121
+ <SliderTrack
107
122
  className="mobius/SliderTrack"
108
- css={{
109
- position: "absolute",
110
- width: "100%",
111
- }}
112
123
  />
113
124
  <SliderThumb index={0} state={state} trackRef={trackRef} />
114
- </div>
125
+ </SliderTrackWrapper>
115
126
  <div className="mobius/SliderLabels">
116
127
  <div className="mobius/SliderMinLabel" data-testid="min-label">
117
128
  {minLabel}
@@ -120,6 +131,6 @@ export function Slider(props: SliderProps) {
120
131
  {maxLabel}
121
132
  </div>
122
133
  </div>
123
- </div>
134
+ </SliderWrapper>
124
135
  );
125
136
  }
@@ -1,3 +1,5 @@
1
+ "use client";
2
+
1
3
  import { RefObject, useRef } from "react";
2
4
  import { useFocusRing } from "@react-aria/focus";
3
5
  import { VisuallyHidden } from "@react-aria/visually-hidden";
@@ -6,12 +8,19 @@ import { useSliderThumb } from "@react-aria/slider";
6
8
  import { SliderThumbProps as SpectrumSliderThumbProps } from "@react-types/slider";
7
9
  import { SliderState } from "@react-stately/slider";
8
10
  import clsx from "clsx";
11
+ import styled from '@emotion/styled';
9
12
 
10
13
  export interface SliderThumbProps extends SpectrumSliderThumbProps {
11
14
  state: SliderState;
12
15
  trackRef: RefObject<HTMLElement>;
13
16
  }
14
17
 
18
+ const StyledThumb = styled.div`
19
+ position: absolute;
20
+ top: calc(50% - 1px);
21
+ transform: translateX(-50%);
22
+ `;
23
+
15
24
  export function SliderThumb(props: SliderThumbProps) {
16
25
  const { state, trackRef, index, isDisabled } = props;
17
26
  const inputRef = useRef(null);
@@ -35,11 +44,8 @@ export function SliderThumb(props: SliderThumbProps) {
35
44
  const thumbClasses = clsx("mobius", "mobius/SliderThumb", classes);
36
45
 
37
46
  return (
38
- <div
39
- css={{
40
- position: "absolute",
41
- top: "calc(50% - 1px)",
42
- transform: "translateX(-50%)",
47
+ <StyledThumb
48
+ style={{
43
49
  left: `${state.getThumbPercent(index) * 100}%`,
44
50
  }}
45
51
  className={wrapperClasses}
@@ -49,6 +55,6 @@ export function SliderThumb(props: SliderThumbProps) {
49
55
  <input ref={inputRef} {...mergeProps(inputProps, focusProps)} />
50
56
  </VisuallyHidden>
51
57
  </div>
52
- </div>
58
+ </StyledThumb>
53
59
  );
54
60
  }
@@ -1,9 +1,12 @@
1
+ "use client";
2
+
1
3
  import { Ref, forwardRef, RefObject, RefAttributes } from "react";
2
4
  import { DOMProps } from "@react-types/shared";
3
5
  import clsx from "clsx";
4
6
  import { AriaTextFieldOptions, useTextField } from "@react-aria/textfield";
5
7
  import { useFocusRing } from "@react-aria/focus";
6
8
  import { HoverProps, useHover } from "@react-aria/interactions";
9
+ import styled from '@emotion/styled';
7
10
  import { TextAreaInput } from "../TextAreaInput";
8
11
  import { Label } from "../Label";
9
12
  import { ForwardedRefComponent } from "../../types/components";
@@ -24,6 +27,10 @@ export interface TextAreaProps
24
27
 
25
28
  export type TextAreaRef = Ref<TextAreaElementType>;
26
29
 
30
+ const ColumnFlex = styled(Flex)`
31
+ flex-direction: column;
32
+ `;
33
+
27
34
  const TextArea: ForwardedRefComponent<TextAreaProps, TextAreaElementType> =
28
35
  forwardRef((props: TextAreaProps, ref: TextAreaRef) => {
29
36
  const {
@@ -70,8 +77,7 @@ const TextArea: ForwardedRefComponent<TextAreaProps, TextAreaElementType> =
70
77
  });
71
78
 
72
79
  return (
73
- <Flex
74
- css={{ flexDirection: "column" }}
80
+ <ColumnFlex
75
81
  className={classes}
76
82
  {...focusProps}
77
83
  >
@@ -91,7 +97,7 @@ const TextArea: ForwardedRefComponent<TextAreaProps, TextAreaElementType> =
91
97
  aria-invalid={errorMessage != null}
92
98
  />
93
99
  <ErrorMessage {...errorMessageProps} errorMessage={errorMessage} />
94
- </Flex>
100
+ </ColumnFlex>
95
101
  );
96
102
  });
97
103