@dxc-technology/halstack-react 0.0.0-e49dc66 → 0.0.0-e4ccd42

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 (373) hide show
  1. package/BackgroundColorContext.d.ts +1 -0
  2. package/BackgroundColorContext.js +6 -26
  3. package/HalstackContext.d.ts +1249 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +47 -0
  6. package/accordion/Accordion.d.ts +1 -1
  7. package/accordion/Accordion.js +118 -194
  8. package/accordion/Accordion.stories.tsx +283 -0
  9. package/accordion/Accordion.test.js +56 -0
  10. package/accordion/types.d.ts +12 -23
  11. package/accordion-group/AccordionGroup.d.ts +5 -4
  12. package/accordion-group/AccordionGroup.js +39 -108
  13. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  14. package/accordion-group/AccordionGroup.test.js +98 -0
  15. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  16. package/accordion-group/AccordionGroupAccordion.js +31 -0
  17. package/accordion-group/types.d.ts +18 -23
  18. package/action-icon/ActionIcon.d.ts +4 -0
  19. package/action-icon/ActionIcon.js +47 -0
  20. package/action-icon/ActionIcon.stories.tsx +41 -0
  21. package/action-icon/ActionIcon.test.js +64 -0
  22. package/action-icon/types.d.ts +26 -0
  23. package/alert/Alert.js +24 -60
  24. package/alert/Alert.stories.tsx +28 -0
  25. package/alert/Alert.test.js +75 -0
  26. package/alert/types.d.ts +6 -6
  27. package/badge/Badge.d.ts +4 -0
  28. package/badge/Badge.js +141 -41
  29. package/badge/Badge.stories.tsx +210 -0
  30. package/badge/Badge.test.js +30 -0
  31. package/badge/types.d.ts +54 -0
  32. package/badge/types.js +5 -0
  33. package/bleed/Bleed.d.ts +3 -0
  34. package/bleed/Bleed.js +43 -0
  35. package/bleed/Bleed.stories.tsx +342 -0
  36. package/bleed/types.d.ts +37 -0
  37. package/bleed/types.js +5 -0
  38. package/box/Box.d.ts +1 -1
  39. package/box/Box.js +32 -86
  40. package/box/Box.stories.tsx +38 -51
  41. package/box/Box.test.js +13 -0
  42. package/box/types.d.ts +3 -18
  43. package/bulleted-list/BulletedList.d.ts +7 -0
  44. package/bulleted-list/BulletedList.js +89 -0
  45. package/bulleted-list/BulletedList.stories.tsx +115 -0
  46. package/bulleted-list/types.d.ts +38 -0
  47. package/bulleted-list/types.js +5 -0
  48. package/button/Button.d.ts +1 -1
  49. package/button/Button.js +65 -122
  50. package/button/Button.stories.tsx +164 -96
  51. package/button/Button.test.js +38 -0
  52. package/button/types.d.ts +14 -14
  53. package/card/Card.d.ts +1 -1
  54. package/card/Card.js +59 -104
  55. package/card/Card.stories.tsx +171 -0
  56. package/card/Card.test.js +39 -0
  57. package/card/types.d.ts +8 -15
  58. package/checkbox/Checkbox.d.ts +2 -2
  59. package/checkbox/Checkbox.js +145 -183
  60. package/checkbox/Checkbox.stories.tsx +166 -136
  61. package/checkbox/Checkbox.test.js +199 -0
  62. package/checkbox/types.d.ts +20 -8
  63. package/chip/Chip.d.ts +4 -0
  64. package/chip/Chip.js +48 -148
  65. package/chip/Chip.stories.tsx +214 -0
  66. package/chip/Chip.test.js +41 -0
  67. package/chip/types.d.ts +45 -0
  68. package/chip/types.js +5 -0
  69. package/common/OpenSans.css +68 -80
  70. package/common/coreTokens.d.ts +237 -0
  71. package/common/coreTokens.js +184 -0
  72. package/common/utils.d.ts +1 -0
  73. package/common/utils.js +6 -12
  74. package/common/variables.d.ts +1395 -0
  75. package/common/variables.js +1033 -1343
  76. package/container/Container.d.ts +4 -0
  77. package/container/Container.js +194 -0
  78. package/container/Container.stories.tsx +214 -0
  79. package/container/types.d.ts +74 -0
  80. package/container/types.js +5 -0
  81. package/date-input/Calendar.d.ts +4 -0
  82. package/date-input/Calendar.js +214 -0
  83. package/date-input/DateInput.js +175 -313
  84. package/date-input/DateInput.stories.tsx +203 -56
  85. package/date-input/DateInput.test.js +808 -0
  86. package/date-input/DatePicker.d.ts +4 -0
  87. package/date-input/DatePicker.js +115 -0
  88. package/date-input/Icons.d.ts +6 -0
  89. package/date-input/Icons.js +58 -0
  90. package/date-input/YearPicker.d.ts +4 -0
  91. package/date-input/YearPicker.js +100 -0
  92. package/date-input/types.d.ts +86 -22
  93. package/dialog/Dialog.d.ts +1 -1
  94. package/dialog/Dialog.js +69 -130
  95. package/dialog/Dialog.stories.tsx +365 -0
  96. package/dialog/Dialog.test.js +307 -0
  97. package/dialog/types.d.ts +18 -25
  98. package/dropdown/Dropdown.d.ts +1 -1
  99. package/dropdown/Dropdown.js +250 -331
  100. package/dropdown/Dropdown.stories.tsx +438 -0
  101. package/dropdown/Dropdown.test.js +599 -0
  102. package/dropdown/DropdownMenu.d.ts +4 -0
  103. package/dropdown/DropdownMenu.js +63 -0
  104. package/dropdown/DropdownMenuItem.d.ts +4 -0
  105. package/dropdown/DropdownMenuItem.js +67 -0
  106. package/dropdown/types.d.ts +37 -28
  107. package/file-input/FileInput.d.ts +4 -0
  108. package/file-input/FileInput.js +274 -327
  109. package/file-input/FileInput.stories.tsx +618 -0
  110. package/file-input/FileInput.test.js +459 -0
  111. package/file-input/FileItem.d.ts +4 -0
  112. package/file-input/FileItem.js +54 -112
  113. package/file-input/types.d.ts +129 -0
  114. package/file-input/types.js +5 -0
  115. package/flex/Flex.d.ts +4 -0
  116. package/flex/Flex.js +57 -0
  117. package/flex/Flex.stories.tsx +112 -0
  118. package/flex/types.d.ts +97 -0
  119. package/flex/types.js +5 -0
  120. package/footer/Footer.d.ts +1 -1
  121. package/footer/Footer.js +73 -201
  122. package/footer/{Footer.stories.jsx → Footer.stories.tsx} +57 -37
  123. package/footer/Footer.test.js +85 -0
  124. package/footer/Icons.d.ts +3 -0
  125. package/footer/Icons.js +67 -8
  126. package/footer/types.d.ts +41 -38
  127. package/grid/Grid.d.ts +7 -0
  128. package/grid/Grid.js +76 -0
  129. package/grid/Grid.stories.tsx +219 -0
  130. package/grid/types.d.ts +115 -0
  131. package/grid/types.js +5 -0
  132. package/header/Header.d.ts +4 -3
  133. package/header/Header.js +100 -204
  134. package/header/Header.stories.tsx +251 -0
  135. package/header/Header.test.js +66 -0
  136. package/header/Icons.d.ts +2 -0
  137. package/header/Icons.js +4 -9
  138. package/header/types.d.ts +4 -16
  139. package/heading/Heading.d.ts +4 -0
  140. package/heading/Heading.js +16 -55
  141. package/heading/Heading.stories.tsx +54 -0
  142. package/heading/Heading.test.js +169 -0
  143. package/heading/types.d.ts +33 -0
  144. package/heading/types.js +5 -0
  145. package/image/Image.d.ts +4 -0
  146. package/image/Image.js +70 -0
  147. package/image/Image.stories.tsx +129 -0
  148. package/image/types.d.ts +72 -0
  149. package/image/types.js +5 -0
  150. package/inset/Inset.d.ts +3 -0
  151. package/inset/Inset.js +43 -0
  152. package/inset/Inset.stories.tsx +230 -0
  153. package/inset/types.d.ts +37 -0
  154. package/inset/types.js +5 -0
  155. package/layout/ApplicationLayout.d.ts +20 -0
  156. package/layout/ApplicationLayout.js +83 -184
  157. package/layout/ApplicationLayout.stories.tsx +162 -0
  158. package/layout/Icons.d.ts +8 -0
  159. package/layout/Icons.js +51 -48
  160. package/layout/SidenavContext.d.ts +5 -0
  161. package/layout/SidenavContext.js +13 -0
  162. package/layout/types.d.ts +41 -0
  163. package/layout/types.js +5 -0
  164. package/link/Link.d.ts +3 -2
  165. package/link/Link.js +65 -111
  166. package/link/Link.stories.tsx +199 -16
  167. package/link/Link.test.js +63 -0
  168. package/link/types.d.ts +15 -35
  169. package/main.d.ts +17 -14
  170. package/main.js +78 -98
  171. package/nav-tabs/NavTabs.d.ts +8 -0
  172. package/nav-tabs/NavTabs.js +93 -0
  173. package/nav-tabs/NavTabs.stories.tsx +276 -0
  174. package/nav-tabs/NavTabs.test.js +76 -0
  175. package/nav-tabs/Tab.d.ts +4 -0
  176. package/nav-tabs/Tab.js +118 -0
  177. package/nav-tabs/types.d.ts +52 -0
  178. package/nav-tabs/types.js +5 -0
  179. package/number-input/NumberInput.d.ts +11 -0
  180. package/number-input/NumberInput.js +49 -91
  181. package/number-input/{NumberInput.stories.jsx → NumberInput.stories.tsx} +44 -28
  182. package/number-input/NumberInput.test.js +989 -0
  183. package/number-input/types.d.ts +130 -0
  184. package/number-input/types.js +5 -0
  185. package/package.json +46 -45
  186. package/paginator/Icons.d.ts +5 -0
  187. package/paginator/Icons.js +21 -47
  188. package/paginator/Paginator.js +35 -98
  189. package/paginator/Paginator.stories.tsx +24 -0
  190. package/paginator/Paginator.test.js +335 -0
  191. package/paginator/types.d.ts +3 -3
  192. package/paragraph/Paragraph.d.ts +5 -0
  193. package/paragraph/Paragraph.js +22 -0
  194. package/paragraph/Paragraph.stories.tsx +27 -0
  195. package/password-input/Icons.d.ts +6 -0
  196. package/password-input/Icons.js +35 -0
  197. package/password-input/PasswordInput.js +60 -125
  198. package/password-input/PasswordInput.stories.tsx +3 -35
  199. package/password-input/PasswordInput.test.js +198 -0
  200. package/password-input/types.d.ts +35 -24
  201. package/progress-bar/ProgressBar.js +66 -92
  202. package/progress-bar/ProgressBar.stories.tsx +93 -0
  203. package/progress-bar/ProgressBar.test.js +93 -0
  204. package/progress-bar/types.d.ts +3 -3
  205. package/quick-nav/QuickNav.d.ts +4 -0
  206. package/quick-nav/QuickNav.js +94 -0
  207. package/quick-nav/QuickNav.stories.tsx +356 -0
  208. package/quick-nav/types.d.ts +21 -0
  209. package/quick-nav/types.js +5 -0
  210. package/radio-group/Radio.d.ts +4 -0
  211. package/radio-group/Radio.js +124 -0
  212. package/radio-group/RadioGroup.d.ts +4 -0
  213. package/radio-group/RadioGroup.js +235 -0
  214. package/radio-group/RadioGroup.stories.tsx +214 -0
  215. package/radio-group/RadioGroup.test.js +756 -0
  216. package/radio-group/types.d.ts +114 -0
  217. package/radio-group/types.js +5 -0
  218. package/resultset-table/Icons.d.ts +7 -0
  219. package/resultset-table/Icons.js +47 -0
  220. package/resultset-table/ResultsetTable.d.ts +7 -0
  221. package/resultset-table/ResultsetTable.js +166 -0
  222. package/resultset-table/ResultsetTable.stories.tsx +397 -0
  223. package/resultset-table/ResultsetTable.test.js +371 -0
  224. package/resultset-table/types.d.ts +73 -0
  225. package/resultset-table/types.js +5 -0
  226. package/select/Icons.d.ts +10 -0
  227. package/select/Icons.js +89 -0
  228. package/select/Listbox.d.ts +4 -0
  229. package/select/Listbox.js +143 -0
  230. package/select/Option.d.ts +4 -0
  231. package/select/Option.js +87 -0
  232. package/select/Select.d.ts +4 -0
  233. package/select/Select.js +240 -515
  234. package/select/Select.stories.tsx +971 -0
  235. package/select/Select.test.js +2370 -0
  236. package/select/types.d.ts +209 -0
  237. package/select/types.js +5 -0
  238. package/sidenav/Icons.d.ts +7 -0
  239. package/sidenav/Icons.js +47 -0
  240. package/sidenav/Sidenav.d.ts +10 -0
  241. package/sidenav/Sidenav.js +132 -81
  242. package/sidenav/Sidenav.stories.tsx +282 -0
  243. package/sidenav/Sidenav.test.js +37 -0
  244. package/sidenav/types.d.ts +76 -0
  245. package/sidenav/types.js +5 -0
  246. package/slider/Slider.d.ts +2 -2
  247. package/slider/Slider.js +151 -183
  248. package/slider/Slider.test.js +254 -0
  249. package/slider/types.d.ts +11 -3
  250. package/spinner/Spinner.js +32 -76
  251. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -26
  252. package/spinner/Spinner.test.js +55 -0
  253. package/spinner/types.d.ts +3 -3
  254. package/status-light/StatusLight.d.ts +4 -0
  255. package/status-light/StatusLight.js +51 -0
  256. package/status-light/StatusLight.stories.tsx +74 -0
  257. package/status-light/StatusLight.test.js +25 -0
  258. package/status-light/types.d.ts +17 -0
  259. package/status-light/types.js +5 -0
  260. package/switch/Switch.d.ts +2 -2
  261. package/switch/Switch.js +150 -115
  262. package/switch/Switch.stories.tsx +45 -68
  263. package/switch/Switch.test.js +180 -0
  264. package/switch/types.d.ts +13 -5
  265. package/table/DropdownTheme.js +62 -0
  266. package/table/Table.d.ts +6 -2
  267. package/table/Table.js +89 -37
  268. package/table/Table.stories.tsx +658 -0
  269. package/table/Table.test.js +113 -0
  270. package/table/types.d.ts +48 -6
  271. package/tabs/Tab.d.ts +4 -0
  272. package/tabs/Tab.js +116 -0
  273. package/tabs/Tabs.d.ts +1 -1
  274. package/tabs/Tabs.js +318 -145
  275. package/tabs/Tabs.stories.tsx +226 -0
  276. package/tabs/Tabs.test.js +294 -0
  277. package/tabs/types.d.ts +48 -27
  278. package/tag/Tag.d.ts +1 -1
  279. package/tag/Tag.js +44 -86
  280. package/tag/Tag.stories.tsx +38 -28
  281. package/tag/Tag.test.js +49 -0
  282. package/tag/types.d.ts +25 -16
  283. package/text-input/Icons.d.ts +8 -0
  284. package/text-input/Icons.js +56 -0
  285. package/text-input/Suggestion.d.ts +4 -0
  286. package/text-input/Suggestion.js +67 -0
  287. package/text-input/Suggestions.d.ts +4 -0
  288. package/text-input/Suggestions.js +84 -0
  289. package/text-input/TextInput.d.ts +4 -0
  290. package/text-input/TextInput.js +333 -593
  291. package/text-input/TextInput.stories.tsx +465 -0
  292. package/text-input/TextInput.test.js +1756 -0
  293. package/text-input/types.d.ts +205 -0
  294. package/text-input/types.js +5 -0
  295. package/textarea/Textarea.d.ts +4 -0
  296. package/textarea/Textarea.js +98 -181
  297. package/textarea/Textarea.stories.tsx +174 -0
  298. package/textarea/Textarea.test.js +406 -0
  299. package/textarea/types.d.ts +141 -0
  300. package/textarea/types.js +5 -0
  301. package/toggle-group/ToggleGroup.d.ts +4 -0
  302. package/toggle-group/ToggleGroup.js +100 -142
  303. package/toggle-group/ToggleGroup.stories.tsx +218 -0
  304. package/toggle-group/ToggleGroup.test.js +137 -0
  305. package/toggle-group/types.d.ts +114 -0
  306. package/toggle-group/types.js +5 -0
  307. package/typography/Typography.d.ts +4 -0
  308. package/typography/Typography.js +23 -0
  309. package/typography/Typography.stories.tsx +198 -0
  310. package/typography/types.d.ts +18 -0
  311. package/typography/types.js +5 -0
  312. package/useTheme.d.ts +1148 -0
  313. package/useTheme.js +4 -11
  314. package/useTranslatedLabels.d.ts +85 -0
  315. package/useTranslatedLabels.js +14 -0
  316. package/utils/BaseTypography.d.ts +21 -0
  317. package/utils/BaseTypography.js +94 -0
  318. package/utils/FocusLock.d.ts +13 -0
  319. package/utils/FocusLock.js +124 -0
  320. package/wizard/Wizard.d.ts +4 -0
  321. package/wizard/Wizard.js +130 -151
  322. package/wizard/Wizard.stories.tsx +253 -0
  323. package/wizard/Wizard.test.js +114 -0
  324. package/wizard/types.d.ts +64 -0
  325. package/wizard/types.js +5 -0
  326. package/ThemeContext.js +0 -246
  327. package/V3Select/V3Select.js +0 -455
  328. package/V3Select/index.d.ts +0 -27
  329. package/V3Textarea/V3Textarea.js +0 -260
  330. package/V3Textarea/index.d.ts +0 -27
  331. package/chip/index.d.ts +0 -22
  332. package/common/RequiredComponent.js +0 -32
  333. package/date/Date.js +0 -373
  334. package/date/index.d.ts +0 -27
  335. package/file-input/index.d.ts +0 -81
  336. package/heading/index.d.ts +0 -17
  337. package/input-text/Icons.js +0 -22
  338. package/input-text/InputText.js +0 -611
  339. package/input-text/index.d.ts +0 -36
  340. package/number-input/NumberInputContext.js +0 -16
  341. package/number-input/index.d.ts +0 -113
  342. package/progress-bar/ProgressBar.stories.jsx +0 -58
  343. package/radio/Radio.d.ts +0 -4
  344. package/radio/Radio.js +0 -174
  345. package/radio/Radio.stories.tsx +0 -192
  346. package/radio/types.d.ts +0 -54
  347. package/resultsetTable/ResultsetTable.js +0 -274
  348. package/resultsetTable/index.d.ts +0 -19
  349. package/select/index.d.ts +0 -131
  350. package/sidenav/index.d.ts +0 -13
  351. package/slider/Slider.stories.tsx +0 -172
  352. package/table/Table.stories.jsx +0 -276
  353. package/text-input/index.d.ts +0 -135
  354. package/textarea/Textarea.stories.jsx +0 -135
  355. package/textarea/index.d.ts +0 -117
  356. package/toggle/Toggle.js +0 -186
  357. package/toggle/index.d.ts +0 -21
  358. package/toggle-group/index.d.ts +0 -21
  359. package/upload/Upload.js +0 -201
  360. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  361. package/upload/buttons-upload/Icons.js +0 -40
  362. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  363. package/upload/dragAndDropArea/Icons.js +0 -39
  364. package/upload/file-upload/FileToUpload.js +0 -115
  365. package/upload/file-upload/Icons.js +0 -66
  366. package/upload/files-upload/FilesToUpload.js +0 -109
  367. package/upload/index.d.ts +0 -15
  368. package/upload/transaction/Icons.js +0 -160
  369. package/upload/transaction/Transaction.js +0 -104
  370. package/upload/transactions/Transactions.js +0 -94
  371. package/wizard/Icons.js +0 -65
  372. package/wizard/index.d.ts +0 -18
  373. /package/{radio → action-icon}/types.js +0 -0
