@dxc-technology/halstack-react 0.0.0-e1a279c → 0.0.0-e201636

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 (281) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +1 -4
  3. package/HalstackContext.d.ts +12 -0
  4. package/HalstackContext.js +295 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +15 -47
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +72 -0
  9. package/accordion/types.d.ts +8 -8
  10. package/accordion-group/AccordionGroup.d.ts +1 -1
  11. package/accordion-group/AccordionGroup.js +15 -17
  12. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  13. package/accordion-group/AccordionGroup.test.js +151 -0
  14. package/accordion-group/types.d.ts +8 -8
  15. package/alert/Alert.js +6 -3
  16. package/alert/Alert.test.js +92 -0
  17. package/alert/types.d.ts +1 -1
  18. package/badge/Badge.d.ts +4 -0
  19. package/badge/Badge.js +6 -4
  20. package/badge/types.d.ts +5 -0
  21. package/{radio → badge}/types.js +0 -0
  22. package/bleed/Bleed.d.ts +3 -0
  23. package/bleed/Bleed.js +84 -0
  24. package/bleed/Bleed.stories.tsx +342 -0
  25. package/bleed/types.d.ts +37 -0
  26. package/bleed/types.js +5 -0
  27. package/box/Box.d.ts +1 -1
  28. package/box/Box.js +26 -39
  29. package/box/Box.test.js +18 -0
  30. package/box/types.d.ts +0 -4
  31. package/button/Button.d.ts +1 -1
  32. package/button/Button.js +24 -27
  33. package/button/Button.stories.tsx +6 -8
  34. package/button/Button.test.js +35 -0
  35. package/button/types.d.ts +5 -9
  36. package/card/Card.js +32 -34
  37. package/card/Card.stories.tsx +201 -0
  38. package/card/Card.test.js +50 -0
  39. package/card/ice-cream.jpg +0 -0
  40. package/card/types.d.ts +4 -6
  41. package/checkbox/Checkbox.d.ts +1 -1
  42. package/checkbox/Checkbox.js +45 -41
  43. package/checkbox/Checkbox.stories.tsx +124 -128
  44. package/checkbox/Checkbox.test.js +78 -0
  45. package/checkbox/types.d.ts +9 -5
  46. package/chip/Chip.d.ts +4 -0
  47. package/chip/Chip.js +16 -76
  48. package/chip/Chip.stories.tsx +6 -8
  49. package/chip/Chip.test.js +56 -0
  50. package/chip/types.d.ts +45 -0
  51. package/chip/types.js +5 -0
  52. package/common/variables.js +234 -341
  53. package/date-input/DateInput.js +63 -52
  54. package/date-input/DateInput.stories.tsx +7 -7
  55. package/date-input/DateInput.test.js +479 -0
  56. package/date-input/types.d.ts +16 -9
  57. package/dialog/Dialog.js +8 -35
  58. package/dialog/Dialog.test.js +40 -0
  59. package/dropdown/Dropdown.d.ts +1 -1
  60. package/dropdown/Dropdown.js +22 -48
  61. package/dropdown/Dropdown.stories.tsx +249 -0
  62. package/dropdown/Dropdown.test.js +189 -0
  63. package/dropdown/types.d.ts +6 -15
  64. package/file-input/FileInput.d.ts +4 -0
  65. package/file-input/FileInput.js +172 -111
  66. package/file-input/FileInput.stories.tsx +507 -0
  67. package/file-input/FileInput.test.js +457 -0
  68. package/file-input/FileItem.d.ts +14 -0
  69. package/file-input/FileItem.js +16 -23
  70. package/file-input/types.d.ts +112 -0
  71. package/file-input/types.js +5 -0
  72. package/footer/Footer.d.ts +1 -1
  73. package/footer/Footer.js +32 -113
  74. package/footer/{Footer.stories.jsx → Footer.stories.tsx} +1 -22
  75. package/footer/Footer.test.js +109 -0
  76. package/footer/Icons.d.ts +2 -0
  77. package/footer/Icons.js +3 -3
  78. package/footer/types.d.ts +22 -18
  79. package/header/Header.js +29 -50
  80. package/header/Header.stories.tsx +172 -0
  81. package/header/Header.test.js +79 -0
  82. package/header/Icons.d.ts +2 -0
  83. package/header/types.d.ts +4 -2
  84. package/heading/Heading.d.ts +4 -0
  85. package/heading/Heading.js +7 -24
  86. package/heading/Heading.stories.tsx +54 -0
  87. package/heading/Heading.test.js +186 -0
  88. package/heading/types.d.ts +33 -0
  89. package/heading/types.js +5 -0
  90. package/inset/Inset.d.ts +3 -0
  91. package/inset/Inset.js +84 -0
  92. package/inset/Inset.stories.tsx +229 -0
  93. package/inset/types.d.ts +37 -0
  94. package/inset/types.js +5 -0
  95. package/layout/ApplicationLayout.d.ts +11 -0
  96. package/layout/ApplicationLayout.js +84 -120
  97. package/layout/ApplicationLayout.stories.tsx +126 -0
  98. package/layout/Icons.d.ts +5 -0
  99. package/layout/Icons.js +13 -2
  100. package/layout/SidenavContext.d.ts +5 -0
  101. package/layout/SidenavContext.js +19 -0
  102. package/layout/types.d.ts +52 -0
  103. package/layout/types.js +5 -0
  104. package/link/Link.d.ts +3 -2
  105. package/link/Link.js +61 -86
  106. package/link/Link.stories.tsx +131 -15
  107. package/link/Link.test.js +83 -0
  108. package/link/types.d.ts +9 -29
  109. package/list/List.d.ts +4 -0
  110. package/list/List.js +47 -0
  111. package/list/List.stories.tsx +95 -0
  112. package/list/types.d.ts +7 -0
  113. package/list/types.js +5 -0
  114. package/main.d.ts +12 -9
  115. package/main.js +72 -42
  116. package/number-input/NumberInput.js +14 -24
  117. package/number-input/NumberInput.stories.tsx +5 -5
  118. package/number-input/NumberInput.test.js +506 -0
  119. package/number-input/NumberInputContext.d.ts +4 -0
  120. package/number-input/NumberInputContext.js +5 -2
  121. package/number-input/numberInputContextTypes.d.ts +19 -0
  122. package/number-input/numberInputContextTypes.js +5 -0
  123. package/number-input/types.d.ts +17 -10
  124. package/package.json +9 -6
  125. package/paginator/Paginator.js +19 -46
  126. package/paginator/Paginator.test.js +266 -0
  127. package/password-input/PasswordInput.js +23 -19
  128. package/password-input/PasswordInput.stories.tsx +3 -3
  129. package/password-input/PasswordInput.test.js +180 -0
  130. package/password-input/types.d.ts +29 -19
  131. package/progress-bar/ProgressBar.js +5 -5
  132. package/progress-bar/ProgressBar.stories.jsx +11 -11
  133. package/progress-bar/ProgressBar.test.js +65 -0
  134. package/quick-nav/QuickNav.d.ts +4 -0
  135. package/quick-nav/QuickNav.js +112 -0
  136. package/quick-nav/QuickNav.stories.tsx +237 -0
  137. package/quick-nav/types.d.ts +21 -0
  138. package/quick-nav/types.js +5 -0
  139. package/radio-group/Radio.d.ts +4 -0
  140. package/radio-group/Radio.js +141 -0
  141. package/radio-group/RadioGroup.d.ts +4 -0
  142. package/radio-group/RadioGroup.js +282 -0
  143. package/radio-group/RadioGroup.stories.tsx +100 -0
  144. package/radio-group/RadioGroup.test.js +695 -0
  145. package/radio-group/types.d.ts +114 -0
  146. package/radio-group/types.js +5 -0
  147. package/resultsetTable/ResultsetTable.d.ts +4 -0
  148. package/resultsetTable/ResultsetTable.js +9 -29
  149. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  150. package/resultsetTable/ResultsetTable.test.js +306 -0
  151. package/resultsetTable/types.d.ts +67 -0
  152. package/resultsetTable/types.js +5 -0
  153. package/row/Row.d.ts +3 -0
  154. package/row/Row.js +127 -0
  155. package/row/Row.stories.tsx +237 -0
  156. package/row/types.d.ts +28 -0
  157. package/row/types.js +5 -0
  158. package/select/Icons.d.ts +10 -0
  159. package/select/Icons.js +93 -0
  160. package/select/Listbox.d.ts +4 -0
  161. package/select/Listbox.js +152 -0
  162. package/select/Option.d.ts +4 -0
  163. package/select/Option.js +110 -0
  164. package/select/Select.d.ts +4 -0
  165. package/select/Select.js +122 -342
  166. package/select/Select.stories.tsx +103 -81
  167. package/select/Select.test.js +2120 -0
  168. package/select/types.d.ts +213 -0
  169. package/select/types.js +5 -0
  170. package/sidenav/Sidenav.d.ts +1 -1
  171. package/sidenav/Sidenav.js +22 -11
  172. package/sidenav/Sidenav.stories.tsx +182 -0
  173. package/sidenav/Sidenav.test.js +56 -0
  174. package/slider/Slider.d.ts +1 -1
  175. package/slider/Slider.js +6 -5
  176. package/slider/Slider.stories.tsx +8 -8
  177. package/slider/Slider.test.js +150 -0
  178. package/slider/types.d.ts +4 -0
  179. package/spinner/Spinner.js +3 -3
  180. package/spinner/Spinner.stories.jsx +1 -0
  181. package/spinner/Spinner.test.js +64 -0
  182. package/stack/Stack.d.ts +3 -0
  183. package/stack/Stack.js +97 -0
  184. package/stack/Stack.stories.tsx +164 -0
  185. package/stack/types.d.ts +24 -0
  186. package/stack/types.js +5 -0
  187. package/switch/Switch.d.ts +1 -1
  188. package/switch/Switch.js +37 -21
  189. package/switch/Switch.stories.tsx +15 -15
  190. package/switch/Switch.test.js +98 -0
  191. package/switch/types.d.ts +6 -2
  192. package/table/Table.js +3 -3
  193. package/table/Table.stories.jsx +2 -1
  194. package/table/Table.test.js +26 -0
  195. package/tabs/Tabs.d.ts +1 -1
  196. package/tabs/Tabs.js +20 -20
  197. package/tabs/Tabs.stories.tsx +112 -0
  198. package/tabs/Tabs.test.js +140 -0
  199. package/tabs/types.d.ts +29 -18
  200. package/tabs-nav/NavTabs.d.ts +8 -0
  201. package/tabs-nav/NavTabs.js +125 -0
  202. package/tabs-nav/NavTabs.stories.tsx +170 -0
  203. package/tabs-nav/NavTabs.test.js +82 -0
  204. package/tabs-nav/Tab.d.ts +4 -0
  205. package/tabs-nav/Tab.js +132 -0
  206. package/tabs-nav/types.d.ts +53 -0
  207. package/tabs-nav/types.js +5 -0
  208. package/tag/Tag.d.ts +1 -1
  209. package/tag/Tag.js +18 -28
  210. package/tag/Tag.stories.tsx +26 -29
  211. package/tag/Tag.test.js +60 -0
  212. package/tag/types.d.ts +23 -14
  213. package/text/Text.d.ts +7 -0
  214. package/text/Text.js +30 -0
  215. package/text/Text.stories.tsx +19 -0
  216. package/text-input/Suggestion.d.ts +4 -0
  217. package/text-input/Suggestion.js +55 -0
  218. package/text-input/TextInput.d.ts +4 -0
  219. package/text-input/TextInput.js +91 -146
  220. package/text-input/TextInput.stories.tsx +474 -0
  221. package/text-input/TextInput.test.js +1712 -0
  222. package/text-input/types.d.ts +178 -0
  223. package/text-input/types.js +5 -0
  224. package/textarea/Textarea.d.ts +4 -0
  225. package/textarea/Textarea.js +39 -79
  226. package/textarea/Textarea.stories.jsx +37 -15
  227. package/textarea/Textarea.test.js +437 -0
  228. package/textarea/types.d.ts +137 -0
  229. package/textarea/types.js +5 -0
  230. package/toggle-group/ToggleGroup.d.ts +4 -0
  231. package/toggle-group/ToggleGroup.js +18 -46
  232. package/toggle-group/ToggleGroup.stories.tsx +27 -32
  233. package/toggle-group/ToggleGroup.test.js +156 -0
  234. package/toggle-group/types.d.ts +105 -0
  235. package/toggle-group/types.js +5 -0
  236. package/useTheme.d.ts +2 -0
  237. package/useTheme.js +2 -2
  238. package/useTranslatedLabels.d.ts +2 -0
  239. package/useTranslatedLabels.js +20 -0
  240. package/wizard/Wizard.d.ts +1 -1
  241. package/wizard/Wizard.js +107 -46
  242. package/wizard/{Wizard.stories.jsx → Wizard.stories.tsx} +13 -23
  243. package/wizard/Wizard.test.js +141 -0
  244. package/wizard/types.d.ts +9 -9
  245. package/ThemeContext.js +0 -246
  246. package/V3Select/V3Select.js +0 -455
  247. package/V3Select/index.d.ts +0 -27
  248. package/V3Textarea/V3Textarea.js +0 -260
  249. package/V3Textarea/index.d.ts +0 -27
  250. package/chip/index.d.ts +0 -22
  251. package/date/Date.js +0 -373
  252. package/date/index.d.ts +0 -27
  253. package/file-input/index.d.ts +0 -81
  254. package/heading/index.d.ts +0 -17
  255. package/input-text/Icons.js +0 -22
  256. package/input-text/InputText.js +0 -611
  257. package/input-text/index.d.ts +0 -36
  258. package/radio/Radio.d.ts +0 -4
  259. package/radio/Radio.js +0 -174
  260. package/radio/Radio.stories.tsx +0 -192
  261. package/radio/types.d.ts +0 -54
  262. package/resultsetTable/index.d.ts +0 -19
  263. package/select/index.d.ts +0 -131
  264. package/text-input/index.d.ts +0 -135
  265. package/textarea/index.d.ts +0 -117
  266. package/toggle/Toggle.js +0 -186
  267. package/toggle/index.d.ts +0 -21
  268. package/toggle-group/index.d.ts +0 -21
  269. package/upload/Upload.js +0 -201
  270. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  271. package/upload/buttons-upload/Icons.js +0 -40
  272. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  273. package/upload/dragAndDropArea/Icons.js +0 -39
  274. package/upload/file-upload/FileToUpload.js +0 -115
  275. package/upload/file-upload/Icons.js +0 -66
  276. package/upload/files-upload/FilesToUpload.js +0 -109
  277. package/upload/index.d.ts +0 -15
  278. package/upload/transaction/Icons.js +0 -160
  279. package/upload/transaction/Transaction.js +0 -104
  280. package/upload/transactions/Transactions.js +0 -94
  281. package/wizard/Icons.js +0 -65
