@dxc-technology/halstack-react 10.1.0 → 12.0.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 (350) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +4 -21
  3. package/HalstackContext.d.ts +45 -143
  4. package/HalstackContext.js +10 -35
  5. package/accordion/Accordion.accessibility.test.js +71 -0
  6. package/accordion/Accordion.js +33 -84
  7. package/accordion/Accordion.stories.tsx +8 -64
  8. package/accordion/Accordion.test.js +18 -33
  9. package/accordion/types.d.ts +6 -6
  10. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  11. package/accordion-group/AccordionGroup.d.ts +2 -3
  12. package/accordion-group/AccordionGroup.js +17 -44
  13. package/accordion-group/AccordionGroup.stories.tsx +24 -24
  14. package/accordion-group/AccordionGroup.test.js +42 -60
  15. package/accordion-group/AccordionGroupAccordion.js +11 -23
  16. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  17. package/accordion-group/AccordionGroupContext.js +8 -0
  18. package/accordion-group/types.d.ts +7 -7
  19. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  20. package/action-icon/ActionIcon.d.ts +4 -0
  21. package/action-icon/ActionIcon.js +48 -0
  22. package/action-icon/ActionIcon.stories.tsx +41 -0
  23. package/action-icon/ActionIcon.test.js +64 -0
  24. package/action-icon/types.d.ts +26 -0
  25. package/alert/Alert.accessibility.test.js +95 -0
  26. package/alert/Alert.js +34 -120
  27. package/alert/Alert.test.js +28 -45
  28. package/alert/types.d.ts +5 -5
  29. package/badge/Badge.accessibility.test.js +129 -0
  30. package/badge/Badge.d.ts +1 -1
  31. package/badge/Badge.js +142 -42
  32. package/badge/Badge.stories.tsx +210 -0
  33. package/badge/Badge.test.js +30 -0
  34. package/badge/types.d.ts +52 -3
  35. package/bleed/Bleed.js +13 -21
  36. package/bleed/types.d.ts +2 -2
  37. package/box/Box.accessibility.test.js +33 -0
  38. package/box/Box.js +11 -33
  39. package/box/Box.test.js +1 -6
  40. package/box/types.d.ts +3 -3
  41. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  42. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  43. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  44. package/breadcrumbs/Breadcrumbs.js +79 -0
  45. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  46. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  47. package/breadcrumbs/Breadcrumbs.test.js +169 -0
  48. package/breadcrumbs/Item.d.ts +4 -0
  49. package/breadcrumbs/Item.js +52 -0
  50. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  51. package/breadcrumbs/dropdownTheme.js +62 -0
  52. package/breadcrumbs/types.d.ts +16 -0
  53. package/breadcrumbs/types.js +5 -0
  54. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  55. package/bulleted-list/BulletedList.js +22 -55
  56. package/bulleted-list/BulletedList.stories.tsx +2 -93
  57. package/bulleted-list/types.d.ts +5 -5
  58. package/button/Button.accessibility.test.js +127 -0
  59. package/button/Button.js +36 -59
  60. package/button/Button.stories.tsx +35 -135
  61. package/button/Button.test.js +13 -21
  62. package/button/types.d.ts +5 -5
  63. package/card/Card.accessibility.test.js +36 -0
  64. package/card/Card.js +23 -45
  65. package/card/Card.test.js +10 -21
  66. package/card/types.d.ts +5 -5
  67. package/checkbox/Checkbox.accessibility.test.js +87 -0
  68. package/checkbox/Checkbox.js +88 -123
  69. package/checkbox/Checkbox.stories.tsx +16 -54
  70. package/checkbox/Checkbox.test.js +107 -63
  71. package/checkbox/types.d.ts +8 -4
  72. package/chip/Chip.accessibility.test.js +67 -0
  73. package/chip/Chip.js +22 -36
  74. package/chip/Chip.stories.tsx +10 -25
  75. package/chip/Chip.test.js +17 -30
  76. package/chip/types.d.ts +4 -4
  77. package/common/coreTokens.d.ts +105 -14
  78. package/common/coreTokens.js +40 -23
  79. package/common/utils.js +2 -8
  80. package/common/variables.d.ts +46 -144
  81. package/common/variables.js +120 -225
  82. package/container/Container.d.ts +4 -0
  83. package/container/Container.js +194 -0
  84. package/container/Container.stories.tsx +214 -0
  85. package/container/types.d.ts +74 -0
  86. package/container/types.js +5 -0
  87. package/contextual-menu/ContextualMenu.accessibility.test.js +97 -0
  88. package/contextual-menu/ContextualMenu.d.ts +5 -0
  89. package/contextual-menu/ContextualMenu.js +88 -0
  90. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  91. package/contextual-menu/ContextualMenu.test.js +205 -0
  92. package/contextual-menu/GroupItem.d.ts +4 -0
  93. package/contextual-menu/GroupItem.js +67 -0
  94. package/contextual-menu/ItemAction.d.ts +4 -0
  95. package/contextual-menu/ItemAction.js +51 -0
  96. package/contextual-menu/MenuItem.d.ts +4 -0
  97. package/contextual-menu/MenuItem.js +29 -0
  98. package/contextual-menu/SingleItem.d.ts +4 -0
  99. package/contextual-menu/SingleItem.js +38 -0
  100. package/contextual-menu/types.d.ts +58 -0
  101. package/contextual-menu/types.js +5 -0
  102. package/date-input/Calendar.js +13 -57
  103. package/date-input/DateInput.accessibility.test.js +228 -0
  104. package/date-input/DateInput.js +53 -100
  105. package/date-input/DateInput.stories.tsx +19 -31
  106. package/date-input/DateInput.test.js +674 -701
  107. package/date-input/DatePicker.js +23 -48
  108. package/date-input/YearPicker.js +8 -34
  109. package/date-input/types.d.ts +28 -22
  110. package/dialog/Dialog.accessibility.test.js +69 -0
  111. package/dialog/Dialog.js +21 -59
  112. package/dialog/Dialog.stories.tsx +176 -0
  113. package/dialog/Dialog.test.js +126 -188
  114. package/dialog/types.d.ts +18 -13
  115. package/divider/Divider.accessibility.test.js +33 -0
  116. package/divider/Divider.d.ts +4 -0
  117. package/divider/Divider.js +36 -0
  118. package/divider/Divider.stories.tsx +223 -0
  119. package/divider/Divider.test.js +38 -0
  120. package/divider/types.d.ts +21 -0
  121. package/divider/types.js +5 -0
  122. package/dropdown/Dropdown.accessibility.test.js +180 -0
  123. package/dropdown/Dropdown.js +63 -130
  124. package/dropdown/Dropdown.stories.tsx +15 -26
  125. package/dropdown/Dropdown.test.js +402 -389
  126. package/dropdown/DropdownMenu.js +12 -23
  127. package/dropdown/DropdownMenuItem.js +13 -21
  128. package/dropdown/types.d.ts +20 -24
  129. package/file-input/FileInput.accessibility.test.js +160 -0
  130. package/file-input/FileInput.js +180 -284
  131. package/file-input/FileInput.stories.tsx +1 -1
  132. package/file-input/FileInput.test.js +279 -354
  133. package/file-input/FileItem.js +29 -66
  134. package/file-input/types.d.ts +9 -9
  135. package/flex/Flex.js +25 -39
  136. package/flex/types.d.ts +6 -6
  137. package/footer/Footer.accessibility.test.js +125 -0
  138. package/footer/Footer.d.ts +1 -1
  139. package/footer/Footer.js +43 -68
  140. package/footer/Footer.stories.tsx +58 -2
  141. package/footer/Footer.test.js +18 -32
  142. package/footer/Icons.d.ts +3 -2
  143. package/footer/Icons.js +53 -22
  144. package/footer/types.d.ts +17 -17
  145. package/grid/Grid.js +1 -16
  146. package/grid/types.d.ts +10 -10
  147. package/header/Header.accessibility.test.js +93 -0
  148. package/header/Header.d.ts +1 -1
  149. package/header/Header.js +38 -104
  150. package/header/Header.stories.tsx +16 -0
  151. package/header/Header.test.js +12 -25
  152. package/header/Icons.d.ts +2 -2
  153. package/header/Icons.js +3 -13
  154. package/header/types.d.ts +7 -8
  155. package/heading/Heading.accessibility.test.js +33 -0
  156. package/heading/Heading.js +9 -31
  157. package/heading/Heading.test.js +70 -87
  158. package/heading/types.d.ts +7 -7
  159. package/icon/Icon.accessibility.test.js +30 -0
  160. package/icon/Icon.d.ts +4 -0
  161. package/icon/Icon.js +33 -0
  162. package/icon/Icon.stories.tsx +28 -0
  163. package/icon/types.d.ts +4 -0
  164. package/icon/types.js +5 -0
  165. package/image/Image.accessibility.test.js +56 -0
  166. package/image/Image.d.ts +2 -2
  167. package/image/Image.js +17 -32
  168. package/image/Image.stories.tsx +3 -1
  169. package/image/types.d.ts +2 -2
  170. package/inset/Inset.js +13 -21
  171. package/inset/types.d.ts +2 -2
  172. package/layout/ApplicationLayout.d.ts +2 -2
  173. package/layout/ApplicationLayout.js +23 -60
  174. package/layout/Icons.d.ts +4 -5
  175. package/layout/Icons.js +2 -16
  176. package/layout/types.d.ts +3 -3
  177. package/link/Link.accessibility.test.js +108 -0
  178. package/link/Link.js +28 -47
  179. package/link/Link.stories.tsx +4 -4
  180. package/link/Link.test.js +23 -41
  181. package/link/types.d.ts +14 -14
  182. package/main.d.ts +8 -4
  183. package/main.js +39 -60
  184. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  185. package/nav-tabs/NavTabs.d.ts +1 -2
  186. package/nav-tabs/NavTabs.js +19 -48
  187. package/nav-tabs/NavTabs.stories.tsx +30 -25
  188. package/nav-tabs/NavTabs.test.js +45 -50
  189. package/nav-tabs/NavTabsContext.d.ts +3 -0
  190. package/nav-tabs/NavTabsContext.js +8 -0
  191. package/nav-tabs/Tab.js +38 -67
  192. package/nav-tabs/types.d.ts +10 -10
  193. package/number-input/NumberInput.accessibility.test.js +228 -0
  194. package/number-input/NumberInput.d.ts +0 -7
  195. package/number-input/NumberInput.js +47 -39
  196. package/number-input/NumberInput.stories.tsx +42 -26
  197. package/number-input/NumberInput.test.js +839 -575
  198. package/number-input/NumberInputContext.d.ts +3 -0
  199. package/number-input/NumberInputContext.js +8 -0
  200. package/number-input/types.d.ts +17 -5
  201. package/package.json +41 -37
  202. package/paginator/Paginator.accessibility.test.js +79 -0
  203. package/paginator/Paginator.js +27 -52
  204. package/paginator/Paginator.test.js +224 -207
  205. package/paginator/types.d.ts +3 -3
  206. package/paragraph/Paragraph.accessibility.test.js +28 -0
  207. package/paragraph/Paragraph.js +3 -19
  208. package/paragraph/Paragraph.stories.tsx +0 -17
  209. package/password-input/PasswordInput.accessibility.test.js +153 -0
  210. package/password-input/PasswordInput.js +32 -54
  211. package/password-input/PasswordInput.stories.tsx +1 -34
  212. package/password-input/PasswordInput.test.js +153 -129
  213. package/password-input/types.d.ts +8 -7
  214. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  215. package/progress-bar/ProgressBar.js +26 -56
  216. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +1 -1
  217. package/progress-bar/ProgressBar.test.js +35 -52
  218. package/progress-bar/types.d.ts +3 -3
  219. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  220. package/quick-nav/QuickNav.js +4 -27
  221. package/quick-nav/QuickNav.stories.tsx +1 -1
  222. package/quick-nav/types.d.ts +10 -10
  223. package/radio-group/Radio.d.ts +1 -1
  224. package/radio-group/Radio.js +22 -54
  225. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  226. package/radio-group/RadioGroup.js +38 -83
  227. package/radio-group/RadioGroup.stories.tsx +10 -10
  228. package/radio-group/RadioGroup.test.js +504 -470
  229. package/radio-group/types.d.ts +8 -8
  230. package/resultset-table/Icons.d.ts +7 -0
  231. package/{resultsetTable → resultset-table}/Icons.js +1 -5
  232. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  233. package/resultset-table/ResultsetTable.d.ts +7 -0
  234. package/{resultsetTable → resultset-table}/ResultsetTable.js +45 -69
  235. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +118 -5
  236. package/{resultsetTable → resultset-table}/ResultsetTable.test.js +148 -92
  237. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  238. package/resultset-table/types.js +5 -0
  239. package/select/Listbox.js +40 -54
  240. package/select/Option.js +28 -36
  241. package/select/Select.accessibility.test.js +228 -0
  242. package/select/Select.js +107 -171
  243. package/select/Select.stories.tsx +59 -111
  244. package/select/Select.test.js +1895 -1858
  245. package/select/types.d.ts +15 -16
  246. package/sidenav/Sidenav.accessibility.test.js +59 -0
  247. package/sidenav/Sidenav.js +44 -81
  248. package/sidenav/Sidenav.stories.tsx +4 -9
  249. package/sidenav/Sidenav.test.js +3 -10
  250. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  251. package/{layout → sidenav}/SidenavContext.js +3 -9
  252. package/sidenav/types.d.ts +20 -20
  253. package/slider/Slider.accessibility.test.js +104 -0
  254. package/slider/Slider.js +70 -126
  255. package/slider/Slider.test.js +107 -103
  256. package/slider/types.d.ts +4 -4
  257. package/spinner/Spinner.accessibility.test.js +96 -0
  258. package/spinner/Spinner.js +21 -55
  259. package/spinner/Spinner.test.js +25 -34
  260. package/spinner/types.d.ts +3 -3
  261. package/status-light/StatusLight.accessibility.test.js +157 -0
  262. package/status-light/StatusLight.d.ts +4 -0
  263. package/status-light/StatusLight.js +51 -0
  264. package/status-light/StatusLight.stories.tsx +74 -0
  265. package/status-light/StatusLight.test.js +25 -0
  266. package/status-light/types.d.ts +17 -0
  267. package/status-light/types.js +5 -0
  268. package/switch/Switch.accessibility.test.js +98 -0
  269. package/switch/Switch.js +49 -97
  270. package/switch/Switch.stories.tsx +12 -34
  271. package/switch/Switch.test.js +51 -96
  272. package/switch/types.d.ts +4 -4
  273. package/table/DropdownTheme.js +62 -0
  274. package/table/Table.accessibility.test.js +93 -0
  275. package/table/Table.d.ts +6 -2
  276. package/table/Table.js +76 -33
  277. package/table/{Table.stories.jsx → Table.stories.tsx} +309 -2
  278. package/table/Table.test.js +93 -6
  279. package/table/types.d.ts +34 -6
  280. package/tabs/Tab.js +22 -37
  281. package/tabs/Tabs.accessibility.test.js +56 -0
  282. package/tabs/Tabs.js +59 -147
  283. package/tabs/Tabs.stories.tsx +8 -4
  284. package/tabs/Tabs.test.js +57 -131
  285. package/tabs/types.d.ts +21 -21
  286. package/tag/Tag.accessibility.test.js +69 -0
  287. package/tag/Tag.js +27 -57
  288. package/tag/Tag.stories.tsx +4 -7
  289. package/tag/Tag.test.js +17 -36
  290. package/tag/types.d.ts +9 -9
  291. package/text-input/Suggestion.js +9 -26
  292. package/text-input/Suggestions.d.ts +1 -1
  293. package/text-input/Suggestions.js +30 -70
  294. package/text-input/TextInput.accessibility.test.js +321 -0
  295. package/text-input/TextInput.js +203 -289
  296. package/text-input/TextInput.stories.tsx +65 -160
  297. package/text-input/TextInput.test.js +1227 -1194
  298. package/text-input/types.d.ts +25 -17
  299. package/textarea/Textarea.accessibility.test.js +155 -0
  300. package/textarea/Textarea.js +68 -109
  301. package/textarea/{Textarea.stories.jsx → Textarea.stories.tsx} +58 -100
  302. package/textarea/Textarea.test.js +150 -179
  303. package/textarea/types.d.ts +9 -5
  304. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  305. package/toggle-group/ToggleGroup.js +25 -64
  306. package/toggle-group/ToggleGroup.stories.tsx +4 -4
  307. package/toggle-group/ToggleGroup.test.js +48 -81
  308. package/toggle-group/types.d.ts +12 -12
  309. package/typography/Typography.accessibility.test.js +339 -0
  310. package/typography/Typography.js +4 -13
  311. package/typography/types.d.ts +1 -1
  312. package/useTheme.d.ts +43 -141
  313. package/useTheme.js +1 -8
  314. package/useTranslatedLabels.js +1 -7
  315. package/utils/BaseTypography.d.ts +2 -2
  316. package/utils/BaseTypography.js +16 -30
  317. package/utils/FocusLock.js +25 -39
  318. package/wizard/Wizard.accessibility.test.js +55 -0
  319. package/wizard/Wizard.js +27 -73
  320. package/wizard/Wizard.stories.tsx +19 -0
  321. package/wizard/Wizard.test.js +53 -80
  322. package/wizard/types.d.ts +8 -8
  323. package/common/OpenSans.css +0 -69
  324. package/common/fonts/OpenSans-Bold.ttf +0 -0
  325. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  326. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  327. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  328. package/common/fonts/OpenSans-Italic.ttf +0 -0
  329. package/common/fonts/OpenSans-Light.ttf +0 -0
  330. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  331. package/common/fonts/OpenSans-Regular.ttf +0 -0
  332. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  333. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  334. package/date-input/Icons.d.ts +0 -6
  335. package/date-input/Icons.js +0 -75
  336. package/paginator/Icons.d.ts +0 -5
  337. package/paginator/Icons.js +0 -54
  338. package/password-input/Icons.d.ts +0 -6
  339. package/password-input/Icons.js +0 -39
  340. package/resultsetTable/Icons.d.ts +0 -7
  341. package/resultsetTable/ResultsetTable.d.ts +0 -4
  342. package/select/Icons.d.ts +0 -10
  343. package/select/Icons.js +0 -93
  344. package/sidenav/Icons.d.ts +0 -7
  345. package/sidenav/Icons.js +0 -51
  346. package/slider/Slider.stories.tsx +0 -240
  347. package/text-input/Icons.d.ts +0 -8
  348. package/text-input/Icons.js +0 -60
  349. /package/{resultsetTable → action-icon}/types.js +0 -0
  350. /package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +0 -0
