@dxc-technology/halstack-react 0.0.0-9bd9511 → 0.0.0-9c20370

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 (213) hide show
  1. package/BackgroundColorContext.d.ts +3 -3
  2. package/BackgroundColorContext.js +12 -2
  3. package/HalstackContext.d.ts +1330 -7
  4. package/HalstackContext.js +84 -67
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +74 -55
  7. package/accordion/Accordion.stories.tsx +3 -101
  8. package/accordion/Accordion.test.js +34 -19
  9. package/accordion/types.d.ts +4 -16
  10. package/accordion-group/AccordionGroup.d.ts +4 -3
  11. package/accordion-group/AccordionGroup.js +49 -42
  12. package/accordion-group/AccordionGroup.stories.tsx +77 -76
  13. package/accordion-group/AccordionGroup.test.js +62 -54
  14. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  15. package/accordion-group/AccordionGroupAccordion.js +43 -0
  16. package/accordion-group/types.d.ts +6 -18
  17. package/alert/Alert.js +47 -20
  18. package/alert/Alert.test.js +46 -29
  19. package/alert/types.d.ts +3 -3
  20. package/badge/Badge.js +14 -2
  21. package/badge/types.d.ts +1 -1
  22. package/bleed/Bleed.js +21 -13
  23. package/bleed/Bleed.stories.tsx +1 -0
  24. package/bleed/types.d.ts +2 -2
  25. package/box/Box.d.ts +1 -1
  26. package/box/Box.js +33 -33
  27. package/box/Box.stories.tsx +25 -53
  28. package/box/Box.test.js +7 -2
  29. package/box/types.d.ts +3 -15
  30. package/bulleted-list/BulletedList.js +36 -9
  31. package/bulleted-list/BulletedList.stories.tsx +7 -1
  32. package/bulleted-list/types.d.ts +32 -5
  33. package/button/Button.d.ts +1 -1
  34. package/button/Button.js +83 -71
  35. package/button/Button.stories.tsx +4 -4
  36. package/button/Button.test.js +28 -8
  37. package/button/types.d.ts +8 -4
  38. package/card/Card.d.ts +1 -1
  39. package/card/Card.js +67 -62
  40. package/card/Card.stories.tsx +12 -42
  41. package/card/Card.test.js +22 -11
  42. package/card/types.d.ts +4 -10
  43. package/checkbox/Checkbox.js +71 -27
  44. package/checkbox/Checkbox.test.js +60 -33
  45. package/checkbox/types.d.ts +4 -4
  46. package/chip/Chip.js +51 -48
  47. package/chip/Chip.stories.tsx +25 -17
  48. package/chip/Chip.test.js +29 -17
  49. package/chip/types.d.ts +4 -4
  50. package/common/OpenSans.css +68 -80
  51. package/common/coreTokens.d.ts +146 -0
  52. package/common/coreTokens.js +167 -0
  53. package/common/utils.d.ts +1 -0
  54. package/common/utils.js +8 -3
  55. package/common/variables.d.ts +226 -175
  56. package/common/variables.js +956 -1133
  57. package/date-input/Calendar.js +55 -12
  58. package/date-input/DateInput.js +82 -35
  59. package/date-input/DateInput.test.js +351 -164
  60. package/date-input/DatePicker.js +38 -8
  61. package/date-input/Icons.js +12 -0
  62. package/date-input/YearPicker.js +30 -5
  63. package/date-input/types.d.ts +7 -7
  64. package/dialog/Dialog.d.ts +1 -1
  65. package/dialog/Dialog.js +83 -86
  66. package/dialog/Dialog.stories.tsx +127 -221
  67. package/dialog/Dialog.test.js +331 -18
  68. package/dialog/types.d.ts +1 -14
  69. package/dropdown/Dropdown.js +86 -32
  70. package/dropdown/Dropdown.test.js +211 -104
  71. package/dropdown/DropdownMenu.js +22 -8
  72. package/dropdown/DropdownMenuItem.js +15 -6
  73. package/dropdown/types.d.ts +8 -8
  74. package/file-input/FileInput.js +218 -134
  75. package/file-input/FileInput.test.js +343 -331
  76. package/file-input/FileItem.js +39 -12
  77. package/file-input/types.d.ts +10 -10
  78. package/flex/Flex.js +39 -25
  79. package/flex/Flex.stories.tsx +35 -26
  80. package/flex/types.d.ts +74 -9
  81. package/footer/Footer.d.ts +1 -1
  82. package/footer/Footer.js +80 -68
  83. package/footer/Footer.stories.tsx +12 -89
  84. package/footer/Footer.test.js +47 -40
  85. package/footer/Icons.js +4 -0
  86. package/footer/types.d.ts +15 -17
  87. package/grid/Grid.d.ts +7 -0
  88. package/grid/Grid.js +91 -0
  89. package/grid/Grid.stories.tsx +219 -0
  90. package/grid/types.d.ts +115 -0
  91. package/header/Header.d.ts +4 -3
  92. package/header/Header.js +72 -55
  93. package/header/Header.stories.tsx +7 -71
  94. package/header/Header.test.js +26 -13
  95. package/header/Icons.js +4 -0
  96. package/header/types.d.ts +2 -16
  97. package/heading/Heading.js +28 -7
  98. package/heading/Heading.test.js +88 -71
  99. package/heading/types.d.ts +3 -3
  100. package/inset/Inset.js +21 -13
  101. package/inset/Inset.stories.tsx +2 -1
  102. package/inset/types.d.ts +2 -2
  103. package/layout/ApplicationLayout.d.ts +5 -5
  104. package/layout/ApplicationLayout.js +57 -15
  105. package/layout/Icons.js +10 -0
  106. package/layout/SidenavContext.d.ts +1 -1
  107. package/layout/SidenavContext.js +4 -0
  108. package/layout/types.d.ts +5 -6
  109. package/link/Link.js +41 -21
  110. package/link/Link.test.js +42 -26
  111. package/link/types.d.ts +4 -4
  112. package/main.d.ts +2 -1
  113. package/main.js +55 -0
  114. package/nav-tabs/NavTabs.d.ts +2 -2
  115. package/nav-tabs/NavTabs.js +43 -16
  116. package/nav-tabs/NavTabs.stories.tsx +14 -0
  117. package/nav-tabs/NavTabs.test.js +44 -37
  118. package/nav-tabs/Tab.js +71 -45
  119. package/nav-tabs/types.d.ts +10 -11
  120. package/number-input/NumberInput.js +30 -20
  121. package/number-input/NumberInput.test.js +249 -113
  122. package/number-input/NumberInputContext.js +5 -0
  123. package/number-input/numberInputContextTypes.d.ts +1 -1
  124. package/number-input/types.d.ts +4 -4
  125. package/package.json +7 -7
  126. package/paginator/Icons.js +10 -0
  127. package/paginator/Paginator.js +39 -17
  128. package/paginator/Paginator.test.js +156 -104
  129. package/paginator/types.d.ts +1 -1
  130. package/paragraph/Paragraph.d.ts +3 -4
  131. package/paragraph/Paragraph.js +18 -8
  132. package/password-input/PasswordInput.js +51 -22
  133. package/password-input/PasswordInput.test.js +94 -51
  134. package/password-input/types.d.ts +4 -4
  135. package/progress-bar/ProgressBar.d.ts +2 -2
  136. package/progress-bar/ProgressBar.js +39 -14
  137. package/progress-bar/ProgressBar.test.js +53 -36
  138. package/progress-bar/types.d.ts +4 -3
  139. package/quick-nav/QuickNav.js +24 -2
  140. package/quick-nav/types.d.ts +2 -2
  141. package/radio-group/Radio.js +53 -22
  142. package/radio-group/RadioGroup.js +84 -41
  143. package/radio-group/RadioGroup.test.js +288 -186
  144. package/radio-group/types.d.ts +4 -4
  145. package/resultsetTable/Icons.js +3 -0
  146. package/resultsetTable/ResultsetTable.js +56 -21
  147. package/resultsetTable/ResultsetTable.test.js +75 -42
  148. package/resultsetTable/types.d.ts +5 -5
  149. package/select/Icons.js +3 -0
  150. package/select/Listbox.js +35 -10
  151. package/select/Option.js +24 -8
  152. package/select/Select.js +143 -56
  153. package/select/Select.test.js +839 -456
  154. package/select/types.d.ts +12 -12
  155. package/sidenav/Icons.d.ts +7 -0
  156. package/sidenav/Icons.js +51 -0
  157. package/sidenav/Sidenav.d.ts +2 -2
  158. package/sidenav/Sidenav.js +116 -104
  159. package/sidenav/Sidenav.stories.tsx +60 -60
  160. package/sidenav/Sidenav.test.js +10 -3
  161. package/sidenav/types.d.ts +26 -23
  162. package/slider/Slider.js +84 -38
  163. package/slider/Slider.test.js +104 -76
  164. package/slider/types.d.ts +4 -4
  165. package/spinner/Spinner.js +51 -28
  166. package/spinner/Spinner.stories.jsx +28 -28
  167. package/spinner/Spinner.test.js +35 -26
  168. package/spinner/types.d.ts +3 -3
  169. package/switch/Switch.js +66 -24
  170. package/switch/Switch.test.js +97 -52
  171. package/switch/types.d.ts +4 -4
  172. package/table/Table.js +22 -4
  173. package/table/Table.test.js +7 -2
  174. package/table/types.d.ts +3 -3
  175. package/tabs/Tab.js +39 -22
  176. package/tabs/Tabs.js +131 -62
  177. package/tabs/Tabs.test.js +122 -67
  178. package/tabs/types.d.ts +8 -8
  179. package/tag/Tag.js +54 -27
  180. package/tag/Tag.test.js +31 -20
  181. package/tag/types.d.ts +7 -7
  182. package/text-input/Icons.js +3 -0
  183. package/text-input/Suggestion.js +24 -8
  184. package/text-input/Suggestions.js +36 -11
  185. package/text-input/TextInput.js +144 -59
  186. package/text-input/TextInput.stories.tsx +1 -1
  187. package/text-input/TextInput.test.js +858 -539
  188. package/text-input/types.d.ts +9 -9
  189. package/textarea/Textarea.js +73 -38
  190. package/textarea/Textarea.test.js +173 -98
  191. package/textarea/types.d.ts +4 -4
  192. package/toggle-group/ToggleGroup.d.ts +2 -2
  193. package/toggle-group/ToggleGroup.js +59 -21
  194. package/toggle-group/ToggleGroup.test.js +72 -40
  195. package/toggle-group/types.d.ts +11 -11
  196. package/typography/Typography.d.ts +2 -2
  197. package/typography/Typography.js +23 -110
  198. package/typography/Typography.stories.tsx +1 -1
  199. package/typography/types.d.ts +1 -1
  200. package/useTheme.d.ts +1234 -1
  201. package/useTheme.js +6 -0
  202. package/useTranslatedLabels.d.ts +84 -2
  203. package/useTranslatedLabels.js +5 -0
  204. package/utils/BaseTypography.d.ts +21 -0
  205. package/utils/BaseTypography.js +108 -0
  206. package/utils/FocusLock.d.ts +13 -0
  207. package/utils/FocusLock.js +138 -0
  208. package/wizard/Wizard.js +47 -13
  209. package/wizard/Wizard.test.js +81 -54
  210. package/wizard/types.d.ts +7 -8
  211. package/card/ice-cream.jpg +0 -0
  212. package/translatedLabelsType.d.ts +0 -82
  213. /package/{translatedLabelsType.js → grid/types.js} +0 -0
