@dxc-technology/halstack-react 0.0.0-d30020b → 0.0.0-d3ac293

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 (290) hide show
  1. package/BackgroundColorContext.d.ts +2 -2
  2. package/BackgroundColorContext.js +1 -1
  3. package/HalstackContext.d.ts +1336 -0
  4. package/HalstackContext.js +335 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +118 -126
  7. package/accordion/Accordion.stories.tsx +115 -27
  8. package/accordion/Accordion.test.js +71 -0
  9. package/accordion/types.d.ts +9 -4
  10. package/accordion-group/AccordionGroup.d.ts +1 -1
  11. package/accordion-group/AccordionGroup.js +17 -38
  12. package/accordion-group/AccordionGroup.stories.tsx +28 -2
  13. package/accordion-group/AccordionGroup.test.js +126 -0
  14. package/accordion-group/types.d.ts +14 -3
  15. package/alert/Alert.js +7 -4
  16. package/alert/Alert.stories.tsx +28 -0
  17. package/alert/Alert.test.js +92 -0
  18. package/badge/Badge.d.ts +4 -0
  19. package/badge/Badge.js +5 -3
  20. package/badge/types.d.ts +5 -0
  21. package/bleed/Bleed.js +1 -34
  22. package/bleed/Bleed.stories.tsx +94 -95
  23. package/bleed/types.d.ts +25 -1
  24. package/box/Box.js +25 -37
  25. package/box/Box.stories.tsx +15 -0
  26. package/box/Box.test.js +18 -0
  27. package/box/types.d.ts +1 -0
  28. package/bulleted-list/BulletedList.d.ts +7 -0
  29. package/bulleted-list/BulletedList.js +123 -0
  30. package/bulleted-list/BulletedList.stories.tsx +200 -0
  31. package/bulleted-list/types.d.ts +11 -0
  32. package/button/Button.js +52 -69
  33. package/button/Button.stories.tsx +159 -8
  34. package/button/Button.test.js +35 -0
  35. package/button/types.d.ts +7 -7
  36. package/card/Card.js +25 -28
  37. package/card/Card.test.js +50 -0
  38. package/card/types.d.ts +1 -0
  39. package/checkbox/Checkbox.d.ts +2 -2
  40. package/checkbox/Checkbox.js +107 -110
  41. package/checkbox/Checkbox.stories.tsx +198 -130
  42. package/checkbox/Checkbox.test.js +155 -0
  43. package/checkbox/types.d.ts +13 -5
  44. package/chip/Chip.js +18 -24
  45. package/chip/Chip.stories.tsx +96 -9
  46. package/chip/Chip.test.js +54 -0
  47. package/chip/types.d.ts +1 -1
  48. package/common/utils.d.ts +1 -0
  49. package/common/utils.js +4 -4
  50. package/common/variables.d.ts +1625 -0
  51. package/common/variables.js +476 -583
  52. package/date-input/Calendar.d.ts +4 -0
  53. package/date-input/Calendar.js +258 -0
  54. package/date-input/DateInput.js +169 -258
  55. package/date-input/DateInput.stories.tsx +199 -33
  56. package/date-input/DateInput.test.js +835 -0
  57. package/date-input/DatePicker.d.ts +4 -0
  58. package/date-input/DatePicker.js +146 -0
  59. package/date-input/Icons.d.ts +6 -0
  60. package/date-input/Icons.js +75 -0
  61. package/date-input/YearPicker.d.ts +4 -0
  62. package/date-input/YearPicker.js +126 -0
  63. package/date-input/types.d.ts +67 -9
  64. package/dialog/Dialog.js +76 -93
  65. package/dialog/Dialog.stories.tsx +230 -123
  66. package/dialog/Dialog.test.js +369 -0
  67. package/dialog/types.d.ts +3 -2
  68. package/dropdown/Dropdown.d.ts +1 -1
  69. package/dropdown/Dropdown.js +246 -253
  70. package/dropdown/Dropdown.stories.tsx +245 -56
  71. package/dropdown/Dropdown.test.js +586 -0
  72. package/dropdown/DropdownMenu.d.ts +4 -0
  73. package/dropdown/DropdownMenu.js +70 -0
  74. package/dropdown/DropdownMenuItem.d.ts +4 -0
  75. package/dropdown/DropdownMenuItem.js +81 -0
  76. package/dropdown/types.d.ts +25 -5
  77. package/file-input/FileInput.d.ts +2 -2
  78. package/file-input/FileInput.js +181 -223
  79. package/file-input/FileInput.stories.tsx +122 -11
  80. package/file-input/FileInput.test.js +457 -0
  81. package/file-input/FileItem.d.ts +4 -14
  82. package/file-input/FileItem.js +44 -66
  83. package/file-input/types.d.ts +17 -0
  84. package/flex/Flex.d.ts +4 -0
  85. package/flex/Flex.js +69 -0
  86. package/flex/Flex.stories.tsx +103 -0
  87. package/flex/types.d.ts +32 -0
  88. package/footer/Footer.js +16 -89
  89. package/footer/Footer.stories.tsx +99 -1
  90. package/footer/Footer.test.js +97 -0
  91. package/footer/Icons.js +1 -1
  92. package/footer/types.d.ts +2 -1
  93. package/header/Header.js +108 -129
  94. package/header/Header.stories.tsx +189 -36
  95. package/header/Header.test.js +79 -0
  96. package/header/Icons.js +2 -2
  97. package/header/types.d.ts +3 -2
  98. package/heading/Heading.js +1 -1
  99. package/heading/Heading.test.js +186 -0
  100. package/inset/Inset.js +1 -34
  101. package/inset/Inset.stories.tsx +36 -36
  102. package/inset/types.d.ts +25 -1
  103. package/layout/ApplicationLayout.d.ts +16 -6
  104. package/layout/ApplicationLayout.js +72 -132
  105. package/layout/ApplicationLayout.stories.tsx +84 -93
  106. package/layout/Icons.d.ts +5 -0
  107. package/layout/Icons.js +13 -2
  108. package/layout/SidenavContext.d.ts +5 -0
  109. package/layout/SidenavContext.js +19 -0
  110. package/layout/types.d.ts +18 -33
  111. package/link/Link.d.ts +3 -2
  112. package/link/Link.js +59 -76
  113. package/link/Link.stories.tsx +155 -53
  114. package/link/Link.test.js +81 -0
  115. package/link/types.d.ts +7 -23
  116. package/main.d.ts +10 -15
  117. package/main.js +48 -82
  118. package/nav-tabs/NavTabs.d.ts +8 -0
  119. package/nav-tabs/NavTabs.js +125 -0
  120. package/nav-tabs/NavTabs.stories.tsx +260 -0
  121. package/nav-tabs/NavTabs.test.js +82 -0
  122. package/nav-tabs/Tab.d.ts +4 -0
  123. package/nav-tabs/Tab.js +150 -0
  124. package/nav-tabs/types.d.ts +53 -0
  125. package/number-input/NumberInput.js +11 -18
  126. package/number-input/NumberInput.stories.tsx +5 -5
  127. package/number-input/NumberInput.test.js +542 -0
  128. package/number-input/types.d.ts +17 -10
  129. package/package.json +20 -23
  130. package/paginator/Icons.d.ts +5 -0
  131. package/paginator/Icons.js +16 -28
  132. package/paginator/Paginator.js +19 -46
  133. package/paginator/Paginator.stories.tsx +24 -0
  134. package/paginator/Paginator.test.js +305 -0
  135. package/paragraph/Paragraph.d.ts +6 -0
  136. package/paragraph/Paragraph.js +38 -0
  137. package/paragraph/Paragraph.stories.tsx +44 -0
  138. package/password-input/PasswordInput.js +7 -4
  139. package/password-input/PasswordInput.test.js +181 -0
  140. package/password-input/types.d.ts +14 -11
  141. package/progress-bar/ProgressBar.d.ts +2 -2
  142. package/progress-bar/ProgressBar.js +61 -55
  143. package/progress-bar/ProgressBar.stories.jsx +47 -12
  144. package/progress-bar/ProgressBar.test.js +110 -0
  145. package/progress-bar/types.d.ts +3 -4
  146. package/quick-nav/QuickNav.d.ts +4 -0
  147. package/quick-nav/QuickNav.js +117 -0
  148. package/quick-nav/QuickNav.stories.tsx +356 -0
  149. package/quick-nav/types.d.ts +21 -0
  150. package/quick-nav/types.js +5 -0
  151. package/radio-group/Radio.d.ts +1 -1
  152. package/radio-group/Radio.js +53 -37
  153. package/radio-group/RadioGroup.js +67 -57
  154. package/radio-group/RadioGroup.stories.tsx +171 -36
  155. package/radio-group/RadioGroup.test.js +563 -89
  156. package/radio-group/types.d.ts +82 -4
  157. package/resultsetTable/Icons.d.ts +7 -0
  158. package/resultsetTable/Icons.js +51 -0
  159. package/resultsetTable/ResultsetTable.js +49 -108
  160. package/resultsetTable/ResultsetTable.stories.tsx +50 -25
  161. package/resultsetTable/ResultsetTable.test.js +325 -0
  162. package/resultsetTable/types.d.ts +2 -2
  163. package/select/Icons.d.ts +10 -0
  164. package/select/Icons.js +93 -0
  165. package/select/Listbox.d.ts +4 -0
  166. package/select/Listbox.js +169 -0
  167. package/select/Option.d.ts +4 -0
  168. package/select/Option.js +97 -0
  169. package/select/Select.js +185 -384
  170. package/select/Select.stories.tsx +600 -201
  171. package/select/Select.test.js +2228 -0
  172. package/select/types.d.ts +53 -13
  173. package/sidenav/Sidenav.d.ts +6 -5
  174. package/sidenav/Sidenav.js +183 -53
  175. package/sidenav/Sidenav.stories.tsx +249 -149
  176. package/sidenav/Sidenav.test.js +44 -0
  177. package/sidenav/types.d.ts +50 -27
  178. package/slider/Slider.d.ts +2 -2
  179. package/slider/Slider.js +124 -98
  180. package/slider/Slider.stories.tsx +72 -9
  181. package/slider/Slider.test.js +250 -0
  182. package/slider/types.d.ts +10 -2
  183. package/spinner/Spinner.js +4 -4
  184. package/spinner/Spinner.stories.jsx +27 -1
  185. package/spinner/Spinner.test.js +64 -0
  186. package/switch/Switch.d.ts +2 -2
  187. package/switch/Switch.js +152 -69
  188. package/switch/Switch.stories.tsx +53 -42
  189. package/switch/Switch.test.js +225 -0
  190. package/switch/types.d.ts +12 -4
  191. package/table/Table.js +3 -3
  192. package/table/Table.stories.jsx +80 -1
  193. package/table/Table.test.js +26 -0
  194. package/tabs/Tab.d.ts +4 -0
  195. package/tabs/Tab.js +133 -0
  196. package/tabs/Tabs.d.ts +1 -1
  197. package/tabs/Tabs.js +363 -109
  198. package/tabs/Tabs.stories.tsx +119 -13
  199. package/tabs/Tabs.test.js +350 -0
  200. package/tabs/types.d.ts +19 -5
  201. package/tag/Tag.js +17 -22
  202. package/tag/Tag.stories.tsx +25 -8
  203. package/tag/Tag.test.js +60 -0
  204. package/tag/types.d.ts +1 -1
  205. package/text-input/Icons.d.ts +8 -0
  206. package/text-input/Icons.js +60 -0
  207. package/text-input/Suggestion.d.ts +4 -0
  208. package/text-input/Suggestion.js +84 -0
  209. package/text-input/Suggestions.d.ts +4 -0
  210. package/text-input/Suggestions.js +134 -0
  211. package/text-input/TextInput.js +224 -345
  212. package/text-input/TextInput.stories.tsx +310 -197
  213. package/text-input/TextInput.test.js +1723 -0
  214. package/text-input/types.d.ts +50 -12
  215. package/textarea/Textarea.js +22 -29
  216. package/textarea/Textarea.stories.jsx +93 -13
  217. package/textarea/Textarea.test.js +437 -0
  218. package/textarea/types.d.ts +18 -11
  219. package/toggle-group/ToggleGroup.d.ts +1 -1
  220. package/toggle-group/ToggleGroup.js +6 -5
  221. package/toggle-group/ToggleGroup.stories.tsx +46 -4
  222. package/toggle-group/ToggleGroup.test.js +156 -0
  223. package/toggle-group/types.d.ts +9 -1
  224. package/typography/Typography.d.ts +4 -0
  225. package/typography/Typography.js +32 -0
  226. package/typography/Typography.stories.tsx +198 -0
  227. package/typography/types.d.ts +18 -0
  228. package/typography/types.js +5 -0
  229. package/useTheme.d.ts +1234 -1
  230. package/useTheme.js +3 -3
  231. package/useTranslatedLabels.d.ts +85 -0
  232. package/useTranslatedLabels.js +20 -0
  233. package/utils/BaseTypography.d.ts +21 -0
  234. package/utils/BaseTypography.js +108 -0
  235. package/utils/FocusLock.d.ts +13 -0
  236. package/utils/FocusLock.js +139 -0
  237. package/wizard/Wizard.d.ts +1 -1
  238. package/wizard/Wizard.js +59 -55
  239. package/wizard/Wizard.stories.tsx +48 -19
  240. package/wizard/Wizard.test.js +141 -0
  241. package/wizard/types.d.ts +10 -5
  242. package/ThemeContext.d.ts +0 -15
  243. package/ThemeContext.js +0 -243
  244. package/V3Select/V3Select.js +0 -455
  245. package/V3Select/index.d.ts +0 -27
  246. package/V3Textarea/V3Textarea.js +0 -260
  247. package/V3Textarea/index.d.ts +0 -27
  248. package/common/RequiredComponent.js +0 -32
  249. package/date/Date.js +0 -373
  250. package/date/index.d.ts +0 -27
  251. package/input-text/Icons.js +0 -22
  252. package/input-text/InputText.js +0 -611
  253. package/input-text/index.d.ts +0 -36
  254. package/list/List.d.ts +0 -4
  255. package/list/List.js +0 -47
  256. package/list/List.stories.tsx +0 -95
  257. package/list/types.d.ts +0 -7
  258. package/radio/Radio.d.ts +0 -4
  259. package/radio/Radio.js +0 -174
  260. package/radio/Radio.stories.tsx +0 -192
  261. package/radio/types.d.ts +0 -54
  262. package/row/Row.d.ts +0 -3
  263. package/row/Row.js +0 -127
  264. package/row/Row.stories.tsx +0 -237
  265. package/row/types.d.ts +0 -10
  266. package/stack/Stack.d.ts +0 -3
  267. package/stack/Stack.js +0 -97
  268. package/stack/Stack.stories.tsx +0 -164
  269. package/stack/types.d.ts +0 -9
  270. package/text/Text.d.ts +0 -7
  271. package/text/Text.js +0 -30
  272. package/text/Text.stories.tsx +0 -19
  273. package/toggle/Toggle.js +0 -186
  274. package/toggle/index.d.ts +0 -21
  275. package/upload/Upload.js +0 -201
  276. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  277. package/upload/buttons-upload/Icons.js +0 -40
  278. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  279. package/upload/dragAndDropArea/Icons.js +0 -39
  280. package/upload/file-upload/FileToUpload.js +0 -115
  281. package/upload/file-upload/Icons.js +0 -66
  282. package/upload/files-upload/FilesToUpload.js +0 -109
  283. package/upload/index.d.ts +0 -15
  284. package/upload/transaction/Icons.js +0 -160
  285. package/upload/transaction/Transaction.js +0 -104
  286. package/upload/transactions/Transactions.js +0 -94
  287. /package/{list → badge}/types.js +0 -0
  288. /package/{radio → bulleted-list}/types.js +0 -0
  289. /package/{row → flex}/types.js +0 -0
  290. /package/{stack → nav-tabs}/types.js +0 -0