@@ -1,15 +1,12 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
4
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
5
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
5
6
  var _react = _interopRequireDefault(require("react"));
6
-
7
7
  var _react2 = require("@testing-library/react");
8
-
9
8
  var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
10
-
11
9
  var _RadioGroup = _interopRequireDefault(require("./RadioGroup.tsx"));
12
-
13
10
  var options = [{
14
11
  label: "Option 01",
15
12
  value: "1"
@@ -52,15 +49,14 @@ var singleDisabledOptions = [{
52
49
  describe("Radio Group component tests", function () {
53
50
  test("Initial render has correct aria attributes and tabIndex", function () {
54
51
  var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
55
- label: "test-radioGroup-label",
56
- options: options,
57
- error: ""
58
- })),
59
- getByRole = _render.getByRole,
60
- getAllByRole = _render.getAllByRole,
61
- getByText = _render.getByText,
62
- container = _render.container;
63
-
52
+ label: "test-radioGroup-label",
53
+ options: options,
54
+ error: ""
55
+ })),
56
+ getByRole = _render.getByRole,
57
+ getAllByRole = _render.getAllByRole,
58
+ getByText = _render.getByText,
59
+ container = _render.container;
64
60
  var radioGroup = getByRole("radiogroup");
65
61
  var radios = getAllByRole("radio");
66
62
  var errorId = "error-".concat(getByText("test-radioGroup-label").id.replace("label-", ""));
@@ -81,410 +77,429 @@ describe("Radio Group component tests", function () {
81
77
  });
82
78
  test("aria-orientation attribute changes depending on stacking prop value", function () {
83
79
  var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
84
- label: "test-radioGroup-label",
85
- options: options,
86
- stacking: "row"
87
- })),
88
- getByRole = _render2.getByRole;
89
-
80
+ label: "test-radioGroup-label",
81
+ options: options,
82
+ stacking: "row"
83
+ })),
84
+ getByRole = _render2.getByRole;
90
85
  var radioGroup = getByRole("radiogroup");