@@ -1,4 +1,4 @@
1
- export type Option = {
1
+ export declare type Option = {
2
2
  /**
3
3
  * Label of the option placed next to the radio input.
4
4
  */
@@ -14,7 +14,7 @@ export type Option = {
14
14
  */
15
15
  disabled?: boolean;
16
16
  };
17
- type RadioGroupProps = {
17
+ declare type RadioGroupProps = {
18
18
  /**
19
19
  * Text to be placed above the radio group.
20
20
  */
@@ -97,11 +97,11 @@ type RadioGroupProps = {
97
97
  /**
98
98
  * Reference to the component.
99
99
  */
100
- export type RefType = HTMLDivElement;
100
+ export declare type RefType = HTMLDivElement;
101
101
  /**
102
102
  * Single radio prop types.
103
103
  */
104
- export type RadioProps = {
104
+ export declare type RadioProps = {
105
105
  label: string;
106
106
  checked: boolean;
107
107
  onClick: () => void;
@@ -1,11 +1,14 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
4
5
  Object.defineProperty(exports, "__esModule", {
5
6
  value: true
6
7
  });
7
8
  exports["default"] = void 0;
9
+
8
10
  var _react = _interopRequireDefault(require("react"));
11
+
9
12
  var icons = {
10
13
  arrowUp: /*#__PURE__*/_react["default"].createElement("svg", {
11
14
  xmlns: "http://www.w3.org/2000/svg",
@@ -1,33 +1,52 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
4
5
  var _typeof3 = require("@babel/runtime/helpers/typeof");
6
+
5
7
  Object.defineProperty(exports, "__esModule", {
6
8
  value: true
7
9
  });
8
10
  exports["default"] = void 0;
11
+
9
12
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
+
10
14
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
+
11
16
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
17
+
12
18
  var _react = _interopRequireWildcard(require("react"));
19
+
13
20
  var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
+
14
22
  var _variables = require("../common/variables");
23
+
15
24
  var _Table = _interopRequireDefault(require("../table/Table"));
25
+
16
26
  var _Paginator = _interopRequireDefault(require("../paginator/Paginator"));
27
+
17
28
  var _useTheme = _interopRequireDefault(require("../useTheme"));
29
+
18
30
  var _Icons = _interopRequireDefault(require("./Icons"));
19
- var _utils = require("../common/utils.js");
31
+
32
+ var _utils = require("../common/utils");
33
+
20
34
  var _templateObject, _templateObject2, _templateObject3;
35
+
21
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); }
37
+
22
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; }
39
+
23
40
  var normalizeSortValue = function normalizeSortValue(sortValue) {
24
41
  return typeof sortValue === "string" ? sortValue.toUpperCase() : sortValue;
25
42
  };
43
+
26
44
  var sortArray = function sortArray(index, order, resultset) {
27
45
  return resultset.slice().sort(function (element1, element2) {
28
46
  var sortValueA = normalizeSortValue(element1[index].sortValue || element1[index].displayValue);
29
47
  var sortValueB = normalizeSortValue(element2[index].sortValue || element2[index].displayValue);
30
48
  var comparison = 0;
49
+
31
50
  if ((0, _typeof2["default"])(sortValueA) === "object") {
32
51
  comparison = -1;
33
52
  } else if ((0, _typeof2["default"])(sortValueB) === "object") {
@@ -37,40 +56,48 @@ var sortArray = function sortArray(index, order, resultset) {
37
56
  } else if (sortValueA < sortValueB) {
38
57
  comparison = -1;
39
58
  }
59
+
40
60
  return order === "descending" ? comparison * -1 : comparison;
41
61
  });
42
62
  };
63
+
43
64
  var getMinItemsPerPageIndex = function getMinItemsPerPageIndex(currentPageInternal, itemsPerPage, page) {
44
65
  return currentPageInternal === 1 ? 0 : itemsPerPage * (page - 1);
45
66
  };
67
+
46
68
  var getMaxItemsPerPageIndex = function getMaxItemsPerPageIndex(minItemsPerPageIndex, itemsPerPage, resultset, page) {
47
69
  return minItemsPerPageIndex + itemsPerPage > resultset.length ? resultset.length : itemsPerPage * page - 1;
48
70
  };
71
+
49
72
  var DxcResultsetTable = function DxcResultsetTable(_ref) {
50
73
  var columns = _ref.columns,
51
- rows = _ref.rows,
52
- _ref$showGoToPage = _ref.showGoToPage,
53
- showGoToPage = _ref$showGoToPage === void 0 ? true : _ref$showGoToPage,
54
- _ref$itemsPerPage = _ref.itemsPerPage,
55
- itemsPerPage = _ref$itemsPerPage === void 0 ? 5 : _ref$itemsPerPage,
56
- itemsPerPageOptions = _ref.itemsPerPageOptions,
57
- itemsPerPageFunction = _ref.itemsPerPageFunction,
58
- margin = _ref.margin,
59
- _ref$tabIndex = _ref.tabIndex,
60
- tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
74
+ rows = _ref.rows,
75
+ _ref$showGoToPage = _ref.showGoToPage,
76
+ showGoToPage = _ref$showGoToPage === void 0 ? true : _ref$showGoToPage,
77
+ _ref$itemsPerPage = _ref.itemsPerPage,
78
+ itemsPerPage = _ref$itemsPerPage === void 0 ? 5 : _ref$itemsPerPage,
79
+ itemsPerPageOptions = _ref.itemsPerPageOptions,
80
+ itemsPerPageFunction = _ref.itemsPerPageFunction,
81
+ margin = _ref.margin,
82
+ _ref$tabIndex = _ref.tabIndex,
83
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
61
84
  var colorsTheme = (0, _useTheme["default"])();
85
+
62
86
  var _useState = (0, _react.useState)(1),
63
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
64
- page = _useState2[0],
65
- changePage = _useState2[1];
87
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
88
+ page = _useState2[0],
89
+ changePage = _useState2[1];
90
+
66
91
  var _useState3 = (0, _react.useState)(-1),
67
- _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
68
- sortColumnIndex = _useState4[0],
69
- changeSortColumnIndex = _useState4[1];
92
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
93
+ sortColumnIndex = _useState4[0],
94
+ changeSortColumnIndex = _useState4[1];
95
+
70
96
  var _useState5 = (0, _react.useState)("ascending"),
71
- _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
72
- sortOrder = _useState6[0],
73
- changeSortOrder = _useState6[1];
97
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
98
+ sortOrder = _useState6[0],
99
+ changeSortOrder = _useState6[1];
100
+
74
101
  var minItemsPerPageIndex = (0, _react.useMemo)(function () {
75
102
  return getMinItemsPerPageIndex(page, itemsPerPage, page);
76
103
  }, [itemsPerPage, page]);
@@ -83,19 +110,22 @@ var DxcResultsetTable = function DxcResultsetTable(_ref) {
83
110
  var filteredResultset = (0, _react.useMemo)(function () {
84
111
  return sortedResultset && sortedResultset.slice(minItemsPerPageIndex, maxItemsPerPageIndex + 1);
85
112
  }, [sortedResultset, minItemsPerPageIndex, maxItemsPerPageIndex]);
113
+
86
114
  var goToPage = function goToPage(newPage) {
87
115
  changePage(newPage);
88
116
  };
117
+
89
118
  var changeSorting = function changeSorting(columnIndex) {
90
119
  changePage(1);
91
120
  changeSortColumnIndex(columnIndex);
92
121
  changeSortOrder(sortColumnIndex === -1 || sortColumnIndex !== columnIndex ? "ascending" : sortOrder === "ascending" ? "descending" : "ascending");
93
122
  };
123
+
94
124
  (0, _react.useEffect)(function () {
95
125
  rows.length > 0 ? changePage(1) : changePage(0);
96
126
  }, [rows]);
97
127
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
98
- theme: colorsTheme["table"]
128
+ theme: colorsTheme.table
99
129
  }, /*#__PURE__*/_react["default"].createElement(DxcResultsetTableContainer, {
100
130
  margin: margin
101
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) {
@@ -130,9 +160,11 @@ var DxcResultsetTable = function DxcResultsetTable(_ref) {
130
160
  tabIndex: tabIndex
131
161
  })));
132
162
  };
163
+
133
164
  var calculateWidth = function calculateWidth(margin) {
134
165
  return "calc(100% - ".concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
135
166
  };
167
+
136
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) {
137
169
  return calculateWidth(props.margin);
138
170
  }, function (props) {
@@ -146,6 +178,7 @@ var DxcResultsetTableContainer = _styledComponents["default"].div(_templateObjec
146
178
  }, function (props) {
147
179
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
148
180
  });
181
+
149
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) {
150
183
  return props.theme.headerTextAlign === "center" ? "center" : props.theme.headerTextAlign === "right" ? "flex-end" : "flex-start";
151
184
  }, function (props) {
@@ -153,8 +186,10 @@ var HeaderContainer = _styledComponents["default"].span(_templateObject2 || (_te
153
186
  }, function (props) {
154
187
  return props.isSortable && "&:focus {\n outline: #0095ff solid 2px;\n }";
155
188
  });
189
+
156
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) {
157
191
  return props.theme.sortIconColor;
158
192
  });
193
+
159
194
  var _default = DxcResultsetTable;
160
195
  exports["default"] = _default;
@@ -1,12 +1,19 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
4
5
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
6
+
5
7
  var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
8
+
6
9
  var _react = _interopRequireDefault(require("react"));
10
+
7
11
  var _react2 = require("@testing-library/react");
12
+
8
13
  var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
9
- var _ResultsetTable = _interopRequireDefault(require("./ResultsetTable"));
14
+
15
+ var _ResultsetTable = _interopRequireDefault(require("./ResultsetTable.tsx"));
16
+
10
17
  // Mocking DOMRect for Radix Primitive Popover
11
18
  global.globalThis = global;
12
19
  global.DOMRect = {
@@ -21,10 +28,12 @@ global.DOMRect = {
21
28
  };
22
29
  }
23
30
  };
31
+
24
32
  global.ResizeObserver = /*#__PURE__*/function () {
25
33
  function ResizeObserver() {
26
34
  (0, _classCallCheck2["default"])(this, ResizeObserver);
27
35
  }
36
+
28
37
  (0, _createClass2["default"])(ResizeObserver, [{
29
38
  key: "observe",
30
39
  value: function observe() {}
@@ -37,6 +46,7 @@ global.ResizeObserver = /*#__PURE__*/function () {
37
46
  }]);
38
47
  return ResizeObserver;
39
48
  }();
49
+
40
50
  var columns = [{
41
51
  displayValue: "Id",
42
52
  isSortable: false
@@ -171,36 +181,41 @@ var rows2 = [[{
171
181
  describe("Resultset table component tests", function () {
172
182
  test("Resultset table rendered correctly", function () {
173
183
  var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
174
- columns: columns,
175
- rows: rows,
176
- itemsPerPage: 3
177
- })),
178
- getByText = _render.getByText;
184
+ columns: columns,
185
+ rows: rows,
186
+ itemsPerPage: 3
187
+ })),
188
+ getByText = _render.getByText;
189
+
179
190
  expect(getByText("Peter")).toBeTruthy();
180
191
  });
181
192
  test("Resultset table shows as many rows as itemsPerPage", function () {
182
193
  var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
183
- columns: columns,
184
- rows: rows,
185
- itemsPerPage: 3
186
- })),
187
- getAllByRole = _render2.getAllByRole;
194
+ columns: columns,
195
+ rows: rows,
196
+ itemsPerPage: 3
197
+ })),
198
+ getAllByRole = _render2.getAllByRole;
199
+
188
200
  expect(getAllByRole("row").length - 1).toEqual(3);
189
201
  });
