@dxc-technology/halstack-react 7.0.0 → 8.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 (44) hide show
  1. package/HalstackContext.js +7 -8
  2. package/checkbox/Checkbox.d.ts +2 -2
  3. package/checkbox/Checkbox.js +16 -15
  4. package/checkbox/Checkbox.stories.tsx +79 -59
  5. package/checkbox/types.d.ts +4 -0
  6. package/common/variables.js +14 -10
  7. package/date-input/Calendar.d.ts +4 -0
  8. package/date-input/Calendar.js +258 -0
  9. package/date-input/DateInput.js +77 -222
  10. package/date-input/DateInput.stories.tsx +30 -17
  11. package/date-input/DateInput.test.js +411 -138
  12. package/date-input/DatePicker.d.ts +4 -0
  13. package/date-input/DatePicker.js +160 -0
  14. package/date-input/YearPicker.d.ts +4 -0
  15. package/date-input/YearPicker.js +115 -0
  16. package/date-input/types.d.ts +53 -0
  17. package/dropdown/Dropdown.js +32 -29
  18. package/dropdown/Dropdown.test.js +17 -22
  19. package/file-input/FileInput.d.ts +2 -2
  20. package/file-input/FileInput.js +166 -216
  21. package/file-input/FileInput.stories.tsx +38 -10
  22. package/file-input/FileInput.test.js +12 -12
  23. package/file-input/FileItem.d.ts +4 -14
  24. package/file-input/FileItem.js +38 -63
  25. package/file-input/types.d.ts +17 -0
  26. package/link/Link.js +1 -1
  27. package/number-input/NumberInput.test.js +5 -6
  28. package/package.json +7 -12
  29. package/resultsetTable/Icons.d.ts +7 -0
  30. package/resultsetTable/Icons.js +51 -0
  31. package/resultsetTable/ResultsetTable.js +48 -105
  32. package/resultsetTable/ResultsetTable.stories.tsx +50 -25
  33. package/resultsetTable/ResultsetTable.test.js +23 -41
  34. package/resultsetTable/types.d.ts +2 -2
  35. package/select/Select.stories.tsx +2 -5
  36. package/slider/Slider.d.ts +2 -2
  37. package/slider/Slider.js +5 -4
  38. package/slider/types.d.ts +4 -0
  39. package/switch/Switch.d.ts +3 -3
  40. package/switch/Switch.js +4 -3
  41. package/switch/types.d.ts +6 -1
  42. package/table/Table.test.js +1 -1
  43. package/text-input/TextInput.test.js +469 -616
  44. package/common/RequiredComponent.js +0 -32
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import { DatePickerPropsType } from "./types";
3
+ declare const _default: React.MemoExoticComponent<({ date, onDateSelect, id }: DatePickerPropsType) => JSX.Element>;
4
+ export default _default;
@@ -0,0 +1,160 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports["default"] = void 0;
11
+
12
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
+
14
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
+
16
+ var _dayjs = _interopRequireDefault(require("dayjs"));
17
+
18
+ var _react = _interopRequireWildcard(require("react"));
19
+
20
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
21
+
22
+ var _Calendar = _interopRequireDefault(require("./Calendar"));
23
+
24
+ var _YearPicker = _interopRequireDefault(require("./YearPicker"));
25
+
26
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
27
+
28
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
29
+
30
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
31
+
32
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
33
+
34
+ var leftCaret = /*#__PURE__*/_react["default"].createElement("svg", {
35
+ fill: "currentColor",
36
+ focusable: "false",
37
+ viewBox: "0 0 24 24",
38
+ "aria-hidden": "true"
39
+ }, /*#__PURE__*/_react["default"].createElement("path", {
40
+ d: "M15.41 16.59L10.83 12l4.58-4.59L14 6l-6 6 6 6 1.41-1.41z"
41
+ }), /*#__PURE__*/_react["default"].createElement("path", {
42
+ fill: "none",
43
+ d: "M0 0h24v24H0V0z"
44
+ }));
45
+
46
+ var rightCaret = /*#__PURE__*/_react["default"].createElement("svg", {
47
+ fill: "currentColor",
48
+ focusable: "false",
49
+ viewBox: "0 0 24 24",
50
+ "aria-hidden": "true"
51
+ }, /*#__PURE__*/_react["default"].createElement("path", {
52
+ d: "M8.59 16.59L13.17 12 8.59 7.41 10 6l6 6-6 6-1.41-1.41z"
53
+ }), /*#__PURE__*/_react["default"].createElement("path", {
54
+ fill: "none",
55
+ d: "M0 0h24v24H0V0z"
56
+ }));
57
+
58
+ var downCaret = /*#__PURE__*/_react["default"].createElement("svg", {
59
+ xmlns: "http://www.w3.org/2000/svg",
60
+ width: "24",
61
+ height: "24",
62
+ viewBox: "0 0 24 24"
63
+ }, /*#__PURE__*/_react["default"].createElement("path", {
64
+ d: "M7.5 10L12.5 15L17.5 10H7.5Z",
65
+ fill: "currentColor"
66
+ }));
67
+
68
+ var DxcDatePicker = function DxcDatePicker(_ref) {
69
+ var date = _ref.date,
70
+ onDateSelect = _ref.onDateSelect,
71
+ id = _ref.id;
72
+
73
+ var _useState = (0, _react.useState)(date.isValid() ? date : (0, _dayjs["default"])()),
74
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
75
+ innerDate = _useState2[0],
76
+ setInnerDate = _useState2[1];
77
+
78
+ var _useState3 = (0, _react.useState)("calendar"),
79
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
80
+ content = _useState4[0],
81
+ setContent = _useState4[1];
82
+
83
+ var selectedDate = date.isValid() ? date : null;
84
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
85
+
86
+ var handleDateSelect = function handleDateSelect(date) {
87
+ setInnerDate(date);
88
+ onDateSelect(date);
89
+ };
90
+
91
+ var handleOnYearSelect = function handleOnYearSelect(year) {
92
+ setInnerDate(innerDate.set("year", year));
93
+ setContent("calendar");
94
+ };
95
+
96
+ var handleMonthChange = function handleMonthChange(date) {
97
+ setInnerDate(date);
98
+ };
99
+
100
+ return /*#__PURE__*/_react["default"].createElement(DatePicker, {
101
+ id: id
102
+ }, /*#__PURE__*/_react["default"].createElement(PickerHeader, null, /*#__PURE__*/_react["default"].createElement(HeaderButton, {
103
+ "aria-label": translatedLabels.calendar.previousMonthTitle,
104
+ title: translatedLabels.calendar.previousMonthTitle,
105
+ onClick: function onClick() {
106
+ return handleMonthChange(innerDate.set("month", innerDate.get("month") - 1));
107
+ }
108
+ }, leftCaret), /*#__PURE__*/_react["default"].createElement(HeaderYearTrigger, {
109
+ "aria-live": "polite",
110
+ onClick: function onClick() {
111
+ return setContent(function (content) {
112
+ return content === "yearPicker" ? "calendar" : "yearPicker";
113
+ });
114
+ }
115
+ }, /*#__PURE__*/_react["default"].createElement(HeaderYearTriggerLabel, null, translatedLabels.calendar.months[innerDate.get("month")], " ", innerDate.format("YYYY")), downCaret), /*#__PURE__*/_react["default"].createElement(HeaderButton, {
116
+ "aria-label": translatedLabels.calendar.nextMonthTitle,
117
+ title: translatedLabels.calendar.nextMonthTitle,
118
+ onClick: function onClick() {
119
+ return handleMonthChange(innerDate.set("month", innerDate.get("month") + 1));
120
+ }
121
+ }, rightCaret)), content === "calendar" && /*#__PURE__*/_react["default"].createElement(_Calendar["default"], {
122
+ innerDate: innerDate,
123
+ selectedDate: selectedDate,
124
+ onInnerDateChange: setInnerDate,
125
+ onDaySelect: handleDateSelect
126
+ }), content === "yearPicker" && /*#__PURE__*/_react["default"].createElement(_YearPicker["default"], {
127
+ selectedDate: selectedDate,
128
+ onYearSelect: handleOnYearSelect
129
+ }));
130
+ };
131
+
132
+ var DatePicker = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n padding-top: 16px;\n background-color: ", ";\n box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);\n border: 1px solid #bfbfbf;\n border-radius: 4px;\n"])), function (props) {
133
+ return props.theme.dateInput.pickerBackgroundColor;
134
+ });
135
+
136
+ var PickerHeader = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n gap: 8px;\n align-items: center;\n justify-content: space-between;\n padding: 0px 16px;\n"])));
137
+
138
+ var HeaderButton = _styledComponents["default"].button(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n width: 24px;\n height: 24px;\n padding: 0px;\n background-color: ", ";\n font-size: 1.5rem;\n border-radius: 4px;\n border: none;\n cursor: pointer;\n\n &:focus {\n outline: ", " solid 2px;\n }\n &:hover {\n background-color: ", ";\n }\n &:active {\n background-color: #4b1c7d;\n color: #ffffff;\n }\n svg {\n display: inline-block;\n flex-shrink: 0;\n width: 1em;\n height: 1em;\n font-size: 1.5rem;\n user-select: none;\n }\n"])), function (props) {
139
+ return props.theme.dateInput.pickerMonthArrowsBackgroundColor;
140
+ }, function (props) {
141
+ return props.theme.dateInput.pickerFocusColor;
142
+ }, function (props) {
143
+ return props.theme.dateInput.pickerHoverDateBackgroundColor;
144
+ });
145
+
146
+ var HeaderYearTrigger = _styledComponents["default"].button(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n gap: 8px;\n align-items: center;\n justify-content: center;\n height: 40px;\n width: 172px;\n color: ", ";\n background-color: transparent;\n border-radius: 4px;\n border: none;\n cursor: pointer;\n\n &:hover {\n background-color: ", ";\n }\n &:focus {\n outline: ", " solid 2px;\n }\n &:active {\n color: #ffffff;\n background-color: #4b1c7d;\n }\n"])), function (props) {
147
+ return props.theme.dateInput.pickerMonthFontColor;
148
+ }, function (props) {
149
+ return props.theme.dateInput.pickerHoverDateBackgroundColor;
150
+ }, function (props) {
151
+ return props.theme.dateInput.pickerFocusColor;
152
+ });
153
+
154
+ var HeaderYearTriggerLabel = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n font-family: ", ";\n font-size: 0.875rem;\n font-weight: 400;\n line-height: 19px;\n"])), function (props) {
155
+ return props.theme.dateInput.pickerFontFamily;
156
+ });
157
+
158
+ var _default = /*#__PURE__*/_react["default"].memo(DxcDatePicker);
159
+
160
+ exports["default"] = _default;
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import { YearPickerPropsType } from "./types";
3
+ declare const _default: React.MemoExoticComponent<({ onYearSelect, selectedDate }: YearPickerPropsType) => JSX.Element>;
4
+ export default _default;
@@ -0,0 +1,115 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports["default"] = void 0;
11
+
12
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
+
14
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
+
16
+ var _dayjs = _interopRequireDefault(require("dayjs"));
17
+
18
+ var _react = _interopRequireWildcard(require("react"));
19
+
20
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
21
+
22
+ var _templateObject, _templateObject2;
23
+
24
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
25
+
26
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
27
+
28
+ var getYearsArray = function getYearsArray() {
29
+ var yearList = [];
30
+
31
+ for (var i = 1899; i <= 2100; i++) {
32
+ yearList.push(i);
33
+ }
34
+
35
+ return yearList;
36
+ };
37
+
38
+ var yearList = getYearsArray();
39
+
40
+ var YearPicker = function YearPicker(_ref) {
41
+ var onYearSelect = _ref.onYearSelect,
42
+ selectedDate = _ref.selectedDate;
43
+
44
+ var _useState = (0, _react.useState)(selectedDate ? selectedDate.get("year") : (0, _dayjs["default"])().get("year")),
45
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
46
+ yearToFocus = _useState2[0],
47
+ setYearToFocus = _useState2[1];
48
+
49
+ (0, _react.useEffect)(function () {
50
+ var _yearToFocusEl$scroll;
51
+
52
+ var yearToFocusEl = document.getElementById("year_".concat(yearToFocus));
53
+ yearToFocusEl === null || yearToFocusEl === void 0 ? void 0 : (_yearToFocusEl$scroll = yearToFocusEl.scrollIntoView) === null || _yearToFocusEl$scroll === void 0 ? void 0 : _yearToFocusEl$scroll.call(yearToFocusEl, {
54
+ block: "nearest",
55
+ inline: "start"
56
+ });
57
+ yearToFocusEl === null || yearToFocusEl === void 0 ? void 0 : yearToFocusEl.focus();
58
+ }, [yearToFocus]);
59
+
60
+ var handleDayKeyboardEvent = function handleDayKeyboardEvent(event) {
61
+ switch (event.key) {
62
+ case "ArrowUp":
63
+ setYearToFocus(function (prev) {
64
+ return prev > 1899 ? prev - 1 : prev;
65
+ });
66
+ break;
67
+
68
+ case "ArrowDown":
69
+ setYearToFocus(function (prev) {
70
+ return prev < 2100 ? prev + 1 : prev;
71
+ });
72
+ break;
73
+ }
74
+ };
75
+
76
+ return /*#__PURE__*/_react["default"].createElement(YearPickerContainer, null, yearList.map(function (year) {
77
+ return /*#__PURE__*/_react["default"].createElement(YearPickerButton, {
78
+ "aria-label": year,
79
+ key: year,
80
+ selected: (selectedDate === null || selectedDate === void 0 ? void 0 : selectedDate.get("year")) === year,
81
+ "aria-selected": (selectedDate === null || selectedDate === void 0 ? void 0 : selectedDate.get("year")) === year,
82
+ tabIndex: yearToFocus === year ? 0 : -1,
83
+ isCurrentYear: (0, _dayjs["default"])().get("year") === year,
84
+ onKeyDown: function onKeyDown(event) {
85
+ return handleDayKeyboardEvent(event);
86
+ },
87
+ id: "year_".concat(year),
88
+ onClick: function onClick() {
89
+ onYearSelect(year);
90
+ }
91
+ }, year);
92
+ }));
93
+ };
94
+
95
+ var YearPickerContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n flex-direction: column;\n gap: 4px;\n align-items: center;\n overflow-y: scroll;\n width: ", ";\n height: 312px;\n padding: 0px 8px 8px 8px;\n"])), function (props) {
96
+ return props.theme.dateInput.pickerWidth;
97
+ });
98
+
99
+ var YearPickerButton = _styledComponents["default"].button(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n width: 80px;\n min-height: 40px;\n font-size: 0.875rem;\n font-weight: 400;\n line-height: 1.75;\n color: ", ";\n background-color: transparent;\n border: none;\n border-radius: 50px;\n cursor: pointer;\n\n ", "\n\n &:hover {\n font-weight: 400;\n font-size: 1.5rem;\n line-height: 33px;\n color: ", ";\n background-color: ", ";\n }\n &:focus {\n font-weight: 400;\n font-size: 1.5rem;\n line-height: 33px;\n color: ", ";\n outline: ", " solid 2px;\n }\n &:active {\n font-weight: 400;\n font-size: 1.5rem;\n line-height: 33px;\n color: #ffffff;\n background-color: #4b1c7d !important;\n }\n"])), function (props) {
100
+ return props.theme.dateInput.pickerYearFontColor;
101
+ }, function (props) {
102
+ return props.selected ? "font-weight: 400;\n font-size: 1.5rem;\n line-height: 33px;\n color: ".concat(props.theme.dateInput.pickerSelectedDateColor, " !important;\n background-color: ").concat(props.theme.dateInput.pickerSelectedDateBackgroundColor, " !important;") : props.isCurrentYear ? "border: 1px solid #cbacec; \n color: #5f249f;" : "";
103
+ }, function (props) {
104
+ return props.theme.dateInput.pickerHoverDateFontColor;
105
+ }, function (props) {
106
+ return props.theme.dateInput.pickerHoverDateBackgroundColor;
107
+ }, function (props) {
108
+ return props.theme.dateInput.pickerHoverDateFontColor;
109
+ }, function (props) {
110
+ return props.theme.dateInput.pickerFocusColor;
111
+ });
112
+
113
+ var _default = /*#__PURE__*/_react["default"].memo(YearPicker);
114
+
115
+ exports["default"] = _default;
@@ -1,3 +1,4 @@
1
+ import { Dayjs } from "dayjs";
1
2
  declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