91
86
  expect(radioGroup.getAttribute("aria-orientation")).toBe("horizontal");
92
87
  });
93
- test("Sends its value when submitted", function () {
94
- var handlerOnSubmit = jest.fn(function (e) {
95
- e.preventDefault();
96
- var formData = new FormData(e.target);
97
- var formProps = Object.fromEntries(formData);
98
- expect(formProps).toStrictEqual({
99
- radiogroup: "5"
100
- });
101
- });
102
-
103
- var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement("form", {
104
- onSubmit: handlerOnSubmit
105
- }, /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
106
- name: "radiogroup",
107
- label: "test-radio-group-label",
108
- options: options
109
- }), /*#__PURE__*/_react["default"].createElement("button", {
110
- type: "submit"
111
- }, "Submit"))),
112
- getByText = _render3.getByText,
113
- getByRole = _render3.getByRole,
114
- getAllByRole = _render3.getAllByRole;
115
-
116
- var radioGroup = getByRole("radiogroup");
117
- var submit = getByText("Submit");
118
-
119
- _userEvent["default"].click(radioGroup);
120
-
121
- _userEvent["default"].click(getAllByRole("radio")[4]);
122
-
123
- _userEvent["default"].click(submit);
124
- });
88
+ test("Sends its value when submitted", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
89
+ var handlerOnSubmit, _render3, getByText, getByRole, getAllByRole, radioGroup, submit;
90
+ return _regenerator["default"].wrap(function _callee$(_context) {
91
+ while (1) switch (_context.prev = _context.next) {
92
+ case 0:
93
+ handlerOnSubmit = jest.fn(function (e) {
94
+ e.preventDefault();
95
+ var formData = new FormData(e.target);
96
+ var formProps = Object.fromEntries(formData);
97
+ expect(formProps).toStrictEqual({
98
+ radiogroup: "5"
99
+ });
100
+ });
101
+ _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement("form", {
102
+ onSubmit: handlerOnSubmit
103
+ }, /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
104
+ name: "radiogroup",
105
+ label: "test-radio-group-label",
106
+ options: options
107
+ }), /*#__PURE__*/_react["default"].createElement("button", {
108
+ type: "submit"
109
+ }, "Submit"))), getByText = _render3.getByText, getByRole = _render3.getByRole, getAllByRole = _render3.getAllByRole;
110
+ radioGroup = getByRole("radiogroup");
111
+ submit = getByText("Submit");
112
+ _context.next = 6;
113
+ return _userEvent["default"].click(radioGroup);
114
+ case 6:
115
+ _context.next = 8;
116
+ return _userEvent["default"].click(getAllByRole("radio")[4]);
117
+ case 8:
118
+ _context.next = 10;
119
+ return _userEvent["default"].click(submit);
120
+ case 10:
121
+ case "end":
122
+ return _context.stop();
123
+ }
124
+ }, _callee);
125
+ })));
125
126
  test("Disabled state renders with correct aria attribute, correct tabIndex values and it is not focusable by keyboard", function () {
126
127
  var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
127
- label: "test-radioGroup-label",
128
- options: options,
129
- disabled: true
130
- })),
131
- getByRole = _render4.getByRole,
132
- getAllByRole = _render4.getAllByRole;
133
-
128
+ label: "test-radioGroup-label",
129
+ options: options,
130
+ disabled: true
131
+ })),
132
+ getByRole = _render4.getByRole,
133
+ getAllByRole = _render4.getAllByRole;
134
134
  var radioGroup = getByRole("radiogroup");
135
135
  var radios = getAllByRole("radio");
136
136
  expect(radioGroup.getAttribute("aria-disabled")).toBe("true");
137
137
  radios.forEach(function (radio) {
138
138
  expect(radio.tabIndex).toBe(-1);
139
139
  });
140
-
141
140
  _react2.fireEvent.keyDown(radioGroup, {
142
141
  key: " ",
143
142
  code: "Space",
144
143
  keyCode: 13,
145
144
  charCode: 13
146
145
  });
147
-
148
146
  _react2.fireEvent.keyDown(radioGroup, {
149
147
  key: "ArrowLeft",
150
148
  code: "ArrowLeft",
151
149
  keyCode: 37,
152
150
  charCode: 37
153
151
  });
154
-
155
152
  _react2.fireEvent.keyDown(radioGroup, {
156
153
  key: "ArrowDown",
157
154
  code: "ArrowDown",
158
155
  keyCode: 40,
159
156
  charCode: 40
160
157
  });
