@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.
Files changed (66) hide show
  1. package/HalstackContext.js +7 -8
  2. package/accordion/types.d.ts +1 -0
  3. package/accordion-group/types.d.ts +1 -0
  4. package/box/types.d.ts +1 -0
  5. package/card/types.d.ts +1 -0
  6. package/checkbox/Checkbox.d.ts +2 -2
  7. package/checkbox/Checkbox.js +16 -15
  8. package/checkbox/Checkbox.stories.tsx +79 -59
  9. package/checkbox/types.d.ts +4 -0
  10. package/common/variables.js +19 -15
  11. package/date-input/Calendar.d.ts +4 -0
  12. package/date-input/Calendar.js +258 -0
  13. package/date-input/DateInput.js +77 -222
  14. package/date-input/DateInput.stories.tsx +30 -17
  15. package/date-input/DateInput.test.js +411 -138
  16. package/date-input/DatePicker.d.ts +4 -0
  17. package/date-input/DatePicker.js +160 -0
  18. package/date-input/YearPicker.d.ts +4 -0
  19. package/date-input/YearPicker.js +115 -0
  20. package/date-input/types.d.ts +53 -0
  21. package/dialog/types.d.ts +1 -0
  22. package/dropdown/Dropdown.js +35 -31
  23. package/dropdown/Dropdown.test.js +18 -24
  24. package/file-input/FileInput.d.ts +2 -2
  25. package/file-input/FileInput.js +177 -219
  26. package/file-input/FileInput.stories.tsx +38 -10
  27. package/file-input/FileInput.test.js +53 -12
  28. package/file-input/FileItem.d.ts +4 -14
  29. package/file-input/FileItem.js +38 -63
  30. package/file-input/types.d.ts +17 -0
  31. package/flex/Flex.d.ts +1 -1
  32. package/flex/Flex.js +31 -19
  33. package/flex/types.d.ts +14 -3
  34. package/footer/types.d.ts +1 -0
  35. package/header/types.d.ts +1 -0
  36. package/link/Link.js +1 -1
  37. package/number-input/NumberInput.test.js +43 -7
  38. package/package.json +7 -12
  39. package/paginator/Paginator.js +2 -2
  40. package/paginator/Paginator.test.js +1 -1
  41. package/password-input/PasswordInput.test.js +13 -12
  42. package/quick-nav/QuickNav.js +11 -12
  43. package/quick-nav/QuickNav.stories.tsx +97 -19
  44. package/radio-group/RadioGroup.js +9 -5
  45. package/radio-group/RadioGroup.test.js +116 -59
  46. package/resultsetTable/Icons.d.ts +7 -0
  47. package/resultsetTable/Icons.js +51 -0
  48. package/resultsetTable/ResultsetTable.js +48 -107
  49. package/resultsetTable/ResultsetTable.stories.tsx +50 -25
  50. package/resultsetTable/ResultsetTable.test.js +23 -41
  51. package/resultsetTable/types.d.ts +2 -2
  52. package/select/Select.js +3 -1
  53. package/select/Select.stories.tsx +2 -5
  54. package/select/Select.test.js +267 -209
  55. package/slider/Slider.d.ts +2 -2
  56. package/slider/Slider.js +5 -4
  57. package/slider/types.d.ts +4 -0
  58. package/switch/Switch.d.ts +3 -3
  59. package/switch/Switch.js +4 -3
  60. package/switch/types.d.ts +6 -1
  61. package/table/Table.js +1 -1
  62. package/table/Table.test.js +1 -1
  63. package/text-input/TextInput.js +165 -151
  64. package/text-input/TextInput.test.js +560 -649
  65. package/text-input/types.d.ts +5 -0
  66. package/common/RequiredComponent.js +0 -32
@@ -27,17 +27,21 @@ var _Paginator = _interopRequireDefault(require("../paginator/Paginator"));
27
27
 
28
28
  var _useTheme = _interopRequireDefault(require("../useTheme"));
29
29
 
30
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9;
30
+ var _Icons = _interopRequireDefault(require("./Icons"));
31
+
32
+ var _utils = require("../common/utils.js");
33
+
34
+ var _templateObject, _templateObject2, _templateObject3;
31
35
 
32
36
  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); }
33
37
 
34
38
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(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; }
35
39
 
36
- function normalizeSortValue(sortValue) {
40
+ var normalizeSortValue = function normalizeSortValue(sortValue) {
37
41
  return typeof sortValue === "string" ? sortValue.toUpperCase() : sortValue;
38
- }
42
+ };
39
43
 