3
  declare type Margin = {
3
4
  top?: Space;
@@ -100,6 +101,58 @@ declare type Props = {
100
101
  */
101
102
  tabIndex?: number;
102
103
  };
104
+ export declare type DatePickerPropsType = {
105
+ /**
106
+ * Initial selected date value. If invalid the actual date will be used instead.
107
+ */
108
+ date: Dayjs;
109
+ /**
110
+ * Function called when a date is selected.
111
+ */
112
+ onDateSelect: (date: Dayjs) => void;
113
+ /**
114
+ * Id assigned to the date picker.
115
+ */
116
+ id: string;
117
+ };
118
+ export declare type CalendarPropsType = {
119
+ /**
120
+ * Initial selected date value. If invalid the actual date will be used instead.
121
+ */
122
+ selectedDate: Dayjs;
123
+ /**
124
+ * Date showed by the calendar.
125
+ */
126
+ innerDate: Dayjs;
127
+ /**
128
+ * Function called when the date showned needs to be updated
129
+ */
130
+ onInnerDateChange: (date: Dayjs) => void;
131
+ /**
132
+ * Function called when a date is selected.
133
+ */
134
+ onDaySelect: (date: Dayjs) => void;
135
+ };
136
+ export declare type MonthPickerPropsType = {
137
+ /**
138
+ * Initial selected date value. If invalid the actual date will be used instead.
139
+ */
140
+ selectedDate: Dayjs;
141
+ /**
142
+ * Function called when a month is selected.
143
+ */
144
+ onMonthSelect: (month: number) => void;
145
+ };
146
+ export declare type YearPickerPropsType = {
147
+ /**
148
+ * Initial selected date value. If invalid the actual date will be used instead.
149
+ */
150
+ selectedDate: Dayjs;
151
+ /**
152
+ * Function called when a year is selected.
153
+ */
154
+ onYearSelect: (year: number) => void;
155
+ };
103
156
  /**
104
157
  * Reference to the component.
105
158
  */
@@ -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, {
@@ -293,7 +294,9 @@ var DxcDropdown = function DxcDropdown(_ref) {
293
294
  visualFocusIndex: visualFocusIndex,
294
295
  menuItemOnClick: handleMenuItemOnClick,
295
296
  onKeyDown: handleMenuOnKeyDown,
296
- styles: menuStyles,
297
+ styles: {
298
+ width: width
299
+ },
297
300
  ref: menuRef
298
301
  })))));