161
-
162
158
  radios.forEach(function (radio) {
163
159
  expect(radio.tabIndex).toBe(-1);
164
160
  });
165
161
  });
166
162
  test("Disabled option renders with correct aria attribute, correct tabIndex value and it is not focusable by keyboard (focus 'jumps' the disabled option)", function () {
167
163
  var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
168
- name: "test",
169
- label: "test-radioGroup-label",
170
- options: singleDisabledOptions
171
- })),
172
- getByRole = _render5.getByRole,
173
- getAllByRole = _render5.getAllByRole;
174
-
164
+ name: "test",
165
+ label: "test-radioGroup-label",
166
+ options: singleDisabledOptions
167
+ })),
168
+ getByRole = _render5.getByRole,
169
+ getAllByRole = _render5.getAllByRole;
175
170
  var radioGroup = getByRole("radiogroup");
176
171
  var radios = getAllByRole("radio");
177
172
  expect(radios[2].getAttribute("aria-disabled")).toBe("true");
178
173
  expect(radios[0].tabIndex).toBe(0);
179
174
  expect(radios[1].tabIndex).toBe(-1);
180
175
  expect(radios[2].tabIndex).toBe(-1);
181
-
182
176
  _react2.fireEvent.keyDown(radioGroup, {
183
177
  key: "ArrowDown",
184
178
  code: "ArrowDown",
185
179
  keyCode: 40,
186
180
  charCode: 40
187
181
  });
188
-
189
182
  _react2.fireEvent.keyDown(radioGroup, {
190
183
  key: "ArrowDown",
191
184
  code: "ArrowDown",
192
185
  keyCode: 40,
193
186
  charCode: 40
194
187
  });
195
-
196
188
  expect(radios[0].tabIndex).toBe(0);
197
189
  expect(radios[1].tabIndex).toBe(-1);
198
190
  expect(radios[2].tabIndex).toBe(-1);
199
191
  });
200
- test("Disabled radio group doesn't send its value when submitted", function () {
201
- var handlerOnSubmit = jest.fn(function (e) {
202
- e.preventDefault();
203
- var formData = new FormData(e.target);
204
- var formProps = Object.fromEntries(formData);
205
- expect(formProps).toStrictEqual({});
206
- });
207
-
208
- var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement("form", {
209
- onSubmit: handlerOnSubmit
210
- }, /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
211
- name: "radiogroup",
212
- defaultValue: "1",
213
- disabled: true,
214
- label: "test-radio-group-label",
215
- options: options
216
- }), /*#__PURE__*/_react["default"].createElement("button", {
217
- type: "submit"
218
- }, "Submit"))),
219
- getByText = _render6.getByText;
220
-
221
- var submit = getByText("Submit");
222
-
223
- _userEvent["default"].click(submit);
224
- });
192
+ test("Disabled radio group doesn't send its value when submitted", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
193
+ var handlerOnSubmit, _render6, getByText, submit;
194
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
195
+ while (1) switch (_context2.prev = _context2.next) {
196
+ case 0:
197
+ handlerOnSubmit = jest.fn(function (e) {
198
+ e.preventDefault();
199
+ var formData = new FormData(e.target);
200
+ var formProps = Object.fromEntries(formData);
201
+ expect(formProps).toStrictEqual({});
202
+ });
203
+ _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement("form", {
204
+ onSubmit: handlerOnSubmit
205
+ }, /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
206
+ name: "radiogroup",
207
+ defaultValue: "1",
208
+ disabled: true,
209
+ label: "test-radio-group-label",
210
+ options: options
211
+ }), /*#__PURE__*/_react["default"].createElement("button", {
212
+ type: "submit"
213
+ }, "Submit"))), getByText = _render6.getByText;
214
+ submit = getByText("Submit");
215
+ _context2.next = 5;
216
+ return _userEvent["default"].click(submit);
217
+ case 5:
218
+ case "end":
219
+ return _context2.stop();
220
+ }
221
+ }, _callee2);
222
+ })));
225
223
  test("Error state renders with correct aria attributes", function () {
226
224
  var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
227
- label: "test-radioGroup-label",
228
- options: options,
229
- error: "Error message"
230
- })),
231
- getByRole = _render7.getByRole,
232
- getByText = _render7.getByText;
233
-
225
+ label: "test-radioGroup-label",
226
+ options: options,
227
+ error: "Error message"
228
+ })),
229
+ getByRole = _render7.getByRole,
230
+ getByText = _render7.getByText;
234
231
  var radioGroup = getByRole("radiogroup");
235
232
  var errorMessage = getByText("Error message");
236
233
  expect(radioGroup.getAttribute("aria-errormessage")).toBe(errorMessage.id);
237
234
  expect(radioGroup.getAttribute("aria-invalid")).toBe("true");
238
235
  expect(errorMessage.getAttribute("aria-live")).toBe("assertive");
239
236
  });
240
- test("Radio group with required constraint and 'undefined' as value, sends an error", function () {
241
- var onChange = jest.fn();
242
- var onBlur = jest.fn();
243
-
244
- var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
245
- label: "test-radioGroup-label",
246
- options: options,
247
- onChange: onChange,
248
- onBlur: onBlur
249
- })),
250
- getByRole = _render8.getByRole,
251
- getAllByRole = _render8.getAllByRole;
252
-
253
- var radioGroup = getByRole("radiogroup");
254
- expect(radioGroup.getAttribute("aria-required")).toBe("true");
255
-
256
- _react2.fireEvent.blur(radioGroup);
257
-
258
- expect(onBlur).toHaveBeenCalledWith({
259
- error: "This field is required. Please, choose an option."
260
- });
261
-
262
- _userEvent["default"].click(radioGroup);
263
-
264
- _userEvent["default"].click(getAllByRole("radio")[0]);
265
-
266
- expect(onChange).toHaveBeenCalledWith("1");
267
-
268
- _react2.fireEvent.blur(radioGroup);
269
-
270
- expect(onBlur).toHaveBeenCalledWith({
271
- value: "1"
272
- });
273
- });
274
- test("Radio group with required constraint and empty string as value, sends an error", function () {
275
- var onChange = jest.fn();
276
- var onBlur = jest.fn();
277
-
278
- var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
279
- label: "test-radioGroup-label",
280
- value: "",
281
- options: options,
282
- onChange: onChange,
283
- onBlur: onBlur
284
- })),
285
- getByRole = _render9.getByRole,
286
- getAllByRole = _render9.getAllByRole;
287
-
288
- var radioGroup = getByRole("radiogroup");
289
- expect(radioGroup.getAttribute("aria-required")).toBe("true");
290
-
291
- _react2.fireEvent.blur(radioGroup);
292
-
293
- expect(onBlur).toHaveBeenCalledWith({
294
- value: "",
295
- error: "This field is required. Please, choose an option."
296
- });
297
-
298
- _userEvent["default"].click(getAllByRole("radio")[0]);
299
-
300
- expect(onChange).toHaveBeenCalledWith("1");
301
- });
237
+ test("Radio group with required constraint and 'undefined' as value, sends an error", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
238
+ var onChange, onBlur, _render8, getByRole, getAllByRole, radioGroup;
239
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
240
+ while (1) switch (_context3.prev = _context3.next) {
241
+ case 0:
242
+ onChange = jest.fn();
243
+ onBlur = jest.fn();
244
+ _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
245
+ label: "test-radioGroup-label",
246
+ options: options,
247
+ onChange: onChange,
248
+ onBlur: onBlur
249
+ })), getByRole = _render8.getByRole, getAllByRole = _render8.getAllByRole;
250
+ radioGroup = getByRole("radiogroup");
251
+ expect(radioGroup.getAttribute("aria-required")).toBe("true");
252
+ _react2.fireEvent.blur(radioGroup);
253
+ expect(onBlur).toHaveBeenCalledWith({
254
+ error: "This field is required. Please, choose an option."
255
+ });
256
+ _context3.next = 9;
257
+ return _userEvent["default"].click(radioGroup);
258
+ case 9:
259
+ _context3.next = 11;
260
+ return _userEvent["default"].click(getAllByRole("radio")[0]);
261
+ case 11:
262
+ expect(onChange).toHaveBeenCalledWith("1");
263
+ _react2.fireEvent.blur(radioGroup);
264
+ expect(onBlur).toHaveBeenCalledWith({
265
+ value: "1"
266
+ });
267
+ case 14:
268
+ case "end":
269
+ return _context3.stop();
270
+ }
271
+ }, _callee3);
272
+ })));
273
+ test("Radio group with required constraint and empty string as value, sends an error", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4() {
274
+ var onChange, onBlur, _render9, getByRole, getAllByRole, radioGroup;
275
+ return _regenerator["default"].wrap(function _callee4$(_context4) {
276
+ while (1) switch (_context4.prev = _context4.next) {
277
+ case 0:
278
+ onChange = jest.fn();
279
+ onBlur = jest.fn();
280
+ _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
281
+ label: "test-radioGroup-label",
282
+ value: "",
283
+ options: options,
284
+ onChange: onChange,
285
+ onBlur: onBlur
286
+ })), getByRole = _render9.getByRole, getAllByRole = _render9.getAllByRole;
287
+ radioGroup = getByRole("radiogroup");
288
+ expect(radioGroup.getAttribute("aria-required")).toBe("true");
289
+ _react2.fireEvent.blur(radioGroup);
290
+ expect(onBlur).toHaveBeenCalledWith({
291
+ value: "",
292
+ error: "This field is required. Please, choose an option."
293
+ });
294
+ _context4.next = 9;
295
+ return _userEvent["default"].click(getAllByRole("radio")[0]);
296
+ case 9:
297
+ expect(onChange).toHaveBeenCalledWith("1");
298
+ case 10:
299
+ case "end":
300
+ return _context4.stop();
301
+ }
302
+ }, _callee4);
303
+ })));
302
304
  test("The 'defaultValue' gives the radio group an initial value when it is uncontrolled", function () {
303
305
  var onChange = jest.fn();
304
-
305
306
  var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
306
- defaultValue: "2",
307
- name: "test",
308
- label: "test-radio-group-label",
309
- helperText: "test-radio-group-helper-text",
310
- options: options,
311
- onChange: onChange
312
- })),
313
- getAllByRole = _render10.getAllByRole,
314
- container = _render10.container;
315
-
307
+ defaultValue: "2",
308
+ name: "test",
309
+ label: "test-radio-group-label",
310
+ helperText: "test-radio-group-helper-text",
311
+ options: options,
312
+ onChange: onChange
313
+ })),
314
+ getAllByRole = _render10.getAllByRole,
315
+ container = _render10.container;
316
316
  var radio = getAllByRole("radio")[1];
