@dxc-technology/halstack-react 0.0.0-ecc45e2 → 0.0.0-ede733c

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 (216) hide show
  1. package/BackgroundColorContext.d.ts +2 -2
  2. package/BackgroundColorContext.js +1 -1
  3. package/HalstackContext.d.ts +1329 -5
  4. package/HalstackContext.js +117 -77
  5. package/accordion/Accordion.js +118 -110
  6. package/accordion/Accordion.stories.tsx +103 -15
  7. package/accordion/Accordion.test.js +10 -11
  8. package/accordion/types.d.ts +1 -0
  9. package/accordion-group/AccordionGroup.d.ts +4 -3
  10. package/accordion-group/AccordionGroup.js +24 -65
  11. package/accordion-group/AccordionGroup.stories.tsx +27 -1
  12. package/accordion-group/AccordionGroup.test.js +21 -46
  13. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  14. package/accordion-group/AccordionGroupAccordion.js +43 -0
  15. package/accordion-group/types.d.ts +7 -0
  16. package/alert/Alert.js +5 -9
  17. package/alert/Alert.stories.tsx +28 -0
  18. package/alert/Alert.test.js +1 -1
  19. package/bleed/Bleed.stories.tsx +1 -0
  20. package/box/Box.js +4 -6
  21. package/box/Box.stories.tsx +15 -0
  22. package/box/Box.test.js +1 -1
  23. package/box/types.d.ts +1 -0
  24. package/bulleted-list/BulletedList.js +4 -2
  25. package/bulleted-list/BulletedList.stories.tsx +7 -1
  26. package/bulleted-list/types.d.ts +31 -4
  27. package/button/Button.js +13 -16
  28. package/button/Button.stories.tsx +151 -9
  29. package/button/Button.test.js +1 -1
  30. package/button/types.d.ts +3 -3
  31. package/card/Card.js +12 -13
  32. package/card/Card.stories.tsx +12 -13
  33. package/card/Card.test.js +1 -1
  34. package/card/types.d.ts +1 -0
  35. package/checkbox/Checkbox.d.ts +2 -2
  36. package/checkbox/Checkbox.js +94 -101
  37. package/checkbox/Checkbox.stories.tsx +131 -59
  38. package/checkbox/Checkbox.test.js +94 -17
  39. package/checkbox/types.d.ts +4 -0
  40. package/chip/Chip.js +28 -49
  41. package/chip/Chip.stories.tsx +121 -26
  42. package/chip/Chip.test.js +3 -5
  43. package/common/OpenSans.css +68 -80
  44. package/common/coreTokens.d.ts +146 -0
  45. package/common/coreTokens.js +167 -0
  46. package/common/utils.d.ts +1 -0
  47. package/common/utils.js +4 -4
  48. package/common/variables.d.ts +1482 -0
  49. package/common/variables.js +994 -1137
  50. package/date-input/Calendar.d.ts +4 -0
  51. package/date-input/Calendar.js +258 -0
  52. package/date-input/DateInput.js +134 -237
  53. package/date-input/DateInput.stories.tsx +199 -33
  54. package/date-input/DateInput.test.js +494 -138
  55. package/date-input/DatePicker.d.ts +4 -0
  56. package/date-input/DatePicker.js +146 -0
  57. package/date-input/Icons.d.ts +6 -0
  58. package/date-input/Icons.js +75 -0
  59. package/date-input/YearPicker.d.ts +4 -0
  60. package/date-input/YearPicker.js +126 -0
  61. package/date-input/types.d.ts +51 -0
  62. package/dialog/Dialog.js +60 -73
  63. package/dialog/Dialog.stories.tsx +229 -121
  64. package/dialog/Dialog.test.js +302 -3
  65. package/dialog/types.d.ts +3 -2
  66. package/dropdown/Dropdown.js +43 -42
  67. package/dropdown/Dropdown.stories.tsx +210 -84
  68. package/dropdown/Dropdown.test.js +22 -27
  69. package/dropdown/DropdownMenu.js +12 -18
  70. package/dropdown/DropdownMenuItem.js +5 -18
  71. package/dropdown/types.d.ts +3 -3
  72. package/file-input/FileInput.d.ts +2 -2
  73. package/file-input/FileInput.js +174 -220
  74. package/file-input/FileInput.stories.tsx +122 -11
  75. package/file-input/FileInput.test.js +14 -14
  76. package/file-input/FileItem.d.ts +4 -14
  77. package/file-input/FileItem.js +39 -63
  78. package/file-input/types.d.ts +17 -0
  79. package/flex/Flex.d.ts +1 -1
  80. package/flex/Flex.js +33 -19
  81. package/flex/Flex.stories.tsx +35 -26
  82. package/flex/types.d.ts +83 -7
  83. package/footer/Footer.js +6 -8
  84. package/footer/Footer.stories.tsx +99 -1
  85. package/footer/Footer.test.js +14 -26
  86. package/footer/types.d.ts +1 -0
  87. package/grid/Grid.d.ts +7 -0
  88. package/grid/Grid.js +91 -0
  89. package/grid/Grid.stories.tsx +219 -0
  90. package/grid/types.d.ts +115 -0
  91. package/header/Header.d.ts +3 -2
  92. package/header/Header.js +21 -23
  93. package/header/Header.stories.tsx +152 -9
  94. package/header/Header.test.js +2 -2
  95. package/header/types.d.ts +3 -2
  96. package/heading/Heading.js +1 -1
  97. package/heading/Heading.test.js +1 -1
  98. package/inset/Inset.stories.tsx +2 -1
  99. package/layout/ApplicationLayout.d.ts +3 -3
  100. package/layout/ApplicationLayout.js +1 -1
  101. package/layout/ApplicationLayout.stories.tsx +1 -0
  102. package/layout/types.d.ts +2 -3
  103. package/link/Link.js +4 -4
  104. package/link/Link.stories.tsx +60 -0
  105. package/link/Link.test.js +2 -4
  106. package/link/types.d.ts +2 -2
  107. package/main.d.ts +3 -2
  108. package/main.js +9 -1
  109. package/{tabs-nav → nav-tabs}/NavTabs.js +1 -1
  110. package/{tabs-nav → nav-tabs}/NavTabs.stories.tsx +96 -6
  111. package/{tabs-nav → nav-tabs}/NavTabs.test.js +1 -1
  112. package/{tabs-nav → nav-tabs}/Tab.js +38 -18
  113. package/nav-tabs/types.js +5 -0
  114. package/number-input/NumberInput.test.js +44 -8
  115. package/package.json +15 -20
  116. package/paginator/Icons.d.ts +5 -0
  117. package/paginator/Icons.js +16 -28
  118. package/paginator/Paginator.js +7 -15
  119. package/paginator/Paginator.stories.tsx +24 -0
  120. package/paginator/Paginator.test.js +45 -48
  121. package/paragraph/Paragraph.d.ts +3 -4
  122. package/paragraph/Paragraph.js +5 -5
  123. package/password-input/PasswordInput.test.js +14 -13
  124. package/progress-bar/ProgressBar.d.ts +2 -2
  125. package/progress-bar/ProgressBar.js +5 -5
  126. package/progress-bar/ProgressBar.stories.jsx +35 -2
  127. package/progress-bar/ProgressBar.test.js +1 -1
  128. package/progress-bar/types.d.ts +4 -3
  129. package/quick-nav/QuickNav.js +11 -12
  130. package/quick-nav/QuickNav.stories.tsx +111 -19
  131. package/radio-group/Radio.d.ts +1 -1
  132. package/radio-group/Radio.js +43 -28
  133. package/radio-group/RadioGroup.js +15 -13
  134. package/radio-group/RadioGroup.stories.tsx +132 -18
  135. package/radio-group/RadioGroup.test.js +124 -97
  136. package/radio-group/types.d.ts +2 -2
  137. package/resultsetTable/Icons.d.ts +7 -0
  138. package/resultsetTable/Icons.js +51 -0
  139. package/resultsetTable/ResultsetTable.js +49 -108
  140. package/resultsetTable/ResultsetTable.stories.tsx +50 -25
  141. package/resultsetTable/ResultsetTable.test.js +41 -64
  142. package/resultsetTable/types.d.ts +1 -1
  143. package/select/Listbox.d.ts +1 -1
  144. package/select/Listbox.js +5 -35
  145. package/select/Option.js +11 -24
  146. package/select/Select.js +59 -36
  147. package/select/Select.stories.tsx +494 -150
  148. package/select/Select.test.js +341 -288
  149. package/select/types.d.ts +2 -2
  150. package/sidenav/Icons.d.ts +7 -0
  151. package/sidenav/Icons.js +51 -0
  152. package/sidenav/Sidenav.d.ts +2 -2
  153. package/sidenav/Sidenav.js +66 -96
  154. package/sidenav/Sidenav.stories.tsx +165 -63
  155. package/sidenav/types.d.ts +21 -18
  156. package/slider/Slider.d.ts +2 -2
  157. package/slider/Slider.js +119 -95
  158. package/slider/Slider.stories.tsx +64 -1
  159. package/slider/Slider.test.js +88 -25
  160. package/slider/types.d.ts +4 -0
  161. package/spinner/Spinner.js +17 -23
  162. package/spinner/Spinner.stories.jsx +53 -27
  163. package/spinner/Spinner.test.js +1 -1
  164. package/switch/Switch.d.ts +3 -3
  165. package/switch/Switch.js +96 -85
  166. package/switch/Switch.stories.tsx +33 -0
  167. package/switch/Switch.test.js +27 -14
  168. package/switch/types.d.ts +8 -3
  169. package/table/Table.js +3 -3
  170. package/table/Table.stories.jsx +80 -1
  171. package/table/Table.test.js +2 -2
  172. package/tabs/Tab.d.ts +4 -0
  173. package/tabs/Tab.js +132 -0
  174. package/tabs/Tabs.js +358 -108
  175. package/tabs/Tabs.stories.tsx +119 -5
  176. package/tabs/Tabs.test.js +220 -10
  177. package/tabs/types.d.ts +12 -2
  178. package/tag/Tag.js +8 -10
  179. package/tag/Tag.stories.tsx +14 -1
  180. package/tag/Tag.test.js +1 -1
  181. package/text-input/Icons.d.ts +8 -0
  182. package/text-input/Icons.js +60 -0
  183. package/text-input/Suggestion.js +40 -11
  184. package/text-input/Suggestions.d.ts +4 -0
  185. package/text-input/Suggestions.js +134 -0
  186. package/text-input/TextInput.js +189 -277
  187. package/text-input/TextInput.stories.tsx +280 -184
  188. package/text-input/TextInput.test.js +736 -725
  189. package/text-input/types.d.ts +21 -2
  190. package/textarea/Textarea.js +3 -4
  191. package/textarea/Textarea.stories.jsx +60 -1
  192. package/textarea/Textarea.test.js +2 -4
  193. package/toggle-group/ToggleGroup.d.ts +2 -2
  194. package/toggle-group/ToggleGroup.js +7 -4
  195. package/toggle-group/ToggleGroup.stories.tsx +42 -0
  196. package/toggle-group/ToggleGroup.test.js +1 -1
  197. package/toggle-group/types.d.ts +1 -1
  198. package/typography/Typography.d.ts +2 -2
  199. package/typography/Typography.js +14 -113
  200. package/typography/Typography.stories.tsx +1 -1
  201. package/useTheme.d.ts +1234 -1
  202. package/useTheme.js +1 -1
  203. package/useTranslatedLabels.d.ts +84 -1
  204. package/utils/BaseTypography.d.ts +21 -0
  205. package/utils/BaseTypography.js +108 -0
  206. package/utils/FocusLock.d.ts +13 -0
  207. package/utils/FocusLock.js +138 -0
  208. package/wizard/Wizard.js +2 -2
  209. package/wizard/Wizard.stories.tsx +20 -0
  210. package/wizard/Wizard.test.js +1 -1
  211. package/wizard/types.d.ts +5 -6
  212. package/common/RequiredComponent.js +0 -32
  213. /package/{tabs-nav → grid}/types.js +0 -0
  214. /package/{tabs-nav → nav-tabs}/NavTabs.d.ts +0 -0
  215. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
  216. /package/{tabs-nav → nav-tabs}/types.d.ts +0 -0