@@ -0,0 +1,397 @@
1
+ import React from "react";
2
+ import DxcResultsetTable from "./ResultsetTable";
3
+ import Title from "../../.storybook/components/Title";
4
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
+ import { userEvent, within } from "@storybook/testing-library";
6
+ import styled from "styled-components";
7
+ import { HalstackProvider } from "../HalstackContext";
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 fill="currentColor" 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 advancedTheme = {
33
+ table: {
34
+ actionIconColor: "#1B75BB",
35
+ hoverActionIconColor: "#1B75BB",
36
+ activeActionIconColor: "#1B75BB",
37
+ focusActionIconColor: "#1B75BB",
38
+ disabledActionIconColor: "#666666",
39
+ hoverButtonBackgroundColor: "#cccccc",
40
+ },
41
+ };
42
+
43
+ const actions = [
44
+ {
45
+ title: "icon",
46
+ onClick: (value?) => {
47
+ console.log(value);
48
+ },
49
+ options: [
50
+ {
51
+ value: "1",
52
+ label: "Amazon with a very long text",
53
+ },
54
+ {
55
+ value: "2",
56
+ label: "Ebay",
57
+ },
58
+ {
59
+ value: "3",
60
+ label: "Apple",
61
+ },
62
+ ],
63
+ },
64
+ {
65
+ icon: "https://www.freepnglogos.com/uploads/facebook-logo-design-1.png",
66
+ title: "icon",
67
+ onClick: () => {},
68
+ },
69
+ {
70
+ icon: deleteIcon,
71
+ title: "icon",
72
+ onClick: () => {},
73
+ disabled: true,
74
+ },
75
+ {
76
+ icon: deleteIcon,
77
+ title: "icon",
78
+ onClick: () => {},
79
+ },
80
+ ];
81
+
82
+ const rowsIcon = [
83
+ [
84
+ { displayValue: "001", sortValue: "001" },
85
+ { displayValue: "Peter" },
86
+ {
87
+ displayValue: <DxcResultsetTable.ActionsCell actions={actions} />,
88
+ },
89
+ ],
90
+ [
91
+ { displayValue: "002", sortValue: "002" },
92
+ { displayValue: "Louis" },
93
+ {
94
+ displayValue: <DxcResultsetTable.ActionsCell actions={actions} />,
95
+ },
96
+ ],
97
+ [
98
+ { displayValue: "003", sortValue: "003" },
99
+ { displayValue: "Mark" },
100
+ {
101
+ displayValue: <DxcResultsetTable.ActionsCell actions={actions} />,
102
+ },
103
+ ],
104
+ ];
105
+
106
+ const columnsSortable = [
107
+ { displayValue: "Id", isSortable: true },
108
+ { displayValue: "Name", isSortable: true },
109
+ { displayValue: "City", isSortable: false },
110
+ ];
111
+
112
+ const longValues = [
113
+ [
114
+ { displayValue: "000000000000000001", sortValue: "000000000000000001" },
115
+ { displayValue: "Peter Larsson González", sortValue: "Peter" },
116
+ { displayValue: "Miami: The city that never sleeps", sortValue: "Miami" },
117
+ ],
118
+ [
119
+ { displayValue: "002", sortValue: "002" },
120
+ { displayValue: "Louis", sortValue: "Louis" },
121
+ { displayValue: "London", sortValue: "London" },
122
+ ],
123
+ [
124
+ { displayValue: "003", sortValue: "003" },
125
+ { displayValue: "Aida", sortValue: "Aida" },
126
+ { displayValue: "Wroclaw", sortValue: "Wroclaw" },
127
+ ],
128
+ ];
129
+
130
+ const rowsSortable = [
131
+ [
132
+ { displayValue: "001", sortValue: "001" },
133
+ { displayValue: "Peter", sortValue: "Peter" },
134
+ { displayValue: "Miami", sortValue: "Miami" },
135
+ ],
136
+ [
137
+ { displayValue: "002", sortValue: "002" },
138
+ { displayValue: "Louis", sortValue: "Louis" },
139
+ { displayValue: "London", sortValue: "London" },
140
+ ],
141
+ [
142
+ { displayValue: "003", sortValue: "003" },
143
+ { displayValue: "Aida", sortValue: "Aida" },
144
+ { displayValue: "Wroclaw", sortValue: "Wroclaw" },
145
+ ],
146
+ [
147
+ { displayValue: "004", sortValue: "004" },
148
+ { displayValue: "Lana", sortValue: "Lana" },
149
+ { displayValue: "Amsterdam", sortValue: "Amsterdam" },
150
+ ],
151
+ ];
152
+
153
+ const longColumns = [
154
+ { displayValue: "Column1" },
155
+ { displayValue: "Column2" },
156
+ { displayValue: "Column3" },
157
+ { displayValue: "Column4" },
158
+ { displayValue: "Column5" },
159
+ { displayValue: "Column6" },
160
+ { displayValue: "Column7" },
161
+ { displayValue: "Column8" },
162
+ { displayValue: "Column9" },
163
+ { displayValue: "Column10" },
164
+ { displayValue: "Column11" },
165
+ { displayValue: "Column12" },
166
+ { displayValue: "Column13" },
167
+ { displayValue: "Column14" },
168
+ { displayValue: "Column15" },
169
+ { displayValue: "Column16" },
170
+ { displayValue: "Column17" },
171
+ { displayValue: "Column18" },
172
+ { displayValue: "Column19" },
173
+ { displayValue: "Column20" },
174
+ ];
175
+
176
+ const longRows = [
177
+ [
178
+ { displayValue: "001", sortValue: "001" },
179
+ { displayValue: "Peter", sortValue: "Peter" },
180
+ { displayValue: "Miami", sortValue: "Miami" },
181
+ { displayValue: "001", sortValue: "001" },
182
+ { displayValue: "Peter", sortValue: "Peter" },
183
+ { displayValue: "Miami", sortValue: "Miami" },
184
+ { displayValue: "Miami", sortValue: "Miami" },
185
+ { displayValue: "001", sortValue: "001" },
186
+ { displayValue: "Peter", sortValue: "Peter" },
187
+ { displayValue: "Miami", sortValue: "Miami" },
188
+ { displayValue: "002", sortValue: "002" },
189
+ { displayValue: "Louis", sortValue: "Louis" },
190
+ { displayValue: "London", sortValue: "London" },
191
+ { displayValue: "002", sortValue: "002" },
192
+ { displayValue: "Louis", sortValue: "Louis" },
193
+ { displayValue: "London", sortValue: "London" },
194
+ { displayValue: "002", sortValue: "002" },
195
+ { displayValue: "Louis", sortValue: "Louis" },
196
+ { displayValue: "London", sortValue: "London" },
197
+ { displayValue: "London", sortValue: "London" },
198
+ ],
199
+ [
200
+ { displayValue: "002", sortValue: "002" },
201
+ { displayValue: "Louis", sortValue: "Louis" },
202
+ { displayValue: "London", sortValue: "London" },
203
+ { displayValue: "002", sortValue: "002" },
204
+ { displayValue: "Louis", sortValue: "Louis" },
205
+ { displayValue: "London", sortValue: "London" },
206
+ { displayValue: "002", sortValue: "002" },
207
+ { displayValue: "Louis", sortValue: "Louis" },
208
+ { displayValue: "London", sortValue: "London" },
209
+ { displayValue: "London", sortValue: "London" },
210
+ { displayValue: "002", sortValue: "002" },
211
+ { displayValue: "Louis", sortValue: "Louis" },
212
+ { displayValue: "London", sortValue: "London" },
213
+ { displayValue: "002", sortValue: "002" },
214
+ { displayValue: "Louis", sortValue: "Louis" },
215
+ { displayValue: "London", sortValue: "London" },
216
+ { displayValue: "002", sortValue: "002" },
217
+ { displayValue: "Louis", sortValue: "Louis" },
218
+ { displayValue: "London", sortValue: "London" },
219
+ { displayValue: "London", sortValue: "London" },
220
+ ],
221
+ [
222
+ { displayValue: "002", sortValue: "002" },
223
+ { displayValue: "Louis", sortValue: "Louis" },
224
+ { displayValue: "London", sortValue: "London" },
225
+ { displayValue: "002", sortValue: "002" },
226
+ { displayValue: "Louis", sortValue: "Louis" },
227
+ { displayValue: "London", sortValue: "London" },
228
+ { displayValue: "002", sortValue: "002" },
229
+ { displayValue: "Louis", sortValue: "Louis" },
230
+ { displayValue: "London", sortValue: "London" },
231
+ { displayValue: "London", sortValue: "London" },
232
+ { displayValue: "002", sortValue: "002" },
233
+ { displayValue: "Louis", sortValue: "Louis" },
234
+ { displayValue: "London", sortValue: "London" },
235
+ { displayValue: "002", sortValue: "002" },
236
+ { displayValue: "Louis", sortValue: "Louis" },
237
+ { displayValue: "London", sortValue: "London" },
238
+ { displayValue: "002", sortValue: "002" },
239
+ { displayValue: "Louis", sortValue: "Louis" },
240
+ { displayValue: "London", sortValue: "London" },
241
+ { displayValue: "London", sortValue: "London" },
242
+ ],
243
+ ];
244
+
245
+ export const Chromatic = () => (
246
+ <>
247
+ <ExampleContainer>
248
+ <Title title="Sortable table" theme="light" level={4} />
249
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
250
+ </ExampleContainer>
251
+ <ExampleContainer>
252
+ <Title title="With action" theme="light" level={4} />
253
+ <DxcResultsetTable columns={columns} rows={rowsIcon} />
254
+ </ExampleContainer>
255
+ <ExampleContainer>
256
+ <Title title="With items per page option" theme="light" level={4} />
257
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} itemsPerPageOptions={[2, 3]} />
258
+ </ExampleContainer>
259
+ <ExampleContainer>
260
+ <Title title="Scroll resultset table" theme="light" level={4} />
261
+ <DxcResultsetTable columns={longColumns} rows={longRows} />
262
+ </ExampleContainer>
263
+ <ExampleContainer>
264
+ <SmallContainer>
265
+ <Title title="Small container and text overflow" theme="light" level={4} />
266
+ <DxcResultsetTable columns={columnsSortable} rows={longValues} />
267
+ </SmallContainer>
268
+ </ExampleContainer>
269
+ <ExampleContainer>
270
+ <Title title="Reduced sortable table" theme="light" level={4} />
271
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} mode="reduced" />
272
+ </ExampleContainer>
273
+ {/* PENDING SMALL ICON VERSION */}
274
+ <ExampleContainer>
275
+ <Title title="Reduced with items per page option" theme="light" level={4} />
276
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} itemsPerPageOptions={[2, 3]} mode="reduced" />
277
+ </ExampleContainer>
278
+ <ExampleContainer>
279
+ <Title title="Reduced scroll resultset table" theme="light" level={4} />
280
+ <DxcResultsetTable columns={longColumns} rows={longRows} mode="reduced" />
281
+ </ExampleContainer>
282
+ <ExampleContainer>
283
+ <SmallContainer>
284
+ <Title title="Reduced small container and text overflow" theme="light" level={4} />
285
+ <DxcResultsetTable columns={columnsSortable} rows={longValues} mode="reduced" />
286
+ </SmallContainer>
287
+ </ExampleContainer>
288
+ <Title title="Margins" theme="light" level={2} />
289
+ <ExampleContainer>
290
+ <Title title="Xxsmall" theme="light" level={4} />
291
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xxsmall"} />
292
+ </ExampleContainer>
293
+ <ExampleContainer>
294
+ <Title title="Xsmall" theme="light" level={4} />
295
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xsmall"} />
296
+ </ExampleContainer>
297
+ <ExampleContainer>
298
+ <Title title="Small" theme="light" level={4} />
299
+ <DxcResultsetTable columns={columns} rows={rows} margin={"small"} />
300
+ </ExampleContainer>
301
+ <ExampleContainer>
302
+ <Title title="Medium" theme="light" level={4} />
303
+ <DxcResultsetTable columns={columns} rows={rows} margin={"medium"} />
304
+ </ExampleContainer>
305
+ <ExampleContainer>
306
+ <Title title="Large" theme="light" level={4} />
307
+ <DxcResultsetTable columns={columns} rows={rows} margin={"large"} />
308
+ </ExampleContainer>
309
+ <ExampleContainer>
310
+ <Title title="Xlarge" theme="light" level={4} />
311
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xlarge"} />
312
+ </ExampleContainer>
313
+ <ExampleContainer expanded>
314
+ <Title title="Xxlarge" theme="light" level={4} />
315
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xxlarge"} />
316
+ </ExampleContainer>
317
+ </>
318
+ );
319
+
320
+ const SmallContainer = styled.div`
321
+ width: 500px;
322
+ `;
323
+
324
+ const ResultsetTableAsc = () => (
325
+ <ExampleContainer>
326
+ <Title title="Ascendant sorting" theme="light" level={4} />
327
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
328
+ </ExampleContainer>
329
+ );
330
+
331
+ export const AscendentSorting = ResultsetTableAsc.bind({});
332
+ AscendentSorting.play = async ({ canvasElement }) => {
333
+ const canvas = within(canvasElement);
334
+ const idHeader = canvas.getAllByRole("button")[0];
335
+ await userEvent.click(idHeader);
336
+ };
337
+
338
+ const ResultsetTableDesc = () => (
339
+ <ExampleContainer>
340
+ <Title title="Descendant sorting" theme="light" level={4} />
341
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
342
+ </ExampleContainer>
343
+ );
344
+
345
+ export const DescendantSorting = ResultsetTableDesc.bind({});
346
+ DescendantSorting.play = async ({ canvasElement }) => {
347
+ const canvas = within(canvasElement);
348
+ const nameHeader = canvas.getAllByRole("button")[1];
349
+ await userEvent.click(nameHeader);
350
+ await userEvent.click(nameHeader);
351
+ };
352
+
353
+ const ResultsetTableMiddle = () => (
354
+ <ExampleContainer>
355
+ <Title title="Middle page" theme="light" level={4} />
356
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
357
+ </ExampleContainer>
358
+ );
359
+
360
+ export const MiddlePage = ResultsetTableMiddle.bind({});
361
+ MiddlePage.play = async ({ canvasElement }) => {
362
+ const canvas = within(canvasElement);
363
+ const nextButton = canvas.getAllByRole("button")[2];
364
+ await userEvent.click(nextButton);
365
+ };
366
+
367
+ const ResultsetTableLast = () => (
368
+ <ExampleContainer>
369
+ <Title title="Last page" theme="light" level={4} />
370
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
371
+ </ExampleContainer>
372
+ );
373
+
374
+ export const LastPage = ResultsetTableLast.bind({});
375
+ LastPage.play = async ({ canvasElement }) => {
376
+ const canvas = within(canvasElement);
377
+ const nextButton = canvas.getAllByRole("button")[3];
378
+ await userEvent.click(nextButton);
379
+ };
380
+
381
+ const ResultsetActionsCellDropdown = () => (
382
+ <ExampleContainer>
383
+ <Title title="Dropdown Action" theme="light" level={4} />
384
+ <DxcResultsetTable columns={columns} rows={rowsIcon} itemsPerPage={2} />
385
+ <Title title="Custom theme actions cell" theme="light" level={4} />
386
+ <HalstackProvider advancedTheme={advancedTheme}>
387
+ <DxcResultsetTable columns={columns} rows={rowsIcon} itemsPerPage={2} />
388
+ </HalstackProvider>
389
+ </ExampleContainer>
390
+ );
391
+
392
+ export const DropdownAction = ResultsetActionsCellDropdown.bind({});
393
+ DropdownAction.play = async ({ canvasElement }) => {
394
+ const canvas = within(canvasElement);
395
+ const dropdown = canvas.getAllByRole("button")[5];
396
+ await userEvent.click(dropdown);
397
+ };