@dxc-technology/halstack-react 0.0.0-f0d662d → 0.0.0-f18281d

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 (361) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1237 -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 +117 -193
  8. package/accordion/Accordion.stories.tsx +103 -127
  9. package/accordion/Accordion.test.js +56 -0
  10. package/accordion/types.d.ts +11 -22
  11. package/accordion-group/AccordionGroup.d.ts +5 -4
  12. package/accordion-group/AccordionGroup.js +38 -107
  13. package/accordion-group/AccordionGroup.stories.tsx +95 -68
  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 +17 -22
  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 +23 -59
  24. package/alert/Alert.stories.tsx +28 -0
  25. package/alert/Alert.test.js +75 -0
  26. package/alert/types.d.ts +5 -5
  27. package/badge/Badge.d.ts +4 -0
  28. package/badge/Badge.js +142 -40
  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/bleed/Bleed.js +14 -55
  33. package/bleed/Bleed.stories.tsx +95 -95
  34. package/bleed/types.d.ts +26 -2
  35. package/box/Box.d.ts +1 -1
  36. package/box/Box.js +30 -81
  37. package/box/Box.stories.tsx +38 -51
  38. package/box/Box.test.js +13 -0
  39. package/box/types.d.ts +3 -14
  40. package/bulleted-list/BulletedList.d.ts +7 -0
  41. package/bulleted-list/BulletedList.js +89 -0
  42. package/bulleted-list/BulletedList.stories.tsx +115 -0
  43. package/bulleted-list/types.d.ts +38 -0
  44. package/button/Button.d.ts +1 -1
  45. package/button/Button.js +62 -113
  46. package/button/Button.stories.tsx +160 -90
  47. package/button/Button.test.js +38 -0
  48. package/button/types.d.ts +12 -8
  49. package/card/Card.d.ts +1 -1
  50. package/card/Card.js +58 -102
  51. package/card/Card.stories.tsx +12 -42
  52. package/card/Card.test.js +39 -0
  53. package/card/types.d.ts +6 -11
  54. package/checkbox/Checkbox.d.ts +2 -2
  55. package/checkbox/Checkbox.js +144 -182
  56. package/checkbox/Checkbox.stories.tsx +166 -136
  57. package/checkbox/Checkbox.test.js +199 -0
  58. package/checkbox/types.d.ts +18 -6
  59. package/chip/Chip.d.ts +1 -1
  60. package/chip/Chip.js +46 -124
  61. package/chip/Chip.stories.tsx +123 -30
  62. package/chip/Chip.test.js +41 -0
  63. package/chip/types.d.ts +8 -16
  64. package/common/OpenSans.css +68 -80
  65. package/common/coreTokens.d.ts +237 -0
  66. package/common/coreTokens.js +184 -0
  67. package/common/utils.d.ts +1 -0
  68. package/common/utils.js +6 -12
  69. package/common/variables.d.ts +1383 -0
  70. package/common/variables.js +1017 -1374
  71. package/container/Container.d.ts +4 -0
  72. package/container/Container.js +194 -0
  73. package/container/Container.stories.tsx +214 -0
  74. package/container/types.d.ts +74 -0
  75. package/date-input/Calendar.d.ts +4 -0
  76. package/date-input/Calendar.js +214 -0
  77. package/date-input/DateInput.js +171 -306
  78. package/date-input/DateInput.stories.tsx +203 -56
  79. package/date-input/DateInput.test.js +808 -0
  80. package/date-input/DatePicker.d.ts +4 -0
  81. package/date-input/DatePicker.js +115 -0
  82. package/date-input/Icons.d.ts +6 -0
  83. package/date-input/Icons.js +58 -0
  84. package/date-input/YearPicker.d.ts +4 -0
  85. package/date-input/YearPicker.js +100 -0
  86. package/date-input/types.d.ts +86 -22
  87. package/dialog/Dialog.d.ts +1 -1
  88. package/dialog/Dialog.js +68 -130
  89. package/dialog/Dialog.stories.tsx +320 -167
  90. package/dialog/Dialog.test.js +307 -0
  91. package/dialog/types.d.ts +18 -25
  92. package/dropdown/Dropdown.d.ts +1 -1
  93. package/dropdown/Dropdown.js +249 -330
  94. package/dropdown/Dropdown.stories.tsx +255 -64
  95. package/dropdown/Dropdown.test.js +599 -0
  96. package/dropdown/DropdownMenu.d.ts +4 -0
  97. package/dropdown/DropdownMenu.js +63 -0
  98. package/dropdown/DropdownMenuItem.d.ts +4 -0
  99. package/dropdown/DropdownMenuItem.js +67 -0
  100. package/dropdown/types.d.ts +36 -27
  101. package/file-input/FileInput.d.ts +2 -2
  102. package/file-input/FileInput.js +246 -357
  103. package/file-input/FileInput.stories.tsx +123 -12
  104. package/file-input/FileInput.test.js +459 -0
  105. package/file-input/FileItem.d.ts +4 -14
  106. package/file-input/FileItem.js +50 -99
  107. package/file-input/types.d.ts +25 -8
  108. package/flex/Flex.d.ts +4 -0
  109. package/flex/Flex.js +57 -0
  110. package/flex/Flex.stories.tsx +112 -0
  111. package/flex/types.d.ts +97 -0
  112. package/footer/Footer.d.ts +1 -1
  113. package/footer/Footer.js +70 -190
  114. package/footer/Footer.stories.tsx +60 -19
  115. package/footer/Footer.test.js +85 -0
  116. package/footer/Icons.d.ts +3 -2
  117. package/footer/Icons.js +67 -8
  118. package/footer/types.d.ts +25 -26
  119. package/grid/Grid.d.ts +7 -0
  120. package/grid/Grid.js +76 -0
  121. package/grid/Grid.stories.tsx +219 -0
  122. package/grid/types.d.ts +115 -0
  123. package/header/Header.d.ts +4 -3
  124. package/header/Header.js +99 -203
  125. package/header/Header.stories.tsx +152 -63
  126. package/header/Header.test.js +66 -0
  127. package/header/Icons.d.ts +2 -2
  128. package/header/Icons.js +4 -9
  129. package/header/types.d.ts +5 -19
  130. package/heading/Heading.js +10 -32
  131. package/heading/Heading.test.js +169 -0
  132. package/heading/types.d.ts +7 -7
  133. package/image/Image.d.ts +4 -0
  134. package/image/Image.js +70 -0
  135. package/image/Image.stories.tsx +127 -0
  136. package/image/types.d.ts +72 -0
  137. package/image/types.js +5 -0
  138. package/inset/Inset.js +14 -55
  139. package/inset/Inset.stories.tsx +37 -36
  140. package/inset/types.d.ts +26 -2
  141. package/layout/ApplicationLayout.d.ts +16 -6
  142. package/layout/ApplicationLayout.js +83 -174
  143. package/layout/ApplicationLayout.stories.tsx +85 -94
  144. package/layout/Icons.d.ts +8 -0
  145. package/layout/Icons.js +51 -48
  146. package/layout/SidenavContext.d.ts +5 -0
  147. package/layout/SidenavContext.js +13 -0
  148. package/layout/types.d.ts +19 -35
  149. package/link/Link.d.ts +3 -2
  150. package/link/Link.js +64 -110
  151. package/link/Link.stories.tsx +159 -52
  152. package/link/Link.test.js +63 -0
  153. package/link/types.d.ts +15 -35
  154. package/main.d.ts +17 -18
  155. package/main.js +68 -120
  156. package/nav-tabs/NavTabs.d.ts +8 -0
  157. package/nav-tabs/NavTabs.js +93 -0
  158. package/nav-tabs/NavTabs.stories.tsx +276 -0
  159. package/nav-tabs/NavTabs.test.js +76 -0
  160. package/nav-tabs/Tab.d.ts +4 -0
  161. package/nav-tabs/Tab.js +118 -0
  162. package/nav-tabs/types.d.ts +52 -0
  163. package/nav-tabs/types.js +5 -0
  164. package/number-input/NumberInput.d.ts +7 -0
  165. package/number-input/NumberInput.js +27 -43
  166. package/number-input/NumberInput.stories.tsx +44 -28
  167. package/number-input/NumberInput.test.js +830 -0
  168. package/number-input/types.d.ts +28 -15
  169. package/package.json +46 -47
  170. package/paginator/Icons.d.ts +5 -0
  171. package/paginator/Icons.js +21 -47
  172. package/paginator/Paginator.js +34 -91
  173. package/paginator/Paginator.stories.tsx +24 -0
  174. package/paginator/Paginator.test.js +335 -0
  175. package/paginator/types.d.ts +3 -3
  176. package/paragraph/Paragraph.d.ts +5 -0
  177. package/paragraph/Paragraph.js +22 -0
  178. package/paragraph/Paragraph.stories.tsx +27 -0
  179. package/password-input/Icons.d.ts +6 -0
  180. package/password-input/Icons.js +35 -0
  181. package/password-input/PasswordInput.js +57 -123
  182. package/password-input/PasswordInput.stories.tsx +1 -33
  183. package/password-input/PasswordInput.test.js +198 -0
  184. package/password-input/types.d.ts +21 -17
  185. package/progress-bar/ProgressBar.js +65 -91
  186. package/progress-bar/ProgressBar.stories.tsx +93 -0
  187. package/progress-bar/ProgressBar.test.js +93 -0
  188. package/progress-bar/types.d.ts +3 -3
  189. package/quick-nav/QuickNav.d.ts +4 -0
  190. package/quick-nav/QuickNav.js +94 -0
  191. package/quick-nav/QuickNav.stories.tsx +356 -0
  192. package/quick-nav/types.d.ts +21 -0
  193. package/quick-nav/types.js +5 -0
  194. package/radio-group/Radio.d.ts +1 -1
  195. package/radio-group/Radio.js +64 -80
  196. package/radio-group/RadioGroup.js +101 -139
  197. package/radio-group/RadioGroup.stories.tsx +171 -36
  198. package/radio-group/RadioGroup.test.js +691 -183
  199. package/radio-group/types.d.ts +89 -11
  200. package/resultset-table/Icons.d.ts +7 -0
  201. package/resultset-table/Icons.js +47 -0
  202. package/resultset-table/ResultsetTable.d.ts +7 -0
  203. package/resultset-table/ResultsetTable.js +167 -0
  204. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +136 -30
  205. package/resultset-table/ResultsetTable.test.js +371 -0
  206. package/{resultsetTable → resultset-table}/types.d.ts +13 -7
  207. package/resultset-table/types.js +5 -0
  208. package/select/Icons.d.ts +10 -0
  209. package/select/Icons.js +89 -0
  210. package/select/Listbox.d.ts +4 -0
  211. package/select/Listbox.js +143 -0
  212. package/select/Option.d.ts +4 -0
  213. package/select/Option.js +87 -0
  214. package/select/Select.js +229 -502
  215. package/select/Select.stories.tsx +603 -204
  216. package/select/Select.test.js +2370 -0
  217. package/select/types.d.ts +64 -25
  218. package/sidenav/Icons.d.ts +7 -0
  219. package/sidenav/Icons.js +47 -0
  220. package/sidenav/Sidenav.d.ts +6 -5
  221. package/sidenav/Sidenav.js +131 -71
  222. package/sidenav/Sidenav.stories.tsx +251 -151
  223. package/sidenav/Sidenav.test.js +37 -0
  224. package/sidenav/types.d.ts +52 -26
  225. package/slider/Slider.d.ts +2 -2
  226. package/slider/Slider.js +148 -180
  227. package/slider/Slider.test.js +254 -0
  228. package/slider/types.d.ts +11 -3
  229. package/spinner/Spinner.js +31 -75
  230. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  231. package/spinner/Spinner.test.js +55 -0
  232. package/spinner/types.d.ts +3 -3
  233. package/status-light/StatusLight.d.ts +4 -0
  234. package/status-light/StatusLight.js +51 -0
  235. package/status-light/StatusLight.stories.tsx +74 -0
  236. package/status-light/StatusLight.test.js +25 -0
  237. package/status-light/types.d.ts +17 -0
  238. package/status-light/types.js +5 -0
  239. package/switch/Switch.d.ts +2 -2
  240. package/switch/Switch.js +149 -114
  241. package/switch/Switch.stories.tsx +44 -67
  242. package/switch/Switch.test.js +180 -0
  243. package/switch/types.d.ts +13 -5
  244. package/table/ActionsCell.d.ts +4 -0
  245. package/table/ActionsCell.js +54 -0
  246. package/table/DropdownTheme.js +57 -0
  247. package/table/Table.d.ts +4 -1
  248. package/table/Table.js +27 -32
  249. package/table/Table.stories.tsx +615 -0
  250. package/table/Table.test.js +113 -0
  251. package/table/types.d.ts +45 -6
  252. package/tabs/Tab.d.ts +4 -0
  253. package/tabs/Tab.js +116 -0
  254. package/tabs/Tabs.d.ts +1 -1
  255. package/tabs/Tabs.js +316 -145
  256. package/tabs/Tabs.stories.tsx +120 -14
  257. package/tabs/Tabs.test.js +294 -0
  258. package/tabs/types.d.ts +29 -15
  259. package/tag/Tag.d.ts +1 -1
  260. package/tag/Tag.js +43 -85
  261. package/tag/Tag.stories.tsx +37 -27
  262. package/tag/Tag.test.js +49 -0
  263. package/tag/types.d.ts +25 -16
  264. package/text-input/Icons.d.ts +8 -0
  265. package/text-input/Icons.js +56 -0
  266. package/text-input/Suggestion.d.ts +4 -0
  267. package/text-input/Suggestion.js +67 -0
  268. package/text-input/Suggestions.d.ts +4 -0
  269. package/text-input/Suggestions.js +84 -0
  270. package/text-input/TextInput.js +326 -548
  271. package/text-input/TextInput.stories.tsx +281 -272
  272. package/text-input/TextInput.test.js +1739 -0
  273. package/text-input/types.d.ts +70 -24
  274. package/textarea/Textarea.js +85 -135
  275. package/textarea/Textarea.stories.tsx +174 -0
  276. package/textarea/Textarea.test.js +406 -0
  277. package/textarea/types.d.ts +27 -16
  278. package/toggle-group/ToggleGroup.d.ts +2 -2
  279. package/toggle-group/ToggleGroup.js +92 -105
  280. package/toggle-group/ToggleGroup.stories.tsx +53 -8
  281. package/toggle-group/ToggleGroup.test.js +137 -0
  282. package/toggle-group/types.d.ts +34 -17
  283. package/typography/Typography.d.ts +4 -0
  284. package/typography/Typography.js +23 -0
  285. package/typography/Typography.stories.tsx +198 -0
  286. package/typography/types.d.ts +18 -0
  287. package/typography/types.js +5 -0
  288. package/useTheme.d.ts +1135 -1
  289. package/useTheme.js +4 -11
  290. package/useTranslatedLabels.d.ts +85 -0
  291. package/useTranslatedLabels.js +14 -0
  292. package/utils/BaseTypography.d.ts +21 -0
  293. package/utils/BaseTypography.js +94 -0
  294. package/utils/FocusLock.d.ts +13 -0
  295. package/utils/FocusLock.js +124 -0
  296. package/wizard/Wizard.d.ts +1 -1
  297. package/wizard/Wizard.js +70 -101
  298. package/wizard/Wizard.stories.tsx +48 -19
  299. package/wizard/Wizard.test.js +114 -0
  300. package/wizard/types.d.ts +12 -8
  301. package/ThemeContext.d.ts +0 -15
  302. package/ThemeContext.js +0 -243
  303. package/V3Select/V3Select.js +0 -455
  304. package/V3Select/index.d.ts +0 -27
  305. package/V3Textarea/V3Textarea.js +0 -260
  306. package/V3Textarea/index.d.ts +0 -27
  307. package/card/ice-cream.jpg +0 -0
  308. package/common/RequiredComponent.js +0 -32
  309. package/date/Date.js +0 -373
  310. package/date/index.d.ts +0 -27
  311. package/input-text/Icons.js +0 -22
  312. package/input-text/InputText.js +0 -611
  313. package/input-text/index.d.ts +0 -36
  314. package/list/List.d.ts +0 -4
  315. package/list/List.js +0 -47
  316. package/list/List.stories.tsx +0 -95
  317. package/list/types.d.ts +0 -7
  318. package/number-input/NumberInputContext.d.ts +0 -4
  319. package/number-input/NumberInputContext.js +0 -19
  320. package/number-input/numberInputContextTypes.d.ts +0 -19
  321. package/progress-bar/ProgressBar.stories.jsx +0 -58
  322. package/radio/Radio.d.ts +0 -4
  323. package/radio/Radio.js +0 -174
  324. package/radio/Radio.stories.tsx +0 -192
  325. package/radio/types.d.ts +0 -54
  326. package/resultsetTable/ResultsetTable.d.ts +0 -4
  327. package/resultsetTable/ResultsetTable.js +0 -251
  328. package/row/Row.d.ts +0 -3
  329. package/row/Row.js +0 -127
  330. package/row/Row.stories.tsx +0 -237
  331. package/row/types.d.ts +0 -10
  332. package/slider/Slider.stories.tsx +0 -177
  333. package/stack/Stack.d.ts +0 -3
  334. package/stack/Stack.js +0 -97
  335. package/stack/Stack.stories.tsx +0 -164
  336. package/stack/types.d.ts +0 -9
  337. package/table/Table.stories.jsx +0 -277
  338. package/text/Text.d.ts +0 -7
  339. package/text/Text.js +0 -30
  340. package/text/Text.stories.tsx +0 -19
  341. package/textarea/Textarea.stories.jsx +0 -136
  342. package/toggle/Toggle.js +0 -186
  343. package/toggle/index.d.ts +0 -21
  344. package/upload/Upload.js +0 -201
  345. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  346. package/upload/buttons-upload/Icons.js +0 -40
  347. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  348. package/upload/dragAndDropArea/Icons.js +0 -39
  349. package/upload/file-upload/FileToUpload.js +0 -115
  350. package/upload/file-upload/Icons.js +0 -66
  351. package/upload/files-upload/FilesToUpload.js +0 -109
  352. package/upload/index.d.ts +0 -15
  353. package/upload/transaction/Icons.js +0 -160
  354. package/upload/transaction/Transaction.js +0 -104
  355. package/upload/transactions/Transactions.js +0 -94
  356. /package/{list → action-icon}/types.js +0 -0
  357. /package/{radio → badge}/types.js +0 -0
  358. /package/{resultsetTable → bulleted-list}/types.js +0 -0
  359. /package/{row → container}/types.js +0 -0
  360. /package/{stack → flex}/types.js +0 -0
  361. /package/{number-input/numberInputContextTypes.js → grid/types.js} +0 -0