@@ -6,8 +6,43 @@ var _react = _interopRequireDefault(require("react"));
6
6
 
7
7
  var _react2 = require("@testing-library/react");
8
8
 
9
- var _Dialog = _interopRequireDefault(require("./Dialog"));
9
+ var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
10
10
 
11
+ var _Dialog = _interopRequireDefault(require("./Dialog.tsx"));
12
+
13
+ var _TextInput = _interopRequireDefault(require("../text-input/TextInput.tsx"));
14
+
15
+ var _Textarea = _interopRequireDefault(require("../textarea/Textarea.tsx"));
16
+
17
+ var _Checkbox = _interopRequireDefault(require("../checkbox/Checkbox.tsx"));
18
+
19
+ var _Select = _interopRequireDefault(require("../select/Select.tsx"));
20
+
21
+ var _Button = _interopRequireDefault(require("../button/Button.tsx"));
22
+
23
+ var _Link = _interopRequireDefault(require("../link/Link.tsx"));
24
+
25
+ var _Card = _interopRequireDefault(require("../card/Card.tsx"));
26
+
27
+ var _RadioGroup = _interopRequireDefault(require("../radio-group/RadioGroup.tsx"));
28
+
29
+ var _Slider = _interopRequireDefault(require("../slider/Slider.tsx"));
30
+
31
+ var _Switch = _interopRequireDefault(require("../switch/Switch.tsx"));
32
+
33
+ var options = [{
34
+ label: "Female",
35
+ value: "female"
36
+ }, {
37
+ label: "Male",
38
+ value: "male"
39
+ }, {
40
+ label: "Non-binary",
41
+ value: "non-binary"
42
+ }, {
43
+ label: "Other",
44
+ value: "other"
45
+ }];
11
46
  describe("Dialog component tests", function () {
12
47
  test("Dialog renders with correct text and accesibility attributes", function () {
13
48
  var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, "dialog-text")),
@@ -50,7 +85,7 @@ describe("Dialog component tests", function () {
50
85
 
51
86
  expect(onCloseClick).toHaveBeenCalled();
52
87
  });
53
- test("Calls correct function onCloseClick when 'escape' key is pressed", function () {
88
+ test("Calls correct function onCloseClick when 'Escape' key is pressed", function () {
54
89
  var onCloseClick = jest.fn();
55
90
 
56
91
  var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
@@ -58,7 +93,7 @@ describe("Dialog component tests", function () {
58
93
  }, "dialog-text")),
59
94
  getByRole = _render5.getByRole;
60
95
 
61
- _react2.fireEvent.keyDown(getByRole("button"), {
96
+ _react2.fireEvent.keyDown(getByRole("dialog"), {
62
97
  key: "Escape",
63
98
  code: "Escape",
64
99
  keyCode: 27,
@@ -67,4 +102,268 @@ describe("Dialog component tests", function () {
67
102
 
68
103
  expect(onCloseClick).toHaveBeenCalled();
69
104
  });
105
+ });
106
+ describe("Dialog component: Focus lock tests", function () {
107
+ test("Close action: when there's no focusable content, the focus never leaves the close action (unless you click outside)", function () {
108
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, "example-dialog")),
109
+ getByRole = _render6.getByRole;
110
+
111
+ var button = getByRole("button");
112
+ var dialog = getByRole("dialog");
113
+ expect(document.activeElement).toEqual(button);
114
+ expect(button.getAttribute("aria-label")).toBe("Close dialog");
115
+
116
+ _userEvent["default"].tab();
117
+
118
+ expect(document.activeElement).toEqual(button);
119
+
120
+ _react2.fireEvent.keyDown(dialog, {
121
+ key: "Tab",
122
+ shiftKey: true
123
+ });
124
+
125
+ expect(document.activeElement).toEqual(button);
126
+ });
127
+ test("Autofocus with Button component", function () {
128
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
129
+ label: "Accept"
130
+ }))),
131
+ getAllByRole = _render7.getAllByRole;
132
+
133
+ var button = getAllByRole("button")[0];
134
+ expect(document.activeElement).toEqual(button);
135
+ expect(button.getAttribute("aria-label")).not.toBe("Close dialog");
136
+ });
137
+ test("Autofocus with Card component", function () {
138
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_Card["default"], {
139
+ linkHref: "https://developer.dxc.com/halstack/next/components/card/"
140
+ }, "example-card"))),
141
+ getByRole = _render8.getByRole;
142
+
143
+ var card = getByRole("link");
144
+ expect(document.activeElement).toEqual(card);
145
+ });
146
+ test("Autofocus with Checkbox component", function () {
147
+ var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
148
+ label: "Name"
149
+ }))),
150
+ getByRole = _render9.getByRole;
151
+
152
+ var checkbox = getByRole("checkbox");
153
+ expect(document.activeElement).toEqual(checkbox);
154
+ });
155
+ test("Autofocus with Link component", function () {
156
+ var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, "This is a text with a ", /*#__PURE__*/_react["default"].createElement(_Link["default"], {
157
+ href: "#"
158
+ }, "Link"), " to another page.")),
159
+ getByRole = _render10.getByRole;
160
+
161
+ var link = getByRole("link");
162
+ expect(document.activeElement).toEqual(link);
163
+ });
164
+ test("Autofocus with RadioGroup component", function () {
165
+ var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
166
+ label: "Example",
167
+ options: options
168
+ }))),
169
+ getAllByRole = _render11.getAllByRole;
170
+
171
+ var checkedRadio = getAllByRole("radio")[0];
172
+ expect(document.activeElement).toEqual(checkedRadio);
173
+ });
174
+ test("Autofocus with Select component", function () {
175
+ var _render12 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_Select["default"], {
176
+ label: "Country",
177
+ options: options
178
+ }))),
179
+ getByRole = _render12.getByRole;
180
+
181
+ var select = getByRole("combobox");
182
+ expect(document.activeElement).toEqual(select);
183
+ });
184
+ test("Autofocus with Slider component", function () {
185
+ var _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_Slider["default"], {
186
+ label: "label",
187
+ minValue: 0,
188
+ maxValue: 100,
189
+ showLimitsValues: true
190
+ }))),
191
+ getByRole = _render13.getByRole;
192
+
193
+ var slider = getByRole("slider");
194
+ expect(document.activeElement).toEqual(slider);
195
+ });
196
+ test("Autofocus with Switch component", function () {
197
+ var _render14 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
198
+ label: "Example"
199
+ }))),
200
+ getByRole = _render14.getByRole;
201
+
202
+ var switchButton = getByRole("switch");
203
+ expect(document.activeElement).toEqual(switchButton);
204
+ });
205
+ test("Autofocus with Text Input component", function () {
206
+ var _render15 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
207
+ label: "Name"
208
+ }))),
209
+ getByRole = _render15.getByRole;
210
+
211
+ var input = getByRole("textbox");
212
+ expect(document.activeElement).toEqual(input);
213
+ });
214
+ test("Autofocus with Textarea component", function () {
215
+ var _render16 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
216
+ label: "Name"
217
+ }))),
218
+ getByRole = _render16.getByRole;
219
+
220
+ var textarea = getByRole("textbox");
221
+ expect(document.activeElement).toEqual(textarea);
222
+ });
223
+ test("Negative tabindex elements are not automatically focused, even if it is enabled and a valid focusable item (programatically and by click)", function () {
224
+ var _render17 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement("input", {
225
+ label: "Name",
226
+ tabIndex: -1
227
+ }), /*#__PURE__*/_react["default"].createElement("input", {
228
+ label: "Name"
229
+ }))),
230
+ getAllByRole = _render17.getAllByRole,
231
+ getByRole = _render17.getByRole;
232
+
233
+ var inputs = getAllByRole("textbox");
234
+ var button = getByRole("button");
235
+ expect(document.activeElement).toEqual(inputs[1]);
236
+
237
+ _userEvent["default"].tab();
238
+
239
+ expect(document.activeElement).toEqual(button);
240
+
241
+ _userEvent["default"].tab();
242
+
243
+ expect(document.activeElement).toEqual(inputs[1]);
244
+ });
245
+ test("Focus jumps disabled components and negative tabIndexes when autofocusing first item", function () {
246
+ var _render18 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
247
+ label: "Accept",
248
+ disabled: true
249
+ }), /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
250
+ label: "Older age",
251
+ disabled: true
252
+ }), /*#__PURE__*/_react["default"].createElement(_Select["default"], {
253
+ label: "Country",
254
+ options: options,
255
+ disabled: true
256
+ }), /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
257
+ label: "Country",
258
+ options: options,
259
+ disabled: true
260
+ }), /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
261
+ label: "Name",
262
+ disabled: true
263
+ }), /*#__PURE__*/_react["default"].createElement(_Button["default"], {
264
+ label: "Accept",
265
+ tabIndex: -1
266
+ }), /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
267
+ label: "Older age",
268
+ tabIndex: -1
269
+ }), /*#__PURE__*/_react["default"].createElement(_Select["default"], {
270
+ label: "Country",
271
+ options: options,
272
+ tabIndex: -1
273
+ }), /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
274
+ label: "Country",
275
+ options: options,
276
+ tabIndex: -1
277
+ }), /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
278
+ label: "Name",
279
+ tabIndex: -1
280
+ }), /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
281
+ label: "Description"
282
+ }))),
283
+ getAllByRole = _render18.getAllByRole;
284
+
285
+ var textarea = getAllByRole("textbox")[2];
286
+ expect(document.activeElement).toEqual(textarea);
287
+ });
288
+ test("Focus jumps from last element to the first", function () {
289
+ var _render19 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
290
+ label: "Accept",
291
+ disabled: true
292
+ }), /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
293
+ label: "Name"
294
+ }), /*#__PURE__*/_react["default"].createElement(_RadioGroup["default"], {
295
+ label: "Name",
296
+ options: options
297
+ }))),
298
+ getByRole = _render19.getByRole;
299
+
300
+ var closeAction = getByRole("button");
301
+ var textarea = getByRole("textbox");
302
+ expect(document.activeElement).toEqual(textarea);
303
+
304
+ _userEvent["default"].tab();
305
+
306
+ _userEvent["default"].tab();
307
+
308
+ expect(document.activeElement).toEqual(closeAction);
309
+
310
+ _userEvent["default"].tab();
311
+
312
+ expect(document.activeElement).toEqual(textarea);
313
+ });
314
+ test("'display: none;', 'visibility: hidden;' and 'type = 'hidden'' elements are never autofocused", function () {
315
+ var _render20 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, /*#__PURE__*/_react["default"].createElement("input", {
316
+ label: "Name",
317
+ style: {
318
+ display: "none"
319
+ }
320
+ }), /*#__PURE__*/_react["default"].createElement("input", {
321
+ label: "Name",
322
+ style: {
323
+ visibility: "hidden"
324
+ }
325
+ }), /*#__PURE__*/_react["default"].createElement("input", {
326
+ type: "hidden",
327
+ name: "example"
328
+ }))),
329
+ getByRole = _render20.getByRole;
330
+
331
+ var closeAction = getByRole("button");
332
+ expect(document.activeElement).toEqual(closeAction);
333
+
334
+ _userEvent["default"].tab();
335
+
336
+ expect(document.activeElement).toEqual(closeAction);
337
+ });
338
+ test("Focus gets trapped in the Dialog when there are not focusable elements inside until it is closed", function () {
339
+ var _render21 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
340
+ label: "Name"
341
+ }), /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
342
+ isCloseVisible: false
343
+ }, /*#__PURE__*/_react["default"].createElement("h2", null, "Policy agreement"), /*#__PURE__*/_react["default"].createElement("p", null, "Sample text.")), /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
344
+ label: "Surname"
345
+ }))),
346
+ getAllByRole = _render21.getAllByRole;
347
+
348
+ var inputs = getAllByRole("textbox");
349
+ var dialog = getAllByRole("dialog")[0];
350
+
351
+ _userEvent["default"].tab();
352
+
353
+ _userEvent["default"].tab();
354
+
355
+ expect(document.activeElement).not.toEqual(inputs[1]);
356
+
357
+ _react2.fireEvent.keyDown(dialog, {
358
+ key: "Tab",
359
+ shiftKey: true
360
+ });
361
+
362
+ _react2.fireEvent.keyDown(dialog, {
363
+ key: "Tab",
364
+ shiftKey: true
365
+ });
366
+
367
+ expect(document.activeElement).not.toEqual(inputs[0]);
368
+ });
70
369
  });