190
202
  test("Resultset table shows rows on second page", function () {
191
203
  var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
192
- columns: columns,
193
- rows: rows,
194
- itemsPerPage: 3
195
- })),
196
- getByText = _render3.getByText,
197
- getAllByRole = _render3.getAllByRole;
204
+ columns: columns,
205
+ rows: rows,
206
+ itemsPerPage: 3
207
+ })),
208
+ getByText = _render3.getByText,
209
+ getAllByRole = _render3.getAllByRole;
210
+
198
211
  expect(getByText("Peter")).toBeTruthy();
199
212
  expect(getByText("Louis")).toBeTruthy();
200
213
  expect(getByText("Lana")).toBeTruthy();
201
214
  expect(getAllByRole("row").length - 1).toEqual(3);
202
215
  var nextButton = getAllByRole("button")[3];
216
+
203
217
  _react2.fireEvent.click(nextButton);
218
+
204
219
  expect(getByText("4 to 6 of 10")).toBeTruthy();
205
220
  expect(getByText("Rick")).toBeTruthy();
206
221
  expect(getByText("Mark")).toBeTruthy();
@@ -209,23 +224,30 @@ describe("Resultset table component tests", function () {
209
224
  });
210
225
  test("Resultset table goToPage works as expected", function () {
211
226
  window.HTMLElement.prototype.scrollIntoView = function () {};
227
+
212
228
  window.HTMLElement.prototype.scrollTo = function () {};
229
+
213
230
  var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
214
- columns: columns,
215
- showGoToPage: true,
216
- rows: rows,
217
- itemsPerPage: 3
218
- })),
219
- getByText = _render4.getByText,
220
- getAllByRole = _render4.getAllByRole;
231
+ columns: columns,
232
+ showGoToPage: true,
233
+ rows: rows,
234
+ itemsPerPage: 3
235
+ })),
236
+ getByText = _render4.getByText,
237
+ getAllByRole = _render4.getAllByRole;
238
+
221
239
  expect(getByText("Peter")).toBeTruthy();