@@ -1,36 +1,114 @@
1
- export declare type Option = {
1
+ export type Option = {
2
+ /**
3
+ * Label of the option placed next to the radio input.
4
+ */
2
5
  value: string;
6
+ /**
7
+ * Value of the option. It should be unique and
8
+ * not an empty string, which is reserved to the optional item added
9
+ * by 'optional' prop.
10
+ */
3
11
  label: string;
12
+ /**
13
+ * If true, disables the option.
14
+ */
4
15
  disabled?: boolean;
5
16
  };
6
- declare type RadioGroupProps = {
7
- label: string;
17
+ type RadioGroupProps = {
18
+ /**
19
+ * Text to be placed above the radio group.
20
+ */
21
+ label?: string;
22
+ /**
23
+ * Name attribute of the input element. This attribute will allow users
24
+ * to find the component's value during the submit event.
25
+ */
8
26
  name?: string;
27
+ /**
28
+ * Helper text to be placed above the radio group.
29
+ */
9
30
  helperText?: string;
31
+ /**
32
+ * An array of objects representing the selectable options.
33
+ */
10
34
  options: Option[];
35
+ /**
36
+ * If true, the component will be disabled.
37
+ */
11
38
  disabled?: boolean;
39
+ /**
40
+ * If true, the radio group will be optional, showing
41
+ * (Optional) next to the label and adding a default last
42
+ * option with an empty string as value. Otherwise, the field will be
43
+ * considered required and an error will be passed as a parameter to the
44
+ * OnBlur functions if an option wasn't selected.
45
+ */
12
46
  optional?: boolean;
47
+ /**
48
+ * Label of the optional radio input.
49
+ */
13
50
  optionalItemLabel?: string;
14
- readonly?: boolean;
51
+ /**
52
+ * If true, the component will not be mutable, meaning the user can not edit the control.
53
+ */
54
+ readOnly?: boolean;
55
+ /**
56
+ * Sets the orientation of the options within the radio group.
57
+ */
15
58
  stacking?: "row" | "column";
59
+ /**
60
+ * Initial value of the radio group, only when it is uncontrolled.
61
+ */
16
62
  defaultValue?: string;
63
+ /**
64
+ * Value of the radio group. If undefined, the component will be
65
+ * uncontrolled and the value will be managed internally by the
66
+ * component.
67
+ */
17
68
  value?: string;
18
- onChange?: (value?: string) => void;
69
+ /**
70
+ * This function will be called when the user chooses an option. The new
71
+ * value will be passed to this function.
72
+ */
73
+ onChange?: (value: string) => void;
74
+ /**
75
+ * This function will be called when the radio group loses the focus. An
76
+ * object including the value and the error will be passed to this
77
+ * function. If there is no error, error will not be defined.
78
+ */
19
79
  onBlur?: (val: {
20
80
  value?: string;
21
81
  error?: string;
22
82
  }) => void;
83
+ /**
84
+ * If it is a defined value and also a truthy string, the component will
85
+ * change its appearance, showing the error below the radio group. If the
86
+ * defined value is an empty string, it will reserve a space below the
87
+ * component for a future error, but it would not change its look. In
88
+ * case of being undefined or null, both the appearance and the space for
89
+ * the error message would not be modified.
90
+ */
23
91
  error?: string;
92
+ /**
93
+ * Value of the tabindex attribute.
94
+ */
95
+ tabIndex?: number;
24
96
  };
25
- export declare type RefType = HTMLDivElement;
26
- export declare type RadioProps = {
27
- option: Option;
28
- currentValue?: string;
97
+ /**
98
+ * Reference to the component.
99
+ */
100
+ export type RefType = HTMLDivElement;
101
+ /**
102
+ * Single radio prop types.
103
+ */
104
+ export type RadioProps = {
105
+ label: string;
106
+ checked: boolean;
29
107
  onClick: () => void;
30
- onFocus: () => void;
31
108
  error?: string;
32
109
  disabled: boolean;
33
110
  focused: boolean;
34
- readonly: boolean;
111
+ readOnly: boolean;
112
+ tabIndex: number;
35
113
  };
36
114
  export default RadioGroupProps;
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ declare const icons: {
3
+ arrowUp: React.JSX.Element;
4
+ arrowDown: React.JSX.Element;
5
+ bothArrows: React.JSX.Element;
6
+ };
7
+ export default icons;
@@ -0,0 +1,47 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports["default"] = void 0;
8
+ var _react = _interopRequireDefault(require("react"));
9
+ var icons = {
10
+ arrowUp: /*#__PURE__*/_react["default"].createElement("svg", {
11
+ xmlns: "http://www.w3.org/2000/svg",
12
+ height: "24",
13
+ viewBox: "0 0 24 24",
14
+ width: "24",
15
+ fill: "currentColor"
16
+ }, /*#__PURE__*/_react["default"].createElement("path", {
17
+ d: "M0 0h24v24H0V0z",
18
+ fill: "none"
19
+ }), /*#__PURE__*/_react["default"].createElement("path", {
20
+ d: "M4 12l1.41 1.41L11 7.83V20h2V7.83l5.58 5.59L20 12l-8-8-8 8z"
21
+ })),
22
+ arrowDown: /*#__PURE__*/_react["default"].createElement("svg", {
23
+ xmlns: "http://www.w3.org/2000/svg",
24
+ height: "24",
25
+ viewBox: "0 0 24 24",
26
+ width: "24",
27
+ fill: "currentColor"
28
+ }, /*#__PURE__*/_react["default"].createElement("path", {
29
+ d: "M0 0h24v24H0V0z",
30
+ fill: "none"
31
+ }), /*#__PURE__*/_react["default"].createElement("path", {
32
+ d: "M20 12l-1.41-1.41L13 16.17V4h-2v12.17l-5.58-5.59L4 12l8 8 8-8z"
33
+ })),
34
+ bothArrows: /*#__PURE__*/_react["default"].createElement("svg", {
35
+ xmlns: "http://www.w3.org/2000/svg",
36
+ height: "24",
37
+ viewBox: "0 0 24 24",
38
+ width: "24",
39
+ fill: "currentColor"
40
+ }, /*#__PURE__*/_react["default"].createElement("path", {
41
+ d: "M0 0h24v24H0z",
42
+ fill: "none"
43
+ }), /*#__PURE__*/_react["default"].createElement("path", {
44
+ d: "M12 5.83L15.17 9l1.41-1.41L12 3 7.41 7.59 8.83 9 12 5.83zm0 12.34L8.83 15l-1.41 1.41L12 21l4.59-4.59L15.17 15 12 18.17z"
45
+ }))
46
+ };
47
+ var _default = exports["default"] = icons;
@@ -0,0 +1,7 @@
1
+ /// <reference types="react" />
2
+ import ResultsetTablePropsType from "./types";
3
+ declare const DxcResultsetTable: {
4
+ ({ columns, rows, showGoToPage, itemsPerPage, itemsPerPageOptions, itemsPerPageFunction, margin, tabIndex, mode, }: ResultsetTablePropsType): JSX.Element;
5
+ ActionsCell: ({ actions }: import("../table/types").ActionCellsPropsType) => JSX.Element;
6
+ };
7
+ export default DxcResultsetTable;
@@ -0,0 +1,167 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof3 = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
10
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
11
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
12
+ var _react = _interopRequireWildcard(require("react"));
13
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
14
+ var _variables = require("../common/variables");
15
+ var _ActionsCell = _interopRequireDefault(require("../table/ActionsCell"));
16
+ var _Paginator = _interopRequireDefault(require("../paginator/Paginator"));
17
+ var _Table = _interopRequireDefault(require("../table/Table"));
18
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
19
+ var _Icons = _interopRequireDefault(require("./Icons"));
20
+ var _utils = require("../common/utils");
21
+ var _coreTokens = _interopRequireDefault(require("../common/coreTokens"));
22
+ var _templateObject, _templateObject2, _templateObject3;
23
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
24
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof3(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
25
+ var normalizeSortValue = function normalizeSortValue(sortValue) {
26
+ return typeof sortValue === "string" ? sortValue.toUpperCase() : sortValue;
27
+ };
28
+ var sortArray = function sortArray(index, order, resultset) {
29
+ return resultset.slice().sort(function (element1, element2) {
30
+ var sortValueA = normalizeSortValue(element1[index].sortValue || element1[index].displayValue);
31
+ var sortValueB = normalizeSortValue(element2[index].sortValue || element2[index].displayValue);
32
+ var comparison = 0;
33
+ if ((0, _typeof2["default"])(sortValueA) === "object") {
34
+ comparison = -1;
35
+ } else if ((0, _typeof2["default"])(sortValueB) === "object") {
36
+ comparison = 1;
37
+ } else if (sortValueA > sortValueB) {
38
+ comparison = 1;
39
+ } else if (sortValueA < sortValueB) {
40
+ comparison = -1;
41
+ }
42
+ return order === "descending" ? comparison * -1 : comparison;
43
+ });
44
+ };
45
+ var getMinItemsPerPageIndex = function getMinItemsPerPageIndex(currentPageInternal, itemsPerPage, page) {
46
+ return currentPageInternal === 1 ? 0 : itemsPerPage * (page - 1);
47
+ };
48
+ var getMaxItemsPerPageIndex = function getMaxItemsPerPageIndex(minItemsPerPageIndex, itemsPerPage, resultset, page) {
49
+ return minItemsPerPageIndex + itemsPerPage > resultset.length ? resultset.length : itemsPerPage * page - 1;
50
+ };
51
+ var DxcResultsetTable = function DxcResultsetTable(_ref) {
52
+ var columns = _ref.columns,
53
+ rows = _ref.rows,
54
+ _ref$showGoToPage = _ref.showGoToPage,
55
+ showGoToPage = _ref$showGoToPage === void 0 ? true : _ref$showGoToPage,
56
+ _ref$itemsPerPage = _ref.itemsPerPage,
57
+ itemsPerPage = _ref$itemsPerPage === void 0 ? 5 : _ref$itemsPerPage,
58
+ itemsPerPageOptions = _ref.itemsPerPageOptions,
59
+ itemsPerPageFunction = _ref.itemsPerPageFunction,
60
+ margin = _ref.margin,
61
+ _ref$tabIndex = _ref.tabIndex,
62
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex,
63
+ _ref$mode = _ref.mode,
64
+ mode = _ref$mode === void 0 ? "default" : _ref$mode;
65
+ var colorsTheme = (0, _useTheme["default"])();
66
+ var _useState = (0, _react.useState)(1),
67
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
68
+ page = _useState2[0],
69
+ changePage = _useState2[1];
70
+ var _useState3 = (0, _react.useState)(-1),
71
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
72
+ sortColumnIndex = _useState4[0],
73
+ changeSortColumnIndex = _useState4[1];
74
+ var _useState5 = (0, _react.useState)("ascending"),
75
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
76
+ sortOrder = _useState6[0],
77
+ changeSortOrder = _useState6[1];
78
+ var minItemsPerPageIndex = (0, _react.useMemo)(function () {
79
+ return getMinItemsPerPageIndex(page, itemsPerPage, page);
80
+ }, [itemsPerPage, page]);
81
+ var maxItemsPerPageIndex = (0, _react.useMemo)(function () {
82
+ return getMaxItemsPerPageIndex(minItemsPerPageIndex, itemsPerPage, rows, page);
83
+ }, [itemsPerPage, minItemsPerPageIndex, page, rows]);
84
+ var sortedResultset = (0, _react.useMemo)(function () {
85
+ return sortColumnIndex !== -1 ? sortArray(sortColumnIndex, sortOrder, rows) : rows;
86
+ }, [sortColumnIndex, sortOrder, rows]);
87
+ var filteredResultset = (0, _react.useMemo)(function () {
88
+ return sortedResultset && sortedResultset.slice(minItemsPerPageIndex, maxItemsPerPageIndex + 1);
89
+ }, [sortedResultset, minItemsPerPageIndex, maxItemsPerPageIndex]);
90
+ var goToPage = function goToPage(newPage) {
91
+ changePage(newPage);
92
+ };
93
+ var changeSorting = function changeSorting(columnIndex) {
94
+ changePage(1);
95
+ changeSortColumnIndex(columnIndex);
96
+ changeSortOrder(sortColumnIndex === -1 || sortColumnIndex !== columnIndex ? "ascending" : sortOrder === "ascending" ? "descending" : "ascending");
97
+ };
98
+ (0, _react.useEffect)(function () {
99
+ rows.length > 0 ? changePage(1) : changePage(0);
100
+ }, [rows]);
101
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
102
+ theme: colorsTheme.table
103
+ }, /*#__PURE__*/_react["default"].createElement(DxcResultsetTableContainer, {
104
+ margin: margin
105
+ }, /*#__PURE__*/_react["default"].createElement(_Table["default"], {
106
+ mode: mode
107
+ }, /*#__PURE__*/_react["default"].createElement("thead", null, /*#__PURE__*/_react["default"].createElement("tr", null, columns.map(function (column, index) {
108
+ return /*#__PURE__*/_react["default"].createElement("th", {
109
+ key: "tableHeader_".concat(index),
110
+ "aria-sort": column.isSortable ? sortColumnIndex === index ? sortOrder : "none" : undefined
111
+ }, /*#__PURE__*/_react["default"].createElement(HeaderContainer, {
112
+ role: column.isSortable ? "button" : undefined,
113
+ key: "headerContainer_".concat(index),
114
+ onClick: function onClick() {
115
+ column.isSortable && changeSorting(index);
116
+ },
117
+ tabIndex: column.isSortable ? tabIndex : -1,
118
+ isSortable: column.isSortable,
119
+ mode: mode
120
+ }, /*#__PURE__*/_react["default"].createElement("span", null, column.displayValue), column.isSortable && /*#__PURE__*/_react["default"].createElement(SortIcon, null, sortColumnIndex === index ? sortOrder === "ascending" ? _Icons["default"].arrowUp : _Icons["default"].arrowDown : _Icons["default"].bothArrows)));
121
+ }))), /*#__PURE__*/_react["default"].createElement("tbody", null, filteredResultset.map(function (cells, index) {
122
+ return /*#__PURE__*/_react["default"].createElement("tr", {
123
+ key: "resultSetTableCell_".concat(page, "_").concat(index)
124
+ }, cells.map(function (cellContent, index) {
125
+ return /*#__PURE__*/_react["default"].createElement("td", {
126
+ key: "resultSetTableCellContent_".concat(index)
127
+ }, cellContent.displayValue);
128
+ }));
129
+ }))), /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
130
+ totalItems: rows.length,
131
+ itemsPerPage: itemsPerPage,
132
+ itemsPerPageOptions: itemsPerPageOptions,
133
+ itemsPerPageFunction: itemsPerPageFunction,
134
+ currentPage: page,
135
+ showGoToPage: showGoToPage,
136
+ onPageChange: goToPage,
137
+ tabIndex: tabIndex
138
+ })));
139
+ };
140
+ var calculateWidth = function calculateWidth(margin) {
141
+ return "calc(100% - ".concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
142
+ };
143
+ var DxcResultsetTableContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"])), function (props) {
144
+ return calculateWidth(props.margin);
145
+ }, function (props) {
146
+ return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
147
+ }, function (props) {
148
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
149
+ }, function (props) {
150
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
151
+ }, function (props) {
152
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
153
+ }, function (props) {
154
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
155
+ });
156
+ var HeaderContainer = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: ", ";\n gap: ", ";\n width: fit-content;\n border: 1px solid transparent;\n border-radius: 2px;\n cursor: ", ";\n\n ", "\n"])), function (props) {
157
+ return props.theme.headerTextAlign === "center" ? "center" : props.theme.headerTextAlign === "right" ? "flex-end" : "flex-start";
158
+ }, _coreTokens["default"].spacing_8, function (props) {
159
+ return props.isSortable ? "pointer" : "default";
160
+ }, function (props) {
161
+ return props.isSortable && "&:focus {\n outline: #0095ff solid 2px;\n }";
162
+ });
163
+ var SortIcon = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n height: 14px;\n width: 14px;\n color: ", ";\n\n svg {\n height: 100%;\n width: 100%;\n }\n"])), function (props) {
164
+ return props.theme.sortIconColor;
165
+ });
166
+ DxcResultsetTable.ActionsCell = _ActionsCell["default"];
167
+ var _default = exports["default"] = DxcResultsetTable;
@@ -1,9 +1,9 @@
1
1
  import React from "react";