@@ -0,0 +1,306 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _react2 = require("@testing-library/react");
8
+
9
+ var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
10
+
11
+ var _ResultsetTable = _interopRequireDefault(require("./ResultsetTable"));
12
+
13
+ var columns = [{
14
+ displayValue: "Id",
15
+ isSortable: false
16
+ }, {
17
+ displayValue: "Name",
18
+ isSortable: true
19
+ }, {
20
+ displayValue: "City",
21
+ isSortable: false
22
+ }];
23
+ var rows = [[{
24
+ displayValue: "001",
25
+ sortValue: "001"
26
+ }, {
27
+ displayValue: "Peter",
28
+ sortValue: "Peter"
29
+ }, {
30
+ displayValue: "Oviedo",
31
+ sortValue: "Oviedo"
32
+ }], [{
33
+ displayValue: "002",
34
+ sortValue: "002"
35
+ }, {
36
+ displayValue: "Louis",
37
+ sortValue: "Louis"
38
+ }, {
39
+ displayValue: "Oviedo",
40
+ sortValue: "Oviedo"
41
+ }, {
42
+ displayValue: ""
43
+ }], [{
44
+ displayValue: "003",
45
+ sortValue: "003"
46
+ }, {
47
+ displayValue: "Lana",
48
+ sortValue: "Lana"
49
+ }, {
50
+ displayValue: "Albacete",
51
+ sortValue: "Albacete"
52
+ }], [{
53
+ displayValue: "004",
54
+ sortValue: "004"
55
+ }, {
56
+ displayValue: "Rick",
57
+ sortValue: "Rick"
58
+ }, {
59
+ displayValue: "Albacete",
60
+ sortValue: "Albacete"
61
+ }], [{
62
+ displayValue: "005",
63
+ sortValue: "005"
64
+ }, {
65
+ displayValue: "Mark",
66
+ sortValue: "Mark"
67
+ }, {
68
+ displayValue: "Madrid",
69
+ sortValue: "Madrid"
70
+ }], [{
71
+ displayValue: "006",
72
+ sortValue: "006"
73
+ }, {
74
+ displayValue: "Cris",
75
+ sortValue: "Cris"
76
+ }, {
77
+ displayValue: "Barcelona",
78
+ sortValue: "Barcelona"
79
+ }, {
80
+ displayValue: ""
81
+ }], [{
82
+ displayValue: "007",
83
+ sortValue: "007"
84
+ }, {
85
+ displayValue: "Susan",
86
+ sortValue: "Susan"
87
+ }, {
88
+ displayValue: "Madrid",
89
+ sortValue: "Madrid"
90
+ }], [{
91
+ displayValue: "008",
92
+ sortValue: "008"
93
+ }, {
94
+ displayValue: "Tina",
95
+ sortValue: "Tina"
96
+ }, {
97
+ displayValue: "Barcelona",
98
+ sortValue: "Barcelona"
99
+ }], [{
100
+ displayValue: "009",
101
+ sortValue: "009"
102
+ }, {
103
+ displayValue: "Kevin",
104
+ sortValue: "Kevin"
105
+ }, {
106
+ displayValue: "Oviedo",
107
+ sortValue: "Oviedo"
108
+ }, {
109
+ displayValue: ""
110
+ }], [{
111
+ displayValue: "010",
112
+ sortValue: "010"
113
+ }, {
114
+ displayValue: "Cosmin",
115
+ sortValue: "Cosmin"
116
+ }, {
117
+ displayValue: "Barcelona",
118
+ sortValue: "Barcelona"
119
+ }, {
120
+ displayValue: ""
121
+ }]];
122
+ var rows2 = [[{
123
+ displayValue: "546",
124
+ sortValue: "465"
125
+ }, {
126
+ displayValue: "OtherValue",
127
+ sortValue: "OtherValue"
128
+ }, {
129
+ displayValue: "OtherValue",
130
+ sortValue: "OtherValue"
131
+ }], [{
132
+ displayValue: "978",
133
+ sortValue: "465"
134
+ }, {
135
+ displayValue: "OtherValue",
136
+ sortValue: "OtherValue"
137
+ }, {
138
+ displayValue: "OtherValue",
139
+ sortValue: "OtherValue"
140
+ }, {
141
+ displayValue: ""
142
+ }], [{
143
+ displayValue: "678",
144
+ sortValue: "344"
145
+ }, {
146
+ displayValue: "OtherValue",
147
+ sortValue: "OtherValue"
148
+ }, {
149
+ displayValue: "OtherValue",
150
+ sortValue: "OtherValue"
151
+ }]];
152
+ describe("ResultsetTable component tests", function () {
153
+ test("ResultsetTable rendered correctly", function () {
154
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
155
+ columns: columns,
156
+ rows: rows,
157
+ itemsPerPage: 3
158
+ })),
159
+ getByText = _render.getByText;
160
+
161
+ expect(getByText("Peter")).toBeTruthy();
162
+ });
163
+ test("Resultsettable shows as many rows as itemsPerPage", function () {
164
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
165
+ columns: columns,
166
+ rows: rows,
167
+ itemsPerPage: 3
168
+ })),
169
+ getAllByRole = _render2.getAllByRole;
170
+
171
+ expect(getAllByRole("row").length - 1).toEqual(3);
172
+ });
173
+ test("Resultsettable shows rows on second page", function () {
174
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
175
+ columns: columns,
176
+ rows: rows,
177
+ itemsPerPage: 3
178
+ })),
179
+ getByText = _render3.getByText,
180
+ getAllByRole = _render3.getAllByRole;
181
+
182
+ expect(getByText("Peter")).toBeTruthy();
183
+ expect(getByText("Louis")).toBeTruthy();
184
+ expect(getByText("Lana")).toBeTruthy();
185
+ expect(getAllByRole("row").length - 1).toEqual(3);
186
+ var nextButton = getAllByRole("button")[2];
187
+
188
+ _react2.fireEvent.click(nextButton);
189
+
190
+ expect(getByText("4 to 6 of 10")).toBeTruthy(); // expect(getByText("Page: 2 of 4")).toBeTruthy();
191
+
192
+ expect(getByText("Rick")).toBeTruthy();
193
+ expect(getByText("Mark")).toBeTruthy();
194
+ expect(getByText("Cris")).toBeTruthy();
195
+ expect(getAllByRole("row").length - 1).toEqual(3);
196
+ });
197
+ test("Resultsettable goToPage works as expected", function () {
198
+ window.HTMLElement.prototype.scrollIntoView = function () {};
199
+
200
+ window.HTMLElement.prototype.scrollTo = function () {};
201
+
202
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
203
+ columns: columns,
204
+ showGoToPage: true,
205
+ rows: rows,
206
+ itemsPerPage: 3
207
+ })),
208
+ getByText = _render4.getByText,
209
+ getAllByRole = _render4.getAllByRole,
210
+ getByRole = _render4.getByRole;
211
+
212
+ expect(getByText("Peter")).toBeTruthy();
213
+ expect(getByText("Louis")).toBeTruthy();
214
+ expect(getByText("Lana")).toBeTruthy();
215
+ expect(getAllByRole("row").length - 1).toEqual(3);
216
+ var goToPageSelect = getAllByRole("button")[2];
217
+ (0, _react2.act)(function () {
218
+ _userEvent["default"].click(goToPageSelect);
219
+ });
220
+ var goToPageOption = getByText("2");
221
+ (0, _react2.act)(function () {
222
+ _userEvent["default"].click(goToPageOption);
223
+ });
224
+ expect(getByText("4 to 6 of 10")).toBeTruthy();
225
+ expect(getByText("Rick")).toBeTruthy();
226
+ expect(getByText("Mark")).toBeTruthy();
227
+ expect(getByText("Cris")).toBeTruthy();
228
+ expect(getAllByRole("row").length - 1).toEqual(3);
229
+ });
230
+ test("Resultsettable going to the last page shows only one row", function () {
231
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
232
+ columns: columns,
233
+ rows: rows,
234
+ itemsPerPage: 3
235
+ })),
236
+ getByText = _render5.getByText,
237
+ getAllByRole = _render5.getAllByRole;
238
+
239
+ var lastButton = getAllByRole("button")[3];
240
+
241
+ _react2.fireEvent.click(lastButton);
242
+
243
+ expect(getByText("10 to 10 of 10")).toBeTruthy();
244
+ expect(getAllByRole("row")).toHaveLength(2);
245
+ expect(getByText("Cosmin")).toBeTruthy();
246
+ });
247
+ test("Resultsettable sort rows by column", function () {
248
+ var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
249
+ columns: columns,
250
+ rows: rows,
251
+ itemsPerPage: 3
252
+ }));
253
+ expect(component.queryByText("Peter")).toBeTruthy();
254
+
255
+ _react2.fireEvent.click(component.queryByText("Name"));
256
+
257
+ expect(component.queryByText("Tina")).not.toBeTruthy();
258
+ expect(component.queryByText("Cosmin")).toBeTruthy();
259
+
260
+ _react2.fireEvent.click(component.queryByText("Name"));
261
+
262
+ expect(component.queryByText("Tina")).toBeTruthy();
263
+ expect(component.queryByText("Cosmin")).not.toBeTruthy();
264
+ });
265
+ test("Resultsettable change rows should go to first page", function () {
266
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
267
+ columns: columns,
268
+ rows: rows,
269
+ itemsPerPage: 3
270
+ })),
271
+ queryByText = _render6.queryByText,
272
+ rerender = _render6.rerender;
273
+
274
+ expect(queryByText("Peter")).toBeTruthy();
275
+ rerender( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
276
+ columns: columns,
277
+ rows: rows2,
278
+ itemsPerPage: 3
279
+ }));
280
+ expect(queryByText("1 to 3 of 3")).toBeTruthy();
281
+ });
282
+ test("Resultsettable change itemsPerPage should go to first page", function () {
283
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
284
+ columns: columns,
285
+ rows: rows,
286
+ itemsPerPage: 3,
287
+ itemsPerPageOptions: [2, 3]
288
+ })),
289
+ getAllByRole = _render7.getAllByRole,
290
+ queryByText = _render7.queryByText,
291
+ rerender = _render7.rerender;
292
+
293
+ var lastButton = getAllByRole("button")[3];
294
+
295
+ _react2.fireEvent.click(lastButton);
296
+
297
+ 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
+ });
306
+ });
@@ -0,0 +1,67 @@
1
+ /// <reference types="react" />
2
+ declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ declare type Margin = {
4
+ top?: Space;
5
+ bottom?: Space;
6
+ left?: Space;
7
+ right?: Space;
8
+ };
9
+ declare type Column = {
10
+ /**
11
+ * Column display value.
12
+ */
13
+ displayValue: React.ReactNode;
14
+ /**
15
+ * Boolean value to indicate whether the column is sortable or not.
16
+ */
17
+ isSortable?: boolean;
18
+ };
19
+ declare type Row = {
20
+ /**
21
+ * Value to be displayed in the cell.
22
+ */
23
+ displayValue: React.ReactNode;
24
+ /**
25
+ * Value to be used when sorting the table by that
26
+ * column. If not indicated displayValue will be used for sorting.
27
+ */
28
+ sortValue?: string;
29
+ };
30
+ declare type Props = {
31
+ /**
32
+ * An array of objects representing the columns of the table.
33
+ */
34
+ columns: Column[];
35
+ /**
36
+ * An array of objects representing the rows of the table, you will have
37
+ * as many objects as columns in the table.
38
+ */
39
+ rows: Row[][];
40
+ /**
41
+ * If true, a select component for navigation between pages will be displayed.
42
+ */
43
+ showGoToPage?: boolean;
44
+ /**
45
+ * Number of items per page.
46
+ */
47
+ itemsPerPage?: number;
48
+ /**
49
+ * An array of numbers representing the items per page options.
50
+ */
51
+ itemsPerPageOptions?: number[];
52
+ /**
53
+ * This function will be called when the user selects an item per page
54
+ * option. The value selected will be passed as a parameter.
55
+ */
56
+ itemsPerPageFunction?: (newValue: number) => void;
57
+ /**
58
+ * Size of the margin to be applied to the component. You can pass an object with 'top',
59
+ * 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
60
+ */
61
+ margin?: Space | Margin;
62
+ /**
63
+ * Value of the tabindex attribute given to the sortable icon.
64
+ */
65
+ tabIndex?: number;
66
+ };
67
+ export default Props;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
package/row/Row.d.ts ADDED
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ import RowPropsType from "./types";
3
+ export default function Row({ gutter, align, justify, wrap, reverse, children, }: RowPropsType): JSX.Element;
package/row/Row.js ADDED
@@ -0,0 +1,127 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = Row;
9
+
10
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
11
+
12
+ var _react = _interopRequireDefault(require("react"));
13
+
14
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
15
+
16
+ var _templateObject;
17
+
18
+ function Row(_ref) {
19
+ var _ref$gutter = _ref.gutter,
20
+ gutter = _ref$gutter === void 0 ? "none" : _ref$gutter,
21
+ align = _ref.align,
22
+ justify = _ref.justify,
23
+ _ref$wrap = _ref.wrap,
24
+ wrap = _ref$wrap === void 0 ? true : _ref$wrap,
25
+ _ref$reverse = _ref.reverse,
26
+ reverse = _ref$reverse === void 0 ? false : _ref$reverse,
27
+ children = _ref.children;
28
+ return /*#__PURE__*/_react["default"].createElement(StyledRow, {
29
+ gutter: gutter,
30
+ align: align,
31
+ justify: justify,
32
+ wrap: wrap,
33
+ reverse: reverse
34
+ }, children);
35
+ }
36
+
37
+ var StyledRow = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: ", ";\n flex-wrap: ", ";\n align-items: ", ";\n justify-content: ", ";\n gap: ", ";\n"])), function (_ref2) {
38
+ var reverse = _ref2.reverse;
39
+ return reverse ? "row-reverse" : "row";
40
+ }, function (_ref3) {
41
+ var wrap = _ref3.wrap;
42
+ return wrap ? "wrap" : "nowrap";
43
+ }, function (_ref4) {
44
+ var align = _ref4.align;
45
+
46
+ switch (align) {
47
+ case "start":
48
+ return "flex-start";
49
+
50
+ case "center":
51
+ return "center";
52
+
53
+ case "end":
54
+ return "flex-end";
55
+
56
+ case "baseline":
57
+ return "baseline";
58
+
59
+ case "stretch":
60
+ return "stretch";
61
+
62
+ default:
63
+ return "initial";
64
+ }
65
+ }, function (_ref5) {
66
+ var justify = _ref5.justify;
67
+
68
+ switch (justify) {
69
+ case "spaceBetween":
70
+ return "space-between";
71
+
72
+ case "spaceAround":
73
+ return "space-around";
74
+
75
+ case "spaceEvenly":
76
+ return "space-evenly";
77
+
78
+ case "start":
79
+ return "flex-start";
80
+
81
+ case "center":
82
+ return "center";
83
+
84
+ case "end":
85
+ return "flex-end";
86
+
87
+ default:
88
+ return "initial";
89
+ }
90
+ }, function (_ref6) {
91
+ var gutter = _ref6.gutter;
92
+
93
+ switch (gutter) {
94
+ case "none":
95
+ return "0";
96
+
97
+ case "xxxsmall":
98
+ return "0.125rem";
99
+
100
+ case "xxsmall":
101
+ return "0.25rem";
102
+
103
+ case "xsmall":
104
+ return "0.5rem";
105
+
106
+ case "small":
107
+ return "1rem";
108
+
109
+ case "medium":
110
+ return "1.5rem";
111
+
112
+ case "large":
113
+ return "2rem";
114
+
115
+ case "xlarge":
116
+ return "3rem";
117
+
118
+ case "xxlarge":
119
+ return "4rem";
120
+
121
+ case "xxxlarge":
122
+ return "5rem";
123
+
124
+ default:
125
+ return "0";
126
+ }
127
+ });