@dxc-technology/halstack-react 0.0.0-b22e2a8 → 0.0.0-b230d97

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 (294) 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 +300 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +119 -138
  7. package/accordion/Accordion.stories.tsx +395 -0
  8. package/accordion/Accordion.test.js +71 -0
  9. package/accordion/types.d.ts +12 -11
  10. package/accordion-group/AccordionGroup.d.ts +1 -1
  11. package/accordion-group/AccordionGroup.js +16 -37
  12. package/accordion-group/AccordionGroup.stories.tsx +251 -0
  13. package/accordion-group/AccordionGroup.test.js +126 -0
  14. package/accordion-group/types.d.ts +17 -10
  15. package/alert/Alert.js +7 -4
  16. package/alert/Alert.test.js +92 -0
  17. package/badge/Badge.d.ts +4 -0
  18. package/badge/Badge.js +6 -4
  19. package/badge/types.d.ts +5 -0
  20. package/{radio → badge}/types.js +0 -0
  21. package/bleed/Bleed.d.ts +3 -0
  22. package/bleed/Bleed.js +51 -0
  23. package/bleed/Bleed.stories.tsx +341 -0
  24. package/bleed/types.d.ts +37 -0
  25. package/bleed/types.js +5 -0
  26. package/box/Box.js +25 -35
  27. package/box/Box.test.js +18 -0
  28. package/box/types.d.ts +1 -0
  29. package/bulleted-list/BulletedList.d.ts +7 -0
  30. package/bulleted-list/BulletedList.js +123 -0
  31. package/bulleted-list/BulletedList.stories.tsx +200 -0
  32. package/bulleted-list/types.d.ts +11 -0
  33. package/bulleted-list/types.js +5 -0
  34. package/button/Button.d.ts +1 -1
  35. package/button/Button.js +59 -82
  36. package/button/Button.stories.tsx +163 -14
  37. package/button/Button.test.js +35 -0
  38. package/button/types.d.ts +10 -14
  39. package/card/Card.js +25 -28
  40. package/card/Card.stories.tsx +1 -1
  41. package/card/Card.test.js +50 -0
  42. package/card/types.d.ts +1 -0
  43. package/checkbox/Checkbox.d.ts +2 -2
  44. package/checkbox/Checkbox.js +108 -111
  45. package/checkbox/Checkbox.stories.tsx +198 -130
  46. package/checkbox/Checkbox.test.js +155 -0
  47. package/checkbox/types.d.ts +14 -6
  48. package/chip/Chip.d.ts +4 -0
  49. package/chip/Chip.js +22 -88
  50. package/chip/Chip.stories.tsx +98 -13
  51. package/chip/Chip.test.js +56 -0
  52. package/chip/types.d.ts +45 -0
  53. package/chip/types.js +5 -0
  54. package/common/variables.js +511 -569
  55. package/date-input/Calendar.d.ts +4 -0
  56. package/date-input/Calendar.js +258 -0
  57. package/date-input/DateInput.js +174 -266
  58. package/date-input/DateInput.stories.tsx +137 -38
  59. package/date-input/DateInput.test.js +835 -0
  60. package/date-input/DatePicker.d.ts +4 -0
  61. package/date-input/DatePicker.js +146 -0
  62. package/date-input/Icons.d.ts +6 -0
  63. package/date-input/Icons.js +75 -0
  64. package/date-input/YearPicker.d.ts +4 -0
  65. package/date-input/YearPicker.js +126 -0
  66. package/date-input/types.d.ts +67 -9
  67. package/dialog/Dialog.js +50 -53
  68. package/dialog/Dialog.stories.tsx +57 -2
  69. package/dialog/Dialog.test.js +70 -0
  70. package/dialog/types.d.ts +3 -2
  71. package/dropdown/Dropdown.d.ts +1 -1
  72. package/dropdown/Dropdown.js +248 -277
  73. package/dropdown/Dropdown.stories.tsx +438 -0
  74. package/dropdown/Dropdown.test.js +585 -0
  75. package/dropdown/DropdownMenu.d.ts +4 -0
  76. package/dropdown/DropdownMenu.js +70 -0
  77. package/dropdown/DropdownMenuItem.d.ts +4 -0
  78. package/dropdown/DropdownMenuItem.js +81 -0
  79. package/dropdown/types.d.ts +30 -19
  80. package/file-input/FileInput.d.ts +2 -2
  81. package/file-input/FileInput.js +182 -142
  82. package/file-input/FileInput.stories.tsx +618 -0
  83. package/file-input/FileInput.test.js +498 -0
  84. package/file-input/FileItem.d.ts +4 -14
  85. package/file-input/FileItem.js +46 -67
  86. package/file-input/types.d.ts +49 -7
  87. package/flex/Flex.d.ts +4 -0
  88. package/flex/Flex.js +69 -0
  89. package/flex/Flex.stories.tsx +103 -0
  90. package/flex/types.d.ts +32 -0
  91. package/flex/types.js +5 -0
  92. package/footer/Footer.d.ts +1 -1
  93. package/footer/Footer.js +32 -113
  94. package/footer/Footer.stories.tsx +228 -0
  95. package/footer/Footer.test.js +109 -0
  96. package/footer/Icons.d.ts +2 -0
  97. package/footer/Icons.js +4 -4
  98. package/footer/types.d.ts +22 -17
  99. package/header/Header.js +109 -130
  100. package/header/Header.stories.tsx +167 -36
  101. package/header/Header.test.js +79 -0
  102. package/header/Icons.d.ts +2 -0
  103. package/header/Icons.js +2 -2
  104. package/header/types.d.ts +3 -2
  105. package/heading/Heading.js +1 -1
  106. package/heading/Heading.stories.tsx +3 -2
  107. package/heading/Heading.test.js +186 -0
  108. package/inset/Inset.d.ts +3 -0
  109. package/inset/Inset.js +51 -0
  110. package/inset/Inset.stories.tsx +229 -0
  111. package/inset/types.d.ts +37 -0
  112. package/inset/types.js +5 -0
  113. package/layout/ApplicationLayout.d.ts +20 -0
  114. package/layout/ApplicationLayout.js +71 -135
  115. package/layout/ApplicationLayout.stories.tsx +162 -0
  116. package/layout/Icons.d.ts +5 -0
  117. package/layout/Icons.js +13 -2
  118. package/layout/SidenavContext.d.ts +5 -0
  119. package/layout/SidenavContext.js +19 -0
  120. package/layout/types.d.ts +42 -0
  121. package/layout/types.js +5 -0
  122. package/link/Link.d.ts +3 -2
  123. package/link/Link.js +62 -87
  124. package/link/Link.stories.tsx +99 -52
  125. package/link/Link.test.js +83 -0
  126. package/link/types.d.ts +9 -29
  127. package/main.d.ts +12 -12
  128. package/main.js +64 -58
  129. package/number-input/NumberInput.js +14 -24
  130. package/number-input/NumberInput.stories.tsx +5 -5
  131. package/number-input/NumberInput.test.js +542 -0
  132. package/number-input/types.d.ts +17 -10
  133. package/package.json +21 -22
  134. package/paginator/Icons.d.ts +5 -0
  135. package/paginator/Icons.js +16 -28
  136. package/paginator/Paginator.js +21 -54
  137. package/paginator/Paginator.stories.tsx +24 -0
  138. package/paginator/Paginator.test.js +315 -0
  139. package/paragraph/Paragraph.d.ts +6 -0
  140. package/paragraph/Paragraph.js +38 -0
  141. package/paragraph/Paragraph.stories.tsx +44 -0
  142. package/password-input/PasswordInput.js +23 -19
  143. package/password-input/PasswordInput.stories.tsx +3 -3
  144. package/password-input/PasswordInput.test.js +181 -0
  145. package/password-input/types.d.ts +26 -21
  146. package/progress-bar/ProgressBar.d.ts +2 -2
  147. package/progress-bar/ProgressBar.js +59 -53
  148. package/progress-bar/ProgressBar.stories.jsx +45 -12
  149. package/progress-bar/ProgressBar.test.js +110 -0
  150. package/progress-bar/types.d.ts +3 -4
  151. package/quick-nav/QuickNav.d.ts +4 -0
  152. package/quick-nav/QuickNav.js +117 -0
  153. package/quick-nav/QuickNav.stories.tsx +356 -0
  154. package/quick-nav/types.d.ts +21 -0
  155. package/quick-nav/types.js +5 -0
  156. package/radio-group/Radio.d.ts +4 -0
  157. package/radio-group/Radio.js +156 -0
  158. package/radio-group/RadioGroup.d.ts +4 -0
  159. package/radio-group/RadioGroup.js +283 -0
  160. package/radio-group/RadioGroup.stories.tsx +214 -0
  161. package/radio-group/RadioGroup.test.js +722 -0
  162. package/radio-group/types.d.ts +114 -0
  163. package/radio-group/types.js +5 -0
  164. package/resultsetTable/Icons.d.ts +7 -0
  165. package/resultsetTable/Icons.js +51 -0
  166. package/resultsetTable/ResultsetTable.d.ts +1 -1
  167. package/resultsetTable/ResultsetTable.js +53 -107
  168. package/resultsetTable/ResultsetTable.stories.tsx +300 -0
  169. package/resultsetTable/ResultsetTable.test.js +325 -0
  170. package/resultsetTable/types.d.ts +8 -4
  171. package/select/Icons.d.ts +10 -0
  172. package/select/Icons.js +93 -0
  173. package/select/Listbox.d.ts +4 -0
  174. package/select/Listbox.js +169 -0
  175. package/select/Option.d.ts +4 -0
  176. package/select/Option.js +97 -0
  177. package/select/Select.d.ts +4 -0
  178. package/select/Select.js +196 -397
  179. package/select/Select.stories.tsx +600 -201
  180. package/select/Select.test.js +2228 -0
  181. package/select/types.d.ts +210 -0
  182. package/select/types.js +5 -0
  183. package/sidenav/Sidenav.d.ts +6 -5
  184. package/sidenav/Sidenav.js +184 -54
  185. package/sidenav/Sidenav.stories.tsx +249 -132
  186. package/sidenav/Sidenav.test.js +44 -0
  187. package/sidenav/types.d.ts +50 -27
  188. package/slider/Slider.d.ts +2 -2
  189. package/slider/Slider.js +124 -98
  190. package/slider/Slider.stories.tsx +72 -9
  191. package/slider/Slider.test.js +250 -0
  192. package/slider/types.d.ts +10 -2
  193. package/spinner/Spinner.js +5 -5
  194. package/spinner/Spinner.stories.jsx +27 -0
  195. package/spinner/Spinner.test.js +64 -0
  196. package/switch/Switch.d.ts +2 -2
  197. package/switch/Switch.js +152 -69
  198. package/switch/Switch.stories.tsx +54 -43
  199. package/switch/Switch.test.js +225 -0
  200. package/switch/types.d.ts +12 -4
  201. package/table/Table.js +3 -3
  202. package/table/Table.stories.jsx +81 -1
  203. package/table/Table.test.js +26 -0
  204. package/tabs/Tab.d.ts +4 -0
  205. package/tabs/Tab.js +133 -0
  206. package/tabs/Tabs.d.ts +1 -1
  207. package/tabs/Tabs.js +364 -110
  208. package/tabs/Tabs.stories.tsx +226 -0
  209. package/tabs/Tabs.test.js +351 -0
  210. package/tabs/types.d.ts +39 -17
  211. package/tabs-nav/NavTabs.d.ts +8 -0
  212. package/tabs-nav/NavTabs.js +125 -0
  213. package/tabs-nav/NavTabs.stories.tsx +172 -0
  214. package/tabs-nav/NavTabs.test.js +82 -0
  215. package/tabs-nav/Tab.d.ts +4 -0
  216. package/tabs-nav/Tab.js +128 -0
  217. package/tabs-nav/types.d.ts +53 -0
  218. package/tabs-nav/types.js +5 -0
  219. package/tag/Tag.d.ts +1 -1
  220. package/tag/Tag.js +19 -29
  221. package/tag/Tag.stories.tsx +26 -29
  222. package/tag/Tag.test.js +60 -0
  223. package/tag/types.d.ts +23 -14
  224. package/text-input/Icons.d.ts +8 -0
  225. package/text-input/Icons.js +60 -0
  226. package/text-input/Suggestion.d.ts +4 -0
  227. package/text-input/Suggestion.js +84 -0
  228. package/text-input/Suggestions.d.ts +4 -0
  229. package/text-input/Suggestions.js +134 -0
  230. package/text-input/TextInput.js +231 -343
  231. package/text-input/TextInput.stories.tsx +569 -0
  232. package/text-input/TextInput.test.js +1724 -0
  233. package/text-input/types.d.ts +63 -23
  234. package/textarea/Textarea.d.ts +4 -0
  235. package/textarea/Textarea.js +39 -79
  236. package/textarea/Textarea.stories.jsx +37 -15
  237. package/textarea/Textarea.test.js +437 -0
  238. package/textarea/types.d.ts +137 -0
  239. package/textarea/types.js +5 -0
  240. package/toggle-group/ToggleGroup.d.ts +4 -0
  241. package/toggle-group/ToggleGroup.js +18 -46
  242. package/toggle-group/ToggleGroup.stories.tsx +69 -32
  243. package/toggle-group/ToggleGroup.test.js +156 -0
  244. package/toggle-group/types.d.ts +105 -0
  245. package/toggle-group/types.js +5 -0
  246. package/typography/Typography.d.ts +4 -0
  247. package/typography/Typography.js +131 -0
  248. package/typography/Typography.stories.tsx +198 -0
  249. package/typography/types.d.ts +18 -0
  250. package/typography/types.js +5 -0
  251. package/useTheme.d.ts +2 -0
  252. package/useTheme.js +2 -2
  253. package/useTranslatedLabels.d.ts +2 -0
  254. package/useTranslatedLabels.js +20 -0
  255. package/wizard/Wizard.d.ts +1 -1
  256. package/wizard/Wizard.js +112 -58
  257. package/wizard/{Wizard.stories.jsx → Wizard.stories.tsx} +48 -19
  258. package/wizard/Wizard.test.js +141 -0
  259. package/wizard/types.d.ts +13 -12
  260. package/ThemeContext.js +0 -246
  261. package/V3Select/V3Select.js +0 -455
  262. package/V3Select/index.d.ts +0 -27
  263. package/V3Textarea/V3Textarea.js +0 -260
  264. package/V3Textarea/index.d.ts +0 -27
  265. package/chip/index.d.ts +0 -22
  266. package/common/RequiredComponent.js +0 -32
  267. package/date/Date.js +0 -373
  268. package/date/index.d.ts +0 -27
  269. package/footer/Footer.stories.jsx +0 -151
  270. package/input-text/Icons.js +0 -22
  271. package/input-text/InputText.js +0 -611
  272. package/input-text/index.d.ts +0 -36
  273. package/radio/Radio.d.ts +0 -4
  274. package/radio/Radio.js +0 -174
  275. package/radio/Radio.stories.tsx +0 -192
  276. package/radio/types.d.ts +0 -54
  277. package/select/index.d.ts +0 -131
  278. package/textarea/index.d.ts +0 -117
  279. package/toggle/Toggle.js +0 -186
  280. package/toggle/index.d.ts +0 -21
  281. package/toggle-group/index.d.ts +0 -21
  282. package/upload/Upload.js +0 -201
  283. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  284. package/upload/buttons-upload/Icons.js +0 -40
  285. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  286. package/upload/dragAndDropArea/Icons.js +0 -39
  287. package/upload/file-upload/FileToUpload.js +0 -115
  288. package/upload/file-upload/Icons.js +0 -66
  289. package/upload/files-upload/FilesToUpload.js +0 -109
  290. package/upload/index.d.ts +0 -15
  291. package/upload/transaction/Icons.js +0 -160
  292. package/upload/transaction/Transaction.js +0 -104
  293. package/upload/transactions/Transactions.js +0 -94
  294. package/wizard/Icons.js +0 -65
