@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.
Files changed (103) hide show
  1. package/HalstackContext.js +7 -8
  2. package/accordion/Accordion.js +122 -103
  3. package/accordion/Accordion.stories.tsx +1 -2
  4. package/accordion/Accordion.test.js +9 -10
  5. package/accordion/types.d.ts +4 -3
  6. package/accordion-group/AccordionGroup.js +1 -21
  7. package/accordion-group/AccordionGroup.stories.tsx +27 -1
  8. package/accordion-group/AccordionGroup.test.js +20 -45
  9. package/accordion-group/types.d.ts +9 -2
  10. package/alert/Alert.js +1 -1
  11. package/box/Box.js +1 -1
  12. package/box/types.d.ts +1 -0
  13. package/card/types.d.ts +1 -0
  14. package/checkbox/Checkbox.d.ts +2 -2
  15. package/checkbox/Checkbox.js +92 -99
  16. package/checkbox/Checkbox.stories.tsx +79 -59
  17. package/checkbox/Checkbox.test.js +93 -16
  18. package/checkbox/types.d.ts +6 -2
  19. package/common/variables.js +27 -19
  20. package/date-input/Calendar.d.ts +4 -0
  21. package/date-input/Calendar.js +258 -0
  22. package/date-input/DateInput.js +77 -222
  23. package/date-input/DateInput.stories.tsx +30 -17
  24. package/date-input/DateInput.test.js +411 -138
  25. package/date-input/DatePicker.d.ts +4 -0
  26. package/date-input/DatePicker.js +160 -0
  27. package/date-input/YearPicker.d.ts +4 -0
  28. package/date-input/YearPicker.js +115 -0
  29. package/date-input/types.d.ts +53 -0
  30. package/dialog/Dialog.js +4 -4
  31. package/dialog/Dialog.stories.tsx +56 -0
  32. package/dialog/types.d.ts +1 -0
  33. package/dropdown/Dropdown.js +38 -34
  34. package/dropdown/Dropdown.test.js +19 -25
  35. package/dropdown/DropdownMenuItem.js +1 -1
  36. package/file-input/FileInput.d.ts +2 -2
  37. package/file-input/FileInput.js +177 -219
  38. package/file-input/FileInput.stories.tsx +38 -10
  39. package/file-input/FileInput.test.js +53 -12
  40. package/file-input/FileItem.d.ts +4 -14
  41. package/file-input/FileItem.js +38 -63
  42. package/file-input/types.d.ts +17 -0
  43. package/flex/Flex.d.ts +1 -1
  44. package/flex/Flex.js +31 -19
  45. package/flex/types.d.ts +14 -3
  46. package/footer/Footer.stories.tsx +8 -1
  47. package/footer/types.d.ts +1 -0
  48. package/header/Header.stories.tsx +4 -4
  49. package/header/types.d.ts +1 -0
  50. package/layout/ApplicationLayout.stories.tsx +1 -0
  51. package/link/Link.js +1 -1
  52. package/number-input/NumberInput.test.js +43 -7
  53. package/package.json +14 -19
  54. package/paginator/Paginator.js +2 -2
  55. package/paginator/Paginator.test.js +1 -1
  56. package/password-input/PasswordInput.test.js +13 -12
  57. package/quick-nav/QuickNav.js +11 -12
  58. package/quick-nav/QuickNav.stories.tsx +97 -19
  59. package/radio-group/Radio.d.ts +1 -1
  60. package/radio-group/Radio.js +43 -28
  61. package/radio-group/RadioGroup.js +15 -13
  62. package/radio-group/RadioGroup.stories.tsx +1 -0
  63. package/radio-group/RadioGroup.test.js +123 -96
  64. package/radio-group/types.d.ts +2 -2
  65. package/resultsetTable/Icons.d.ts +7 -0
  66. package/resultsetTable/Icons.js +51 -0
  67. package/resultsetTable/ResultsetTable.js +48 -107
  68. package/resultsetTable/ResultsetTable.stories.tsx +50 -25
  69. package/resultsetTable/ResultsetTable.test.js +23 -41
  70. package/resultsetTable/types.d.ts +2 -2
  71. package/select/Listbox.js +0 -1
  72. package/select/Select.js +3 -1
  73. package/select/Select.stories.tsx +2 -5
  74. package/select/Select.test.js +267 -209
  75. package/slider/Slider.d.ts +2 -2
  76. package/slider/Slider.js +118 -93
  77. package/slider/Slider.stories.tsx +7 -1
  78. package/slider/Slider.test.js +87 -24
  79. package/slider/types.d.ts +6 -2
  80. package/switch/Switch.d.ts +3 -3
  81. package/switch/Switch.js +94 -83
  82. package/switch/Switch.test.js +26 -13
  83. package/switch/types.d.ts +6 -1
  84. package/table/Table.js +1 -1
  85. package/table/Table.test.js +1 -1
  86. package/tabs/Tab.d.ts +4 -0
  87. package/tabs/Tab.js +135 -0
  88. package/tabs/Tabs.js +360 -104
  89. package/tabs/Tabs.stories.tsx +74 -0
  90. package/tabs/Tabs.test.js +217 -6
  91. package/tabs/types.d.ts +14 -4
  92. package/tabs-nav/Tab.js +1 -1
  93. package/tag/Tag.js +1 -1
  94. package/text-input/Icons.d.ts +8 -0
  95. package/text-input/Icons.js +60 -0
  96. package/text-input/Suggestion.js +7 -5
  97. package/text-input/Suggestions.d.ts +4 -0
  98. package/text-input/Suggestions.js +134 -0
  99. package/text-input/TextInput.js +179 -263
  100. package/text-input/TextInput.stories.tsx +189 -181
  101. package/text-input/TextInput.test.js +639 -727
  102. package/text-input/types.d.ts +21 -2
  103. 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
  */
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\n padding: ", ";\n padding-top: ", ";\n padding-right: ", ";\n padding-bottom: ", ";\n padding-left: ", ";\n"])), function (props) {
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: relative;\n top: 20px;\n right: 20px;\n color: ", ";\n width: ", ";\n height: ", ";\n"])), function (props) {
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
  */