299
302
  };
@@ -15,42 +15,37 @@ var _Dropdown = _interopRequireDefault(require("./Dropdown"));
15
15
  var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
16
16
 
17
17
  global.globalThis = global;
18
+ global.DOMRect = {
19
+ fromRect: function fromRect() {
20
+ return {
21
+ top: 0,
22
+ left: 0,
23
+ bottom: 0,
24
+ right: 0,
25
+ width: 0,
26
+ height: 0
27
+ };
28
+ }
29
+ };
18
30
 
19
31
  global.ResizeObserver = /*#__PURE__*/function () {
20
- function ResizeObserver(cb) {
32
+ function ResizeObserver() {
21
33
  (0, _classCallCheck2["default"])(this, ResizeObserver);
22
- this.cb = cb;
23
34
  }
24
35
 
25
36
  (0, _createClass2["default"])(ResizeObserver, [{
26
37
  key: "observe",
27
- value: function observe() {
28
- this.cb([{
29
- borderBoxSize: {
30
- inlineSize: 0,
31
- blockSize: 0
32
- }
33
- }]);
34
- }
38
+ value: function observe() {}
35
39
  }, {
36
40
  key: "unobserve",
37
41
  value: function unobserve() {}
42
+ }, {
43
+ key: "disconnect",
44
+ value: function disconnect() {}
38
45
  }]);
39
46
  return ResizeObserver;
40
47
  }();
41
48
 
42
- global.DOMRect = {
43
- fromRect: function fromRect() {
44
- return {
45
- top: 0,
46
- left: 0,
47
- bottom: 0,
48
- right: 0,
49
- width: 0,
50
- height: 0
51
- };
52
- }
53
- };
54
49
  var options = [{
55
50
  value: "1",
56
51
  label: "Amazon"
@@ -1,4 +1,4 @@
1
- /// <reference types="react" />
1
+ import React from "react";
2
2
  import FileInputPropsType from "./types";
3
- declare const DxcFileInput: ({ name, mode, label, buttonLabel, dropAreaLabel, helperText, accept, minSize, maxSize, showPreview, multiple, disabled, callbackFile, value, margin, tabIndex, }: FileInputPropsType) => JSX.Element;
3
+ declare const DxcFileInput: React.ForwardRefExoticComponent<FileInputPropsType & React.RefAttributes<HTMLDivElement>>;
4
4
  export default DxcFileInput;