@dxc-technology/halstack-react 0.0.0-f53e801 → 0.0.0-f54247d
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/Accordion.js +122 -103
- package/accordion/Accordion.stories.tsx +1 -2
- package/accordion/Accordion.test.js +9 -10
- package/accordion/types.d.ts +4 -3
- package/accordion-group/AccordionGroup.js +1 -21
- package/accordion-group/AccordionGroup.stories.tsx +27 -1
- package/accordion-group/AccordionGroup.test.js +20 -45
- package/accordion-group/types.d.ts +9 -2
- package/alert/Alert.js +1 -1
- package/box/Box.js +1 -1
- 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 +92 -99
- package/checkbox/Checkbox.stories.tsx +79 -59
- package/checkbox/Checkbox.test.js +93 -16
- package/checkbox/types.d.ts +6 -2
- package/common/variables.js +27 -19
- 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/Dialog.js +4 -4
- package/dialog/Dialog.stories.tsx +56 -0
- package/dialog/types.d.ts +1 -0
- package/dropdown/Dropdown.js +38 -34
- package/dropdown/Dropdown.test.js +19 -25
- package/dropdown/DropdownMenuItem.js +1 -1
- 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/Footer.stories.tsx +8 -1
- package/footer/types.d.ts +1 -0
- package/header/Header.stories.tsx +4 -4
- package/header/types.d.ts +1 -0
- package/layout/ApplicationLayout.stories.tsx +1 -0
- package/link/Link.js +1 -1
- package/number-input/NumberInput.test.js +43 -7
- package/package.json +14 -19
- 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/Radio.d.ts +1 -1
- package/radio-group/Radio.js +43 -28
- package/radio-group/RadioGroup.js +15 -13
- package/radio-group/RadioGroup.stories.tsx +1 -0
- package/radio-group/RadioGroup.test.js +123 -96
- package/radio-group/types.d.ts +2 -2
- 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/Listbox.js +0 -1
- 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 +118 -93
- package/slider/Slider.stories.tsx +7 -1
- package/slider/Slider.test.js +87 -24
- package/slider/types.d.ts +6 -2
- package/switch/Switch.d.ts +3 -3
- package/switch/Switch.js +94 -83
- package/switch/Switch.test.js +26 -13
- package/switch/types.d.ts +6 -1
- package/table/Table.js +1 -1
- package/table/Table.test.js +1 -1
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +135 -0
- package/tabs/Tabs.js +360 -104
- package/tabs/Tabs.stories.tsx +74 -0
- package/tabs/Tabs.test.js +217 -6
- package/tabs/types.d.ts +14 -4
- package/tabs-nav/Tab.js +1 -1
- package/tag/Tag.js +1 -1
- package/text-input/Icons.d.ts +8 -0
- package/text-input/Icons.js +60 -0
- package/text-input/Suggestion.js +7 -5
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +134 -0
- package/text-input/TextInput.js +179 -263
- package/text-input/TextInput.stories.tsx +189 -181
- package/text-input/TextInput.test.js +639 -727
- package/text-input/types.d.ts +21 -2
- 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/Dialog.js
CHANGED
|
@@ -108,7 +108,7 @@ var Overlay = _styledComponents["default"].div(_templateObject3 || (_templateObj
|
|
|
108
108
|
return props.theme.overlayOpacity;
|
|
109
109
|
});
|
|
110
110
|
|
|
111
|
-
var Dialog = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n z-index: 1300;\n background-color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n ", "\n box-sizing: border-box;\n box-shadow: ", ";\n border-radius: 4px;\n\n @media (min-width: ", "rem) {\n max-width: 80%;\n min-width: 800px;\n }\n\n @media (max-width: ", "rem) {\n //mobile phones\n max-width: 92%;\n min-width: 92%;\n }\n"])), function (props) {
|
|
111
|
+
var Dialog = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n z-index: 1300;\n background-color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n ", "\n box-sizing: border-box;\n box-shadow: ", ";\n border-radius: 4px;\n position: relative;\n\n @media (min-width: ", "rem) {\n max-width: 80%;\n min-width: 800px;\n }\n\n @media (max-width: ", "rem) {\n //mobile phones\n max-width: 92%;\n min-width: 92%;\n }\n"])), function (props) {
|
|
112
112
|
return props.theme.backgroundColor;
|
|
113
113
|
}, function (props) {
|
|
114
114
|
return props.theme.fontFamily;
|
|
@@ -117,12 +117,12 @@ var Dialog = _styledComponents["default"].div(_templateObject4 || (_templateObje
|
|
|
117
117
|
}, function (props) {
|
|
118
118
|
return props.theme.fontWeight;
|
|
119
119
|
}, function (props) {
|
|
120
|
-
return props.isCloseVisible && "min-height: 72px;";
|
|
120
|
+
return props.isCloseVisible && "min-height: 72px; padding-top: 24px;";
|
|
121
121
|
}, function (props) {
|
|
122
122
|
return "".concat(props.theme.boxShadowOffsetX, " ").concat(props.theme.boxShadowOffsetY, " ").concat(props.theme.boxShadowBlur, " ").concat(props.theme.boxShadowColor);
|
|
123
123
|
}, _variables.responsiveSizes.medium, _variables.responsiveSizes.medium);
|
|
124
124
|
|
|
125
|
-
var Children = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n
|
|
125
|
+
var Children = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n width: 100%;\n padding: ", ";\n padding-top: ", ";\n padding-right: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n"])), function (props) {
|
|
126
126
|
return props.padding && (0, _typeof2["default"])(props.padding) !== "object" ? _variables.spaces[props.padding] : _variables.spaces["small"];
|
|
127
127
|
}, function (props) {
|
|
128
128
|
return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.top ? _variables.spaces[props.padding.top] : "";
|
|
@@ -134,7 +134,7 @@ var Children = _styledComponents["default"].div(_templateObject5 || (_templateOb
|
|
|
134
134
|
return props.padding && (0, _typeof2["default"])(props.padding) === "object" && props.padding.left ? _variables.spaces[props.padding.left] : "";
|
|
135
135
|
});
|
|
136
136
|
|
|
137
|
-
var CloseIconContainer = _styledComponents["default"].button(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n cursor: pointer;\n padding: 0;\n margin: 0;\n background: none;\n border: none;\n position:
|
|
137
|
+
var CloseIconContainer = _styledComponents["default"].button(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n cursor: pointer;\n padding: 0;\n margin: 0;\n background: none;\n border: none;\n position: absolute;\n top: 20px;\n right: 20px;\n color: ", ";\n width: ", ";\n height: ", ";\n"])), function (props) {
|
|
138
138
|
return props.theme.closeIconColor;
|
|
139
139
|
}, function (props) {
|
|
140
140
|
return props.theme.closeIconWidth;
|
|
@@ -1,5 +1,9 @@
|
|
|
1
1
|
import React from "react";
|
|
2
2
|
import DxcDialog from "./Dialog";
|
|
3
|
+
import DxcTextInput from "../text-input/TextInput";
|
|
4
|
+
import DxcButton from "../button/Button";
|
|
5
|
+
import DxcFlex from "../flex/Flex";
|
|
6
|
+
import DxcInset from "../inset/Inset";
|
|
3
7
|
import Title from "../../.storybook/components/Title";
|
|
4
8
|
import ExampleContainer from "../../.storybook/components/ExampleContainer";
|
|
5
9
|
|
|
@@ -30,6 +34,50 @@ export const DefaultDialog = () => (
|
|
|
30
34
|
</>
|
|
31
35
|
);
|
|
32
36
|
|
|
37
|
+
export const DialogWithInputs = () => (
|
|
38
|
+
<>
|
|
39
|
+
<ExampleContainer expanded={true}>
|
|
40
|
+
<Title title="Dialog with inputs" theme="light" level={4} />
|
|
41
|
+
<DxcDialog>
|
|
42
|
+
<DxcInset bottom="1rem">
|
|
43
|
+
<DxcFlex gap="2rem" direction="column">
|
|
44
|
+
<DxcFlex gap="1rem" direction="column">
|
|
45
|
+
<DxcTextInput size="fillParent" label="Name"></DxcTextInput>
|
|
46
|
+
<DxcTextInput size="fillParent" label="Surname"></DxcTextInput>
|
|
47
|
+
</DxcFlex>
|
|
48
|
+
<DxcFlex justifyContent="flex-end" gap="1rem">
|
|
49
|
+
<DxcButton label="Save"></DxcButton>
|
|
50
|
+
<DxcButton label="Cancel" mode="secondary"></DxcButton>
|
|
51
|
+
</DxcFlex>
|
|
52
|
+
</DxcFlex>
|
|
53
|
+
</DxcInset>
|
|
54
|
+
</DxcDialog>
|
|
55
|
+
</ExampleContainer>
|
|
56
|
+
</>
|
|
57
|
+
);
|
|
58
|
+
|
|
59
|
+
const RespDialog = () => (
|
|
60
|
+
<>
|
|
61
|
+
<ExampleContainer expanded={true}>
|
|
62
|
+
<Title title="Responsive dialog" theme="light" level={4} />
|
|
63
|
+
<DxcDialog>
|
|
64
|
+
<DxcInset bottom="1rem">
|
|
65
|
+
<DxcFlex gap="2rem" direction="column">
|
|
66
|
+
<DxcFlex gap="1rem" direction="column">
|
|
67
|
+
<DxcTextInput size="fillParent" label="Name"></DxcTextInput>
|
|
68
|
+
<DxcTextInput size="fillParent" label="Surname"></DxcTextInput>
|
|
69
|
+
</DxcFlex>
|
|
70
|
+
<DxcFlex justifyContent="flex-end" gap="1rem">
|
|
71
|
+
<DxcButton label="Save"></DxcButton>
|
|
72
|
+
<DxcButton label="Cancel" mode="secondary"></DxcButton>
|
|
73
|
+
</DxcFlex>
|
|
74
|
+
</DxcFlex>
|
|
75
|
+
</DxcInset>
|
|
76
|
+
</DxcDialog>
|
|
77
|
+
</ExampleContainer>
|
|
78
|
+
</>
|
|
79
|
+
);
|
|
80
|
+
|
|
33
81
|
export const DialogWithoutOverlay = () => (
|
|
34
82
|
<ExampleContainer expanded={true}>
|
|
35
83
|
<Title title="Dialog Without Overlay" theme="light" level={4} />
|
|
@@ -209,3 +257,11 @@ export const DialogWithXxlargePadding = () => (
|
|
|
209
257
|
</DxcDialog>
|
|
210
258
|
</ExampleContainer>
|
|
211
259
|
);
|
|
260
|
+
|
|
261
|
+
export const ResponsiveDialog = RespDialog.bind({});
|
|
262
|
+
ResponsiveDialog.parameters = {
|
|
263
|
+
viewport: {
|
|
264
|
+
defaultViewport: "iphonex",
|
|
265
|
+
},
|
|
266
|
+
chromatic: { viewports: [375] },
|
|
267
|
+
};
|
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);
|
|
@@ -146,7 +164,7 @@ var DxcDropdown = function DxcDropdown(_ref) {
|
|
|
146
164
|
handleOnOpenMenu();
|
|
147
165
|
break;
|
|
148
166
|
|
|
149
|
-
case "
|
|
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 "
|
|
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,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
|
};
|
|
@@ -302,7 +306,7 @@ var sizes = {
|
|
|
302
306
|
medium: "240px",
|
|
303
307
|
large: "480px",
|
|
304
308
|
fillParent: "100%",
|
|
305
|
-
fitContent: "
|
|
309
|
+
fitContent: "fit-content"
|
|
306
310
|
};
|
|
307
311
|
|
|
308
312
|
var calculateWidth = function calculateWidth(margin, size) {
|