@@ -4,13 +4,13 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
4
4
 
5
5
  var _react = _interopRequireDefault(require("react"));
6
6
 
7
- var _RadioGroup = _interopRequireDefault(require("./RadioGroup"));
8
-
9
7
  var _react2 = require("@testing-library/react");
10
8
 
11
9
  var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
12
10
 
13
- var single_options = [{
11
+ var _RadioGroup = _interopRequireDefault(require("./RadioGroup.tsx"));
12
+
13
+ var options = [{
14
14
  label: "Option 01",
15
15
  value: "1"
16
16
  }, {
@@ -37,32 +37,224 @@ var single_options = [{
37
37
  }, {
38
38
  label: "Option 09",
39
39
  value: "9"
40
+ }];
41
+ var singleDisabledOptions = [{
42
+ label: "Option 01",
43
+ value: "1"
44
+ }, {
45
+ label: "Option 02",
46
+ value: "2"
40
47
  }, {
41
- label: "Option 10",
42
- value: "10"
48
+ label: "Option 03",
49
+ value: "3",
50
+ disabled: true
43
51
  }];
44
52
  describe("Radio Group component tests", function () {
45
- test("Controlled - Not optional constraint - undefined", function () {
53
+ test("Initial render has correct aria attributes and tabIndex", function () {
54
+ 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
+
64
+ var radioGroup = getByRole("radiogroup");
65
+ var radios = getAllByRole("radio");
66
+ var errorId = "error-".concat(getByText("test-radioGroup-label").id.replace("label-", ""));
67
+ var error = container.querySelector("#".concat(errorId));
68
+ expect(radioGroup.getAttribute("aria-disabled")).toBe("false");
69
+ expect(radioGroup.getAttribute("aria-labelledby")).toBe(getByText("test-radioGroup-label").id);
70
+ expect(radioGroup.getAttribute("aria-invalid")).toBe("false");
71
+ expect(radioGroup.getAttribute("aria-required")).toBe("true");
72
+ expect(radioGroup.getAttribute("aria-orientation")).toBe("vertical");
73
+ expect(error.getAttribute("aria-live")).toBe("off");
74
+ radios.forEach(function (radio, index) {
75
+ // if no option was previously selected, first option is the focusable one
76
+ if (index === 0) expect(radio.tabIndex).toBe(0);else expect(radio.tabIndex).toBe(-1);
77
+ expect(radio.getAttribute("aria-checked")).toBe("false");
78
+ expect(radio.getAttribute("aria-disabled")).toBe("false");
79
+ expect(radio.getAttribute("aria-labelledby")).toBe(getByText("Option 0".concat(index + 1)).id);
80
+ });
81
+ });
82
+ test("aria-orientation attribute changes depending on stacking prop value", function () {
83
+ 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
+
90
+ var radioGroup = getByRole("radiogroup");
91
+ expect(radioGroup.getAttribute("aria-orientation")).toBe("horizontal");
92
+ });
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
+ });
125
+ test("Disabled state renders with correct aria attribute, correct tabIndex values and it is not focusable by keyboard", function () {
126
+ 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
+
134
+ var radioGroup = getByRole("radiogroup");
135
+ var radios = getAllByRole("radio");
136
+ expect(radioGroup.getAttribute("aria-disabled")).toBe("true");
137
+ radios.forEach(function (radio) {
138
+ expect(radio.tabIndex).toBe(-1);
139
+ });
140
+
141
+ _react2.fireEvent.keyDown(radioGroup, {
142
+ key: " ",
143
+ code: "Space",
144
+ keyCode: 13,
145
+ charCode: 13
146
+ });
147
+
148
+ _react2.fireEvent.keyDown(radioGroup, {
149
+ key: "ArrowLeft",
150
+ code: "ArrowLeft",
151
+ keyCode: 37,
152
+ charCode: 37
153
+ });
154
+
155
+ _react2.fireEvent.keyDown(radioGroup, {
156
+ key: "ArrowDown",
157
+ code: "ArrowDown",
158
+ keyCode: 40,
159
+ charCode: 40
160
+ });
161
+
162
+ radios.forEach(function (radio) {
163
+ expect(radio.tabIndex).toBe(-1);
164
+ });
165
+ });
166
+ 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
+ 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
+
175
+ var radioGroup = getByRole("radiogroup");
176
+ var radios = getAllByRole("radio");
177
+ expect(radios[2].getAttribute("aria-disabled")).toBe("true");
178
+ expect(radios[0].tabIndex).toBe(0);
179
+ expect(radios[1].tabIndex).toBe(-1);
180
+ expect(radios[2].tabIndex).toBe(-1);
181
+
182
+ _react2.fireEvent.keyDown(radioGroup, {
183
+ key: "ArrowDown",
184
+ code: "ArrowDown",
185
+ keyCode: 40,
186
+ charCode: 40
187
+ });
188
+
189
+ _react2.fireEvent.keyDown(radioGroup, {
190
+ key: "ArrowDown",
191
+ code: "ArrowDown",
192
+ keyCode: 40,
193
+ charCode: 40
194
+ });
195
+
196
+ expect(radios[0].tabIndex).toBe(0);
197
+ expect(radios[1].tabIndex).toBe(-1);
198
+ expect(radios[2].tabIndex).toBe(-1);
199
+ });
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
+ });
225
+ test("Error state renders with correct aria attributes", function () {
226
+ 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
+
234
+ var radioGroup = getByRole("radiogroup");
235
+ var errorMessage = getByText("Error message");
236
+ expect(radioGroup.getAttribute("aria-errormessage")).toBe(errorMessage.id);
237
+ expect(radioGroup.getAttribute("aria-invalid")).toBe("true");
238
+ expect(errorMessage.getAttribute("aria-live")).toBe("assertive");
239
+ });
240
+ test("Radio group with required constraint and 'undefined' as value, sends an error", function () {
46
241
  var onChange = jest.fn();
47
242
  var onBlur = jest.fn();
48
243
 
49
- var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
50
- label: "test-select-label",
51
- options: single_options,
244
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
245
+ label: "test-radioGroup-label",
246
+ options: options,
52
247
  onChange: onChange,
53
248
  onBlur: onBlur
54
249
  })),
55
- getByRole = _render.getByRole,
56
- getAllByRole = _render.getAllByRole;
250
+ getByRole = _render8.getByRole,
251
+ getAllByRole = _render8.getAllByRole;
57
252
 
58
253
  var radioGroup = getByRole("radiogroup");
59
254
  expect(radioGroup.getAttribute("aria-required")).toBe("true");
60
255
 
61
- _react2.fireEvent.focus(radioGroup);
62
-
63
256
  _react2.fireEvent.blur(radioGroup);
64
257
 
65
- expect(onBlur).toHaveBeenCalled();
66
258
  expect(onBlur).toHaveBeenCalledWith({
67
259
  error: "This field is required. Please, choose an option."
68
260
  });
@@ -71,40 +263,33 @@ describe("Radio Group component tests", function () {
71
263
 
72
264
  _userEvent["default"].click(getAllByRole("radio")[0]);
73
265
 
74
- expect(onChange).toHaveBeenCalled();
75
266
  expect(onChange).toHaveBeenCalledWith("1");
76
267
 
77
- _react2.fireEvent.focus(radioGroup);
78
-
79
268
  _react2.fireEvent.blur(radioGroup);
80
269
 
81
- expect(onBlur).toHaveBeenCalled();
82
270
  expect(onBlur).toHaveBeenCalledWith({
83
271
  value: "1"
84
272
  });
85
273
  });
86
- test("Controlled - Not optional constraint - empty string", function () {
274
+ test("Radio group with required constraint and empty string as value, sends an error", function () {
87
275
  var onChange = jest.fn();
88
276
  var onBlur = jest.fn();
89
277
 
90
- var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
91
- label: "test-select-label",
278
+ var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
279
+ label: "test-radioGroup-label",
92
280
  value: "",
93
- options: single_options,
281
+ options: options,
94
282
  onChange: onChange,
95
283
  onBlur: onBlur
96
284
  })),
97
- getByRole = _render2.getByRole,
98
- getAllByRole = _render2.getAllByRole;
285
+ getByRole = _render9.getByRole,
286
+ getAllByRole = _render9.getAllByRole;
99
287
 
100
288
  var radioGroup = getByRole("radiogroup");
101
289
  expect(radioGroup.getAttribute("aria-required")).toBe("true");
102
290
 
103
- _react2.fireEvent.focus(radioGroup);
104
-
105
291
  _react2.fireEvent.blur(radioGroup);
106
292
 
107
- expect(onBlur).toHaveBeenCalled();
108
293
  expect(onBlur).toHaveBeenCalledWith({
109
294
  value: "",
110
295
  error: "This field is required. Please, choose an option."
@@ -112,137 +297,426 @@ describe("Radio Group component tests", function () {
112
297
 
113
298
  _userEvent["default"].click(getAllByRole("radio")[0]);
114
299
 
115
- expect(onChange).toHaveBeenCalled();
116
300
  expect(onChange).toHaveBeenCalledWith("1");
117
301
  });
118
- test("Controlled - Optional constraint", function () {
302
+ test("The 'defaultValue' gives the radio group an initial value when it is uncontrolled", function () {
303
+ var onChange = jest.fn();
304
+
305
+ 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
+
316
+ var radio = getAllByRole("radio")[1];
317
+ var submitInput = container.querySelector("input[name=\"test\"]");
318
+ expect(radio.tabIndex).toBe(0);
319
+ expect(radio.getAttribute("aria-checked")).toBe("true");
320
+ expect(submitInput.value).toBe("2");
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 () {
119
323
  var onChange = jest.fn();
120
324
  var onBlur = jest.fn();
121
325
 
122
- var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
326
+ var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
327
+ name: "test",
123
328
  label: "test-radio-group-label",
124
329
  helperText: "test-radio-group-helper-text",
125
- options: single_options,
330
+ options: options,
126
331
  onChange: onChange,
127
332
  onBlur: onBlur,
128
- optional: true
333
+ optional: true,
334
+ optionalItemLabel: "No selection"
129
335
  })),
130
- getByRole = _render3.getByRole;
336
+ getByRole = _render11.getByRole,
337
+ getByText = _render11.getByText,
338
+ container = _render11.container;
131
339
 
132
340
  var radioGroup = getByRole("radiogroup");
133
341
  expect(radioGroup.getAttribute("aria-required")).toBe("false");
134
342
 
135
- _react2.fireEvent.focus(radioGroup);
136
-
137
343
  _react2.fireEvent.blur(radioGroup);
138
344
 
139
- expect(onBlur).toHaveBeenCalled();
140
345
  expect(onBlur).toHaveBeenCalledWith({});
141
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("");
142
354
  });
143
- test("Select an option - Click on radio input label", function () {
355
+ test("Controlled radio group", function () {
144
356
  var onChange = jest.fn();
357
+ var onBlur = jest.fn();
145
358
 
146
- var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
359
+ var _render12 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
360
+ name: "test",
361
+ value: "2",
147
362
  label: "test-radio-group-label",
148
363
  helperText: "test-radio-group-helper-text",
149
- options: single_options,
150
- onChange: onChange
364
+ options: options,
365
+ onChange: onChange,
366
+ onBlur: onBlur
151
367
  })),
152
- getByText = _render4.getByText,
153
- getAllByRole = _render4.getAllByRole;
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");
154
378
 
155
- var radio = getByText("Option 10");
379
+ _userEvent["default"].click(radios[6]);
156
380
 
157
- _userEvent["default"].click(radio);
381
+ expect(onChange).toHaveBeenCalledWith("7");
382
+
383
+ _react2.fireEvent.blur(radioGroup);
158
384
 
159
- expect(onChange).toHaveBeenCalled();
160
- expect(onChange).toHaveBeenCalledWith("10");
161
- expect(getAllByRole("radio")[9].getAttribute("aria-checked")).toBe("true");
385
+ expect(onBlur).toHaveBeenCalledWith({
386
+ value: "2"
387
+ });
162
388
  });
163
- test("Select an option - Click on radio input", function () {
389
+ test("Select an option by clicking on its label", function () {
164
390
  var onChange = jest.fn();
165
391
 
166
- var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
392
+ var _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
393
+ name: "test",
167
394
  label: "test-radio-group-label",
168
395
  helperText: "test-radio-group-helper-text",
169
- options: single_options,
396
+ options: options,
170
397
  onChange: onChange
171
398
  })),
172
- getAllByRole = _render5.getAllByRole;
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;
173
428
 
174
- var radio = getAllByRole("radio")[6];
429
+ var checkedRadio = getAllByRole("radio")[6];
430
+ var submitInput = container.querySelector("input[name=\"test\"]");
431
+ expect(checkedRadio.tabIndex).toBe(-1);
175
432
 
176
- _userEvent["default"].click(radio);
433
+ _userEvent["default"].click(checkedRadio);
177
434
 
178
- expect(onChange).toHaveBeenCalled();
179
435
  expect(onChange).toHaveBeenCalledWith("7");
180
- expect(radio.getAttribute("aria-checked")).toBe("true");
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");
181
440
  });
182
- test("Select an option - Tab and Enter key", function () {
441
+ test("Select an option that is already checked does not call onChange event but gives the focus", function () {
183
442
  var onChange = jest.fn();
184
443
 
185
- var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
444
+ var _render15 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
445
+ defaultValue: "2",
446
+ name: "test",
186
447
  label: "test-radio-group-label",
187
448
  helperText: "test-radio-group-helper-text",
188
- options: single_options,
449
+ options: options,
189
450
  onChange: onChange
190
451
  })),
191
- getByRole = _render6.getByRole,
192
- getAllByRole = _render6.getAllByRole;
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
+ });
463
+ test("The 'space' key checks the current focused option if anyone is checked", function () {
464
+ var onChange = jest.fn();
465
+
466
+ 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;
193
476
 
194
477
  var radioGroup = getByRole("radiogroup");
195
- var radio = getAllByRole("radio")[0];
478
+ var checkedRadio = getAllByRole("radio")[0];
479
+ var submitInput = container.querySelector("input[name=\"test\"]");
196
480
 
197
481
  _react2.fireEvent.keyDown(radioGroup, {
198
- key: "Tab",
199
- code: "Tab",
200
- keyCode: 9,
201
- charCode: 9
482
+ key: " ",
483
+ code: "Space",
484
+ keyCode: 32,
485
+ charCode: 32
202
486
  });
203
487
 
488
+ expect(onChange).toHaveBeenCalledWith("1");
489
+ expect(checkedRadio.getAttribute("aria-checked")).toBe("true");
490
+ expect(checkedRadio.tabIndex).toBe(0);
491
+ expect(submitInput.value).toBe("1");
492
+ });
493
+ 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
+ var onChange = jest.fn();
495
+ var onBlur = jest.fn();
496
+
497
+ 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
+
509
+ var radioGroup = getByRole("radiogroup");
510
+ var radios = getAllByRole("radio");
511
+ var submitInput = container.querySelector("input[name=\"test\"]");
512
+ var checkedRadio = getAllByRole("radio")[0];
513
+
514
+ _userEvent["default"].tab();
515
+
516
+ expect(onChange).not.toHaveBeenCalled();
517
+ expect(submitInput.value).toBe("");
518
+ expect(checkedRadio.tabIndex).toBe(0);
519
+ expect(checkedRadio.getAttribute("aria-checked")).toBe("false");
520
+ expect(document.activeElement).toEqual(checkedRadio);
521
+
204
522
  _react2.fireEvent.keyDown(radioGroup, {
205
- key: "Enter",
206
- code: "Enter",
207
- keyCode: 13,
208
- charCode: 13
523
+ key: "ArrowRight",
524
+ code: "ArrowRight",
525
+ keyCode: 39,
526
+ charCode: 39
209
527
  });
210
528
 
211
- expect(onChange).toHaveBeenCalled();
212
- expect(onChange).toHaveBeenCalledWith("1");
213
- expect(radio.getAttribute("aria-checked")).toBe("true");
529
+ expect(onBlur).not.toHaveBeenCalled();
530
+ expect(onChange).toHaveBeenCalledTimes(1);
531
+ expect(radios[1].getAttribute("aria-checked")).toBe("true");
532
+ expect(document.activeElement).toEqual(radios[1]);
533
+ expect(radios[1].tabIndex).toBe(0);
534
+ expect(submitInput.value).toBe("2");
214
535
  });