40
- function sortArray(index, order, resultset) {
44
+ var sortArray = function sortArray(index, order, resultset) {
41
45
  return resultset.slice().sort(function (element1, element2) {
42
46
  var sortValueA = normalizeSortValue(element1[index].sortValue || element1[index].displayValue);
43
47
  var sortValueB = normalizeSortValue(element2[index].sortValue || element2[index].displayValue);
@@ -53,9 +57,9 @@ function sortArray(index, order, resultset) {
53
57
  comparison = -1;
54
58
  }
55
59
 
56
- return order === "desc" ? comparison * -1 : comparison;
60
+ return order === "descending" ? comparison * -1 : comparison;
57
61
  });
58
- }
62
+ };
59
63
 
60
64
  var getMinItemsPerPageIndex = function getMinItemsPerPageIndex(currentPageInternal, itemsPerPage, page) {
61
65
  return currentPageInternal === 1 ? 0 : itemsPerPage * (page - 1);
@@ -65,51 +69,6 @@ var getMaxItemsPerPageIndex = function getMaxItemsPerPageIndex(minItemsPerPageIn
65
69
  return minItemsPerPageIndex + itemsPerPage > resultset.length ? resultset.length : itemsPerPage * page - 1;
66
70
  };
67
71
 
68
- var ArrowUp = function ArrowUp() {
69
- return /*#__PURE__*/_react["default"].createElement("svg", {
70
- xmlns: "http://www.w3.org/2000/svg",
71
- height: "24",
72
- viewBox: "0 0 24 24",
73
- width: "24",
74
- fill: "currentColor"
75
- }, /*#__PURE__*/_react["default"].createElement("path", {
76
- d: "M0 0h24v24H0V0z",
77
- fill: "none"
78
- }), /*#__PURE__*/_react["default"].createElement("path", {
79
- d: "M4 12l1.41 1.41L11 7.83V20h2V7.83l5.58 5.59L20 12l-8-8-8 8z"
80
- }));
81
- };
82
-
83
- var ArrowDown = function ArrowDown() {
84
- return /*#__PURE__*/_react["default"].createElement("svg", {
85
- xmlns: "http://www.w3.org/2000/svg",
86
- height: "24",
87
- viewBox: "0 0 24 24",
88
- width: "24",
89
- fill: "currentColor"
90
- }, /*#__PURE__*/_react["default"].createElement("path", {
91
- d: "M0 0h24v24H0V0z",
92
- fill: "none"
93
- }), /*#__PURE__*/_react["default"].createElement("path", {
94
- d: "M20 12l-1.41-1.41L13 16.17V4h-2v12.17l-5.58-5.59L4 12l8 8 8-8z"
95
- }));
96
- };
97
-
98
- var BothArrows = function BothArrows() {
99
- return /*#__PURE__*/_react["default"].createElement("svg", {
100
- xmlns: "http://www.w3.org/2000/svg",
101
- height: "24",
102
- viewBox: "0 0 24 24",
103
- width: "24",
104
- fill: "currentColor"
105
- }, /*#__PURE__*/_react["default"].createElement("path", {
106
- d: "M0 0h24v24H0z",
107
- fill: "none"
108
- }), /*#__PURE__*/_react["default"].createElement("path", {
109
- d: "M12 5.83L15.17 9l1.41-1.41L12 3 7.41 7.59 8.83 9 12 5.83zm0 12.34L8.83 15l-1.41 1.41L12 21l4.59-4.59L15.17 15 12 18.17z"
110
- }));
111
- };
112
-
113
72
  var DxcResultsetTable = function DxcResultsetTable(_ref) {
114
73
  var columns = _ref.columns,
115
74
  rows = _ref.rows,
@@ -129,12 +88,12 @@ var DxcResultsetTable = function DxcResultsetTable(_ref) {
129
88
  page = _useState2[0],
130
89
  changePage = _useState2[1];
131
90
 
132
- var _useState3 = (0, _react.useState)(""),
91
+ var _useState3 = (0, _react.useState)(-1),
133
92
  _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
134
93
  sortColumnIndex = _useState4[0],
135
94
  changeSortColumnIndex = _useState4[1];
136
95
 
137
- var _useState5 = (0, _react.useState)("asc"),
96
+ var _useState5 = (0, _react.useState)("ascending"),
138
97
  _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
139
98
  sortOrder = _useState6[0],
140
99
  changeSortOrder = _useState6[1];
@@ -145,6 +104,12 @@ var DxcResultsetTable = function DxcResultsetTable(_ref) {
145
104
  var maxItemsPerPageIndex = (0, _react.useMemo)(function () {
146
105
  return getMaxItemsPerPageIndex(minItemsPerPageIndex, itemsPerPage, rows, page);
147
106
  }, [itemsPerPage, minItemsPerPageIndex, page, rows]);
107
+ var sortedResultset = (0, _react.useMemo)(function () {
108
+ return sortColumnIndex !== -1 ? sortArray(sortColumnIndex, sortOrder, rows) : rows;
109
+ }, [sortColumnIndex, sortOrder, rows]);
110
+ var filteredResultset = (0, _react.useMemo)(function () {
111
+ return sortedResultset && sortedResultset.slice(minItemsPerPageIndex, maxItemsPerPageIndex + 1);
112
+ }, [sortedResultset, minItemsPerPageIndex, maxItemsPerPageIndex]);
148
113
 
149
114
  var goToPage = function goToPage(newPage) {
150
115
  changePage(newPage);
@@ -153,44 +118,30 @@ var DxcResultsetTable = function DxcResultsetTable(_ref) {
153
118
  var changeSorting = function changeSorting(columnIndex) {
154
119
  changePage(1);
155
120
  changeSortColumnIndex(columnIndex);
156
- changeSortOrder(sortColumnIndex === "" || sortColumnIndex !== columnIndex ? "asc" : sortOrder === "asc" ? "desc" : "asc");
157
- };
158
-
159
- var getIconForSortableColumn = function getIconForSortableColumn(clickedColumnIndex) {
160
- return sortColumnIndex === clickedColumnIndex ? sortOrder === "asc" ? /*#__PURE__*/_react["default"].createElement(ArrowUp, null) : /*#__PURE__*/_react["default"].createElement(ArrowDown, null) : /*#__PURE__*/_react["default"].createElement(BothArrows, null);
121
+ changeSortOrder(sortColumnIndex === -1 || sortColumnIndex !== columnIndex ? "ascending" : sortOrder === "ascending" ? "descending" : "ascending");
161
122
  };
162
123
 
163
124
  (0, _react.useEffect)(function () {
164
- if (rows.length > 0) {
165
- changePage(1);
166
- } else {
167
- changePage(0);
168
- }
169
- }, [rows.length, itemsPerPage]);
170
- var sortedResultset = (0, _react.useMemo)(function () {
171
- return sortColumnIndex !== "" ? sortArray(sortColumnIndex, sortOrder, rows) : rows;
172
- }, [sortColumnIndex, sortOrder, rows]);
173
- var filteredResultset = (0, _react.useMemo)(function () {
174
- return sortedResultset && sortedResultset.slice(minItemsPerPageIndex, maxItemsPerPageIndex + 1);
175
- }, [sortedResultset, minItemsPerPageIndex, maxItemsPerPageIndex]);
125
+ rows.length > 0 ? changePage(1) : changePage(0);
126
+ }, [rows]);
176
127
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
177
128
  theme: colorsTheme.table
178
129
  }, /*#__PURE__*/_react["default"].createElement(DxcResultsetTableContainer, {
179
130
  margin: margin
180
- }, /*#__PURE__*/_react["default"].createElement(TableContainer, null, /*#__PURE__*/_react["default"].createElement(_Table["default"], null, /*#__PURE__*/_react["default"].createElement(HeaderRow, null, /*#__PURE__*/_react["default"].createElement("tr", null, columns.map(function (column, index) {
181
- return /*#__PURE__*/_react["default"].createElement(TableHeader, {
182
- key: "tableHeader_".concat(index)
131
+ }, /*#__PURE__*/_react["default"].createElement(_Table["default"], null, /*#__PURE__*/_react["default"].createElement("thead", null, /*#__PURE__*/_react["default"].createElement("tr", null, columns.map(function (column, index) {
132
+ return /*#__PURE__*/_react["default"].createElement("th", {
133
+ key: "tableHeader_".concat(index),
134
+ "aria-sort": column.isSortable ? sortColumnIndex === index ? sortOrder : "none" : undefined
183
135
  }, /*#__PURE__*/_react["default"].createElement(HeaderContainer, {
136
+ role: column.isSortable ? "button" : undefined,
184
137
  key: "headerContainer_".concat(index),
185
138
  onClick: function onClick() {
186
- return column.isSortable && changeSorting(index);
139
+ column.isSortable && changeSorting(index);
187
140
  },
188
141
  tabIndex: column.isSortable ? tabIndex : -1,
189
142
  isSortable: column.isSortable
190
- }, /*#__PURE__*/_react["default"].createElement(TitleDiv, {
191
- isSortable: column.isSortable
192
- }, column.displayValue), column.isSortable && /*#__PURE__*/_react["default"].createElement(SortIcon, null, getIconForSortableColumn(index))));
193
- }))), /*#__PURE__*/_react["default"].createElement(TableRowGroup, null, filteredResultset.map(function (cells, index) {
143
+ }, /*#__PURE__*/_react["default"].createElement("span", null, column.displayValue), column.isSortable && /*#__PURE__*/_react["default"].createElement(SortIcon, null, sortColumnIndex === index ? sortOrder === "ascending" ? _Icons["default"].arrowUp : _Icons["default"].arrowDown : _Icons["default"].bothArrows)));
144
+ }))), /*#__PURE__*/_react["default"].createElement("tbody", null, filteredResultset.map(function (cells, index) {
194
145
  return /*#__PURE__*/_react["default"].createElement("tr", {
195
146
  key: "resultSetTableCell_".concat(index)
196
147
  }, cells.map(function (cellContent, index) {
@@ -198,7 +149,7 @@ var DxcResultsetTable = function DxcResultsetTable(_ref) {
198
149
  key: "resultSetTableCellContent_".concat(index)
199
150
  }, cellContent.displayValue);
200
151
  }));
201
- })))), /*#__PURE__*/_react["default"].createElement(PaginatorContainer, null, /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
152
+ }))), /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
202
153
  totalItems: rows.length,
203
154
  itemsPerPage: itemsPerPage,
204
155
  itemsPerPageOptions: itemsPerPageOptions,
@@ -207,37 +158,15 @@ var DxcResultsetTable = function DxcResultsetTable(_ref) {
207
158
  showGoToPage: showGoToPage,
208
159
  onPageChange: goToPage,
209
160
  tabIndex: tabIndex
210
- }))));
161
+ })));
211
162
  };
