@dxc-technology/halstack-react 7.0.0 → 9.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 (109) hide show
  1. package/HalstackContext.js +98 -50
  2. package/accordion/Accordion.js +7 -13
  3. package/accordion/Accordion.stories.tsx +102 -13
  4. package/alert/Alert.stories.tsx +28 -0
  5. package/box/Box.js +1 -3
  6. package/box/Box.stories.tsx +15 -0
  7. package/button/Button.js +11 -13
  8. package/button/Button.stories.tsx +150 -8
  9. package/checkbox/Checkbox.d.ts +2 -2
  10. package/checkbox/Checkbox.js +16 -15
  11. package/checkbox/Checkbox.stories.tsx +131 -59
  12. package/checkbox/types.d.ts +4 -0
  13. package/chip/Chip.js +16 -22
  14. package/chip/Chip.stories.tsx +96 -9
  15. package/common/variables.js +286 -290
  16. package/date-input/Calendar.d.ts +4 -0
  17. package/date-input/Calendar.js +258 -0
  18. package/date-input/DateInput.js +134 -237
  19. package/date-input/DateInput.stories.tsx +199 -33
  20. package/date-input/DateInput.test.js +494 -138
  21. package/date-input/DatePicker.d.ts +4 -0
  22. package/date-input/DatePicker.js +146 -0
  23. package/date-input/Icons.d.ts +6 -0
  24. package/date-input/Icons.js +75 -0
  25. package/date-input/YearPicker.d.ts +4 -0
  26. package/date-input/YearPicker.js +126 -0
  27. package/date-input/types.d.ts +51 -0
  28. package/dialog/Dialog.js +60 -73
  29. package/dialog/Dialog.stories.tsx +211 -159
  30. package/dialog/Dialog.test.js +301 -2
  31. package/dropdown/Dropdown.js +35 -35
  32. package/dropdown/Dropdown.stories.tsx +210 -84
  33. package/dropdown/Dropdown.test.js +17 -22
  34. package/dropdown/DropdownMenu.js +8 -18
  35. package/dropdown/DropdownMenuItem.js +4 -15
  36. package/file-input/FileInput.d.ts +2 -2
  37. package/file-input/FileInput.js +169 -222
  38. package/file-input/FileInput.stories.tsx +122 -11
  39. package/file-input/FileInput.test.js +12 -53
  40. package/file-input/FileItem.d.ts +4 -14
  41. package/file-input/FileItem.js +39 -63
  42. package/file-input/types.d.ts +17 -0
  43. package/footer/Footer.stories.tsx +91 -0
  44. package/header/Header.js +18 -20
  45. package/header/Header.stories.tsx +149 -6
  46. package/link/Link.js +1 -1
  47. package/link/Link.stories.tsx +60 -0
  48. package/main.d.ts +1 -1
  49. package/main.js +1 -1
  50. package/{tabs-nav → nav-tabs}/NavTabs.js +1 -1
  51. package/{tabs-nav → nav-tabs}/NavTabs.stories.tsx +96 -6
  52. package/{tabs-nav → nav-tabs}/Tab.js +35 -15
  53. package/number-input/NumberInput.test.js +5 -6
  54. package/package.json +7 -12
  55. package/paginator/Icons.d.ts +5 -0
  56. package/paginator/Icons.js +16 -28
  57. package/paginator/Paginator.js +5 -11
  58. package/paginator/Paginator.stories.tsx +24 -0
  59. package/paginator/Paginator.test.js +17 -10
  60. package/progress-bar/ProgressBar.js +4 -4
  61. package/progress-bar/ProgressBar.stories.jsx +35 -2
  62. package/quick-nav/QuickNav.stories.tsx +14 -0
  63. package/radio-group/RadioGroup.stories.tsx +131 -18
  64. package/resultsetTable/Icons.d.ts +7 -0
  65. package/resultsetTable/Icons.js +51 -0
  66. package/resultsetTable/ResultsetTable.js +48 -105
  67. package/resultsetTable/ResultsetTable.stories.tsx +50 -25
  68. package/resultsetTable/ResultsetTable.test.js +40 -63
  69. package/resultsetTable/types.d.ts +2 -2
  70. package/select/Listbox.d.ts +1 -1
  71. package/select/Listbox.js +5 -34
  72. package/select/Option.js +11 -24
  73. package/select/Select.js +43 -24
  74. package/select/Select.stories.tsx +494 -150
  75. package/select/Select.test.js +17 -22
  76. package/select/types.d.ts +2 -2
  77. package/sidenav/Sidenav.js +8 -10
  78. package/sidenav/Sidenav.stories.tsx +148 -46
  79. package/slider/Slider.d.ts +2 -2
  80. package/slider/Slider.js +9 -8
  81. package/slider/Slider.stories.tsx +57 -0
  82. package/slider/types.d.ts +4 -0
  83. package/spinner/Spinner.js +2 -2
  84. package/spinner/Spinner.stories.jsx +27 -1
  85. package/switch/Switch.d.ts +3 -3
  86. package/switch/Switch.js +5 -4
  87. package/switch/Switch.stories.tsx +33 -0
  88. package/switch/types.d.ts +6 -1
  89. package/table/Table.stories.jsx +80 -1
  90. package/table/Table.test.js +1 -1
  91. package/tabs/Tab.js +3 -5
  92. package/tabs/Tabs.js +3 -3
  93. package/tabs/Tabs.stories.tsx +45 -5
  94. package/tag/Tag.stories.tsx +14 -1
  95. package/text-input/Suggestion.js +32 -5
  96. package/text-input/TextInput.js +7 -11
  97. package/text-input/TextInput.stories.tsx +92 -4
  98. package/text-input/TextInput.test.js +587 -634
  99. package/textarea/Textarea.stories.jsx +60 -1
  100. package/toggle-group/ToggleGroup.stories.tsx +42 -0
  101. package/utils/FocusLock.d.ts +13 -0
  102. package/utils/FocusLock.js +139 -0
  103. package/wizard/Wizard.stories.tsx +20 -0
  104. package/common/RequiredComponent.js +0 -32
  105. /package/{tabs-nav → nav-tabs}/NavTabs.d.ts +0 -0
  106. /package/{tabs-nav → nav-tabs}/NavTabs.test.js +0 -0
  107. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
  108. /package/{tabs-nav → nav-tabs}/types.d.ts +0 -0
  109. /package/{tabs-nav → nav-tabs}/types.js +0 -0