317
317
  var submitInput = container.querySelector("input[name=\"test\"]");
318
318
  expect(radio.tabIndex).toBe(0);
319
319
  expect(radio.getAttribute("aria-checked")).toBe("true");
320
320
  expect(submitInput.value).toBe("2");
321
321
  });
322
- test("Optional radio group conditions: onBlur event doesn't send an error when no radio was checked, has correct aria attributes, custom label and its value is the empty string", function () {
323
- var onChange = jest.fn();
324
- var onBlur = jest.fn();
325
-
326
- var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
327
- name: "test",
328
- label: "test-radio-group-label",
329
- helperText: "test-radio-group-helper-text",
330
- options: options,
331
- onChange: onChange,
332
- onBlur: onBlur,
333
- optional: true,
334
- optionalItemLabel: "No selection"
335
- })),
336
- getByRole = _render11.getByRole,
337
- getByText = _render11.getByText,
338
- container = _render11.container;
339
-
340
- var radioGroup = getByRole("radiogroup");
341
- expect(radioGroup.getAttribute("aria-required")).toBe("false");
342
-
343
- _react2.fireEvent.blur(radioGroup);
344
-
345
- expect(onBlur).toHaveBeenCalledWith({});
346
- expect(radioGroup.getAttribute("aria-invalid")).toBe("false");
347
- var optionalLabel = getByText("No selection");
348
- var submitInput = container.querySelector("input[name=\"test\"]");
349
-
350
- _userEvent["default"].click(optionalLabel);
351
-
352
- expect(onChange).toHaveBeenCalledWith("");
353
- expect(submitInput.value).toBe("");
354
- });
355
- test("Controlled radio group", function () {
356
- var onChange = jest.fn();
357
- var onBlur = jest.fn();
358
-
359
- var _render12 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
360
- name: "test",
361
- value: "2",
362
- label: "test-radio-group-label",
363
- helperText: "test-radio-group-helper-text",
364
- options: options,
365
- onChange: onChange,
366
- onBlur: onBlur
367
- })),
368
- getByRole = _render12.getByRole,
369
- getAllByRole = _render12.getAllByRole,
370
- container = _render12.container;
371
-
372
- var radioGroup = getByRole("radiogroup");
373
- var radios = getAllByRole("radio");
374
- var submitInput = container.querySelector("input[name=\"test\"]");
375
- expect(submitInput.value).toBe("2");
376
- expect(radios[1].tabIndex).toBe(0);
377
- expect(radios[1].getAttribute("aria-checked")).toBe("true");
378
-
379
- _userEvent["default"].click(radios[6]);
380
-
381
- expect(onChange).toHaveBeenCalledWith("7");
382
-
383
- _react2.fireEvent.blur(radioGroup);
384
-
385
- expect(onBlur).toHaveBeenCalledWith({
386
- value: "2"
387
- });
388
- });
389
- test("Select an option by clicking on its label", function () {
390
- var onChange = jest.fn();
391
-
392
- var _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
393
- name: "test",
394
- label: "test-radio-group-label",
395
- helperText: "test-radio-group-helper-text",
396
- options: options,
397
- onChange: onChange
398
- })),
399
- getByText = _render13.getByText,
400
- getAllByRole = _render13.getAllByRole,
401
- container = _render13.container;
402
-
403
- var radioLabel = getByText("Option 09");
404
- var checkedRadio = getAllByRole("radio")[8];
405
- var submitInput = container.querySelector("input[name=\"test\"]");
406
- expect(checkedRadio.tabIndex).toBe(-1);
407
-
408
- _userEvent["default"].click(radioLabel);
409
-
410
- expect(onChange).toHaveBeenCalledWith("9");
411
- expect(checkedRadio.getAttribute("aria-checked")).toBe("true");
412
- expect(checkedRadio.tabIndex).toBe(0);
413
- expect(document.activeElement).toEqual(checkedRadio);
414
- expect(submitInput.value).toBe("9");
415
- });
416
- test("Select an option by clicking on its radio input", function () {
417
- var onChange = jest.fn();
418
-
419
- var _render14 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
420
- name: "test",
421
- label: "test-radio-group-label",
422
- helperText: "test-radio-group-helper-text",
423
- options: options,
424
- onChange: onChange
425
- })),
426
- getAllByRole = _render14.getAllByRole,
427
- container = _render14.container;
428
-
429
- var checkedRadio = getAllByRole("radio")[6];
430
- var submitInput = container.querySelector("input[name=\"test\"]");
431
- expect(checkedRadio.tabIndex).toBe(-1);
432
-
433
- _userEvent["default"].click(checkedRadio);
434
-
435
- expect(onChange).toHaveBeenCalledWith("7");
436
- expect(checkedRadio.getAttribute("aria-checked")).toBe("true");
437
- expect(checkedRadio.tabIndex).toBe(0);
438
- expect(document.activeElement).toEqual(checkedRadio);
439
- expect(submitInput.value).toBe("7");
440
- });
441
- test("Select an option that is already checked does not call onChange event but gives the focus", function () {
442
- var onChange = jest.fn();
443
-
444
- var _render15 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
445
- defaultValue: "2",
446
- name: "test",
447
- label: "test-radio-group-label",
448
- helperText: "test-radio-group-helper-text",
449
- options: options,
450
- onChange: onChange
451
- })),
452
- getAllByRole = _render15.getAllByRole;
453
-
454
- var checkedRadio = getAllByRole("radio")[1];
455
- expect(checkedRadio.tabIndex).toBe(0);
456
- expect(checkedRadio.getAttribute("aria-checked")).toBe("true");
457
-
458
- _userEvent["default"].click(checkedRadio);
459
-
460
- expect(onChange).not.toHaveBeenCalled();
461
- expect(document.activeElement).toEqual(checkedRadio);
462
- });
322
+ test("Optional radio group conditions: onBlur event doesn't send an error when no radio was checked, has correct aria attributes, custom label and its value is the empty string", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee5() {
323
+ var onChange, onBlur, _render11, getByRole, getByText, container, radioGroup, optionalLabel, submitInput;
324
+ return _regenerator["default"].wrap(function _callee5$(_context5) {
325
+ while (1) switch (_context5.prev = _context5.next) {
326
+ case 0:
327
+ onChange = jest.fn();
328
+ onBlur = jest.fn();
329
+ _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
330
+ name: "test",
331
+ label: "test-radio-group-label",
332
+ helperText: "test-radio-group-helper-text",
333
+ options: options,
334
+ onChange: onChange,
335
+ onBlur: onBlur,
336
+ optional: true,
337
+ optionalItemLabel: "No selection"
338
+ })), getByRole = _render11.getByRole, getByText = _render11.getByText, container = _render11.container;
339
+ radioGroup = getByRole("radiogroup");
340
+ expect(radioGroup.getAttribute("aria-required")).toBe("false");
341
+ _react2.fireEvent.blur(radioGroup);
342
+ expect(onBlur).toHaveBeenCalledWith({});
343
+ expect(radioGroup.getAttribute("aria-invalid")).toBe("false");
344
+ optionalLabel = getByText("No selection");
345
+ submitInput = container.querySelector("input[name=\"test\"]");
346
+ _context5.next = 12;
347
+ return _userEvent["default"].click(optionalLabel);
348
+ case 12:
349
+ expect(onChange).toHaveBeenCalledWith("");
350
+ expect(submitInput.value).toBe("");
351
+ case 14:
352
+ case "end":
353
+ return _context5.stop();
354
+ }
355
+ }, _callee5);
356
+ })));
357
+ test("Controlled radio group", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee6() {
358
+ var onChange, onBlur, _render12, getByRole, getAllByRole, container, radioGroup, radios, submitInput;
359
+ return _regenerator["default"].wrap(function _callee6$(_context6) {
360
+ while (1) switch (_context6.prev = _context6.next) {
361
+ case 0:
362
+ onChange = jest.fn();
363
+ onBlur = jest.fn();
364
+ _render12 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
365
+ name: "test",
366
+ value: "2",
367
+ label: "test-radio-group-label",
368
+ helperText: "test-radio-group-helper-text",
369
+ options: options,
370
+ onChange: onChange,
371
+ onBlur: onBlur
372
+ })), getByRole = _render12.getByRole, getAllByRole = _render12.getAllByRole, container = _render12.container;
373
+ radioGroup = getByRole("radiogroup");
374
+ radios = getAllByRole("radio");
375
+ submitInput = container.querySelector("input[name=\"test\"]");
376
+ expect(submitInput.value).toBe("2");
377
+ expect(radios[1].tabIndex).toBe(0);
378
+ expect(radios[1].getAttribute("aria-checked")).toBe("true");
379
+ _context6.next = 11;
380
+ return _userEvent["default"].click(radios[6]);
381
+ case 11:
382
+ expect(onChange).toHaveBeenCalledWith("7");
383
+ _react2.fireEvent.blur(radioGroup);
384
+ expect(onBlur).toHaveBeenCalledWith({
385
+ value: "2"
386
+ });
387
+ case 14:
388
+ case "end":
389
+ return _context6.stop();
390
+ }
391
+ }, _callee6);
392
+ })));
393
+ test("Select an option by clicking on its label", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee7() {
394
+ var onChange, _render13, getByText, getAllByRole, container, radioLabel, checkedRadio, submitInput;
395
+ return _regenerator["default"].wrap(function _callee7$(_context7) {
396
+ while (1) switch (_context7.prev = _context7.next) {
397
+ case 0:
398
+ onChange = jest.fn();
399
+ _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
400
+ name: "test",
401
+ label: "test-radio-group-label",
402
+ helperText: "test-radio-group-helper-text",
403
+ options: options,
404
+ onChange: onChange
405
+ })), getByText = _render13.getByText, getAllByRole = _render13.getAllByRole, container = _render13.container;
406
+ radioLabel = getByText("Option 09");
407
+ checkedRadio = getAllByRole("radio")[8];
408
+ submitInput = container.querySelector("input[name=\"test\"]");
409
+ expect(checkedRadio.tabIndex).toBe(-1);
410
+ _context7.next = 8;
411
+ return _userEvent["default"].click(radioLabel);
412
+ case 8:
413
+ expect(onChange).toHaveBeenCalledWith("9");
414
+ expect(checkedRadio.getAttribute("aria-checked")).toBe("true");
415
+ expect(checkedRadio.tabIndex).toBe(0);
416
+ expect(document.activeElement).toEqual(checkedRadio);
417
+ expect(submitInput.value).toBe("9");
418
+ case 13:
419
+ case "end":
420
+ return _context7.stop();
421
+ }
422
+ }, _callee7);
423
+ })));
424
+ test("Select an option by clicking on its radio input", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee8() {
425
+ var onChange, _render14, getAllByRole, container, checkedRadio, submitInput;
426
+ return _regenerator["default"].wrap(function _callee8$(_context8) {
427
+ while (1) switch (_context8.prev = _context8.next) {
428
+ case 0:
429
+ onChange = jest.fn();
430
+ _render14 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
431
+ name: "test",
432
+ label: "test-radio-group-label",
433
+ helperText: "test-radio-group-helper-text",
434
+ options: options,
435
+ onChange: onChange
436
+ })), getAllByRole = _render14.getAllByRole, container = _render14.container;
437
+ checkedRadio = getAllByRole("radio")[6];
438
+ submitInput = container.querySelector("input[name=\"test\"]");
439
+ expect(checkedRadio.tabIndex).toBe(-1);
440
+ _context8.next = 7;
441
+ return _userEvent["default"].click(checkedRadio);
442
+ case 7:
443
+ expect(onChange).toHaveBeenCalledWith("7");
444
+ expect(checkedRadio.getAttribute("aria-checked")).toBe("true");
445
+ expect(checkedRadio.tabIndex).toBe(0);
446
+ expect(document.activeElement).toEqual(checkedRadio);
447
+ expect(submitInput.value).toBe("7");
448
+ case 12:
449
+ case "end":
450
+ return _context8.stop();
451
+ }
452
+ }, _callee8);
453
+ })));
454
+ test("Select an option that is already checked does not call onChange event but gives the focus", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee9() {
455
+ var onChange, _render15, getAllByRole, checkedRadio;
456
+ return _regenerator["default"].wrap(function _callee9$(_context9) {
457
+ while (1) switch (_context9.prev = _context9.next) {
458
+ case 0:
459
+ onChange = jest.fn();
460
+ _render15 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
461
+ defaultValue: "2",
462
+ name: "test",
463
+ label: "test-radio-group-label",
464
+ helperText: "test-radio-group-helper-text",
465
+ options: options,
466
+ onChange: onChange
467
+ })), getAllByRole = _render15.getAllByRole;
468
+ checkedRadio = getAllByRole("radio")[1];
469
+ expect(checkedRadio.tabIndex).toBe(0);
470
+ expect(checkedRadio.getAttribute("aria-checked")).toBe("true");
471
+ _context9.next = 7;
472
+ return _userEvent["default"].click(checkedRadio);
473
+ case 7:
474
+ expect(onChange).not.toHaveBeenCalled();
475
+ expect(document.activeElement).toEqual(checkedRadio);
476
+ case 9:
477
+ case "end":
478
+ return _context9.stop();
479
+ }
480
+ }, _callee9);
481
+ })));
463
482
  test("The 'space' key checks the current focused option if anyone is checked", function () {
464
483
  var onChange = jest.fn();
465
-
466
484
  var _render16 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
467
- name: "test",
468
- label: "test-radio-group-label",
469
- helperText: "test-radio-group-helper-text",
470
- options: options,
471
- onChange: onChange
472
- })),
473
- getByRole = _render16.getByRole,
474
- getAllByRole = _render16.getAllByRole,
475
- container = _render16.container;
476
-
485
+ name: "test",
486
+ label: "test-radio-group-label",
487
+ helperText: "test-radio-group-helper-text",
488
+ options: options,
489
+ onChange: onChange
490
+ })),
491
+ getByRole = _render16.getByRole,
492
+ getAllByRole = _render16.getAllByRole,
493
+ container = _render16.container;
477
494
  var radioGroup = getByRole("radiogroup");