212
163
 
213
- var TableContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n & table {\n table-layout: auto;\n }\n"])));
214
-
215
- var PaginatorContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])([""])));
216
-
217
- var TableRowGroup = _styledComponents["default"].tbody(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n > div:nth-child(1) {\n position: absolute;\n left: calc(50% - 68.5px);\n bottom: calc(50% - 68.5px - 30px);\n }\n & tr {\n height: ", ";\n }\n"])), function (props) {
218
- return props.theme.rowHeight || "70px";
219
- });
220
-
221
- var SortIcon = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n top: 409px;\n left: 390px;\n height: 14px;\n cursor: pointer;\n color: ", ";\n\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
222
- return props.theme.sortIconColor;
223
- });
224
-
225
- var TitleDiv = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n cursor: ", ";\n"])), function (props) {
226
- return props.isSortable && "pointer" || "default";
227
- });
228
-
229
- var TableHeader = _styledComponents["default"].th(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])([""])));
230
-
231
- var HeaderContainer = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: ", ";\n width: fit-content;\n :focus {\n ", "\n }\n"])), function (props) {
232
- return props.theme.headerTextAlign === "center" ? "center" : props.theme.headerTextAlign === "right" ? "flex-end" : "flex-start";
233
- }, function (props) {
234
- return props.isSortable && "outline: #0095ff solid 2px; \n outline-offset: 4px;";
235
- });
236
-
237
- var HeaderRow = _styledComponents["default"].thead(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n height: 60px;\n"])));
164
+ var calculateWidth = function calculateWidth(margin) {
165
+ return "calc(100% - ".concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
166
+ };
238
167
 
239
- var DxcResultsetTableContainer = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n font-size: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"])), function (props) {
240
- return props.theme.fontSizeBase;
168
+ var DxcResultsetTableContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"])), function (props) {
169
+ return calculateWidth(props.margin);
241
170
  }, function (props) {
242
171
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
243
172
  }, function (props) {
@@ -250,5 +179,17 @@ var DxcResultsetTableContainer = _styledComponents["default"].div(_templateObjec
250
179
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
251
180
  });