222
240
  expect(getByText("Louis")).toBeTruthy();
223
241
  expect(getByText("Lana")).toBeTruthy();
224
242
  expect(getAllByRole("row").length - 1).toEqual(3);
225
243
  var goToPageSelect = getAllByRole("button")[3];
244
+
226
245
  _userEvent["default"].click(goToPageSelect);
246
+
227
247
  var goToPageOption = getByText("2");
248
+
228
249
  _userEvent["default"].click(goToPageOption);
250
+
229
251
  expect(getByText("4 to 6 of 10")).toBeTruthy();
230
252
  expect(getByText("Rick")).toBeTruthy();
231
253
  expect(getByText("Mark")).toBeTruthy();
@@ -234,14 +256,17 @@ describe("Resultset table component tests", function () {
234
256
  });
235
257
  test("Resultset table going to the last page shows only one row", function () {
236
258
  var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
237
- columns: columns,
238
- rows: rows,
239
- itemsPerPage: 3
240
- })),
241
- getByText = _render5.getByText,
242
- getAllByRole = _render5.getAllByRole;
259
+ columns: columns,
260
+ rows: rows,
261
+ itemsPerPage: 3
262
+ })),
263
+ getByText = _render5.getByText,
264
+ getAllByRole = _render5.getAllByRole;
265
+
243
266
  var lastButton = getAllByRole("button")[4];