478
495
  var checkedRadio = getAllByRole("radio")[0];
479
496
  var submitInput = container.querySelector("input[name=\"test\"]");
480
-
481
497
  _react2.fireEvent.keyDown(radioGroup, {
482
498
  key: " ",
483
499
  code: "Space",
484
500
  keyCode: 32,
485
501
  charCode: 32
486
502
  });
487
-
488
503
  expect(onChange).toHaveBeenCalledWith("1");
489
504
  expect(checkedRadio.getAttribute("aria-checked")).toBe("true");
490
505
  expect(checkedRadio.tabIndex).toBe(0);
@@ -493,39 +508,33 @@ describe("Radio Group component tests", function () {
493
508
  test("When the radio group gains the focus by keyboard ('tab' key), it goes to the first option (if no one was previously selected), without selecting it", function () {
494
509
  var onChange = jest.fn();
495
510
  var onBlur = jest.fn();
496
-
497
511
  var _render17 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
498
- name: "test",
499
- label: "test-radio-group-label",
500
- helperText: "test-radio-group-helper-text",
501
- options: options,
502
- onChange: onChange,
503
- onBlur: onBlur
504
- })),
505
- getByRole = _render17.getByRole,
506
- getAllByRole = _render17.getAllByRole,
507
- container = _render17.container;
508
-
512
+ name: "test",
513
+ label: "test-radio-group-label",
514
+ helperText: "test-radio-group-helper-text",
515
+ options: options,
516
+ onChange: onChange,
517
+ onBlur: onBlur
518
+ })),
519
+ getByRole = _render17.getByRole,
520
+ getAllByRole = _render17.getAllByRole,
521
+ container = _render17.container;
509
522
  var radioGroup = getByRole("radiogroup");