@@ -63,6 +63,28 @@ var downArrowIcon = /*#__PURE__*/_react["default"].createElement("svg", {
63
63
  fill: "none"
64
64
  }));
65
65
 
66
+ var useWidth = function useWidth(target) {
67
+ var _useState = (0, _react.useState)(0),
68
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
69
+ width = _useState2[0],
70
+ setWidth = _useState2[1];
71
+
72
+ (0, _react.useEffect)(function () {
73
+ if (target != null) {
74
+ setWidth(target.getBoundingClientRect().width);
75
+ var triggerObserver = new ResizeObserver(function (entries) {
76
+ var rect = entries[0].target.getBoundingClientRect();
77
+ setWidth(rect === null || rect === void 0 ? void 0 : rect.width);
78
+ });
79
+ triggerObserver.observe(target);
80
+ return function () {
81
+ triggerObserver.unobserve(target);
82
+ };
83
+ }
84
+ }, [target]);
85
+ return width;
86
+ };
87
+
66
88
  var DxcDropdown = function DxcDropdown(_ref) {
67
89
  var options = _ref.options,
68
90
  _ref$optionsIconPosit = _ref.optionsIconPosition,
@@ -85,21 +107,16 @@ var DxcDropdown = function DxcDropdown(_ref) {
85
107
  _ref$tabIndex = _ref.tabIndex,
86
108
  tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
87
109
 
88
- var _useState = (0, _react.useState)("trigger-".concat((0, _uuid.v4)())),
89
- _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
90
- triggerId = _useState2[0];
110
+ var _useState3 = (0, _react.useState)("trigger-".concat((0, _uuid.v4)())),
111
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 1),
112
+ triggerId = _useState4[0];
91
113
 
92
114
  var menuId = "menu-".concat(triggerId);
93
115
 
94
- var _useState3 = (0, _react.useState)(false),
95
- _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
96
- isOpen = _useState4[0],
97
- changeIsOpen = _useState4[1];
98
-
99
- var _useState5 = (0, _react.useState)(null),
116
+ var _useState5 = (0, _react.useState)(false),
100
117
  _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
101
- menuStyles = _useState6[0],
102
- setMenuStyles = _useState6[1];
118
+ isOpen = _useState6[0],
119
+ changeIsOpen = _useState6[1];
103
120
 
104
121
  var _useState7 = (0, _react.useState)(0),
105
122
  _useState8 = (0, _slicedToArray2["default"])(_useState7, 2),
@@ -109,6 +126,7 @@ var DxcDropdown = function DxcDropdown(_ref) {
109
126
  var colorsTheme = (0, _useTheme["default"])();
110
127
  var triggerRef = (0, _react.useRef)(null);
111
128
  var menuRef = (0, _react.useRef)(null);
129
+ var width = useWidth(triggerRef.current);
112
130
 
113
131
  var handleOnOpenMenu = function handleOnOpenMenu() {
114
132
  changeIsOpen(true);
@@ -146,7 +164,7 @@ var DxcDropdown = function DxcDropdown(_ref) {
146
164
  handleOnOpenMenu();
147
165
  break;
148
166
 
149
- case "Space":
167
+ case " ":
150
168
  case "Down":
151
169
  case "ArrowDown":
152
170
  case "Enter":
@@ -186,7 +204,7 @@ var DxcDropdown = function DxcDropdown(_ref) {
186
204
  setNextIndexFocus();
187
205
  break;
188
206
 
189
- case "Space":
207
+ case " ":
190
208
  case "Enter":
191
209
  event.preventDefault();
192
210
  handleMenuItemOnClick(options[visualFocusIndex].value);
@@ -226,23 +244,6 @@ var DxcDropdown = function DxcDropdown(_ref) {
226
244
  inline: "start"
227
245
  });
228
246
  }, [visualFocusIndex]);
229
-
230
- var handleMenuResize = function handleMenuResize() {
231
- var _triggerRef$current4;
232
-
233
- var rect = triggerRef === null || triggerRef === void 0 ? void 0 : (_triggerRef$current4 = triggerRef.current) === null || _triggerRef$current4 === void 0 ? void 0 : _triggerRef$current4.getBoundingClientRect();
234
- setMenuStyles({
235
- width: rect === null || rect === void 0 ? void 0 : rect.width
236
- });
237
- };
238
-
239
- (0, _react.useEffect)(function () {
240
- handleMenuResize();
241
- window.addEventListener("resize", handleMenuResize);
242
- return function () {
243
- window.removeEventListener("resize", handleMenuResize);
244
- };
245
- }, []);
246
247
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
247
248
  theme: colorsTheme.dropdown
248
249
  }, /*#__PURE__*/_react["default"].createElement(DropdownContainer, {
@@ -254,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: menuStyles,
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: "unset"
309
+ fitContent: "fit-content"
306
310
  };
307
311
 
308
312
  var calculateWidth = function calculateWidth(margin, size) {