267
+
244
268
  _react2.fireEvent.click(lastButton);
269
+
245
270
  expect(getByText("10 to 10 of 10")).toBeTruthy();
246
271
  expect(getAllByRole("row")).toHaveLength(2);
247
272
  expect(getByText("Cosmin")).toBeTruthy();
@@ -253,21 +278,26 @@ describe("Resultset table component tests", function () {
253
278
  itemsPerPage: 3
254
279
  }));
255
280
  expect(component.queryByText("Peter")).toBeTruthy();
281
+
256
282
  _react2.fireEvent.click(component.queryByText("Name"));
283
+
257
284
  expect(component.queryByText("Tina")).not.toBeTruthy();
258
285
  expect(component.queryByText("Cosmin")).toBeTruthy();
286
+
259
287
  _react2.fireEvent.click(component.queryByText("Name"));
288
+
260
289
  expect(component.queryByText("Tina")).toBeTruthy();
261
290
  expect(component.queryByText("Cosmin")).not.toBeTruthy();
262
291
  });
263
292
  test("Resultset table change rows should go to first page", function () {
264
293
  var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
265
- columns: columns,
266
- rows: rows,
267
- itemsPerPage: 3
268
- })),
269
- queryByText = _render6.queryByText,
270
- rerender = _render6.rerender;
294
+ columns: columns,
295
+ rows: rows,
296
+ itemsPerPage: 3
297
+ })),
298
+ queryByText = _render6.queryByText,
299
+ rerender = _render6.rerender;
300
+
271
301
  expect(queryByText("Peter")).toBeTruthy();