510
523
  var radios = getAllByRole("radio");
511
524
  var submitInput = container.querySelector("input[name=\"test\"]");
512
525
  var checkedRadio = getAllByRole("radio")[0];
513
-
514
526
  _userEvent["default"].tab();
515
-
516
527
  expect(onChange).not.toHaveBeenCalled();
517
528
  expect(submitInput.value).toBe("");
518
529
  expect(checkedRadio.tabIndex).toBe(0);
519
530
  expect(checkedRadio.getAttribute("aria-checked")).toBe("false");
520
531
  expect(document.activeElement).toEqual(checkedRadio);
521
-
522
532
  _react2.fireEvent.keyDown(radioGroup, {
523
533
  key: "ArrowRight",
524
534
  code: "ArrowRight",
525
535
  keyCode: 39,
526
536
  charCode: 39
527
537
  });
528
-
529
538
  expect(onBlur).not.toHaveBeenCalled();
530
539
  expect(onChange).toHaveBeenCalledTimes(1);
531
540
  expect(radios[1].getAttribute("aria-checked")).toBe("true");
@@ -536,45 +545,39 @@ describe("Radio Group component tests", function () {
536
545
  test("The 'arrowDown' and 'arrowRight' keys move the selection to the next radio. When the last radio is reached, moves the selection to the first one", function () {
537
546
  var onChange = jest.fn();
538
547
  var onBlur = jest.fn();
539
-
540
548
  var _render18 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
541
- defaultValue: "8",
542
- name: "test",
543
- label: "test-radio-group-label",
544
- helperText: "test-radio-group-helper-text",
545
- options: options,
546
- onChange: onChange,
547
- onBlur: onBlur
548
- })),
549
- getByRole = _render18.getByRole,
550
- getAllByRole = _render18.getAllByRole,
551
- container = _render18.container;
552
-
549
+ defaultValue: "8",
550
+ name: "test",
551
+ label: "test-radio-group-label",
552
+ helperText: "test-radio-group-helper-text",
553
+ options: options,
554
+ onChange: onChange,
555
+ onBlur: onBlur
556
+ })),
557
+ getByRole = _render18.getByRole,
558
+ getAllByRole = _render18.getAllByRole,
559
+ container = _render18.container;
553
560
  var radioGroup = getByRole("radiogroup");
554
561
  var radios = getAllByRole("radio");
555
562
  var submitInput = container.querySelector("input[name=\"test\"]");
556
-
557
563
  _react2.fireEvent.keyDown(radioGroup, {
558
564
  key: "ArrowDown",
559
565
  code: "ArrowDown",
560
566
  keyCode: 40,
561
567
  charCode: 40
562
568
  });
563
-
564
569
  expect(onBlur).not.toHaveBeenCalled();
565
570
  expect(onChange).toHaveBeenCalledTimes(1);
566
571
  expect(radios[8].getAttribute("aria-checked")).toBe("true");
567
572
  expect(document.activeElement).toEqual(radios[8]);
568
573
  expect(radios[8].tabIndex).toBe(0);
569
574
  expect(submitInput.value).toBe("9");
570
-
571
575
  _react2.fireEvent.keyDown(radioGroup, {
572
576
  key: "ArrowRight",
573
577
  code: "ArrowRight",
574
578
  keyCode: 39,
575
579
  charCode: 39
576
580
  });
577
-
578
581
  expect(onBlur).not.toHaveBeenCalled();
579
582
  expect(onChange).toHaveBeenCalledTimes(2);
580
583
  expect(radios[0].getAttribute("aria-checked")).toBe("true");
@@ -585,45 +588,39 @@ describe("Radio Group component tests", function () {
585
588
  test("The 'arrowUp' and 'arrowLeft' keys move the selection to the previous radio. When the first radio is reached, moves the selection to the last one", function () {
586
589
  var onChange = jest.fn();
587
590
  var onBlur = jest.fn();
588
-
589
591
  var _render19 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
590
- defaultValue: "2",
591
- name: "test",
592
- label: "test-radio-group-label",
593
- helperText: "test-radio-group-helper-text",
594
- options: options,
595
- onChange: onChange,
596
- onBlur: onBlur
597
- })),
598
- getByRole = _render19.getByRole,
599
- getAllByRole = _render19.getAllByRole,
600
- container = _render19.container;
601
-
592
+ defaultValue: "2",
593
+ name: "test",
594
+ label: "test-radio-group-label",
595
+ helperText: "test-radio-group-helper-text",
596
+ options: options,
597
+ onChange: onChange,
598
+ onBlur: onBlur
599
+ })),
600
+ getByRole = _render19.getByRole,
601
+ getAllByRole = _render19.getAllByRole,
602
+ container = _render19.container;
602
603
  var radioGroup = getByRole("radiogroup");
603
604
  var radios = getAllByRole("radio");
604
605
  var submitInput = container.querySelector("input[name=\"test\"]");
605
-
606
606
  _react2.fireEvent.keyDown(radioGroup, {
607
607
  key: "ArrowUp",
608
608
  code: "ArrowUp",
609
609
  keyCode: 38,
610
610
  charCode: 38
611
611
  });
612
-
613
612
  expect(onBlur).not.toHaveBeenCalled();
614
613
  expect(onChange).toHaveBeenCalledTimes(1);
615
614
  expect(radios[0].getAttribute("aria-checked")).toBe("true");
616
615
  expect(document.activeElement).toEqual(radios[0]);
617
616
  expect(radios[0].tabIndex).toBe(0);
618
617
  expect(submitInput.value).toBe("1");
619
-
620
618
  _react2.fireEvent.keyDown(radioGroup, {
621
619
  key: "ArrowLeft",
622
620
  code: "ArrowLeft",
623
621
  keyCode: 37,
624
622
  charCode: 37
625
623
  });
626
-
627
624
  expect(onBlur).not.toHaveBeenCalled();
628
625
  expect(onChange).toHaveBeenCalledTimes(2);
629
626
  expect(radios[8].getAttribute("aria-checked")).toBe("true");
@@ -631,92 +628,129 @@ describe("Radio Group component tests", function () {
631
628
  expect(radios[8].tabIndex).toBe(0);
632
629
  expect(submitInput.value).toBe("9");
633
630
  });