package/dialog/types.d.ts CHANGED
@@ -1,6 +1,6 @@
1
1
  /// <reference types="react" />
2
- export declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- export declare type Padding = {
2
+ declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ declare type Padding = {
4
4
  top?: Space;
5
5
  bottom?: Space;
6
6
  left?: Space;
@@ -26,6 +26,7 @@ declare type Props = {
26
26
  */
27
27
  onBackgroundClick?: () => void;
28
28
  /**
29
+ * @deprecated This prop will be removed shortly, consider using the Inset component for this purpose.
29
30
  * Size of the padding to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
30
31
  * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different padding sizes.
31
32
  */
@@ -19,9 +19,9 @@ var _react = _interopRequireWildcard(require("react"));
19
19
 
20
20
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
21
 
22
- var _variables = require("../common/variables.js");
22
+ var _variables = require("../common/variables");
23
23
 
24
- var _utils = require("../common/utils.js");
24
+ var _utils = require("../common/utils");
25
25
 
26
26
  var _useTheme = _interopRequireDefault(require("../useTheme"));
27
27
 
@@ -63,6 +63,28 @@ var downArrowIcon = /*#__PURE__*/_react["default"].createElement("svg", {
63
63
  fill: "none"
64
64
  }));
65
65
 
66
+ var useWidth = function useWidth(target) {
67
+ var _useState = (0, _react.useState)(0),
68
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
69
+ width = _useState2[0],
70
+ setWidth = _useState2[1];
71
+
72
+ (0, _react.useEffect)(function () {
73
+ if (target != null) {
74
+ setWidth(target.getBoundingClientRect().width);
75
+ var triggerObserver = new ResizeObserver(function (entries) {
76
+ var rect = entries[0].target.getBoundingClientRect();
77
+ setWidth(rect === null || rect === void 0 ? void 0 : rect.width);
78
+ });
79
+ triggerObserver.observe(target);
80
+ return function () {
81
+ triggerObserver.unobserve(target);
82
+ };
83
+ }
84
+ }, [target]);
85
+ return width;
86
+ };
87
+
66
88
  var DxcDropdown = function DxcDropdown(_ref) {
67
89
  var options = _ref.options,
68
90
  _ref$optionsIconPosit = _ref.optionsIconPosition,
@@ -85,21 +107,16 @@ var DxcDropdown = function DxcDropdown(_ref) {
85
107
  _ref$tabIndex = _ref.tabIndex,
86
108
  tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
87
109
 
88
- var _useState = (0, _react.useState)("trigger-".concat((0, _uuid.v4)())),
89
- _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
90
- triggerId = _useState2[0];
110
+ var _useState3 = (0, _react.useState)("trigger-".concat((0, _uuid.v4)())),
111
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 1),
112
+ triggerId = _useState4[0];
91
113
 
92
114
  var menuId = "menu-".concat(triggerId);
93
115
 
94
- var _useState3 = (0, _react.useState)(false),
95
- _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
96
- isOpen = _useState4[0],
97
- changeIsOpen = _useState4[1];
98
-
99
- var _useState5 = (0, _react.useState)(null),
116
+ var _useState5 = (0, _react.useState)(false),
100
117
  _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
101
- menuStyles = _useState6[0],
102
- setMenuStyles = _useState6[1];
118
+ isOpen = _useState6[0],
119
+ changeIsOpen = _useState6[1];
103
120
 
104
121
  var _useState7 = (0, _react.useState)(0),
105
122
  _useState8 = (0, _slicedToArray2["default"])(_useState7, 2),
@@ -109,6 +126,7 @@ var DxcDropdown = function DxcDropdown(_ref) {
109
126
  var colorsTheme = (0, _useTheme["default"])();
110
127
  var triggerRef = (0, _react.useRef)(null);
111
128
  var menuRef = (0, _react.useRef)(null);
129
+ var width = useWidth(triggerRef.current);
112
130
 
113
131
  var handleOnOpenMenu = function handleOnOpenMenu() {
114
132
  changeIsOpen(true);
@@ -146,7 +164,7 @@ var DxcDropdown = function DxcDropdown(_ref) {
146
164
  handleOnOpenMenu();
147
165
  break;
148
166
 
149
- case "Space":
167
+ case " ":
150
168
  case "Down":
151
169
  case "ArrowDown":
152
170
  case "Enter":
@@ -186,7 +204,7 @@ var DxcDropdown = function DxcDropdown(_ref) {
186
204
  setNextIndexFocus();
187
205
  break;
188
206
 
189
- case "Space":
207
+ case " ":
190
208
  case "Enter":
191
209
  event.preventDefault();
192
210
  handleMenuItemOnClick(options[visualFocusIndex].value);
@@ -226,23 +244,6 @@ var DxcDropdown = function DxcDropdown(_ref) {
226
244
  inline: "start"
227
245
  });
228
246
  }, [visualFocusIndex]);
229
-
230
- var handleMenuResize = function handleMenuResize() {
231
- var _triggerRef$current4;
232
-
233
- var rect = triggerRef === null || triggerRef === void 0 ? void 0 : (_triggerRef$current4 = triggerRef.current) === null || _triggerRef$current4 === void 0 ? void 0 : _triggerRef$current4.getBoundingClientRect();
234
- setMenuStyles({
235
- width: rect === null || rect === void 0 ? void 0 : rect.width
236
- });
237
- };
238
-
239
- (0, _react.useEffect)(function () {
240
- handleMenuResize();
241
- window.addEventListener("resize", handleMenuResize);
242
- return function () {
243
- window.removeEventListener("resize", handleMenuResize);
244
- };
245
- }, []);
246
247
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
247
248
  theme: colorsTheme.dropdown
248
249
  }, /*#__PURE__*/_react["default"].createElement(DropdownContainer, {
@@ -254,9 +255,9 @@ var DxcDropdown = function DxcDropdown(_ref) {
254
255
  }, /*#__PURE__*/_react["default"].createElement(Popover.Root, {
255
256
  open: isOpen
256
257
  }, /*#__PURE__*/_react["default"].createElement(Popover.Trigger, {
257
- asChild: true
258
+ asChild: true,
259
+ type: undefined
258
260
  }, /*#__PURE__*/_react["default"].createElement(DropdownTrigger, {
259
- opened: isOpen,
260
261
  onClick: handleTriggerOnClick,
261
262
  onKeyDown: handleTriggerOnKeyDown,
262
263
  onBlur: function onBlur(event) {
@@ -267,14 +268,12 @@ var DxcDropdown = function DxcDropdown(_ref) {
267
268
  margin: margin,
268
269
  size: size,
269
270
  id: triggerId,
270
- "aria-disabled": disabled,
271
271
  "aria-haspopup": "true",
272
+ "aria-controls": menuId,
272
273
  "aria-expanded": isOpen ? true : undefined,
273
274
  tabIndex: tabIndex,
274
275
  ref: triggerRef
275
276
  }, /*#__PURE__*/_react["default"].createElement(DropdownTriggerContent, null, label && iconPosition === "after" && /*#__PURE__*/_react["default"].createElement(DropdownTriggerLabel, null, label), icon && /*#__PURE__*/_react["default"].createElement(DropdownTriggerIcon, {
276
- label: label,
277
- iconPosition: iconPosition,
278
277
  disabled: disabled,
279
278
  role: typeof icon === "string" ? undefined : "img"
280
279
  }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement("img", {
@@ -292,7 +291,9 @@ var DxcDropdown = function DxcDropdown(_ref) {
292
291
  visualFocusIndex: visualFocusIndex,
293
292
  menuItemOnClick: handleMenuItemOnClick,
294
293
  onKeyDown: handleMenuOnKeyDown,
295
- styles: menuStyles,
294
+ styles: {
295
+ width: width
296
+ },
296
297
  ref: menuRef
297
298
  })))));
298
299
  };
@@ -302,7 +303,7 @@ var sizes = {
302
303
  medium: "240px",
303
304
  large: "480px",
304
305
  fillParent: "100%",
305
- fitContent: "unset"
306
+ fitContent: "fit-content"
306
307
  };
307
308
 
308
309
  var calculateWidth = function calculateWidth(margin, size) {
@@ -367,12 +368,12 @@ var DropdownTriggerLabel = _styledComponents["default"].span(_templateObject4 ||
367
368
  return props.theme.buttonFontWeight;
368
369
  });
369
370
 
370
- var DropdownTriggerIcon = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n height: ", ";\n color: ", ";\n\n img,\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
371
- return props.theme.buttonIconSize;
371
+ var DropdownTriggerIcon = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n color: ", ";\n\n img,\n svg {\n width: ", ";\n height: ", ";\n }\n"])), function (props) {
372
+ return props.disabled ? props.theme.disabledColor : props.theme.buttonIconColor;
372
373
  }, function (props) {
373
374
  return props.theme.buttonIconSize;
374
375
  }, function (props) {
375
- return props.disabled ? props.theme.disabledColor : props.theme.buttonIconColor;
376
+ return props.theme.buttonIconSize;
376
377
  });
377
378
 
378
379
  var CaretIcon = _styledComponents["default"].span(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n color: ", ";\n\n svg {\n width: ", ";\n height: ", ";\n }\n"])), function (props) {