272
302
  rerender( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
273
303
  columns: columns,
@@ -278,15 +308,18 @@ describe("Resultset table component tests", function () {
278
308
  });
279
309
  test("Resultset table change itemsPerPage should go to first page", function () {
280
310
  var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
281
- columns: columns,
282
- rows: rows,
283
- itemsPerPage: 3,
284
- itemsPerPageOptions: [2, 3]
285
- })),
286
- getAllByRole = _render7.getAllByRole;
311
+ columns: columns,
312
+ rows: rows,
313
+ itemsPerPage: 3,
314
+ itemsPerPageOptions: [2, 3]
315
+ })),
316
+ getAllByRole = _render7.getAllByRole;
317
+
287
318
  var lastButton = getAllByRole("button")[4];
288
319
  expect(getAllByRole("row").length - 1).toEqual(3);
320
+
289
321
  _react2.fireEvent.click(lastButton);
322
+
290
323
  expect(getAllByRole("row").length - 1).toEqual(1);
291
324
  });
292
325
  });
@@ -1,12 +1,12 @@
1
1
  /// <reference types="react" />
2
- export type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- export type Margin = {
2
+ declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ declare type Margin = {
4
4
  top?: Space;
5
5
  bottom?: Space;
6
6
  left?: Space;
7
7
  right?: Space;
8
8
  };
9
- type Column = {
9
+ export declare type Column = {
10
10
  /**
11
11
  * Column display value.
12
12
  */
@@ -16,7 +16,7 @@ type Column = {
16
16
  */
17
17
  isSortable?: boolean;
18
18
  };
19
- type Row = {
19
+ declare type Row = {
20
20
  /**
21
21
  * Value to be displayed in the cell.
22
22
  */
@@ -27,7 +27,7 @@ type Row = {
27
27
  */
28
28
  sortValue?: string;
29
29
  };
30
- type Props = {
30
+ declare type Props = {
31
31
  /**
32
32
  * An array of objects representing the columns of the table.
33
33
  */
package/select/Icons.js CHANGED
@@ -1,11 +1,14 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
4
5
  Object.defineProperty(exports, "__esModule", {
5
6
  value: true
6
7
  });
7
8
  exports["default"] = void 0;
9
+
8
10
  var _react = _interopRequireDefault(require("react"));
11
+
9
12
  var selectIcons = {
10
13
  error: /*#__PURE__*/_react["default"].createElement("svg", {
11
14
  role: "img",
package/select/Listbox.js CHANGED
@@ -1,41 +1,56 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
4
5
  var _typeof = require("@babel/runtime/helpers/typeof");
6
+
5
7
  Object.defineProperty(exports, "__esModule", {
6
8
  value: true
7
9
  });
8
10
  exports["default"] = void 0;
11
+
9
12
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
+
10
14
  var _react = _interopRequireWildcard(require("react"));
15
+
11
16
  var _styledComponents = _interopRequireDefault(require("styled-components"));
17
+
12
18
  var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
19
+
13
20
  var _Option = _interopRequireDefault(require("./Option"));
21
+
14
22
  var _Icons = _interopRequireDefault(require("./Icons"));
23
+
15
24
  var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
25
+
16
26
  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); }
27
+
17
28
  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; }
29
+
18
30
  var groupsHaveOptions = function groupsHaveOptions(options) {
19
31
  return options !== null && options !== void 0 && options[0].options ? options.some(function (groupOption) {
20
32
  var _groupOption$options;
33
+
21
34
  return ((_groupOption$options = groupOption.options) === null || _groupOption$options === void 0 ? void 0 : _groupOption$options.length) > 0;
22
35
  }) : true;
23
36
  };
37
+
24
38
  var Listbox = function Listbox(_ref) {
25
39
  var id = _ref.id,
26
- currentValue = _ref.currentValue,
27
- options = _ref.options,
28
- visualFocusIndex = _ref.visualFocusIndex,
29
- lastOptionIndex = _ref.lastOptionIndex,
30
- multiple = _ref.multiple,
31
- optional = _ref.optional,
32
- optionalItem = _ref.optionalItem,
33
- searchable = _ref.searchable,
34
- handleOptionOnClick = _ref.handleOptionOnClick,
35
- styles = _ref.styles;
40
+ currentValue = _ref.currentValue,
41
+ options = _ref.options,
42
+ visualFocusIndex = _ref.visualFocusIndex,
43
+ lastOptionIndex = _ref.lastOptionIndex,
44
+ multiple = _ref.multiple,
45
+ optional = _ref.optional,
46
+ optionalItem = _ref.optionalItem,
47
+ searchable = _ref.searchable,
48
+ handleOptionOnClick = _ref.handleOptionOnClick,
49
+ styles = _ref.styles;
36
50
  var translatedLabels = (0, _useTranslatedLabels["default"])();
37
51
  var listboxRef = (0, _react.useRef)(null);
38
52
  var globalIndex = optional && !multiple ? 0 : -1;
53
+
39
54
  var mapOptionFunc = function mapOptionFunc(option, mapIndex) {
40
55
  if (option.options) {
41
56
  var groupId = "group-".concat(mapIndex);
@@ -75,9 +90,11 @@ var Listbox = function Listbox(_ref) {
75
90
  });
76
91
  }
77
92
  };
93
+
78
94
  (0, _react.useLayoutEffect)(function () {
79
95
  if (currentValue && !multiple) {
80
96
  var _listEl$scrollTo;
97
+
81
98
  var listEl = listboxRef === null || listboxRef === void 0 ? void 0 : listboxRef.current;
82
99
  var selectedListOptionEl = listEl === null || listEl === void 0 ? void 0 : listEl.querySelector("[aria-selected='true']");
83
100
  listEl === null || listEl === void 0 ? void 0 : (_listEl$scrollTo = listEl.scrollTo) === null || _listEl$scrollTo === void 0 ? void 0 : _listEl$scrollTo.call(listEl, {
@@ -87,6 +104,7 @@ var Listbox = function Listbox(_ref) {
87
104
  }, [currentValue, multiple]);
88
105
  (0, _react.useLayoutEffect)(function () {
89
106
  var _listboxRef$current, _visualFocusedOptionE;
107
+
90
108
  var visualFocusedOptionEl = listboxRef === null || listboxRef === void 0 ? void 0 : (_listboxRef$current = listboxRef.current) === null || _listboxRef$current === void 0 ? void 0 : _listboxRef$current.querySelectorAll("[role='option']")[visualFocusIndex];
91
109
  visualFocusedOptionEl === null || visualFocusedOptionEl === void 0 ? void 0 : (_visualFocusedOptionE = visualFocusedOptionEl.scrollIntoView) === null || _visualFocusedOptionE === void 0 ? void 0 : _visualFocusedOptionE.call(visualFocusedOptionEl, {
92
110
  block: "nearest",
@@ -117,6 +135,7 @@ var Listbox = function Listbox(_ref) {
117
135
  isSelected: multiple ? currentValue.includes(optionalItem.value) : currentValue === optionalItem.value
118
136
  }), options.map(mapOptionFunc));
119
137
  };
138
+
120
139
  var ListboxContainer = _styledComponents["default"].ul(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n max-height: 304px;\n overflow-y: auto;\n margin: 0;\n padding: 0.25rem 0;\n background-color: ", ";\n border: 1px solid ", ";\n border-radius: 0.25rem;\n box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);\n cursor: default;\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n"])), function (props) {
121
140
  return props.theme.listDialogBackgroundColor;
122
141
  }, function (props) {
@@ -132,13 +151,19 @@ var ListboxContainer = _styledComponents["default"].ul(_templateObject || (_temp
132
151
  }, function (props) {
133
152
  return props.theme.listOptionFontWeight;
134
153
  });
154
+
135
155
  var OptionsSystemMessage = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n padding: 4px 16px;\n color: ", ";\n font-size: 0.875rem;\n line-height: 1.715em;\n"])), function (props) {
136
156
  return props.theme.systemMessageFontColor;
137
157
  });
158
+
138
159
  var NoMatchesFoundIcon = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-wrap: wrap;\n align-content: center;\n height: 16px;\n width: 16px;\n padding: 4px;\n margin-right: 0.25rem;\n"])));
160
+
139
161
  var GroupList = _styledComponents["default"].ul(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n padding: 0;\n"])));
162
+
140
163
  var GroupLabel = _styledComponents["default"].li(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n padding: 4px 16px;\n font-weight: ", ";\n line-height: 1.715em;\n"])), function (props) {
141
164
  return props.theme.listGroupLabelFontWeight;
142
165
  });
166
+
143
167
  var _default = /*#__PURE__*/_react["default"].memo(Listbox);
168
+
144
169
  exports["default"] = _default;