634
- test("Keyboard focus movement continues from the last radio input clicked", function () {
635
- var onChange = jest.fn();
636
-
637
- var _render20 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
638
- name: "test",
639
- label: "test-radio-group-label",
640
- helperText: "test-radio-group-helper-text",
641
- options: options,
642
- onChange: onChange
643
- })),
644
- getByRole = _render20.getByRole,
645
- getAllByRole = _render20.getAllByRole,
646
- container = _render20.container;
647
-
648
- var radioGroup = getByRole("radiogroup");
649
- var radios = getAllByRole("radio");
650
- var submitInput = container.querySelector("input[name=\"test\"]");
651
-
652
- _userEvent["default"].click(radios[3]);
653
-
654
- _react2.fireEvent.keyDown(radioGroup, {
655
- key: "ArrowDown",
656
- code: "ArrowDown",
657
- keyCode: 40,
658
- charCode: 40
659
- });
660
-
661
- expect(onChange).toHaveBeenCalledWith("5");
662
- expect(radios[4].getAttribute("aria-checked")).toBe("true");
663
- expect(document.activeElement).toEqual(radios[4]);
664
- expect(radios[4].tabIndex).toBe(0);
665
- expect(submitInput.value).toBe("5");
666
-
667
- _userEvent["default"].click(radios[8]);
668
-
669
- _react2.fireEvent.keyDown(radioGroup, {
670
- key: "ArrowLeft",
671
- code: "ArrowLeft",
672
- keyCode: 37,
673
- charCode: 37
674
- });
675
-
676
- expect(onChange).toHaveBeenCalledWith("8");
677
- expect(radios[7].getAttribute("aria-checked")).toBe("true");
678
- expect(document.activeElement).toEqual(radios[7]);
679
- expect(radios[7].tabIndex).toBe(0);
680
- expect(submitInput.value).toBe("8");
681
- });
682
- test("Readonly radio group lets the user move the focus, but neither click nor keyboard press changes the value", function () {
683
- var onChange = jest.fn();
684
-
685
- var _render21 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
686
- name: "test",
687
- label: "test-radio-group-label",
688
- helperText: "test-radio-group-helper-text",
689
- options: options,
690
- onChange: onChange,
691
- readonly: true
692
- })),
693
- getByRole = _render21.getByRole,
694
- getAllByRole = _render21.getAllByRole,
695
- container = _render21.container;
696
-
697
- var radioGroup = getByRole("radiogroup");
698
- var radios = getAllByRole("radio");
699
- var submitInput = container.querySelector("input[name=\"test\"]");
700
-
701
- _userEvent["default"].click(radios[5]);
702
-
703
- expect(onChange).not.toHaveBeenCalled();
704
- expect(radios[5].getAttribute("aria-checked")).toBe("false");
705
- expect(document.activeElement).toEqual(radios[5]);
706
- expect(radios[5].tabIndex).toBe(0);
707
- expect(submitInput.value).toBe("");
708
-
709
- _react2.fireEvent.keyDown(radioGroup, {
710
- key: "ArrowUp",
711
- code: "ArrowUp",
712
- keyCode: 38,
713
- charCode: 38
714
- });
715
-
716
- expect(onChange).not.toHaveBeenCalled();
717
- expect(radios[4].getAttribute("aria-checked")).toBe("false");
718
- expect(document.activeElement).toEqual(radios[4]);
719
- expect(radios[4].tabIndex).toBe(0);
720
- expect(submitInput.value).toBe("");
721
- });
631
+ test("Keyboard focus movement continues from the last radio input clicked", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee10() {
632
+ var onChange, _render20, getByRole, getAllByRole, container, radioGroup, radios, submitInput;
633
+ return _regenerator["default"].wrap(function _callee10$(_context10) {
634
+ while (1) switch (_context10.prev = _context10.next) {
635
+ case 0:
636
+ onChange = jest.fn();
637
+ _render20 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
638
+ name: "test",
639
+ label: "test-radio-group-label",
640
+ helperText: "test-radio-group-helper-text",
641
+ options: options,
642
+ onChange: onChange
643
+ })), getByRole = _render20.getByRole, getAllByRole = _render20.getAllByRole, container = _render20.container;
644
+ radioGroup = getByRole("radiogroup");
645
+ radios = getAllByRole("radio");
646
+ submitInput = container.querySelector("input[name=\"test\"]");
647
+ _context10.next = 7;
648
+ return _userEvent["default"].click(radios[3]);
649
+ case 7:
650
+ _react2.fireEvent.keyDown(radioGroup, {
651
+ key: "ArrowDown",
652
+ code: "ArrowDown",
653
+ keyCode: 40,
654
+ charCode: 40
655
+ });
656
+ expect(onChange).toHaveBeenCalledWith("5");
657
+ expect(radios[4].getAttribute("aria-checked")).toBe("true");
658
+ expect(document.activeElement).toEqual(radios[4]);
659
+ expect(radios[4].tabIndex).toBe(0);
660
+ expect(submitInput.value).toBe("5");
661
+ _context10.next = 15;
662
+ return _userEvent["default"].click(radios[8]);
663
+ case 15:
664
+ _react2.fireEvent.keyDown(radioGroup, {
665
+ key: "ArrowLeft",
666
+ code: "ArrowLeft",
667
+ keyCode: 37,
668
+ charCode: 37
669
+ });
670
+ expect(onChange).toHaveBeenCalledWith("8");
671
+ expect(radios[7].getAttribute("aria-checked")).toBe("true");
672
+ expect(document.activeElement).toEqual(radios[7]);
673
+ expect(radios[7].tabIndex).toBe(0);
674
+ expect(submitInput.value).toBe("8");
675
+ case 21:
676
+ case "end":
677
+ return _context10.stop();
678
+ }
679
+ }, _callee10);
680
+ })));
681
+ test("Read-only radio group lets the user move the focus, but neither click nor keyboard press changes the value", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee11() {
682
+ var onChange, _render21, getByRole, getAllByRole, container, radioGroup, radios, submitInput;
683
+ return _regenerator["default"].wrap(function _callee11$(_context11) {
684
+ while (1) switch (_context11.prev = _context11.next) {
685
+ case 0:
686
+ onChange = jest.fn();
687
+ _render21 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
688
+ name: "test",
689
+ label: "test-radio-group-label",
690
+ helperText: "test-radio-group-helper-text",
691
+ options: options,
692
+ onChange: onChange,
693
+ readOnly: true
694
+ })), getByRole = _render21.getByRole, getAllByRole = _render21.getAllByRole, container = _render21.container;
695
+ radioGroup = getByRole("radiogroup");
696
+ radios = getAllByRole("radio");
697
+ submitInput = container.querySelector("input[name=\"test\"]");
698
+ _context11.next = 7;
699
+ return _userEvent["default"].click(radios[5]);
700
+ case 7:
701
+ expect(onChange).not.toHaveBeenCalled();
702
+ expect(radios[5].getAttribute("aria-checked")).toBe("false");
703
+ expect(document.activeElement).toEqual(radios[5]);
704
+ expect(radios[5].tabIndex).toBe(0);
705
+ expect(submitInput.value).toBe("");
706
+ _react2.fireEvent.keyDown(radioGroup, {
707
+ key: "ArrowUp",
708
+ code: "ArrowUp",
709
+ keyCode: 38,
710
+ charCode: 38
711
+ });
712
+ expect(onChange).not.toHaveBeenCalled();
713
+ expect(radios[4].getAttribute("aria-checked")).toBe("false");
714
+ expect(document.activeElement).toEqual(radios[4]);
715
+ expect(radios[4].tabIndex).toBe(0);
716
+ expect(submitInput.value).toBe("");
717
+ case 18:
718
+ case "end":
719
+ return _context11.stop();
720
+ }
721
+ }, _callee11);
722
+ })));
723
+ test("Read-only radio group sends its value on submit", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee12() {
724
+ var handlerOnSubmit, _render22, getByText, submit;
725
+ return _regenerator["default"].wrap(function _callee12$(_context12) {
726
+ while (1) switch (_context12.prev = _context12.next) {
727
+ case 0:
728
+ handlerOnSubmit = jest.fn(function (e) {
729
+ e.preventDefault();
730
+ var formData = new FormData(e.target);
731
+ var formProps = Object.fromEntries(formData);
732
+ expect(formProps).toStrictEqual({
733
+ radiogroup: "data"
734
+ });
735
+ });
736
+ _render22 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement("form", {
737
+ onSubmit: handlerOnSubmit
738
+ }, /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
739
+ name: "radiogroup",
740
+ label: "test-radio-group-label",
741
+ value: "data",
742
+ options: options,
743
+ readOnly: true
744
+ }), /*#__PURE__*/_react["default"].createElement("button", {
745
+ type: "submit"
746
+ }, "Submit"))), getByText = _render22.getByText;
747
+ submit = getByText("Submit");
748
+ _context12.next = 5;
749
+ return _userEvent["default"].click(submit);
750
+ case 5:
751
+ case "end":
752
+ return _context12.stop();
753
+ }
754
+ }, _callee12);
755
+ })));
722
756
  });