252
181
 
182
+ var HeaderContainer = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: ", ";\n gap: 8px;\n width: fit-content;\n border: 1px solid transparent;\n border-radius: 2px;\n padding: 3px;\n cursor: ", ";\n\n ", "\n"])), function (props) {
183
+ return props.theme.headerTextAlign === "center" ? "center" : props.theme.headerTextAlign === "right" ? "flex-end" : "flex-start";
184
+ }, function (props) {
185
+ return props.isSortable ? "pointer" : "default";
186
+ }, function (props) {
187
+ return props.isSortable && "&:focus {\n outline: #0095ff solid 2px;\n }";
188
+ });
189
+
190
+ var SortIcon = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n height: 14px;\n width: 14px;\n color: ", ";\n\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
191
+ return props.theme.sortIconColor;
192
+ });
193
+
253
194
  var _default = DxcResultsetTable;
254
195
  exports["default"] = _default;
@@ -4,6 +4,7 @@ import DxcButton from "../button/Button";
4
4
  import Title from "../../.storybook/components/Title";
5
5
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
6
  import { userEvent, within } from "@storybook/testing-library";
7
+ import styled from "styled-components";
7
8
 
8
9
  export default {
9
10
  title: "Resultset Table",
@@ -48,6 +49,24 @@ const columnsSortable = [
48
49
  { displayValue: "City", isSortable: false },
49
50
  ];
50
51
 
52
+ const longValues = [
53
+ [
54
+ { displayValue: "000000000000000001", sortValue: "000000000000000001" },
55
+ { displayValue: "Peter Larsson González", sortValue: "Peter" },
56
+ { displayValue: "Miami: The city that never sleeps", sortValue: "Miami" },
57
+ ],
58
+ [
59
+ { displayValue: "002", sortValue: "002" },
60
+ { displayValue: "Louis", sortValue: "Louis" },
61
+ { displayValue: "London", sortValue: "London" },
62
+ ],
63
+ [
64
+ { displayValue: "003", sortValue: "003" },
65
+ { displayValue: "Aida", sortValue: "Aida" },
66
+ { displayValue: "Wroclaw", sortValue: "Wroclaw" },
67
+ ],
68
+ ];
69
+
51
70
  const rowsSortable = [
52
71
  [
53
72
  { displayValue: "001", sortValue: "001" },
@@ -167,89 +186,95 @@ export const Chromatic = () => (
167
186
  <>
168
187
  <ExampleContainer>
169
188
  <Title title="Sortable table" theme="light" level={4} />
170
- <DxcResultsetTable columns={columnsSortable} rows={rowsSortable}></DxcResultsetTable>
189
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
171
190
  </ExampleContainer>
172
191
  <ExampleContainer>
173
192
  <Title title="With action" theme="light" level={4} />
174
- <DxcResultsetTable columns={columns} rows={rowsIcon}></DxcResultsetTable>
193
+ <DxcResultsetTable columns={columns} rows={rowsIcon} />
175
194
  </ExampleContainer>
176
195
  <ExampleContainer>
177
196
  <Title title="With items per page option" theme="light" level={4} />
178
- <DxcResultsetTable
179
- columns={columns}
180
- rows={rows}
181
- itemsPerPage={2}
182
- itemsPerPageOptions={[2, 3]}
183
- ></DxcResultsetTable>
197
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} itemsPerPageOptions={[2, 3]} />
184
198
  </ExampleContainer>
185
199
  <ExampleContainer>
186
200
  <Title title="Scroll resultset table" theme="light" level={4} />
187
- <DxcResultsetTable columns={longColumns} rows={longRows}></DxcResultsetTable>
201
+ <DxcResultsetTable columns={longColumns} rows={longRows} />
202
+ </ExampleContainer>
203
+ <ExampleContainer>
204
+ <SmallContainer>
205
+ <Title title="Small container and text overflow" theme="light" level={4} />
206
+ <DxcResultsetTable columns={columnsSortable} rows={longValues} />
207
+ </SmallContainer>
188
208
  </ExampleContainer>
189
209
  <Title title="Margins" theme="light" level={2} />
190
210
  <ExampleContainer>
191
211
  <Title title="Xxsmall" theme="light" level={4} />
192
- <DxcResultsetTable columns={columns} rows={rows} margin={"xxsmall"}></DxcResultsetTable>
212
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xxsmall"} />
193
213
  </ExampleContainer>
194
214
  <ExampleContainer>
195
215
  <Title title="Xsmall" theme="light" level={4} />
196
- <DxcResultsetTable columns={columns} rows={rows} margin={"xsmall"}></DxcResultsetTable>
216
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xsmall"} />
197
217
  </ExampleContainer>
198
218
  <ExampleContainer>
199
219
  <Title title="Small" theme="light" level={4} />
200
- <DxcResultsetTable columns={columns} rows={rows} margin={"small"}></DxcResultsetTable>
220
+ <DxcResultsetTable columns={columns} rows={rows} margin={"small"} />
201
221
  </ExampleContainer>
202
222
  <ExampleContainer>
203
223
  <Title title="Medium" theme="light" level={4} />
204
- <DxcResultsetTable columns={columns} rows={rows} margin={"medium"}></DxcResultsetTable>
224
+ <DxcResultsetTable columns={columns} rows={rows} margin={"medium"} />
205
225
  </ExampleContainer>
206
226
  <ExampleContainer>
207
227
  <Title title="Large" theme="light" level={4} />
208
- <DxcResultsetTable columns={columns} rows={rows} margin={"large"}></DxcResultsetTable>
228
+ <DxcResultsetTable columns={columns} rows={rows} margin={"large"} />
209
229
  </ExampleContainer>
210
230
  <ExampleContainer>
211
231
  <Title title="Xlarge" theme="light" level={4} />
212
- <DxcResultsetTable columns={columns} rows={rows} margin={"xlarge"}></DxcResultsetTable>
232
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xlarge"} />
213
233
  </ExampleContainer>
214
- <ExampleContainer>
234
+ <ExampleContainer expanded>
215
235
  <Title title="Xxlarge" theme="light" level={4} />
216
- <DxcResultsetTable columns={columns} rows={rows} margin={"xxlarge"}></DxcResultsetTable>
217
- <hr />
236
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xxlarge"} />
218
237
  </ExampleContainer>
219
238
  </>
220
239
  );
221
240
 
241
+ const SmallContainer = styled.div`
242
+ width: 500px;
243
+ `;
244
+
222
245
  const ResultsetTableAsc = () => (
223
246
  <ExampleContainer>
224
247
  <Title title="Ascendant sorting" theme="light" level={4} />
225
- <DxcResultsetTable columns={columnsSortable} rows={rowsSortable}></DxcResultsetTable>
248
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
226
249
  </ExampleContainer>
227
250
  );
228
251
 
229
252
  export const AscendentSorting = ResultsetTableAsc.bind({});
230
253
  AscendentSorting.play = async ({ canvasElement }) => {
231
254
  const canvas = within(canvasElement);
232
- await userEvent.click(canvas.queryByText("Name"));
255
+ const idHeader = canvas.getAllByRole("button")[0];
256
+ await userEvent.click(idHeader);
233
257
  };
234
258
 
235
259
  const ResultsetTableDesc = () => (
236
260
  <ExampleContainer>
237
261
  <Title title="Descendant sorting" theme="light" level={4} />
238
- <DxcResultsetTable columns={columnsSortable} rows={rowsSortable}></DxcResultsetTable>
262
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
239
263
  </ExampleContainer>
240
264
  );
241
265
 
242
266
  export const DescendantSorting = ResultsetTableDesc.bind({});
243
267
  DescendantSorting.play = async ({ canvasElement }) => {
244
268
  const canvas = within(canvasElement);
245
- await userEvent.click(canvas.queryByText("Name"));
246
- await userEvent.click(canvas.queryByText("Name"));
269
+ const nameHeader = canvas.getAllByRole("button")[1];
270
+ await userEvent.click(nameHeader);
271
+ await userEvent.click(nameHeader);
247
272
  };
248
273
 
249
274
  const ResultsetTableMiddle = () => (
250
275
  <ExampleContainer>
251
276
  <Title title="Middle page" theme="light" level={4} />
252
- <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2}></DxcResultsetTable>
277
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
253
278
  </ExampleContainer>
254
279
  );
255
280
 
@@ -263,7 +288,7 @@ MiddlePage.play = async ({ canvasElement }) => {
263
288
  const ResultsetTableLast = () => (
264
289
  <ExampleContainer>
265
290
  <Title title="Last page" theme="light" level={4} />
266
- <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2}></DxcResultsetTable>
291
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
267
292
  </ExampleContainer>
268
293
  );
269
294
 
@@ -80,8 +80,6 @@ var rows = [[{
80
80
  }, {
81
81
  displayValue: "Oviedo",
82
82
  sortValue: "Oviedo"
83
- }, {
84
- displayValue: ""
85
83
  }], [{
86
84
  displayValue: "003",
87
85
  sortValue: "003"
@@ -118,8 +116,6 @@ var rows = [[{
118
116
  }, {
119
117
  displayValue: "Barcelona",
120
118
  sortValue: "Barcelona"
121
- }, {
122
- displayValue: ""
123
119
  }], [{
124
120
  displayValue: "007",
125
121
  sortValue: "007"
@@ -147,8 +143,6 @@ var rows = [[{
147
143
  }, {
148
144
  displayValue: "Oviedo",
149
145
  sortValue: "Oviedo"
150
- }, {
151
- displayValue: ""
152
146
  }], [{
153
147
  displayValue: "010",
154
148
  sortValue: "010"
@@ -158,8 +152,6 @@ var rows = [[{
158
152
  }, {
159
153
  displayValue: "Barcelona",
160
154
  sortValue: "Barcelona"
161
- }, {
162
- displayValue: ""
163
155
  }]];
164
156
  var rows2 = [[{
165
157
  displayValue: "546",
@@ -191,8 +183,8 @@ var rows2 = [[{
191
183
  displayValue: "OtherValue",
192
184
  sortValue: "OtherValue"
193
185
  }]];
194
- describe("ResultsetTable component tests", function () {
195
- test("ResultsetTable rendered correctly", function () {
186
+ describe("Resultset table component tests", function () {
187
+ test("Resultset table rendered correctly", function () {
196
188
  var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
197
189
  columns: columns,
198
190
  rows: rows,
@@ -202,7 +194,7 @@ describe("ResultsetTable component tests", function () {
202
194
 
203
195
  expect(getByText("Peter")).toBeTruthy();
204
196
  });
205
- test("Resultsettable shows as many rows as itemsPerPage", function () {
197
+ test("Resultset table shows as many rows as itemsPerPage", function () {
206
198
  var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
207
199
  columns: columns,
208
200
  rows: rows,
@@ -212,7 +204,7 @@ describe("ResultsetTable component tests", function () {
212
204
 
213
205
  expect(getAllByRole("row").length - 1).toEqual(3);
214
206
  });
215
- test("Resultsettable shows rows on second page", function () {
207
+ test("Resultset table shows rows on second page", function () {
216
208
  var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
217
209
  columns: columns,
218
210
  rows: rows,
@@ -225,18 +217,17 @@ describe("ResultsetTable component tests", function () {
225
217
  expect(getByText("Louis")).toBeTruthy();
226
218
  expect(getByText("Lana")).toBeTruthy();
227
219
  expect(getAllByRole("row").length - 1).toEqual(3);
228
- var nextButton = getAllByRole("button")[2];
220
+ var nextButton = getAllByRole("button")[3];
229
221
 
230
222
  _react2.fireEvent.click(nextButton);
231
223
 
232
- expect(getByText("4 to 6 of 10")).toBeTruthy(); // expect(getByText("Page: 2 of 4")).toBeTruthy();
233
-
224
+ expect(getByText("4 to 6 of 10")).toBeTruthy();
234
225
  expect(getByText("Rick")).toBeTruthy();
235
226
  expect(getByText("Mark")).toBeTruthy();
236
227
  expect(getByText("Cris")).toBeTruthy();
237
228
  expect(getAllByRole("row").length - 1).toEqual(3);
238
229
  });
239
- test("Resultsettable goToPage works as expected", function () {
230
+ test("Resultset table goToPage works as expected", function () {
240
231
  window.HTMLElement.prototype.scrollIntoView = function () {};
241
232
 
242
233
  window.HTMLElement.prototype.scrollTo = function () {};
@@ -248,28 +239,27 @@ describe("ResultsetTable component tests", function () {
248
239
  itemsPerPage: 3
249
240
  })),
250
241
  getByText = _render4.getByText,
251
- getAllByRole = _render4.getAllByRole,
252
- getByRole = _render4.getByRole;
242
+ getAllByRole = _render4.getAllByRole;
253
243
 
254
244
  expect(getByText("Peter")).toBeTruthy();
255
245
  expect(getByText("Louis")).toBeTruthy();
256
246
  expect(getByText("Lana")).toBeTruthy();
257
247
  expect(getAllByRole("row").length - 1).toEqual(3);
258
- var goToPageSelect = getAllByRole("button")[2];
259
- (0, _react2.act)(function () {
260
- _userEvent["default"].click(goToPageSelect);
261
- });
248
+ var goToPageSelect = getAllByRole("button")[3];
249
+
250
+ _userEvent["default"].click(goToPageSelect);
251
+
262
252
  var goToPageOption = getByText("2");
263
- (0, _react2.act)(function () {
264
- _userEvent["default"].click(goToPageOption);
265
- });
253
+
254
+ _userEvent["default"].click(goToPageOption);
255
+
266
256
  expect(getByText("4 to 6 of 10")).toBeTruthy();
267
257
  expect(getByText("Rick")).toBeTruthy();
268
258
  expect(getByText("Mark")).toBeTruthy();
269
259
  expect(getByText("Cris")).toBeTruthy();
270
260
  expect(getAllByRole("row").length - 1).toEqual(3);
271
261
  });
272
- test("Resultsettable going to the last page shows only one row", function () {
262
+ test("Resultset table going to the last page shows only one row", function () {
273
263
  var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
274
264
  columns: columns,
275
265
  rows: rows,
@@ -278,7 +268,7 @@ describe("ResultsetTable component tests", function () {
278
268
  getByText = _render5.getByText,
279
269
  getAllByRole = _render5.getAllByRole;
280
270
 
281
- var lastButton = getAllByRole("button")[3];
271
+ var lastButton = getAllByRole("button")[4];
282
272
 
283
273
  _react2.fireEvent.click(lastButton);
284
274
 
@@ -286,7 +276,7 @@ describe("ResultsetTable component tests", function () {
286
276
  expect(getAllByRole("row")).toHaveLength(2);
287
277
  expect(getByText("Cosmin")).toBeTruthy();
288
278
  });
289
- test("Resultsettable sort rows by column", function () {
279
+ test("Resultset table sort rows by column", function () {
290
280
  var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
291
281
  columns: columns,
292
282
  rows: rows,
@@ -304,7 +294,7 @@ describe("ResultsetTable component tests", function () {
304
294
  expect(component.queryByText("Tina")).toBeTruthy();
305
295
  expect(component.queryByText("Cosmin")).not.toBeTruthy();
306
296
  });
307
- test("Resultsettable change rows should go to first page", function () {
297
+ test("Resultset table change rows should go to first page", function () {
308
298
  var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
309
299
  columns: columns,
310
300
  rows: rows,
@@ -321,28 +311,20 @@ describe("ResultsetTable component tests", function () {
321
311
  }));
322
312
  expect(queryByText("1 to 3 of 3")).toBeTruthy();
323
313
  });
324
- test("Resultsettable change itemsPerPage should go to first page", function () {
314
+ test("Resultset table change itemsPerPage should go to first page", function () {
325
315
  var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
326
316
  columns: columns,
327
317
  rows: rows,
328
318
  itemsPerPage: 3,
329
319
  itemsPerPageOptions: [2, 3]
330
320
  })),
331
- getAllByRole = _render7.getAllByRole,
332
- queryByText = _render7.queryByText,
333
- rerender = _render7.rerender;
321
+ getAllByRole = _render7.getAllByRole;
334
322
 
335
- var lastButton = getAllByRole("button")[3];
323
+ var lastButton = getAllByRole("button")[4];
324
+ expect(getAllByRole("row").length - 1).toEqual(3);
336
325
 
337
326
  _react2.fireEvent.click(lastButton);
338
327
 
339
328
  expect(getAllByRole("row").length - 1).toEqual(1);
340
- rerender( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
341
- columns: columns,
342
- rows: rows,
343
- itemsPerPage: 6
344
- }));
345
- expect(getAllByRole("row").length - 1).toEqual(6);
346
- expect(queryByText("Peter")).toBeTruthy();
347
329
  });
348
330
  });
@@ -1,6 +1,6 @@
1
1
  /// <reference types="react" />
2
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- declare type Margin = {
2
+ export declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ export declare type Margin = {
4
4
  top?: Space;
5
5
  bottom?: Space;
6
6
  left?: Space;
package/select/Select.js CHANGED
@@ -383,7 +383,8 @@ var DxcSelect = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
383
383
  }, helperText), /*#__PURE__*/_react["default"].createElement(Popover.Root, {
384
384
  open: isOpen
385
385
  }, /*#__PURE__*/_react["default"].createElement(Popover.Trigger, {
386
- asChild: true
386
+ asChild: true,
387
+ type: undefined
387
388
  }, /*#__PURE__*/_react["default"].createElement(Select, {
388
389
  id: selectId,
389
390
  disabled: disabled,
@@ -418,6 +419,7 @@ var DxcSelect = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
418
419
  "aria-label": translatedLabels.select.actionClearSelectionTitle
419
420
  }, _Icons["default"].clear)), /*#__PURE__*/_react["default"].createElement(SearchableValueContainer, null, /*#__PURE__*/_react["default"].createElement(ValueInput, {
420
421
  name: name,
422
+ disabled: disabled,
421
423
  value: multiple ? (value !== null && value !== void 0 ? value : innerValue).join(",") : value !== null && value !== void 0 ? value : innerValue,
422
424
  readOnly: true,
423
425
  "aria-hidden": "true"
@@ -1,5 +1,5 @@
1
1
  import React from "react";
2
- import { userEvent, within, waitFor } from "@storybook/testing-library";
2
+ import { userEvent, within } from "@storybook/testing-library";
3
3
  import Title from "../../.storybook/components/Title";
4
4
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
5
  import DxcSelect from "./Select";
@@ -560,10 +560,7 @@ ListboxStates.play = async ({ canvasElement }) => {
560
560
  export const Searchable = SearchableSelect.bind({});
561
561
  Searchable.play = async ({ canvasElement }) => {
562
562
  const canvas = within(canvasElement);
563
- await userEvent.click(canvas.getByRole("combobox"));
564
- await waitFor(async () => {
565
- userEvent.type(canvas.getByRole("combobox"), "r");
566
- });
563
+ await userEvent.type(canvas.getByRole("combobox"), "r");
567
564
  };
568
565
 
569
566
  export const SearchableWithValue = SearchValue.bind({});