@@ -0,0 +1,300 @@
1
+ import React from "react";
2
+ import DxcResultsetTable from "./ResultsetTable";
3
+ import DxcButton from "../button/Button";
4
+ import Title from "../../.storybook/components/Title";
5
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+ import { userEvent, within } from "@storybook/testing-library";
7
+ import styled from "styled-components";
8
+
9
+ export default {
10
+ title: "Resultset Table",
11
+ component: DxcResultsetTable,
12
+ };
13
+
14
+ const deleteIcon = (
15
+ <svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24">
16
+ <path d="M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zM19 4h-3.5l-1-1h-5l-1 1H5v2h14V4z" />
17
+ <path d="M0 0h24v24H0z" fill="none" />
18
+ </svg>
19
+ );
20
+
21
+ const columns = [{ displayValue: "Id" }, { displayValue: "Name" }, { displayValue: "City" }];
22
+
23
+ const rows = [
24
+ [{ displayValue: "001" }, { displayValue: "Peter" }, { displayValue: "Miami" }],
25
+ [{ displayValue: "002" }, { displayValue: "Louis" }, { displayValue: "London" }],
26
+ [{ displayValue: "003" }, { displayValue: "Lana" }, { displayValue: "Amsterdam" }],
27
+ [{ displayValue: "004" }, { displayValue: "Rick" }, { displayValue: "London" }],
28
+ [{ displayValue: "005" }, { displayValue: "Mark" }, { displayValue: "Miami" }],
29
+ [{ displayValue: "006" }, { displayValue: "Cris" }, { displayValue: "Paris" }],
30
+ ];
31
+
32
+ const rowsIcon = [
33
+ [
34
+ { displayValue: "001", sortValue: "001" },
35
+ { displayValue: "Peter" },
36
+ { displayValue: <DxcButton icon={deleteIcon} /> },
37
+ ],
38
+ [{ displayValue: "002", sortValue: "002" }, { displayValue: "Louis" }, { displayValue: "" }],
39
+ [
40
+ { displayValue: "003", sortValue: "003" },
41
+ { displayValue: "Mark" },
42
+ { displayValue: <DxcButton icon={deleteIcon} /> },
43
+ ],
44
+ ];
45
+
46
+ const columnsSortable = [
47
+ { displayValue: "Id", isSortable: true },
48
+ { displayValue: "Name", isSortable: true },
49
+ { displayValue: "City", isSortable: false },
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
+
70
+ const rowsSortable = [
71
+ [
72
+ { displayValue: "001", sortValue: "001" },
73
+ { displayValue: "Peter", sortValue: "Peter" },
74
+ { displayValue: "Miami", sortValue: "Miami" },
75
+ ],
76
+ [
77
+ { displayValue: "002", sortValue: "002" },
78
+ { displayValue: "Louis", sortValue: "Louis" },
79
+ { displayValue: "London", sortValue: "London" },
80
+ ],
81
+ [
82
+ { displayValue: "003", sortValue: "003" },
83
+ { displayValue: "Aida", sortValue: "Aida" },
84
+ { displayValue: "Wroclaw", sortValue: "Wroclaw" },
85
+ ],
86
+ [
87
+ { displayValue: "004", sortValue: "004" },
88
+ { displayValue: "Lana", sortValue: "Lana" },
89
+ { displayValue: "Amsterdam", sortValue: "Amsterdam" },
90
+ ],
91
+ ];
92
+
93
+ const longColumns = [
94
+ { displayValue: "Column1" },
95
+ { displayValue: "Column2" },
96
+ { displayValue: "Column3" },
97
+ { displayValue: "Column4" },
98
+ { displayValue: "Column5" },
99
+ { displayValue: "Column6" },
100
+ { displayValue: "Column7" },
101
+ { displayValue: "Column8" },
102
+ { displayValue: "Column9" },
103
+ { displayValue: "Column10" },
104
+ { displayValue: "Column11" },
105
+ { displayValue: "Column12" },
106
+ { displayValue: "Column13" },
107
+ { displayValue: "Column14" },
108
+ { displayValue: "Column15" },
109
+ { displayValue: "Column16" },
110
+ { displayValue: "Column17" },
111
+ { displayValue: "Column18" },
112
+ { displayValue: "Column19" },
113
+ { displayValue: "Column20" },
114
+ ];
115
+
116
+ const longRows = [
117
+ [
118
+ { displayValue: "001", sortValue: "001" },
119
+ { displayValue: "Peter", sortValue: "Peter" },
120
+ { displayValue: "Miami", sortValue: "Miami" },
121
+ { displayValue: "001", sortValue: "001" },
122
+ { displayValue: "Peter", sortValue: "Peter" },
123
+ { displayValue: "Miami", sortValue: "Miami" },
124
+ { displayValue: "Miami", sortValue: "Miami" },
125
+ { displayValue: "001", sortValue: "001" },
126
+ { displayValue: "Peter", sortValue: "Peter" },
127
+ { displayValue: "Miami", sortValue: "Miami" },
128
+ { displayValue: "002", sortValue: "002" },
129
+ { displayValue: "Louis", sortValue: "Louis" },
130
+ { displayValue: "London", sortValue: "London" },
131
+ { displayValue: "002", sortValue: "002" },
132
+ { displayValue: "Louis", sortValue: "Louis" },
133
+ { displayValue: "London", sortValue: "London" },
134
+ { displayValue: "002", sortValue: "002" },
135
+ { displayValue: "Louis", sortValue: "Louis" },
136
+ { displayValue: "London", sortValue: "London" },
137
+ { displayValue: "London", sortValue: "London" },
138
+ ],
139
+ [
140
+ { displayValue: "002", sortValue: "002" },
141
+ { displayValue: "Louis", sortValue: "Louis" },
142
+ { displayValue: "London", sortValue: "London" },
143
+ { displayValue: "002", sortValue: "002" },
144
+ { displayValue: "Louis", sortValue: "Louis" },
145
+ { displayValue: "London", sortValue: "London" },
146
+ { displayValue: "002", sortValue: "002" },
147
+ { displayValue: "Louis", sortValue: "Louis" },
148
+ { displayValue: "London", sortValue: "London" },
149
+ { displayValue: "London", sortValue: "London" },
150
+ { displayValue: "002", sortValue: "002" },
151
+ { displayValue: "Louis", sortValue: "Louis" },
152
+ { displayValue: "London", sortValue: "London" },
153
+ { displayValue: "002", sortValue: "002" },
154
+ { displayValue: "Louis", sortValue: "Louis" },
155
+ { displayValue: "London", sortValue: "London" },
156
+ { displayValue: "002", sortValue: "002" },
157
+ { displayValue: "Louis", sortValue: "Louis" },
158
+ { displayValue: "London", sortValue: "London" },
159
+ { displayValue: "London", sortValue: "London" },
160
+ ],
161
+ [
162
+ { displayValue: "002", sortValue: "002" },
163
+ { displayValue: "Louis", sortValue: "Louis" },
164
+ { displayValue: "London", sortValue: "London" },
165
+ { displayValue: "002", sortValue: "002" },
166
+ { displayValue: "Louis", sortValue: "Louis" },
167
+ { displayValue: "London", sortValue: "London" },
168
+ { displayValue: "002", sortValue: "002" },
169
+ { displayValue: "Louis", sortValue: "Louis" },
170
+ { displayValue: "London", sortValue: "London" },
171
+ { displayValue: "London", sortValue: "London" },
172
+ { displayValue: "002", sortValue: "002" },
173
+ { displayValue: "Louis", sortValue: "Louis" },
174
+ { displayValue: "London", sortValue: "London" },
175
+ { displayValue: "002", sortValue: "002" },
176
+ { displayValue: "Louis", sortValue: "Louis" },
177
+ { displayValue: "London", sortValue: "London" },
178
+ { displayValue: "002", sortValue: "002" },
179
+ { displayValue: "Louis", sortValue: "Louis" },
180
+ { displayValue: "London", sortValue: "London" },
181
+ { displayValue: "London", sortValue: "London" },
182
+ ],
183
+ ];
184
+
185
+ export const Chromatic = () => (
186
+ <>
187
+ <ExampleContainer>
188
+ <Title title="Sortable table" theme="light" level={4} />
189
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
190
+ </ExampleContainer>
191
+ <ExampleContainer>
192
+ <Title title="With action" theme="light" level={4} />
193
+ <DxcResultsetTable columns={columns} rows={rowsIcon} />
194
+ </ExampleContainer>
195
+ <ExampleContainer>
196
+ <Title title="With items per page option" theme="light" level={4} />
197
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} itemsPerPageOptions={[2, 3]} />
198
+ </ExampleContainer>
199
+ <ExampleContainer>
200
+ <Title title="Scroll resultset table" theme="light" level={4} />
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>
208
+ </ExampleContainer>
209
+ <Title title="Margins" theme="light" level={2} />
210
+ <ExampleContainer>
211
+ <Title title="Xxsmall" theme="light" level={4} />
212
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xxsmall"} />
213
+ </ExampleContainer>
214
+ <ExampleContainer>
215
+ <Title title="Xsmall" theme="light" level={4} />
216
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xsmall"} />
217
+ </ExampleContainer>
218
+ <ExampleContainer>
219
+ <Title title="Small" theme="light" level={4} />
220
+ <DxcResultsetTable columns={columns} rows={rows} margin={"small"} />
221
+ </ExampleContainer>
222
+ <ExampleContainer>
223
+ <Title title="Medium" theme="light" level={4} />
224
+ <DxcResultsetTable columns={columns} rows={rows} margin={"medium"} />
225
+ </ExampleContainer>
226
+ <ExampleContainer>
227
+ <Title title="Large" theme="light" level={4} />
228
+ <DxcResultsetTable columns={columns} rows={rows} margin={"large"} />
229
+ </ExampleContainer>
230
+ <ExampleContainer>
231
+ <Title title="Xlarge" theme="light" level={4} />
232
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xlarge"} />
233
+ </ExampleContainer>
234
+ <ExampleContainer expanded>
235
+ <Title title="Xxlarge" theme="light" level={4} />
236
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xxlarge"} />
237
+ </ExampleContainer>
238
+ </>
239
+ );
240
+
241
+ const SmallContainer = styled.div`
242
+ width: 500px;
243
+ `;
244
+
245
+ const ResultsetTableAsc = () => (
246
+ <ExampleContainer>
247
+ <Title title="Ascendant sorting" theme="light" level={4} />
248
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
249
+ </ExampleContainer>
250
+ );
251
+
252
+ export const AscendentSorting = ResultsetTableAsc.bind({});
253
+ AscendentSorting.play = async ({ canvasElement }) => {
254
+ const canvas = within(canvasElement);
255
+ const idHeader = canvas.getAllByRole("button")[0];
256
+ await userEvent.click(idHeader);
257
+ };
258
+
259
+ const ResultsetTableDesc = () => (
260
+ <ExampleContainer>
261
+ <Title title="Descendant sorting" theme="light" level={4} />
262
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
263
+ </ExampleContainer>
264
+ );
265
+
266
+ export const DescendantSorting = ResultsetTableDesc.bind({});
267
+ DescendantSorting.play = async ({ canvasElement }) => {
268
+ const canvas = within(canvasElement);
269
+ const nameHeader = canvas.getAllByRole("button")[1];
270
+ await userEvent.click(nameHeader);
271
+ await userEvent.click(nameHeader);
272
+ };
273
+
274
+ const ResultsetTableMiddle = () => (
275
+ <ExampleContainer>
276
+ <Title title="Middle page" theme="light" level={4} />
277
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
278
+ </ExampleContainer>
279
+ );
280
+
281
+ export const MiddlePage = ResultsetTableMiddle.bind({});
282
+ MiddlePage.play = async ({ canvasElement }) => {
283
+ const canvas = within(canvasElement);
284
+ const nextButton = canvas.getAllByRole("button")[2];
285
+ await userEvent.click(nextButton);
286
+ };
287
+
288
+ const ResultsetTableLast = () => (
289
+ <ExampleContainer>
290
+ <Title title="Last page" theme="light" level={4} />
291
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
292
+ </ExampleContainer>
293
+ );
294
+
295
+ export const LastPage = ResultsetTableLast.bind({});
296
+ LastPage.play = async ({ canvasElement }) => {
297
+ const canvas = within(canvasElement);
298
+ const nextButton = canvas.getAllByRole("button")[3];
299
+ await userEvent.click(nextButton);
300
+ };
@@ -0,0 +1,325 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
6
+
7
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
8
+
9
+ var _react = _interopRequireDefault(require("react"));
10
+
11
+ var _react2 = require("@testing-library/react");
12
+
13
+ var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
14
+
15
+ var _ResultsetTable = _interopRequireDefault(require("./ResultsetTable"));
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
+ }();
49
+
50
+ var columns = [{
51
+ displayValue: "Id",
52
+ isSortable: false
53
+ }, {
54
+ displayValue: "Name",
55
+ isSortable: true
56
+ }, {
57
+ displayValue: "City",
58
+ isSortable: false
59
+ }];
60
+ var rows = [[{
61
+ displayValue: "001",
62
+ sortValue: "001"
63
+ }, {
64
+ displayValue: "Peter",
65
+ sortValue: "Peter"
66
+ }, {
67
+ displayValue: "Oviedo",
68
+ sortValue: "Oviedo"
69
+ }], [{
70
+ displayValue: "002",
71
+ sortValue: "002"
72
+ }, {
73
+ displayValue: "Louis",
74
+ sortValue: "Louis"
75
+ }, {
76
+ displayValue: "Oviedo",
77
+ sortValue: "Oviedo"
78
+ }], [{
79
+ displayValue: "003",
80
+ sortValue: "003"
81
+ }, {
82
+ displayValue: "Lana",
83
+ sortValue: "Lana"
84
+ }, {
85
+ displayValue: "Albacete",
86
+ sortValue: "Albacete"
87
+ }], [{
88
+ displayValue: "004",
89
+ sortValue: "004"
90
+ }, {
91
+ displayValue: "Rick",
92
+ sortValue: "Rick"
93
+ }, {
94
+ displayValue: "Albacete",
95
+ sortValue: "Albacete"
96
+ }], [{
97
+ displayValue: "005",
98
+ sortValue: "005"
99
+ }, {
100
+ displayValue: "Mark",
101
+ sortValue: "Mark"
102
+ }, {
103
+ displayValue: "Madrid",
104
+ sortValue: "Madrid"
105
+ }], [{
106
+ displayValue: "006",
107
+ sortValue: "006"
108
+ }, {
109
+ displayValue: "Cris",
110
+ sortValue: "Cris"
111
+ }, {
112
+ displayValue: "Barcelona",
113
+ sortValue: "Barcelona"
114
+ }], [{
115
+ displayValue: "007",
116
+ sortValue: "007"
117
+ }, {
118
+ displayValue: "Susan",
119
+ sortValue: "Susan"
120
+ }, {
121
+ displayValue: "Madrid",
122
+ sortValue: "Madrid"
123
+ }], [{
124
+ displayValue: "008",
125
+ sortValue: "008"
126
+ }, {
127
+ displayValue: "Tina",
128
+ sortValue: "Tina"
129
+ }, {
130
+ displayValue: "Barcelona",
131
+ sortValue: "Barcelona"
132
+ }], [{
133
+ displayValue: "009",
134
+ sortValue: "009"
135
+ }, {
136
+ displayValue: "Kevin",
137
+ sortValue: "Kevin"
138
+ }, {
139
+ displayValue: "Oviedo",
140
+ sortValue: "Oviedo"
141
+ }], [{
142
+ displayValue: "010",
143
+ sortValue: "010"
144
+ }, {
145
+ displayValue: "Cosmin",
146
+ sortValue: "Cosmin"
147
+ }, {
148
+ displayValue: "Barcelona",
149
+ sortValue: "Barcelona"
150
+ }]];
151
+ var rows2 = [[{
152
+ displayValue: "546",
153
+ sortValue: "465"
154
+ }, {
155
+ displayValue: "OtherValue",
156
+ sortValue: "OtherValue"
157
+ }, {
158
+ displayValue: "OtherValue",
159
+ sortValue: "OtherValue"
160
+ }], [{
161
+ displayValue: "978",
162
+ sortValue: "465"
163
+ }, {
164
+ displayValue: "OtherValue",
165
+ sortValue: "OtherValue"
166
+ }, {
167
+ displayValue: "OtherValue",
168
+ sortValue: "OtherValue"
169
+ }, {
170
+ displayValue: ""
171
+ }], [{
172
+ displayValue: "678",
173
+ sortValue: "344"
174
+ }, {
175
+ displayValue: "OtherValue",
176
+ sortValue: "OtherValue"
177
+ }, {
178
+ displayValue: "OtherValue",
179
+ sortValue: "OtherValue"
180
+ }]];
181
+ describe("Resultset table component tests", function () {
182
+ test("Resultset table rendered correctly", function () {
183
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
184
+ columns: columns,
185
+ rows: rows,
186
+ itemsPerPage: 3
187
+ })),
188
+ getByText = _render.getByText;
189
+
190
+ expect(getByText("Peter")).toBeTruthy();
191
+ });
192
+ test("Resultset table shows as many rows as itemsPerPage", function () {
193
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
194
+ columns: columns,
195
+ rows: rows,
196
+ itemsPerPage: 3
197
+ })),
198
+ getAllByRole = _render2.getAllByRole;
199
+
200
+ expect(getAllByRole("row").length - 1).toEqual(3);
201
+ });
202
+ test("Resultset table shows rows on second page", function () {
203
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
204
+ columns: columns,
205
+ rows: rows,
206
+ itemsPerPage: 3
207
+ })),
208
+ getByText = _render3.getByText,
209
+ getAllByRole = _render3.getAllByRole;
210
+
211
+ expect(getByText("Peter")).toBeTruthy();
212
+ expect(getByText("Louis")).toBeTruthy();
213
+ expect(getByText("Lana")).toBeTruthy();
214
+ expect(getAllByRole("row").length - 1).toEqual(3);
215
+ var nextButton = getAllByRole("button")[3];
216
+
217
+ _react2.fireEvent.click(nextButton);
218
+
219
+ expect(getByText("4 to 6 of 10")).toBeTruthy();
220
+ expect(getByText("Rick")).toBeTruthy();
221
+ expect(getByText("Mark")).toBeTruthy();
222
+ expect(getByText("Cris")).toBeTruthy();
223
+ expect(getAllByRole("row").length - 1).toEqual(3);
224
+ });
225
+ test("Resultset table goToPage works as expected", function () {
226
+ window.HTMLElement.prototype.scrollIntoView = function () {};
227
+
228
+ window.HTMLElement.prototype.scrollTo = function () {};
229
+
230
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
231
+ columns: columns,
232
+ showGoToPage: true,
233
+ rows: rows,
234
+ itemsPerPage: 3
235
+ })),
236
+ getByText = _render4.getByText,
237
+ getAllByRole = _render4.getAllByRole;
238
+
239
+ expect(getByText("Peter")).toBeTruthy();
240
+ expect(getByText("Louis")).toBeTruthy();
241
+ expect(getByText("Lana")).toBeTruthy();
242
+ expect(getAllByRole("row").length - 1).toEqual(3);
243
+ var goToPageSelect = getAllByRole("button")[3];
244
+
245
+ _userEvent["default"].click(goToPageSelect);
246
+
247
+ var goToPageOption = getByText("2");
248
+
249
+ _userEvent["default"].click(goToPageOption);
250
+
251
+ expect(getByText("4 to 6 of 10")).toBeTruthy();
252
+ expect(getByText("Rick")).toBeTruthy();
253
+ expect(getByText("Mark")).toBeTruthy();
254
+ expect(getByText("Cris")).toBeTruthy();
255
+ expect(getAllByRole("row").length - 1).toEqual(3);
256
+ });
257
+ test("Resultset table going to the last page shows only one row", function () {
258
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
259
+ columns: columns,
260
+ rows: rows,
261
+ itemsPerPage: 3
262
+ })),
263
+ getByText = _render5.getByText,
264
+ getAllByRole = _render5.getAllByRole;
265
+
266
+ var lastButton = getAllByRole("button")[4];
267
+
268
+ _react2.fireEvent.click(lastButton);
269
+
270
+ expect(getByText("10 to 10 of 10")).toBeTruthy();
271
+ expect(getAllByRole("row")).toHaveLength(2);
272
+ expect(getByText("Cosmin")).toBeTruthy();
273
+ });
274
+ test("Resultset table sort rows by column", function () {
275
+ var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
276
+ columns: columns,
277
+ rows: rows,
278
+ itemsPerPage: 3
279
+ }));
280
+ expect(component.queryByText("Peter")).toBeTruthy();
281
+
282
+ _react2.fireEvent.click(component.queryByText("Name"));
283
+
284
+ expect(component.queryByText("Tina")).not.toBeTruthy();
285
+ expect(component.queryByText("Cosmin")).toBeTruthy();
286
+
287
+ _react2.fireEvent.click(component.queryByText("Name"));
288
+
289
+ expect(component.queryByText("Tina")).toBeTruthy();
290
+ expect(component.queryByText("Cosmin")).not.toBeTruthy();
291
+ });
292
+ test("Resultset table change rows should go to first page", function () {
293
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
294
+ columns: columns,
295
+ rows: rows,
296
+ itemsPerPage: 3
297
+ })),
298
+ queryByText = _render6.queryByText,
299
+ rerender = _render6.rerender;
300
+
301
+ expect(queryByText("Peter")).toBeTruthy();
302
+ rerender( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
303
+ columns: columns,
304
+ rows: rows2,
305
+ itemsPerPage: 3
306
+ }));
307
+ expect(queryByText("1 to 3 of 3")).toBeTruthy();
308
+ });
309
+ test("Resultset table change itemsPerPage should go to first page", function () {
310
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
311
+ columns: columns,
312
+ rows: rows,
313
+ itemsPerPage: 3,
314
+ itemsPerPageOptions: [2, 3]
315
+ })),
316
+ getAllByRole = _render7.getAllByRole;
317
+
318
+ var lastButton = getAllByRole("button")[4];
319
+ expect(getAllByRole("row").length - 1).toEqual(3);
320
+
321
+ _react2.fireEvent.click(lastButton);
322
+
323
+ expect(getAllByRole("row").length - 1).toEqual(1);
324
+ });
325
+ });
@@ -1,6 +1,6 @@
1
1
  /// <reference types="react" />
2
- declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
- declare type Margin = {
2
+ export declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ export declare type Margin = {
4
4
  top?: Space;
5
5
  bottom?: Space;
6
6
  left?: Space;
@@ -31,12 +31,16 @@ declare type Props = {
31
31
  /**
32
32
  * An array of objects representing the columns of the table.
33
33
  */
34
- columns: [Column, ...Column[]];
34
+ columns: Column[];
35
35
  /**
36
36
  * An array of objects representing the rows of the table, you will have
37
37
  * as many objects as columns in the table.
38
38
  */
39
- rows: [Row, ...Row[]];
39
+ rows: Row[][];
40
+ /**
41
+ * If true, a select component for navigation between pages will be displayed.
42
+ */
43
+ showGoToPage?: boolean;
40
44
  /**
41
45
  * Number of items per page.
42
46
  */
@@ -0,0 +1,10 @@
1
+ /// <reference types="react" />
2
+ declare const selectIcons: {
3
+ error: JSX.Element;
4
+ arrowUp: JSX.Element;
5
+ arrowDown: JSX.Element;
6
+ clear: JSX.Element;
7
+ selected: JSX.Element;
8
+ searchOff: JSX.Element;
9
+ };
10
+ export default selectIcons;