@dxc-technology/halstack-react 6.2.2 → 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.
- package/HalstackContext.js +7 -8
- package/accordion/types.d.ts +1 -0
- package/accordion-group/types.d.ts +1 -0
- package/box/types.d.ts +1 -0
- package/card/types.d.ts +1 -0
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +16 -15
- package/checkbox/Checkbox.stories.tsx +79 -59
- package/checkbox/types.d.ts +4 -0
- package/common/variables.js +19 -15
- package/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +258 -0
- package/date-input/DateInput.js +77 -222
- package/date-input/DateInput.stories.tsx +30 -17
- package/date-input/DateInput.test.js +411 -138
- package/date-input/DatePicker.d.ts +4 -0
- package/date-input/DatePicker.js +160 -0
- package/date-input/YearPicker.d.ts +4 -0
- package/date-input/YearPicker.js +115 -0
- package/date-input/types.d.ts +53 -0
- package/dialog/types.d.ts +1 -0
- package/dropdown/Dropdown.js +35 -31
- package/dropdown/Dropdown.test.js +18 -24
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +177 -219
- package/file-input/FileInput.stories.tsx +38 -10
- package/file-input/FileInput.test.js +53 -12
- package/file-input/FileItem.d.ts +4 -14
- package/file-input/FileItem.js +38 -63
- package/file-input/types.d.ts +17 -0
- package/flex/Flex.d.ts +1 -1
- package/flex/Flex.js +31 -19
- package/flex/types.d.ts +14 -3
- package/footer/types.d.ts +1 -0
- package/header/types.d.ts +1 -0
- package/link/Link.js +1 -1
- package/number-input/NumberInput.test.js +43 -7
- package/package.json +7 -12
- package/paginator/Paginator.js +2 -2
- package/paginator/Paginator.test.js +1 -1
- package/password-input/PasswordInput.test.js +13 -12
- package/quick-nav/QuickNav.js +11 -12
- package/quick-nav/QuickNav.stories.tsx +97 -19
- package/radio-group/RadioGroup.js +9 -5
- package/radio-group/RadioGroup.test.js +116 -59
- package/resultsetTable/Icons.d.ts +7 -0
- package/resultsetTable/Icons.js +51 -0
- package/resultsetTable/ResultsetTable.js +48 -107
- package/resultsetTable/ResultsetTable.stories.tsx +50 -25
- package/resultsetTable/ResultsetTable.test.js +23 -41
- package/resultsetTable/types.d.ts +2 -2
- package/select/Select.js +3 -1
- package/select/Select.stories.tsx +2 -5
- package/select/Select.test.js +267 -209
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +5 -4
- package/slider/types.d.ts +4 -0
- package/switch/Switch.d.ts +3 -3
- package/switch/Switch.js +4 -3
- package/switch/types.d.ts +6 -1
- package/table/Table.js +1 -1
- package/table/Table.test.js +1 -1
- package/text-input/TextInput.js +165 -151
- package/text-input/TextInput.test.js +560 -649
- package/text-input/types.d.ts +5 -0
- package/common/RequiredComponent.js +0 -32
|
@@ -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,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;
|
package/date-input/types.d.ts
CHANGED
|
@@ -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
|
*/
|
package/dialog/types.d.ts
CHANGED
|
@@ -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
|
*/
|
package/dropdown/Dropdown.js
CHANGED
|
@@ -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
|
|
89
|
-
|
|
90
|
-
triggerId =
|
|
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
|
|
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
|
-
|
|
102
|
-
|
|
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, {
|
|
@@ -254,7 +255,8 @@ 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
261
|
opened: isOpen,
|
|
260
262
|
onClick: handleTriggerOnClick,
|
|
@@ -267,8 +269,8 @@ var DxcDropdown = function DxcDropdown(_ref) {
|
|
|
267
269
|
margin: margin,
|
|
268
270
|
size: size,
|
|
269
271
|
id: triggerId,
|
|
270
|
-
"aria-disabled": disabled,
|
|
271
272
|
"aria-haspopup": "true",
|
|
273
|
+
"aria-controls": menuId,
|
|
272
274
|
"aria-expanded": isOpen ? true : undefined,
|
|
273
275
|
tabIndex: tabIndex,
|
|
274
276
|
ref: triggerRef
|
|
@@ -292,7 +294,9 @@ var DxcDropdown = function DxcDropdown(_ref) {
|
|
|
292
294
|
visualFocusIndex: visualFocusIndex,
|
|
293
295
|
menuItemOnClick: handleMenuItemOnClick,
|
|
294
296
|
onKeyDown: handleMenuOnKeyDown,
|
|
295
|
-
styles:
|
|
297
|
+
styles: {
|
|
298
|
+
width: width
|
|
299
|
+
},
|
|
296
300
|
ref: menuRef
|
|
297
301
|
})))));
|
|
298
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(
|
|
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"
|
|
@@ -74,7 +69,6 @@ describe("Dropdown component tests", function () {
|
|
|
74
69
|
getByRole = _render.getByRole;
|
|
75
70
|
|
|
76
71
|
var dropdown = getByRole("button");
|
|
77
|
-
expect(dropdown.getAttribute("aria-disabled")).toBe("false");
|
|
78
72
|
expect(dropdown.getAttribute("aria-haspopup")).toBe("true");
|
|
79
73
|
expect(dropdown.getAttribute("aria-expanded")).toBeNull();
|
|
80
74
|
expect(dropdown.getAttribute("aria-activedescendant")).toBeNull();
|
|
@@ -82,6 +76,7 @@ describe("Dropdown component tests", function () {
|
|
|
82
76
|
_userEvent["default"].click(dropdown);
|
|
83
77
|
|
|
84
78
|
var menu = getByRole("menu");
|
|
79
|
+
expect(dropdown.getAttribute("aria-controls")).toBe(menu.id);
|
|
85
80
|
expect(dropdown.getAttribute("aria-expanded")).toBe("true");
|
|
86
81
|
expect(menu.getAttribute("aria-activedescendant")).toBe("option-0");
|
|
87
82
|
expect(menu.getAttribute("aria-orientation")).toBe("vertical");
|
|
@@ -123,7 +118,6 @@ describe("Dropdown component tests", function () {
|
|
|
123
118
|
queryByText = _render3.queryByText;
|
|
124
119
|
|
|
125
120
|
var dropdown = getByRole("button");
|
|
126
|
-
expect(dropdown.getAttribute("aria-disabled")).toBe("true");
|
|
127
121
|
expect(queryByRole("menu")).toBeFalsy();
|
|
128
122
|
|
|
129
123
|
_userEvent["default"].click(dropdown);
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
|
|
1
|
+
import React from "react";
|
|
2
2
|
import FileInputPropsType from "./types";
|
|
3
|
-
declare const DxcFileInput:
|
|
3
|
+
declare const DxcFileInput: React.ForwardRefExoticComponent<FileInputPropsType & React.RefAttributes<HTMLDivElement>>;
|
|
4
4
|
export default DxcFileInput;
|