2
2
  import DxcResultsetTable from "./ResultsetTable";
3
- import DxcButton from "../button/Button";
4
3
  import Title from "../../.storybook/components/Title";
5
4
  import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
5
  import { userEvent, within } from "@storybook/testing-library";
6
+ import styled from "styled-components";
7
7
 
8
8
  export default {
9
9
  title: "Resultset Table",
@@ -12,7 +12,7 @@ export default {
12
12
 
13
13
  const deleteIcon = (
14
14
  <svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24">
15
- <path d="M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zM19 4h-3.5l-1-1h-5l-1 1H5v2h14V4z" />
15
+ <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" />
16
16
  <path d="M0 0h24v24H0z" fill="none" />
17
17
  </svg>
18
18
  );
@@ -28,17 +28,66 @@ const rows = [
28
28
  [{ displayValue: "006" }, { displayValue: "Cris" }, { displayValue: "Paris" }],
29
29
  ];
30
30
 
31
+ const actions = [
32
+ {
33
+ title: "icon",
34
+ onClick: (value?) => {
35
+ console.log(value);
36
+ },
37
+ options: [
38
+ {
39
+ value: "1",
40
+ label: "Amazon with a very long text",
41
+ },
42
+ {
43
+ value: "2",
44
+ label: "Ebay",
45
+ },
46
+ {
47
+ value: "3",
48
+ label: "Apple",
49
+ },
50
+ ],
51
+ },
52
+ {
53
+ icon: "https://www.freepnglogos.com/uploads/facebook-logo-design-1.png",
54
+ title: "icon",
55
+ onClick: () => {},
56
+ },
57
+ {
58
+ icon: deleteIcon,
59
+ title: "icon",
60
+ onClick: () => {},
61
+ disabled: true,
62
+ },
63
+ {
64
+ icon: deleteIcon,
65
+ title: "icon",
66
+ onClick: () => {},
67
+ },
68
+ ];
69
+
31
70
  const rowsIcon = [
32
71
  [
33
72
  { displayValue: "001", sortValue: "001" },
34
73
  { displayValue: "Peter" },
35
- { displayValue: <DxcButton icon={deleteIcon} /> },
74
+ {
75
+ displayValue: <DxcResultsetTable.ActionsCell actions={actions} />,
76
+ },
77
+ ],
78
+ [
79
+ { displayValue: "002", sortValue: "002" },
80
+ { displayValue: "Louis" },
81
+ {
82
+ displayValue: <DxcResultsetTable.ActionsCell actions={actions} />,
83
+ },
36
84
  ],
37
- [{ displayValue: "002", sortValue: "002" }, { displayValue: "Louis" }, { displayValue: "" }],
38
85
  [
39
86
  { displayValue: "003", sortValue: "003" },
40
87
  { displayValue: "Mark" },
41
- { displayValue: <DxcButton icon={deleteIcon} /> },
88
+ {
89
+ displayValue: <DxcResultsetTable.ActionsCell actions={actions} />,
90
+ },
42
91
  ],
43
92
  ];
44
93
 
@@ -48,6 +97,24 @@ const columnsSortable = [
48
97
  { displayValue: "City", isSortable: false },
49
98
  ];
50
99
 
100
+ const longValues = [
101
+ [
102
+ { displayValue: "000000000000000001", sortValue: "000000000000000001" },
103
+ { displayValue: "Peter Larsson González", sortValue: "Peter" },
104
+ { displayValue: "Miami: The city that never sleeps", sortValue: "Miami" },
105
+ ],
106
+ [
107
+ { displayValue: "002", sortValue: "002" },
108
+ { displayValue: "Louis", sortValue: "Louis" },
109
+ { displayValue: "London", sortValue: "London" },
110
+ ],
111
+ [
112
+ { displayValue: "003", sortValue: "003" },
113
+ { displayValue: "Aida", sortValue: "Aida" },
114
+ { displayValue: "Wroclaw", sortValue: "Wroclaw" },
115
+ ],
116
+ ];
117
+
51
118
  const rowsSortable = [
52
119
  [
53
120
  { displayValue: "001", sortValue: "001" },
@@ -167,89 +234,114 @@ export const Chromatic = () => (
167
234
  <>
168
235
  <ExampleContainer>
169
236
  <Title title="Sortable table" theme="light" level={4} />
170
- <DxcResultsetTable columns={columnsSortable} rows={rowsSortable}></DxcResultsetTable>
237
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
171
238
  </ExampleContainer>
172
239
  <ExampleContainer>
173
240
  <Title title="With action" theme="light" level={4} />
174
- <DxcResultsetTable columns={columns} rows={rowsIcon}></DxcResultsetTable>
241
+ <DxcResultsetTable columns={columns} rows={rowsIcon} />
175
242
  </ExampleContainer>
176
243
  <ExampleContainer>
177
244
  <Title title="With items per page option" theme="light" level={4} />
178
- <DxcResultsetTable
179
- columns={columns}
180
- rows={rows}
181
- itemsPerPage={2}
182
- itemsPerPageOptions={[2, 3]}
183
- ></DxcResultsetTable>
245
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} itemsPerPageOptions={[2, 3]} />
184
246
  </ExampleContainer>
185
247
  <ExampleContainer>
186
248
  <Title title="Scroll resultset table" theme="light" level={4} />
187
- <DxcResultsetTable columns={longColumns} rows={longRows}></DxcResultsetTable>
249
+ <DxcResultsetTable columns={longColumns} rows={longRows} />
250
+ </ExampleContainer>
251
+ <ExampleContainer>
252
+ <SmallContainer>
253
+ <Title title="Small container and text overflow" theme="light" level={4} />
254
+ <DxcResultsetTable columns={columnsSortable} rows={longValues} />
255
+ </SmallContainer>
256
+ </ExampleContainer>
257
+ <ExampleContainer>
258
+ <Title title="Reduced sortable table" theme="light" level={4} />
259
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} mode="reduced" />
260
+ </ExampleContainer>
261
+ {/* PENDING SMALL ICON VERSION */}
262
+ <ExampleContainer>
263
+ <Title title="Reduced with items per page option" theme="light" level={4} />
264
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} itemsPerPageOptions={[2, 3]} mode="reduced" />
265
+ </ExampleContainer>
266
+ <ExampleContainer>
267
+ <Title title="Reduced scroll resultset table" theme="light" level={4} />
268
+ <DxcResultsetTable columns={longColumns} rows={longRows} mode="reduced" />
269
+ </ExampleContainer>
270
+ <ExampleContainer>
271
+ <SmallContainer>
272
+ <Title title="Reduced small container and text overflow" theme="light" level={4} />
273
+ <DxcResultsetTable columns={columnsSortable} rows={longValues} mode="reduced" />
274
+ </SmallContainer>
188
275
  </ExampleContainer>
189
276
  <Title title="Margins" theme="light" level={2} />
190
277
  <ExampleContainer>
191
278
  <Title title="Xxsmall" theme="light" level={4} />
192
- <DxcResultsetTable columns={columns} rows={rows} margin={"xxsmall"}></DxcResultsetTable>
279
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xxsmall"} />
193
280
  </ExampleContainer>
194
281
  <ExampleContainer>
195
282
  <Title title="Xsmall" theme="light" level={4} />
196
- <DxcResultsetTable columns={columns} rows={rows} margin={"xsmall"}></DxcResultsetTable>
283
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xsmall"} />
197
284
  </ExampleContainer>
198
285
  <ExampleContainer>
199
286
  <Title title="Small" theme="light" level={4} />
200
- <DxcResultsetTable columns={columns} rows={rows} margin={"small"}></DxcResultsetTable>
287
+ <DxcResultsetTable columns={columns} rows={rows} margin={"small"} />
201
288
  </ExampleContainer>
202
289
  <ExampleContainer>
203
290
  <Title title="Medium" theme="light" level={4} />
204
- <DxcResultsetTable columns={columns} rows={rows} margin={"medium"}></DxcResultsetTable>
291
+ <DxcResultsetTable columns={columns} rows={rows} margin={"medium"} />
205
292
  </ExampleContainer>
206
293
  <ExampleContainer>
207
294
  <Title title="Large" theme="light" level={4} />
208
- <DxcResultsetTable columns={columns} rows={rows} margin={"large"}></DxcResultsetTable>
295
+ <DxcResultsetTable columns={columns} rows={rows} margin={"large"} />
209
296
  </ExampleContainer>
210
297
  <ExampleContainer>
211
298
  <Title title="Xlarge" theme="light" level={4} />
212
- <DxcResultsetTable columns={columns} rows={rows} margin={"xlarge"}></DxcResultsetTable>
299
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xlarge"} />
213
300
  </ExampleContainer>
214
- <ExampleContainer>
301
+ <ExampleContainer expanded>
215
302
  <Title title="Xxlarge" theme="light" level={4} />
216
- <DxcResultsetTable columns={columns} rows={rows} margin={"xxlarge"}></DxcResultsetTable>
217
- <hr />
303
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xxlarge"} />
218
304
  </ExampleContainer>
219
305
  </>
220
306
  );
221
307
 
308
+ const SmallContainer = styled.div`
309
+ width: 500px;
310
+ `;
311
+
222
312
  const ResultsetTableAsc = () => (
223
313
  <ExampleContainer>
224
314
  <Title title="Ascendant sorting" theme="light" level={4} />
225
- <DxcResultsetTable columns={columnsSortable} rows={rowsSortable}></DxcResultsetTable>
315
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
226
316
  </ExampleContainer>
227
317
  );
228
318
 
229
319
  export const AscendentSorting = ResultsetTableAsc.bind({});
230
320
  AscendentSorting.play = async ({ canvasElement }) => {
231
321
  const canvas = within(canvasElement);
232
- await userEvent.click(canvas.queryByText("Name"));
322
+ const idHeader = canvas.getAllByRole("button")[0];
323
+ await userEvent.click(idHeader);
233
324
  };
234
325
 
235
326
  const ResultsetTableDesc = () => (
236
327
  <ExampleContainer>
237
328
  <Title title="Descendant sorting" theme="light" level={4} />
238
- <DxcResultsetTable columns={columnsSortable} rows={rowsSortable}></DxcResultsetTable>
329
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
239
330
  </ExampleContainer>
240
331
  );
241
332
 
242
333
  export const DescendantSorting = ResultsetTableDesc.bind({});
243
334
  DescendantSorting.play = async ({ canvasElement }) => {
244
335
  const canvas = within(canvasElement);
245
- await userEvent.click(canvas.queryByText("Name"));
246
- await userEvent.click(canvas.queryByText("Name"));
336
+ const nameHeader = canvas.getAllByRole("button")[1];
337
+ await userEvent.click(nameHeader);
338
+ await userEvent.click(nameHeader);
247
339
  };
248
340
 
249
341
  const ResultsetTableMiddle = () => (
250
342
  <ExampleContainer>
251
343
  <Title title="Middle page" theme="light" level={4} />
252
- <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2}></DxcResultsetTable>
344
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
253
345
  </ExampleContainer>
254
346
  );
255
347
 
@@ -263,7 +355,7 @@ MiddlePage.play = async ({ canvasElement }) => {
263
355
  const ResultsetTableLast = () => (
264
356
  <ExampleContainer>
265
357
  <Title title="Last page" theme="light" level={4} />
266
- <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2}></DxcResultsetTable>
358
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
267
359
  </ExampleContainer>
268
360
  );
269
361
 
@@ -273,3 +365,17 @@ LastPage.play = async ({ canvasElement }) => {
273
365
  const nextButton = canvas.getAllByRole("button")[3];
274
366
  await userEvent.click(nextButton);
275
367
  };
368
+
369
+ const ResultsetActionsCellDropdown = () => (
370
+ <ExampleContainer>
371
+ <Title title="Dropdown Action" theme="light" level={4} />
372
+ <DxcResultsetTable columns={columns} rows={rowsIcon} itemsPerPage={2} />
373
+ </ExampleContainer>
374
+ );
375
+
376
+ export const DropdownAction = ResultsetActionsCellDropdown.bind({});
377
+ DropdownAction.play = async ({ canvasElement }) => {
378
+ const canvas = within(canvasElement);
379
+ const dropdown = canvas.getAllByRole("button")[5];
380
+ await userEvent.click(dropdown);
381
+ };