@@ -6,8 +6,30 @@ var _react = _interopRequireDefault(require("react"));
6
6
 
7
7
  var _react2 = require("@testing-library/react");
8
8
 
9
+ var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
10
+
9
11
  var _Dialog = _interopRequireDefault(require("./Dialog"));
10
12
 
13
+ var _TextInput = _interopRequireDefault(require("../text-input/TextInput"));
14
+
15
+ var _Textarea = _interopRequireDefault(require("../textarea/Textarea"));
16
+
17
+ var _Checkbox = _interopRequireDefault(require("../checkbox/Checkbox"));
18
+
19
+ var _Select = _interopRequireDefault(require("../select/Select"));
20
+
21
+ var _Button = _interopRequireDefault(require("../button/Button"));
22
+
23
+ var _Link = _interopRequireDefault(require("../link/Link"));
24
+
25
+ var _Card = _interopRequireDefault(require("../card/Card"));
26
+
27
+ var _RadioGroup = _interopRequireDefault(require("../radio-group/RadioGroup"));
28
+
29
+ var _Slider = _interopRequireDefault(require("../slider/Slider"));
30
+
31
+ var _Switch = _interopRequireDefault(require("../switch/Switch"));
32
+
11
33
  describe("Dialog component tests", function () {
12
34
  test("Dialog renders with correct text and accesibility attributes", function () {
13
35
  var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], null, "dialog-text")),
@@ -50,7 +72,7 @@ describe("Dialog component tests", function () {
50
72
 
51
73
  expect(onCloseClick).toHaveBeenCalled();
52
74
  });
53
- test("Calls correct function onCloseClick when 'escape' key is pressed", function () {
75
+ test("Calls correct function onCloseClick when 'Escape' key is pressed", function () {
54
76
  var onCloseClick = jest.fn();
55
77
 
56
78
  var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Dialog["default"], {
@@ -58,7 +80,7 @@ describe("Dialog component tests", function () {
58
80
  }, "dialog-text")),
59
81
  getByRole = _render5.getByRole;
60
82
 
61
- _react2.fireEvent.keyDown(getByRole("button"), {
83
+ _react2.fireEvent.keyDown(getByRole("dialog"), {
62
84
  key: "Escape",
63
85
  code: "Escape",
64
86
  keyCode: 27,
@@ -67,4 +89,281 @@ describe("Dialog component tests", function () {
67
89
 
68
90
  expect(onCloseClick).toHaveBeenCalled();
69
91
  });
92
+ });
93
+ var options = [{
94
+ label: "Female",
95
+ value: "female"
96
+ }, {
97
+ label: "Male",
98
+ value: "male"
99
+ }, {
100
+ label: "Non-binary",
101
+ value: "non-binary"
102
+ }, {
103
+ label: "Other",
104
+ value: "other"
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
  });
@@ -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);
@@ -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, {
@@ -257,7 +258,6 @@ var DxcDropdown = function DxcDropdown(_ref) {
257
258
  asChild: true,
258
259
  type: undefined
259
260
  }, /*#__PURE__*/_react["default"].createElement(DropdownTrigger, {
260
- opened: isOpen,
261
261
  onClick: handleTriggerOnClick,
262
262
  onKeyDown: handleTriggerOnKeyDown,
263
263
  onBlur: function onBlur(event) {
@@ -274,8 +274,6 @@ var DxcDropdown = function DxcDropdown(_ref) {
274
274
  tabIndex: tabIndex,
275
275
  ref: triggerRef
276
276
  }, /*#__PURE__*/_react["default"].createElement(DropdownTriggerContent, null, label && iconPosition === "after" && /*#__PURE__*/_react["default"].createElement(DropdownTriggerLabel, null, label), icon && /*#__PURE__*/_react["default"].createElement(DropdownTriggerIcon, {
277
- label: label,
278
- iconPosition: iconPosition,
279
277
  disabled: disabled,
280
278
  role: typeof icon === "string" ? undefined : "img"
281
279
  }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement("img", {
@@ -293,7 +291,9 @@ var DxcDropdown = function DxcDropdown(_ref) {
293
291
  visualFocusIndex: visualFocusIndex,
294
292
  menuItemOnClick: handleMenuItemOnClick,
295
293
  onKeyDown: handleMenuOnKeyDown,
296
- styles: menuStyles,
294
+ styles: {
295
+ width: width
296
+ },
297
297
  ref: menuRef
298
298
  })))));
299
299
  };
@@ -368,12 +368,12 @@ var DropdownTriggerLabel = _styledComponents["default"].span(_templateObject4 ||
368
368
  return props.theme.buttonFontWeight;
369
369
  });
370
370
 
371
- 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) {
372
- 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;
373
373
  }, function (props) {
374
374
  return props.theme.buttonIconSize;
375
375
  }, function (props) {
376
- return props.disabled ? props.theme.disabledColor : props.theme.buttonIconColor;
376
+ return props.theme.buttonIconSize;
377
377
  });
378
378
 
379
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) {