215
- test("Select an option - Tab and Space key", function () {
536
+ 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 () {
216
537
  var onChange = jest.fn();
538
+ var onBlur = jest.fn();
217
539
 
218
- var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
540
+ var _render18 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
541
+ defaultValue: "8",
542
+ name: "test",
219
543
  label: "test-radio-group-label",
220
544
  helperText: "test-radio-group-helper-text",
221
- options: single_options,
545
+ options: options,
546
+ onChange: onChange,
547
+ onBlur: onBlur
548
+ })),
549
+ getByRole = _render18.getByRole,
550
+ getAllByRole = _render18.getAllByRole,
551
+ container = _render18.container;
552
+
553
+ var radioGroup = getByRole("radiogroup");
554
+ var radios = getAllByRole("radio");
555
+ var submitInput = container.querySelector("input[name=\"test\"]");
556
+
557
+ _react2.fireEvent.keyDown(radioGroup, {
558
+ key: "ArrowDown",
559
+ code: "ArrowDown",
560
+ keyCode: 40,
561
+ charCode: 40
562
+ });
563
+
564
+ expect(onBlur).not.toHaveBeenCalled();
565
+ expect(onChange).toHaveBeenCalledTimes(1);
566
+ expect(radios[8].getAttribute("aria-checked")).toBe("true");
567
+ expect(document.activeElement).toEqual(radios[8]);
568
+ expect(radios[8].tabIndex).toBe(0);
569
+ expect(submitInput.value).toBe("9");
570
+
571
+ _react2.fireEvent.keyDown(radioGroup, {
572
+ key: "ArrowRight",
573
+ code: "ArrowRight",
574
+ keyCode: 39,
575
+ charCode: 39
576
+ });
577
+
578
+ expect(onBlur).not.toHaveBeenCalled();
579
+ expect(onChange).toHaveBeenCalledTimes(2);
580
+ expect(radios[0].getAttribute("aria-checked")).toBe("true");
581
+ expect(document.activeElement).toEqual(radios[0]);
582
+ expect(radios[0].tabIndex).toBe(0);
583
+ expect(submitInput.value).toBe("1");
584
+ });
585
+ 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
+ var onChange = jest.fn();
587
+ var onBlur = jest.fn();
588
+
589
+ 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
+
602
+ var radioGroup = getByRole("radiogroup");
603
+ var radios = getAllByRole("radio");
604
+ var submitInput = container.querySelector("input[name=\"test\"]");
605
+
606
+ _react2.fireEvent.keyDown(radioGroup, {
607
+ key: "ArrowUp",
608
+ code: "ArrowUp",
609
+ keyCode: 38,
610
+ charCode: 38
611
+ });
612
+
613
+ expect(onBlur).not.toHaveBeenCalled();
614
+ expect(onChange).toHaveBeenCalledTimes(1);
615
+ expect(radios[0].getAttribute("aria-checked")).toBe("true");
616
+ expect(document.activeElement).toEqual(radios[0]);
617
+ expect(radios[0].tabIndex).toBe(0);
618
+ expect(submitInput.value).toBe("1");
619
+
620
+ _react2.fireEvent.keyDown(radioGroup, {
621
+ key: "ArrowLeft",
622
+ code: "ArrowLeft",
623
+ keyCode: 37,
624
+ charCode: 37
625
+ });
626
+
627
+ expect(onBlur).not.toHaveBeenCalled();
628
+ expect(onChange).toHaveBeenCalledTimes(2);
629
+ expect(radios[8].getAttribute("aria-checked")).toBe("true");
630
+ expect(document.activeElement).toEqual(radios[8]);
631
+ expect(radios[8].tabIndex).toBe(0);
632
+ expect(submitInput.value).toBe("9");
633
+ });
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,
222
642
  onChange: onChange
