@dxc-technology/halstack-react 0.0.0-c9b5c13 → 0.0.0-ca55cbe
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/BackgroundColorContext.d.ts +2 -2
- package/BackgroundColorContext.js +1 -1
- package/HalstackContext.d.ts +1329 -5
- package/HalstackContext.js +117 -77
- package/accordion/Accordion.js +118 -110
- package/accordion/Accordion.stories.tsx +104 -16
- package/accordion/Accordion.test.js +10 -11
- package/accordion/types.d.ts +2 -1
- package/accordion-group/AccordionGroup.js +4 -23
- package/accordion-group/AccordionGroup.stories.tsx +27 -1
- package/accordion-group/AccordionGroup.test.js +21 -46
- package/accordion-group/types.d.ts +8 -1
- package/alert/Alert.js +4 -6
- package/alert/Alert.stories.tsx +28 -0
- package/alert/Alert.test.js +1 -1
- package/bleed/Bleed.js +1 -34
- package/bleed/Bleed.stories.tsx +95 -95
- package/bleed/types.d.ts +1 -1
- package/box/Box.js +4 -6
- package/box/Box.stories.tsx +15 -0
- package/box/Box.test.js +1 -1
- package/box/types.d.ts +1 -0
- package/bulleted-list/BulletedList.d.ts +7 -0
- package/bulleted-list/BulletedList.js +125 -0
- package/bulleted-list/BulletedList.stories.tsx +206 -0
- package/bulleted-list/types.d.ts +11 -0
- package/button/Button.js +52 -73
- package/button/Button.stories.tsx +159 -8
- package/button/Button.test.js +1 -1
- package/button/types.d.ts +5 -5
- package/card/Card.js +12 -13
- package/card/Card.stories.tsx +12 -13
- package/card/Card.test.js +1 -1
- package/card/types.d.ts +1 -0
- package/checkbox/Checkbox.d.ts +2 -2
- package/checkbox/Checkbox.js +94 -101
- package/checkbox/Checkbox.stories.tsx +131 -59
- package/checkbox/Checkbox.test.js +94 -17
- package/checkbox/types.d.ts +4 -0
- package/chip/Chip.js +18 -26
- package/chip/Chip.stories.tsx +96 -9
- package/chip/Chip.test.js +3 -5
- package/chip/types.d.ts +1 -1
- package/common/OpenSans.css +68 -80
- package/common/coreTokens.d.ts +146 -0
- package/common/coreTokens.js +167 -0
- package/common/utils.d.ts +1 -0
- package/common/utils.js +4 -4
- package/common/variables.d.ts +1482 -0
- package/common/variables.js +1009 -1118
- package/date-input/Calendar.d.ts +4 -0
- package/date-input/Calendar.js +258 -0
- package/date-input/DateInput.js +134 -237
- package/date-input/DateInput.stories.tsx +199 -33
- package/date-input/DateInput.test.js +494 -138
- package/date-input/DatePicker.d.ts +4 -0
- package/date-input/DatePicker.js +146 -0
- package/date-input/Icons.d.ts +6 -0
- package/date-input/Icons.js +75 -0
- package/date-input/YearPicker.d.ts +4 -0
- package/date-input/YearPicker.js +126 -0
- package/date-input/types.d.ts +51 -0
- package/dialog/Dialog.js +80 -69
- package/dialog/Dialog.stories.tsx +230 -123
- package/dialog/Dialog.test.js +334 -5
- package/dialog/types.d.ts +1 -0
- package/dropdown/Dropdown.d.ts +1 -1
- package/dropdown/Dropdown.js +246 -249
- package/dropdown/Dropdown.stories.tsx +245 -56
- package/dropdown/Dropdown.test.js +507 -110
- package/dropdown/DropdownMenu.d.ts +4 -0
- package/dropdown/DropdownMenu.js +74 -0
- package/dropdown/DropdownMenuItem.d.ts +4 -0
- package/dropdown/DropdownMenuItem.js +79 -0
- package/dropdown/types.d.ts +23 -3
- package/file-input/FileInput.d.ts +2 -2
- package/file-input/FileInput.js +174 -220
- package/file-input/FileInput.stories.tsx +122 -11
- package/file-input/FileInput.test.js +14 -14
- package/file-input/FileItem.d.ts +4 -14
- package/file-input/FileItem.js +39 -63
- package/file-input/types.d.ts +17 -0
- package/flex/Flex.d.ts +4 -0
- package/flex/Flex.js +71 -0
- package/flex/Flex.stories.tsx +112 -0
- package/flex/types.d.ts +97 -0
- package/footer/Footer.js +6 -8
- package/footer/Footer.stories.tsx +99 -1
- package/footer/Footer.test.js +14 -26
- package/footer/Icons.js +1 -1
- package/footer/types.d.ts +2 -1
- package/grid/Grid.d.ts +7 -0
- package/grid/Grid.js +91 -0
- package/grid/Grid.stories.tsx +219 -0
- package/grid/types.d.ts +115 -0
- package/header/Header.d.ts +3 -2
- package/header/Header.js +89 -89
- package/header/Header.stories.tsx +152 -9
- package/header/Header.test.js +2 -2
- package/header/Icons.js +2 -2
- package/header/types.d.ts +1 -0
- package/heading/Heading.js +1 -1
- package/heading/Heading.test.js +1 -1
- package/inset/Inset.js +1 -34
- package/inset/Inset.stories.tsx +37 -36
- package/inset/types.d.ts +1 -1
- package/layout/ApplicationLayout.d.ts +15 -6
- package/layout/ApplicationLayout.js +38 -66
- package/layout/ApplicationLayout.stories.tsx +80 -44
- package/layout/types.d.ts +18 -29
- package/link/Link.js +4 -4
- package/link/Link.stories.tsx +73 -6
- package/link/Link.test.js +2 -4
- package/link/types.d.ts +3 -3
- package/main.d.ts +7 -9
- package/main.js +33 -49
- package/{tabs-nav → nav-tabs}/NavTabs.js +6 -6
- package/{tabs-nav → nav-tabs}/NavTabs.stories.tsx +96 -6
- package/{tabs-nav → nav-tabs}/NavTabs.test.js +1 -1
- package/{tabs-nav → nav-tabs}/Tab.js +40 -22
- package/{tabs-nav → nav-tabs}/types.d.ts +1 -1
- package/number-input/NumberInput.test.js +44 -8
- package/package.json +17 -21
- package/paginator/Icons.d.ts +5 -0
- package/paginator/Icons.js +16 -28
- package/paginator/Paginator.js +7 -15
- package/paginator/Paginator.stories.tsx +24 -0
- package/paginator/Paginator.test.js +78 -39
- package/paragraph/Paragraph.d.ts +5 -0
- package/paragraph/Paragraph.js +38 -0
- package/paragraph/Paragraph.stories.tsx +44 -0
- package/password-input/PasswordInput.test.js +14 -13
- package/progress-bar/ProgressBar.js +60 -54
- package/progress-bar/ProgressBar.stories.jsx +38 -3
- package/progress-bar/ProgressBar.test.js +68 -23
- package/quick-nav/QuickNav.js +25 -20
- package/quick-nav/QuickNav.stories.tsx +145 -26
- package/radio-group/Radio.d.ts +1 -1
- package/radio-group/Radio.js +43 -28
- package/radio-group/RadioGroup.js +23 -22
- package/radio-group/RadioGroup.stories.tsx +132 -18
- package/radio-group/RadioGroup.test.js +124 -97
- package/radio-group/types.d.ts +2 -2
- package/resultsetTable/Icons.d.ts +7 -0
- package/resultsetTable/Icons.js +51 -0
- package/resultsetTable/ResultsetTable.js +49 -108
- package/resultsetTable/ResultsetTable.stories.tsx +50 -25
- package/resultsetTable/ResultsetTable.test.js +61 -42
- package/resultsetTable/types.d.ts +1 -1
- package/select/Listbox.d.ts +1 -1
- package/select/Listbox.js +33 -16
- package/select/Option.js +11 -24
- package/select/Select.js +92 -71
- package/select/Select.stories.tsx +513 -136
- package/select/Select.test.js +413 -305
- package/select/types.d.ts +3 -6
- package/sidenav/Icons.d.ts +7 -0
- package/sidenav/Icons.js +51 -0
- package/sidenav/Sidenav.d.ts +6 -5
- package/sidenav/Sidenav.js +139 -48
- package/sidenav/Sidenav.stories.tsx +251 -151
- package/sidenav/Sidenav.test.js +25 -37
- package/sidenav/types.d.ts +52 -26
- package/slider/Slider.d.ts +2 -2
- package/slider/Slider.js +121 -97
- package/slider/Slider.stories.tsx +64 -1
- package/slider/Slider.test.js +122 -22
- package/slider/types.d.ts +4 -0
- package/spinner/Spinner.js +17 -23
- package/spinner/Spinner.stories.jsx +53 -27
- package/spinner/Spinner.test.js +1 -1
- package/switch/Switch.d.ts +2 -2
- package/switch/Switch.js +137 -70
- package/switch/Switch.stories.tsx +41 -30
- package/switch/Switch.test.js +145 -18
- package/switch/types.d.ts +4 -0
- package/table/Table.js +3 -3
- package/table/Table.stories.jsx +80 -1
- package/table/Table.test.js +2 -2
- package/tabs/Tab.d.ts +4 -0
- package/tabs/Tab.js +132 -0
- package/tabs/Tabs.js +358 -108
- package/tabs/Tabs.stories.tsx +119 -5
- package/tabs/Tabs.test.js +220 -10
- package/tabs/types.d.ts +13 -3
- package/tag/Tag.js +8 -10
- package/tag/Tag.stories.tsx +14 -1
- package/tag/Tag.test.js +1 -1
- package/tag/types.d.ts +1 -1
- package/text-input/Icons.d.ts +8 -0
- package/text-input/Icons.js +60 -0
- package/text-input/Suggestion.js +40 -11
- package/text-input/Suggestions.d.ts +4 -0
- package/text-input/Suggestions.js +134 -0
- package/text-input/TextInput.js +198 -295
- package/text-input/TextInput.stories.tsx +280 -185
- package/text-input/TextInput.test.js +736 -725
- package/text-input/types.d.ts +22 -3
- package/textarea/Textarea.js +3 -4
- package/textarea/Textarea.stories.jsx +60 -1
- package/textarea/Textarea.test.js +2 -4
- package/toggle-group/ToggleGroup.js +7 -4
- package/toggle-group/ToggleGroup.stories.tsx +42 -0
- package/toggle-group/ToggleGroup.test.js +1 -1
- package/toggle-group/types.d.ts +2 -2
- package/typography/Typography.d.ts +4 -0
- package/typography/Typography.js +32 -0
- package/typography/Typography.stories.tsx +198 -0
- package/typography/types.d.ts +18 -0
- package/typography/types.js +5 -0
- package/useTheme.d.ts +1234 -1
- package/useTheme.js +1 -1
- package/useTranslatedLabels.d.ts +84 -1
- package/utils/BaseTypography.d.ts +21 -0
- package/utils/BaseTypography.js +108 -0
- package/utils/FocusLock.d.ts +13 -0
- package/utils/FocusLock.js +139 -0
- package/wizard/Wizard.js +10 -17
- package/wizard/Wizard.stories.tsx +40 -1
- package/wizard/Wizard.test.js +1 -1
- package/wizard/types.d.ts +3 -3
- package/common/RequiredComponent.js +0 -32
- package/list/List.d.ts +0 -4
- package/list/List.js +0 -47
- package/list/List.stories.tsx +0 -95
- package/list/types.d.ts +0 -7
- package/row/Row.d.ts +0 -3
- package/row/Row.js +0 -127
- package/row/Row.stories.tsx +0 -237
- package/row/types.d.ts +0 -28
- package/stack/Stack.d.ts +0 -3
- package/stack/Stack.js +0 -97
- package/stack/Stack.stories.tsx +0 -164
- package/stack/types.d.ts +0 -24
- package/text/Text.d.ts +0 -7
- package/text/Text.js +0 -30
- package/text/Text.stories.tsx +0 -19
- /package/{list → bulleted-list}/types.js +0 -0
- /package/{row → flex}/types.js +0 -0
- /package/{stack → grid}/types.js +0 -0
- /package/{tabs-nav → nav-tabs}/NavTabs.d.ts +0 -0
- /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
- /package/{tabs-nav → nav-tabs}/types.js +0 -0
|
@@ -19,7 +19,7 @@ var _react = _interopRequireWildcard(require("react"));
|
|
|
19
19
|
|
|
20
20
|
var _styledComponents = _interopRequireWildcard(require("styled-components"));
|
|
21
21
|
|
|
22
|
-
var _variables = require("../common/variables
|
|
22
|
+
var _variables = require("../common/variables");
|
|
23
23
|
|
|
24
24
|
var _Table = _interopRequireDefault(require("../table/Table"));
|
|
25
25
|
|
|
@@ -27,17 +27,21 @@ var _Paginator = _interopRequireDefault(require("../paginator/Paginator"));
|
|
|
27
27
|
|
|
28
28
|
var _useTheme = _interopRequireDefault(require("../useTheme"));
|
|
29
29
|
|
|
30
|
-
var
|
|
30
|
+
var _Icons = _interopRequireDefault(require("./Icons"));
|
|
31
|
+
|
|
32
|
+
var _utils = require("../common/utils");
|
|
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 === "
|
|
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)("
|
|
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 ===
|
|
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
|
-
|
|
165
|
-
|
|
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(
|
|
181
|
-
return /*#__PURE__*/_react["default"].createElement(
|
|
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
|
-
|
|
139
|
+
column.isSortable && changeSorting(index);
|
|
187
140
|
},
|
|
188
141
|
tabIndex: column.isSortable ? tabIndex : -1,
|
|
189
142
|
isSortable: column.isSortable
|
|
190
|
-
}, /*#__PURE__*/_react["default"].createElement(
|
|
191
|
-
|
|
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
|
-
})))
|
|
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
|
|
214
|
-
|
|
215
|
-
|
|
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(
|
|
240
|
-
return props.
|
|
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}
|
|
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}
|
|
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}
|
|
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"}
|
|
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"}
|
|
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"}
|
|
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"}
|
|
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"}
|
|
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"}
|
|
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"}
|
|
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}
|
|
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
|
-
|
|
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}
|
|
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
|
-
|
|
246
|
-
await userEvent.click(
|
|
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}
|
|
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}
|
|
291
|
+
<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
|
|
267
292
|
</ExampleContainer>
|
|
268
293
|
);
|
|
269
294
|
|
|
@@ -2,13 +2,50 @@
|
|
|
2
2
|
|
|
3
3
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
4
|
|
|
5
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
6
|
+
|
|
7
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
8
|
+
|
|
5
9
|
var _react = _interopRequireDefault(require("react"));
|
|
6
10
|
|
|
7
11
|
var _react2 = require("@testing-library/react");
|
|
8
12
|
|
|
9
13
|
var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
|
|
10
14
|
|
|
11
|
-
var _ResultsetTable = _interopRequireDefault(require("./ResultsetTable"));
|
|
15
|
+
var _ResultsetTable = _interopRequireDefault(require("./ResultsetTable.tsx"));
|
|
16
|
+
|
|
17
|
+
// Mocking DOMRect for Radix Primitive Popover
|
|
18
|
+
global.globalThis = global;
|
|
19
|
+
global.DOMRect = {
|
|
20
|
+
fromRect: function fromRect() {
|
|
21
|
+
return {
|
|
22
|
+
top: 0,
|
|
23
|
+
left: 0,
|
|
24
|
+
bottom: 0,
|
|
25
|
+
right: 0,
|
|
26
|
+
width: 0,
|
|
27
|
+
height: 0
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
global.ResizeObserver = /*#__PURE__*/function () {
|
|
33
|
+
function ResizeObserver() {
|
|
34
|
+
(0, _classCallCheck2["default"])(this, ResizeObserver);
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
(0, _createClass2["default"])(ResizeObserver, [{
|
|
38
|
+
key: "observe",
|
|
39
|
+
value: function observe() {}
|
|
40
|
+
}, {
|
|
41
|
+
key: "unobserve",
|
|
42
|
+
value: function unobserve() {}
|
|
43
|
+
}, {
|
|
44
|
+
key: "disconnect",
|
|
45
|
+
value: function disconnect() {}
|
|
46
|
+
}]);
|
|
47
|
+
return ResizeObserver;
|
|
48
|
+
}();
|
|
12
49
|
|
|
13
50
|
var columns = [{
|
|
14
51
|
displayValue: "Id",
|
|
@@ -38,8 +75,6 @@ var rows = [[{
|
|
|
38
75
|
}, {
|
|
39
76
|
displayValue: "Oviedo",
|
|
40
77
|
sortValue: "Oviedo"
|
|
41
|
-
}, {
|
|
42
|
-
displayValue: ""
|
|
43
78
|
}], [{
|
|
44
79
|
displayValue: "003",
|
|
45
80
|
sortValue: "003"
|
|
@@ -76,8 +111,6 @@ var rows = [[{
|
|
|
76
111
|
}, {
|
|
77
112
|
displayValue: "Barcelona",
|
|
78
113
|
sortValue: "Barcelona"
|
|
79
|
-
}, {
|
|
80
|
-
displayValue: ""
|
|
81
114
|
}], [{
|
|
82
115
|
displayValue: "007",
|
|
83
116
|
sortValue: "007"
|
|
@@ -105,8 +138,6 @@ var rows = [[{
|
|
|
105
138
|
}, {
|
|
106
139
|
displayValue: "Oviedo",
|
|
107
140
|
sortValue: "Oviedo"
|
|
108
|
-
}, {
|
|
109
|
-
displayValue: ""
|
|
110
141
|
}], [{
|
|
111
142
|
displayValue: "010",
|
|
112
143
|
sortValue: "010"
|
|
@@ -116,8 +147,6 @@ var rows = [[{
|
|
|
116
147
|
}, {
|
|
117
148
|
displayValue: "Barcelona",
|
|
118
149
|
sortValue: "Barcelona"
|
|
119
|
-
}, {
|
|
120
|
-
displayValue: ""
|
|
121
150
|
}]];
|
|
122
151
|
var rows2 = [[{
|
|
123
152
|
displayValue: "546",
|
|
@@ -149,8 +178,8 @@ var rows2 = [[{
|
|
|
149
178
|
displayValue: "OtherValue",
|
|
150
179
|
sortValue: "OtherValue"
|
|
151
180
|
}]];
|
|
152
|
-
describe("
|
|
153
|
-
test("
|
|
181
|
+
describe("Resultset table component tests", function () {
|
|
182
|
+
test("Resultset table rendered correctly", function () {
|
|
154
183
|
var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
155
184
|
columns: columns,
|
|
156
185
|
rows: rows,
|
|
@@ -160,7 +189,7 @@ describe("ResultsetTable component tests", function () {
|
|
|
160
189
|
|
|
161
190
|
expect(getByText("Peter")).toBeTruthy();
|
|
162
191
|
});
|
|
163
|
-
test("
|
|
192
|
+
test("Resultset table shows as many rows as itemsPerPage", function () {
|
|
164
193
|
var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
165
194
|
columns: columns,
|
|
166
195
|
rows: rows,
|
|
@@ -170,7 +199,7 @@ describe("ResultsetTable component tests", function () {
|
|
|
170
199
|
|
|
171
200
|
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
172
201
|
});
|
|
173
|
-
test("
|
|
202
|
+
test("Resultset table shows rows on second page", function () {
|
|
174
203
|
var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
175
204
|
columns: columns,
|
|
176
205
|
rows: rows,
|
|
@@ -183,18 +212,17 @@ describe("ResultsetTable component tests", function () {
|
|
|
183
212
|
expect(getByText("Louis")).toBeTruthy();
|
|
184
213
|
expect(getByText("Lana")).toBeTruthy();
|
|
185
214
|
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
186
|
-
var nextButton = getAllByRole("button")[
|
|
215
|
+
var nextButton = getAllByRole("button")[3];
|
|
187
216
|
|
|
188
217
|
_react2.fireEvent.click(nextButton);
|
|
189
218
|
|
|
190
|
-
expect(getByText("4 to 6 of 10")).toBeTruthy();
|
|
191
|
-
|
|
219
|
+
expect(getByText("4 to 6 of 10")).toBeTruthy();
|
|
192
220
|
expect(getByText("Rick")).toBeTruthy();
|
|
193
221
|
expect(getByText("Mark")).toBeTruthy();
|
|
194
222
|
expect(getByText("Cris")).toBeTruthy();
|
|
195
223
|
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
196
224
|
});
|
|
197
|
-
test("
|
|
225
|
+
test("Resultset table goToPage works as expected", function () {
|
|
198
226
|
window.HTMLElement.prototype.scrollIntoView = function () {};
|
|
199
227
|
|
|
200
228
|
window.HTMLElement.prototype.scrollTo = function () {};
|
|
@@ -206,28 +234,27 @@ describe("ResultsetTable component tests", function () {
|
|
|
206
234
|
itemsPerPage: 3
|
|
207
235
|
})),
|
|
208
236
|
getByText = _render4.getByText,
|
|
209
|
-
getAllByRole = _render4.getAllByRole
|
|
210
|
-
getByRole = _render4.getByRole;
|
|
237
|
+
getAllByRole = _render4.getAllByRole;
|
|
211
238
|
|
|
212
239
|
expect(getByText("Peter")).toBeTruthy();
|
|
213
240
|
expect(getByText("Louis")).toBeTruthy();
|
|
214
241
|
expect(getByText("Lana")).toBeTruthy();
|
|
215
242
|
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
216
|
-
var goToPageSelect = getAllByRole("button")[
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
243
|
+
var goToPageSelect = getAllByRole("button")[3];
|
|
244
|
+
|
|
245
|
+
_userEvent["default"].click(goToPageSelect);
|
|
246
|
+
|
|
220
247
|
var goToPageOption = getByText("2");
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
248
|
+
|
|
249
|
+
_userEvent["default"].click(goToPageOption);
|
|
250
|
+
|
|
224
251
|
expect(getByText("4 to 6 of 10")).toBeTruthy();
|
|
225
252
|
expect(getByText("Rick")).toBeTruthy();
|
|
226
253
|
expect(getByText("Mark")).toBeTruthy();
|
|
227
254
|
expect(getByText("Cris")).toBeTruthy();
|
|
228
255
|
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
229
256
|
});
|
|
230
|
-
test("
|
|
257
|
+
test("Resultset table going to the last page shows only one row", function () {
|
|
231
258
|
var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
232
259
|
columns: columns,
|
|
233
260
|
rows: rows,
|
|
@@ -236,7 +263,7 @@ describe("ResultsetTable component tests", function () {
|
|
|
236
263
|
getByText = _render5.getByText,
|
|
237
264
|
getAllByRole = _render5.getAllByRole;
|
|
238
265
|
|
|
239
|
-
var lastButton = getAllByRole("button")[
|
|
266
|
+
var lastButton = getAllByRole("button")[4];
|
|
240
267
|
|
|
241
268
|
_react2.fireEvent.click(lastButton);
|
|
242
269
|
|
|
@@ -244,7 +271,7 @@ describe("ResultsetTable component tests", function () {
|
|
|
244
271
|
expect(getAllByRole("row")).toHaveLength(2);
|
|
245
272
|
expect(getByText("Cosmin")).toBeTruthy();
|
|
246
273
|
});
|
|
247
|
-
test("
|
|
274
|
+
test("Resultset table sort rows by column", function () {
|
|
248
275
|
var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
249
276
|
columns: columns,
|
|
250
277
|
rows: rows,
|
|
@@ -262,7 +289,7 @@ describe("ResultsetTable component tests", function () {
|
|
|
262
289
|
expect(component.queryByText("Tina")).toBeTruthy();
|
|
263
290
|
expect(component.queryByText("Cosmin")).not.toBeTruthy();
|
|
264
291
|
});
|
|
265
|
-
test("
|
|
292
|
+
test("Resultset table change rows should go to first page", function () {
|
|
266
293
|
var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
267
294
|
columns: columns,
|
|
268
295
|
rows: rows,
|
|
@@ -279,28 +306,20 @@ describe("ResultsetTable component tests", function () {
|
|
|
279
306
|
}));
|
|
280
307
|
expect(queryByText("1 to 3 of 3")).toBeTruthy();
|
|
281
308
|
});
|
|
282
|
-
test("
|
|
309
|
+
test("Resultset table change itemsPerPage should go to first page", function () {
|
|
283
310
|
var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
284
311
|
columns: columns,
|
|
285
312
|
rows: rows,
|
|
286
313
|
itemsPerPage: 3,
|
|
287
314
|
itemsPerPageOptions: [2, 3]
|
|
288
315
|
})),
|
|
289
|
-
getAllByRole = _render7.getAllByRole
|
|
290
|
-
queryByText = _render7.queryByText,
|
|
291
|
-
rerender = _render7.rerender;
|
|
316
|
+
getAllByRole = _render7.getAllByRole;
|
|
292
317
|
|
|
293
|
-
var lastButton = getAllByRole("button")[
|
|
318
|
+
var lastButton = getAllByRole("button")[4];
|
|
319
|
+
expect(getAllByRole("row").length - 1).toEqual(3);
|
|
294
320
|
|
|
295
321
|
_react2.fireEvent.click(lastButton);
|
|
296
322
|
|
|
297
323
|
expect(getAllByRole("row").length - 1).toEqual(1);
|
|
298
|
-
rerender( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
|
|
299
|
-
columns: columns,
|
|
300
|
-
rows: rows,
|
|
301
|
-
itemsPerPage: 6
|
|
302
|
-
}));
|
|
303
|
-
expect(getAllByRole("row").length - 1).toEqual(6);
|
|
304
|
-
expect(queryByText("Peter")).toBeTruthy();
|
|
305
324
|
});
|
|
306
325
|
});
|