223
643
  })),
224
- getByRole = _render7.getByRole,
225
- getAllByRole = _render7.getAllByRole;
644
+ getByRole = _render20.getByRole,
645
+ getAllByRole = _render20.getAllByRole,
646
+ container = _render20.container;
226
647
 
227
648
  var radioGroup = getByRole("radiogroup");
228
- var radio = getAllByRole("radio")[0];
649
+ var radios = getAllByRole("radio");
650
+ var submitInput = container.querySelector("input[name=\"test\"]");
651
+
652
+ _userEvent["default"].click(radios[3]);
229
653
 
230
654
  _react2.fireEvent.keyDown(radioGroup, {
231
- key: "Tab",
232
- code: "Tab",
233
- keyCode: 9,
234
- charCode: 9
655
+ key: "ArrowDown",
656
+ code: "ArrowDown",
657
+ keyCode: 40,
658
+ charCode: 40
235
659
  });
236
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
+
237
669
  _react2.fireEvent.keyDown(radioGroup, {
238
- key: "Space",
239
- code: "Space",
240
- keyCode: 32,
241
- charCode: 32
670
+ key: "ArrowLeft",
671
+ code: "ArrowLeft",
672
+ keyCode: 37,
673
+ charCode: 37
242
674
  });
243
675
 
244
- expect(onChange).toHaveBeenCalled();
245
- expect(onChange).toHaveBeenCalledWith("1");
246
- expect(radio.getAttribute("aria-checked")).toBe("true");
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("");
247
721
  });
248
722
  });