@dxc-technology/halstack-react 0.0.0-b41d935 → 0.0.0-b4aec06

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 (329) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1243 -6
  4. package/HalstackContext.js +126 -111
  5. package/README.md +47 -0
  6. package/accordion/Accordion.d.ts +1 -1
  7. package/accordion/Accordion.js +42 -118
  8. package/accordion/Accordion.stories.tsx +85 -139
  9. package/accordion/Accordion.test.js +19 -34
  10. package/accordion/types.d.ts +6 -18
  11. package/accordion-group/AccordionGroup.d.ts +2 -2
  12. package/accordion-group/AccordionGroup.js +29 -77
  13. package/accordion-group/AccordionGroup.stories.tsx +78 -77
  14. package/accordion-group/AccordionGroup.test.js +44 -72
  15. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  16. package/accordion-group/AccordionGroupAccordion.js +31 -0
  17. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  18. package/accordion-group/AccordionGroupContext.js +8 -0
  19. package/accordion-group/types.d.ts +7 -19
  20. package/action-icon/ActionIcon.d.ts +4 -0
  21. package/action-icon/ActionIcon.js +48 -0
  22. package/action-icon/ActionIcon.stories.tsx +41 -0
  23. package/action-icon/ActionIcon.test.js +64 -0
  24. package/action-icon/types.d.ts +26 -0
  25. package/alert/Alert.js +31 -124
  26. package/alert/Alert.stories.tsx +28 -0
  27. package/alert/Alert.test.js +29 -46
  28. package/alert/types.d.ts +5 -5
  29. package/badge/Badge.d.ts +1 -1
  30. package/badge/Badge.js +141 -43
  31. package/badge/Badge.stories.tsx +210 -0
  32. package/badge/Badge.test.js +30 -0
  33. package/badge/types.d.ts +52 -3
  34. package/bleed/Bleed.js +13 -21
  35. package/bleed/Bleed.stories.tsx +1 -0
  36. package/bleed/types.d.ts +2 -2
  37. package/box/Box.d.ts +1 -1
  38. package/box/Box.js +18 -59
  39. package/box/Box.stories.tsx +38 -51
  40. package/box/Box.test.js +2 -7
  41. package/box/types.d.ts +3 -15
  42. package/bulleted-list/BulletedList.js +19 -53
  43. package/bulleted-list/BulletedList.stories.tsx +8 -93
  44. package/bulleted-list/types.d.ts +32 -5
  45. package/button/Button.d.ts +1 -1
  46. package/button/Button.js +71 -106
  47. package/button/Button.stories.tsx +144 -101
  48. package/button/Button.test.js +20 -17
  49. package/button/types.d.ts +9 -5
  50. package/card/Card.d.ts +1 -1
  51. package/card/Card.js +48 -89
  52. package/card/Card.stories.tsx +12 -42
  53. package/card/Card.test.js +11 -22
  54. package/card/types.d.ts +6 -12
  55. package/checkbox/Checkbox.d.ts +2 -2
  56. package/checkbox/Checkbox.js +90 -124
  57. package/checkbox/Checkbox.stories.tsx +68 -54
  58. package/checkbox/Checkbox.test.js +108 -64
  59. package/checkbox/types.d.ts +11 -3
  60. package/chip/Chip.js +39 -79
  61. package/chip/Chip.stories.tsx +121 -26
  62. package/chip/Chip.test.js +16 -31
  63. package/chip/types.d.ts +4 -4
  64. package/common/coreTokens.d.ts +237 -0
  65. package/common/coreTokens.js +184 -0
  66. package/common/utils.d.ts +1 -0
  67. package/common/utils.js +6 -12
  68. package/common/variables.d.ts +1395 -0
  69. package/common/variables.js +914 -1156
  70. package/container/Container.d.ts +4 -0
  71. package/container/Container.js +194 -0
  72. package/container/Container.stories.tsx +214 -0
  73. package/container/types.d.ts +74 -0
  74. package/contextual-menu/ContextualMenu.d.ts +7 -0
  75. package/contextual-menu/ContextualMenu.js +71 -0
  76. package/contextual-menu/ContextualMenu.stories.tsx +182 -0
  77. package/contextual-menu/ContextualMenu.test.js +71 -0
  78. package/contextual-menu/MenuItemAction.d.ts +4 -0
  79. package/contextual-menu/MenuItemAction.js +46 -0
  80. package/contextual-menu/types.d.ts +22 -0
  81. package/date-input/Calendar.d.ts +4 -0
  82. package/date-input/Calendar.js +214 -0
  83. package/date-input/DateInput.js +150 -299
  84. package/date-input/DateInput.stories.tsx +203 -56
  85. package/date-input/DateInput.test.js +700 -371
  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 +72 -15
  93. package/dialog/Dialog.d.ts +1 -1
  94. package/dialog/Dialog.js +61 -119
  95. package/dialog/Dialog.stories.tsx +310 -212
  96. package/dialog/Dialog.test.js +269 -32
  97. package/dialog/types.d.ts +18 -26
  98. package/divider/Divider.d.ts +4 -0
  99. package/divider/Divider.js +36 -0
  100. package/divider/Divider.stories.tsx +223 -0
  101. package/divider/Divider.test.js +38 -0
  102. package/divider/types.d.ts +21 -0
  103. package/divider/types.js +5 -0
  104. package/dropdown/Dropdown.js +84 -153
  105. package/dropdown/Dropdown.stories.tsx +209 -94
  106. package/dropdown/Dropdown.test.js +409 -400
  107. package/dropdown/DropdownMenu.js +20 -37
  108. package/dropdown/DropdownMenuItem.js +15 -37
  109. package/dropdown/types.d.ts +20 -24
  110. package/file-input/FileInput.d.ts +2 -2
  111. package/file-input/FileInput.js +193 -262
  112. package/file-input/FileInput.stories.tsx +86 -3
  113. package/file-input/FileInput.test.js +356 -395
  114. package/file-input/FileItem.js +15 -41
  115. package/file-input/types.d.ts +13 -9
  116. package/flex/Flex.js +27 -39
  117. package/flex/Flex.stories.tsx +35 -26
  118. package/flex/types.d.ts +74 -9
  119. package/footer/Footer.d.ts +1 -1
  120. package/footer/Footer.js +70 -117
  121. package/footer/Footer.stories.tsx +55 -21
  122. package/footer/Footer.test.js +33 -57
  123. package/footer/Icons.d.ts +3 -2
  124. package/footer/Icons.js +66 -7
  125. package/footer/types.d.ts +25 -27
  126. package/grid/Grid.d.ts +7 -0
  127. package/grid/Grid.js +76 -0
  128. package/grid/Grid.stories.tsx +219 -0
  129. package/grid/types.d.ts +115 -0
  130. package/grid/types.js +5 -0
  131. package/header/Header.d.ts +4 -3
  132. package/header/Header.js +48 -133
  133. package/header/Header.stories.tsx +115 -36
  134. package/header/Header.test.js +13 -26
  135. package/header/Icons.d.ts +2 -2
  136. package/header/Icons.js +2 -7
  137. package/header/types.d.ts +7 -22
  138. package/heading/Heading.js +10 -32
  139. package/heading/Heading.test.js +71 -88
  140. package/heading/types.d.ts +7 -7
  141. package/icon/Icon.d.ts +4 -0
  142. package/icon/Icon.js +33 -0
  143. package/icon/Icon.stories.tsx +28 -0
  144. package/icon/types.d.ts +4 -0
  145. package/icon/types.js +5 -0
  146. package/image/Image.d.ts +4 -0
  147. package/image/Image.js +70 -0
  148. package/image/Image.stories.tsx +129 -0
  149. package/image/types.d.ts +72 -0
  150. package/image/types.js +5 -0
  151. package/inset/Inset.js +13 -21
  152. package/inset/Inset.stories.tsx +2 -1
  153. package/inset/types.d.ts +2 -2
  154. package/layout/ApplicationLayout.d.ts +5 -5
  155. package/layout/ApplicationLayout.js +30 -67
  156. package/layout/ApplicationLayout.stories.tsx +1 -1
  157. package/layout/Icons.d.ts +8 -5
  158. package/layout/Icons.js +51 -59
  159. package/layout/types.d.ts +5 -6
  160. package/link/Link.js +25 -46
  161. package/link/Link.stories.tsx +60 -0
  162. package/link/Link.test.js +24 -44
  163. package/link/types.d.ts +14 -14
  164. package/main.d.ts +10 -5
  165. package/main.js +47 -59
  166. package/nav-tabs/NavTabs.d.ts +7 -0
  167. package/{tabs-nav → nav-tabs}/NavTabs.js +25 -57
  168. package/{tabs-nav → nav-tabs}/NavTabs.stories.tsx +115 -9
  169. package/{tabs-nav → nav-tabs}/NavTabs.test.js +39 -45
  170. package/nav-tabs/NavTabsContext.d.ts +3 -0
  171. package/nav-tabs/NavTabsContext.js +8 -0
  172. package/nav-tabs/Tab.js +118 -0
  173. package/{tabs-nav → nav-tabs}/types.d.ts +14 -15
  174. package/nav-tabs/types.js +5 -0
  175. package/number-input/NumberInput.js +46 -36
  176. package/number-input/NumberInput.stories.tsx +42 -26
  177. package/number-input/NumberInput.test.js +860 -414
  178. package/number-input/NumberInputContext.d.ts +3 -4
  179. package/number-input/NumberInputContext.js +3 -14
  180. package/number-input/types.d.ts +17 -5
  181. package/package.json +37 -40
  182. package/paginator/Icons.d.ts +5 -0
  183. package/paginator/Icons.js +21 -47
  184. package/paginator/Paginator.js +22 -58
  185. package/paginator/Paginator.stories.tsx +24 -0
  186. package/paginator/Paginator.test.js +252 -225
  187. package/paginator/types.d.ts +3 -3
  188. package/paragraph/Paragraph.d.ts +3 -4
  189. package/paragraph/Paragraph.js +6 -22
  190. package/paragraph/Paragraph.stories.tsx +0 -17
  191. package/password-input/Icons.d.ts +6 -0
  192. package/password-input/Icons.js +35 -0
  193. package/password-input/PasswordInput.js +57 -126
  194. package/password-input/PasswordInput.stories.tsx +1 -33
  195. package/password-input/PasswordInput.test.js +158 -141
  196. package/password-input/types.d.ts +8 -7
  197. package/progress-bar/ProgressBar.d.ts +2 -2
  198. package/progress-bar/ProgressBar.js +23 -55
  199. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +36 -3
  200. package/progress-bar/ProgressBar.test.js +36 -53
  201. package/progress-bar/types.d.ts +4 -3
  202. package/quick-nav/QuickNav.js +4 -27
  203. package/quick-nav/QuickNav.stories.tsx +15 -1
  204. package/quick-nav/types.d.ts +10 -10
  205. package/radio-group/Radio.d.ts +1 -1
  206. package/radio-group/Radio.js +31 -63
  207. package/radio-group/RadioGroup.js +45 -93
  208. package/radio-group/RadioGroup.stories.tsx +131 -18
  209. package/radio-group/RadioGroup.test.js +505 -471
  210. package/radio-group/types.d.ts +8 -8
  211. package/resultset-table/Icons.d.ts +7 -0
  212. package/resultset-table/Icons.js +47 -0
  213. package/resultset-table/ResultsetTable.d.ts +7 -0
  214. package/resultset-table/ResultsetTable.js +170 -0
  215. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +156 -30
  216. package/resultset-table/ResultsetTable.test.js +381 -0
  217. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  218. package/resultset-table/types.js +5 -0
  219. package/select/Icons.d.ts +7 -7
  220. package/select/Icons.js +1 -5
  221. package/select/Listbox.d.ts +1 -1
  222. package/select/Listbox.js +17 -72
  223. package/select/Option.js +27 -50
  224. package/select/Select.js +120 -175
  225. package/select/Select.stories.tsx +497 -153
  226. package/select/Select.test.js +1974 -1837
  227. package/select/types.d.ts +16 -17
  228. package/sidenav/Icons.d.ts +7 -0
  229. package/{text-input → sidenav}/Icons.js +10 -23
  230. package/sidenav/Sidenav.d.ts +2 -2
  231. package/sidenav/Sidenav.js +83 -154
  232. package/sidenav/Sidenav.stories.tsx +165 -63
  233. package/sidenav/Sidenav.test.js +3 -10
  234. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  235. package/{layout → sidenav}/SidenavContext.js +3 -9
  236. package/sidenav/types.d.ts +31 -28
  237. package/slider/Slider.d.ts +2 -2
  238. package/slider/Slider.js +77 -134
  239. package/slider/Slider.test.js +108 -104
  240. package/slider/types.d.ts +7 -3
  241. package/spinner/Spinner.js +31 -75
  242. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  243. package/spinner/Spinner.test.js +26 -35
  244. package/spinner/types.d.ts +3 -3
  245. package/status-light/StatusLight.d.ts +4 -0
  246. package/status-light/StatusLight.js +51 -0
  247. package/status-light/StatusLight.stories.tsx +74 -0
  248. package/status-light/StatusLight.test.js +25 -0
  249. package/status-light/types.d.ts +17 -0
  250. package/status-light/types.js +5 -0
  251. package/switch/Switch.d.ts +3 -3
  252. package/switch/Switch.js +56 -103
  253. package/switch/Switch.stories.tsx +33 -34
  254. package/switch/Switch.test.js +52 -97
  255. package/switch/types.d.ts +8 -3
  256. package/table/DropdownTheme.js +62 -0
  257. package/table/Table.d.ts +6 -2
  258. package/table/Table.js +78 -35
  259. package/table/Table.stories.tsx +651 -0
  260. package/table/Table.test.js +95 -8
  261. package/table/types.d.ts +34 -6
  262. package/tabs/Tab.js +26 -45
  263. package/tabs/Tabs.js +62 -145
  264. package/tabs/Tabs.stories.tsx +46 -6
  265. package/tabs/Tabs.test.js +66 -123
  266. package/tabs/types.d.ts +19 -19
  267. package/tag/Tag.js +28 -60
  268. package/tag/Tag.stories.tsx +14 -1
  269. package/tag/Tag.test.js +20 -31
  270. package/tag/types.d.ts +7 -7
  271. package/text-input/Suggestion.js +35 -25
  272. package/text-input/Suggestions.d.ts +1 -1
  273. package/text-input/Suggestions.js +19 -67
  274. package/text-input/TextInput.js +223 -333
  275. package/text-input/TextInput.stories.tsx +139 -155
  276. package/text-input/TextInput.test.js +1389 -1404
  277. package/text-input/types.d.ts +25 -17
  278. package/textarea/Textarea.js +70 -113
  279. package/textarea/Textarea.stories.tsx +174 -0
  280. package/textarea/Textarea.test.js +152 -183
  281. package/textarea/types.d.ts +9 -5
  282. package/toggle-group/ToggleGroup.d.ts +2 -2
  283. package/toggle-group/ToggleGroup.js +92 -106
  284. package/toggle-group/ToggleGroup.stories.tsx +49 -4
  285. package/toggle-group/ToggleGroup.test.js +69 -88
  286. package/toggle-group/types.d.ts +26 -17
  287. package/typography/Typography.d.ts +2 -2
  288. package/typography/Typography.js +15 -123
  289. package/typography/Typography.stories.tsx +1 -1
  290. package/typography/types.d.ts +1 -1
  291. package/useTheme.d.ts +1147 -1
  292. package/useTheme.js +2 -9
  293. package/useTranslatedLabels.d.ts +84 -1
  294. package/useTranslatedLabels.js +1 -7
  295. package/utils/BaseTypography.d.ts +21 -0
  296. package/utils/BaseTypography.js +94 -0
  297. package/utils/FocusLock.d.ts +13 -0
  298. package/utils/FocusLock.js +124 -0
  299. package/wizard/Wizard.js +16 -51
  300. package/wizard/Wizard.stories.tsx +20 -0
  301. package/wizard/Wizard.test.js +54 -81
  302. package/wizard/types.d.ts +9 -10
  303. package/card/ice-cream.jpg +0 -0
  304. package/common/OpenSans.css +0 -81
  305. package/common/RequiredComponent.js +0 -32
  306. package/common/fonts/OpenSans-Bold.ttf +0 -0
  307. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  308. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  309. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  310. package/common/fonts/OpenSans-Italic.ttf +0 -0
  311. package/common/fonts/OpenSans-Light.ttf +0 -0
  312. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  313. package/common/fonts/OpenSans-Regular.ttf +0 -0
  314. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  315. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  316. package/number-input/numberInputContextTypes.d.ts +0 -19
  317. package/resultsetTable/ResultsetTable.d.ts +0 -4
  318. package/resultsetTable/ResultsetTable.js +0 -252
  319. package/resultsetTable/ResultsetTable.test.js +0 -348
  320. package/slider/Slider.stories.tsx +0 -183
  321. package/table/Table.stories.jsx +0 -277
  322. package/tabs-nav/NavTabs.d.ts +0 -8
  323. package/tabs-nav/Tab.js +0 -130
  324. package/text-input/Icons.d.ts +0 -8
  325. package/textarea/Textarea.stories.jsx +0 -157
  326. /package/{resultsetTable → action-icon}/types.js +0 -0
  327. /package/{tabs-nav → container}/types.js +0 -0
  328. /package/{number-input/numberInputContextTypes.js → contextual-menu/types.js} +0 -0
  329. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
@@ -1,4 +1,4 @@
1
- export declare type Option = {
1
+ export type Option = {
2
2
  /**
3
3
  * Label of the option placed next to the radio input.
4
4
  */
@@ -14,11 +14,11 @@ export declare type Option = {
14
14
  */
15
15
  disabled?: boolean;
16
16
  };
17
- declare type RadioGroupProps = {
17
+ type RadioGroupProps = {
18
18
  /**
19
19
  * Text to be placed above the radio group.
20
20
  */
21
- label: string;
21
+ label?: string;
22
22
  /**
23
23
  * Name attribute of the input element. This attribute will allow users
24
24
  * to find the component's value during the submit event.
@@ -49,9 +49,9 @@ declare type RadioGroupProps = {
49
49
  */
50
50
  optionalItemLabel?: string;
51
51
  /**
52
- * If true, the component will be marked as readonly.
52
+ * If true, the component will not be mutable, meaning the user can not edit the control.
53
53
  */
54
- readonly?: boolean;
54
+ readOnly?: boolean;
55
55
  /**
56
56
  * Sets the orientation of the options within the radio group.
57
57
  */
@@ -97,18 +97,18 @@ declare type RadioGroupProps = {
97
97
  /**
98
98
  * Reference to the component.
99
99
  */
100
- export declare type RefType = HTMLDivElement;
100
+ export type RefType = HTMLDivElement;
101
101
  /**
102
102
  * Single radio prop types.
103
103
  */
104
- export declare type RadioProps = {
104
+ export type RadioProps = {
105
105
  label: string;
106
106
  checked: boolean;
107
107
  onClick: () => void;
108
108
  error?: string;
109
109
  disabled: boolean;
110
110
  focused: boolean;
111
- readonly: boolean;
111
+ readOnly: boolean;
112
112
  tabIndex: number;
113
113
  };
114
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, hidePaginator, 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,170 @@
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 _Paginator = _interopRequireDefault(require("../paginator/Paginator"));
16
+ var _Table = _interopRequireWildcard(require("../table/Table"));
17
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
18
+ var _Icons = _interopRequireDefault(require("./Icons"));
19
+ var _utils = require("../common/utils");
20
+ var _coreTokens = _interopRequireDefault(require("../common/coreTokens"));
21
+ var _templateObject, _templateObject2, _templateObject3;
22
+ 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); }
23
+ 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; }
24
+ var normalizeSortValue = function normalizeSortValue(sortValue) {
25
+ return typeof sortValue === "string" ? sortValue.toUpperCase() : sortValue;
26
+ };
27
+ var sortArray = function sortArray(index, order, resultset) {
28
+ return resultset.slice().sort(function (element1, element2) {
29
+ var sortValueA = normalizeSortValue(element1[index].sortValue || element1[index].displayValue);
30
+ var sortValueB = normalizeSortValue(element2[index].sortValue || element2[index].displayValue);
31
+ var comparison = 0;
32
+ if ((0, _typeof2["default"])(sortValueA) === "object") {
33
+ comparison = -1;
34
+ } else if ((0, _typeof2["default"])(sortValueB) === "object") {
35
+ comparison = 1;
36
+ } else if (sortValueA > sortValueB) {
37
+ comparison = 1;
38
+ } else if (sortValueA < sortValueB) {
39
+ comparison = -1;
40
+ }
41
+ return order === "descending" ? comparison * -1 : comparison;
42
+ });
43
+ };
44
+ var getMinItemsPerPageIndex = function getMinItemsPerPageIndex(currentPageInternal, itemsPerPage, page) {
45
+ return currentPageInternal === 1 ? 0 : itemsPerPage * (page - 1);
46
+ };
47
+ var getMaxItemsPerPageIndex = function getMaxItemsPerPageIndex(minItemsPerPageIndex, itemsPerPage, resultset, page) {
48
+ return minItemsPerPageIndex + itemsPerPage > resultset.length ? resultset.length : itemsPerPage * page - 1;
49
+ };
50
+ var DxcResultsetTable = function DxcResultsetTable(_ref) {
51
+ var columns = _ref.columns,
52
+ rows = _ref.rows,
53
+ _ref$hidePaginator = _ref.hidePaginator,
54
+ hidePaginator = _ref$hidePaginator === void 0 ? false : _ref$hidePaginator,
55
+ _ref$showGoToPage = _ref.showGoToPage,
56
+ showGoToPage = _ref$showGoToPage === void 0 ? true : _ref$showGoToPage,
57
+ _ref$itemsPerPage = _ref.itemsPerPage,
58
+ itemsPerPage = _ref$itemsPerPage === void 0 ? 5 : _ref$itemsPerPage,
59
+ itemsPerPageOptions = _ref.itemsPerPageOptions,
60
+ itemsPerPageFunction = _ref.itemsPerPageFunction,
61
+ margin = _ref.margin,
62
+ _ref$tabIndex = _ref.tabIndex,
63
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex,
64
+ _ref$mode = _ref.mode,
65
+ mode = _ref$mode === void 0 ? "default" : _ref$mode;
66
+ var colorsTheme = (0, _useTheme["default"])();
67
+ var _useState = (0, _react.useState)(1),
68
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
69
+ page = _useState2[0],
70
+ changePage = _useState2[1];
71
+ var _useState3 = (0, _react.useState)(-1),
72
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
73
+ sortColumnIndex = _useState4[0],
74
+ changeSortColumnIndex = _useState4[1];
75
+ var _useState5 = (0, _react.useState)("ascending"),
76
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
77
+ sortOrder = _useState6[0],
78
+ changeSortOrder = _useState6[1];
79
+ var minItemsPerPageIndex = (0, _react.useMemo)(function () {
80
+ return getMinItemsPerPageIndex(page, itemsPerPage, page);
81
+ }, [itemsPerPage, page]);
82
+ var maxItemsPerPageIndex = (0, _react.useMemo)(function () {
83
+ return getMaxItemsPerPageIndex(minItemsPerPageIndex, itemsPerPage, rows, page);
84
+ }, [itemsPerPage, minItemsPerPageIndex, page, rows]);
85
+ var sortedResultset = (0, _react.useMemo)(function () {
86
+ return sortColumnIndex !== -1 ? sortArray(sortColumnIndex, sortOrder, rows) : rows;
87
+ }, [sortColumnIndex, sortOrder, rows]);
88
+ var filteredResultset = (0, _react.useMemo)(function () {
89
+ return sortedResultset && sortedResultset.slice(minItemsPerPageIndex, maxItemsPerPageIndex + 1);
90
+ }, [sortedResultset, minItemsPerPageIndex, maxItemsPerPageIndex]);
91
+ var goToPage = function goToPage(newPage) {
92
+ changePage(newPage);
93
+ };
94
+ var changeSorting = function changeSorting(columnIndex) {
95
+ changePage(1);
96
+ changeSortColumnIndex(columnIndex);
97
+ changeSortOrder(sortColumnIndex === -1 || sortColumnIndex !== columnIndex ? "ascending" : sortOrder === "ascending" ? "descending" : "ascending");
98
+ };
99
+ (0, _react.useEffect)(function () {
100
+ if (!hidePaginator) {
101
+ rows.length > 0 ? changePage(1) : changePage(0);
102
+ }
103
+ }, [rows]);
104
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
105
+ theme: colorsTheme.table
106
+ }, /*#__PURE__*/_react["default"].createElement(DxcResultsetTableContainer, {
107
+ margin: margin
108
+ }, /*#__PURE__*/_react["default"].createElement(_Table["default"], {
109
+ mode: mode
110
+ }, /*#__PURE__*/_react["default"].createElement("thead", null, /*#__PURE__*/_react["default"].createElement("tr", null, columns.map(function (column, index) {
111
+ return /*#__PURE__*/_react["default"].createElement("th", {
112
+ key: "tableHeader_".concat(index),
113
+ "aria-sort": column.isSortable ? sortColumnIndex === index ? sortOrder : "none" : undefined
114
+ }, /*#__PURE__*/_react["default"].createElement(HeaderContainer, {
115
+ role: column.isSortable ? "button" : undefined,
116
+ key: "headerContainer_".concat(index),
117
+ onClick: function onClick() {
118
+ column.isSortable && changeSorting(index);
119
+ },
120
+ tabIndex: column.isSortable ? tabIndex : -1,
121
+ isSortable: column.isSortable,
122
+ mode: mode
123
+ }, /*#__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)));
124
+ }))), /*#__PURE__*/_react["default"].createElement("tbody", null, filteredResultset.map(function (cells, rowIndex) {
125
+ return /*#__PURE__*/_react["default"].createElement("tr", {
126
+ key: "resultSetTableCell_".concat(page, "_").concat(rowIndex)
127
+ }, cells.map(function (cellContent, cellIndex) {
128
+ return /*#__PURE__*/_react["default"].createElement("td", {
129
+ key: "resultSetTableCellContent_".concat(cellIndex)
130
+ }, cellContent.displayValue);
131
+ }));
132
+ }))), !hidePaginator && /*#__PURE__*/_react["default"].createElement(_Paginator["default"], {
133
+ totalItems: rows.length,
134
+ itemsPerPage: itemsPerPage,
135
+ itemsPerPageOptions: itemsPerPageOptions,
136
+ itemsPerPageFunction: itemsPerPageFunction,
137
+ currentPage: page,
138
+ showGoToPage: showGoToPage,
139
+ onPageChange: goToPage,
140
+ tabIndex: tabIndex
141
+ })));
142
+ };
143
+ var calculateWidth = function calculateWidth(margin) {
144
+ return "calc(100% - ".concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
145
+ };
146
+ 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) {
147
+ return calculateWidth(props.margin);
148
+ }, function (props) {
149
+ return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
150
+ }, function (props) {
151
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
152
+ }, function (props) {
153
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
154
+ }, function (props) {
155
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
156
+ }, function (props) {
157
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
158
+ });
159
+ 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) {
160
+ return props.theme.headerTextAlign === "center" ? "center" : props.theme.headerTextAlign === "right" ? "flex-end" : "flex-start";
161
+ }, _coreTokens["default"].spacing_8, function (props) {
162
+ return props.isSortable ? "pointer" : "default";
163
+ }, function (props) {
164
+ return props.isSortable && "&:focus {\n outline: #0095ff solid 2px;\n }";
165
+ });
166
+ 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) {
167
+ return props.theme.sortIconColor;
168
+ });
169
+ DxcResultsetTable.ActionsCell = _Table.DxcActionsCell;
170
+ var _default = exports["default"] = DxcResultsetTable;
@@ -1,9 +1,10 @@
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
+ import { HalstackProvider } from "../HalstackContext";
7
8
 
8
9
  export default {
9
10
  title: "Resultset Table",
@@ -12,7 +13,7 @@ export default {
12
13
 
13
14
  const deleteIcon = (
14
15
  <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" />
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" />
16
17
  <path d="M0 0h24v24H0z" fill="none" />
17
18
  </svg>
18
19
  );
@@ -28,17 +29,77 @@ const rows = [
28
29
  [{ displayValue: "006" }, { displayValue: "Cris" }, { displayValue: "Paris" }],
29
30
  ];
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: "filled_edit",
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
+
31
82
  const rowsIcon = [
32
83
  [
33
84
  { displayValue: "001", sortValue: "001" },
34
85
  { displayValue: "Peter" },
35
- { displayValue: <DxcButton icon={deleteIcon} /> },
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
+ },
36
96
  ],
37
- [{ displayValue: "002", sortValue: "002" }, { displayValue: "Louis" }, { displayValue: "" }],
38
97
  [
39
98
  { displayValue: "003", sortValue: "003" },
40
99
  { displayValue: "Mark" },
41
- { displayValue: <DxcButton icon={deleteIcon} /> },
100
+ {
101
+ displayValue: <DxcResultsetTable.ActionsCell actions={actions} />,
102
+ },
42
103
  ],
43
104
  ];
44
105
 
@@ -48,6 +109,24 @@ const columnsSortable = [
48
109
  { displayValue: "City", isSortable: false },
49
110
  ];
50
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
+
51
130
  const rowsSortable = [
52
131
  [
53
132
  { displayValue: "001", sortValue: "001" },
@@ -167,89 +246,118 @@ export const Chromatic = () => (
167
246
  <>
168
247
  <ExampleContainer>
169
248
  <Title title="Sortable table" theme="light" level={4} />
170
- <DxcResultsetTable columns={columnsSortable} rows={rowsSortable}></DxcResultsetTable>
249
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
171
250
  </ExampleContainer>
172
251
  <ExampleContainer>
173
252
  <Title title="With action" theme="light" level={4} />
174
- <DxcResultsetTable columns={columns} rows={rowsIcon}></DxcResultsetTable>
253
+ <DxcResultsetTable columns={columns} rows={rowsIcon} />
175
254
  </ExampleContainer>
176
255
  <ExampleContainer>
177
256
  <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>
257
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} itemsPerPageOptions={[2, 3]} />
184
258
  </ExampleContainer>
185
259
  <ExampleContainer>
186
260
  <Title title="Scroll resultset table" theme="light" level={4} />
187
- <DxcResultsetTable columns={longColumns} rows={longRows}></DxcResultsetTable>
261
+ <DxcResultsetTable columns={longColumns} rows={longRows} />
262
+ </ExampleContainer>
263
+ <ExampleContainer>
264
+ <Title title="Without paginator" theme="light" level={4} />
265
+ <DxcResultsetTable columns={columns} rows={rows} hidePaginator />
266
+ </ExampleContainer>
267
+ <ExampleContainer>
268
+ <SmallContainer>
269
+ <Title title="Small container and text overflow" theme="light" level={4} />
270
+ <DxcResultsetTable columns={columnsSortable} rows={longValues} />
271
+ </SmallContainer>
272
+ </ExampleContainer>
273
+ <ExampleContainer>
274
+ <Title title="Reduced sortable table" theme="light" level={4} />
275
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} mode="reduced" />
276
+ </ExampleContainer>
277
+ {/* PENDING SMALL ICON VERSION */}
278
+ <ExampleContainer>
279
+ <Title title="Reduced with items per page option" theme="light" level={4} />
280
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} itemsPerPageOptions={[2, 3]} mode="reduced" />
281
+ </ExampleContainer>
282
+ <ExampleContainer>
283
+ <Title title="Reduced scroll resultset table" theme="light" level={4} />
284
+ <DxcResultsetTable columns={longColumns} rows={longRows} mode="reduced" />
285
+ </ExampleContainer>
286
+ <ExampleContainer>
287
+ <SmallContainer>
288
+ <Title title="Reduced small container and text overflow" theme="light" level={4} />
289
+ <DxcResultsetTable columns={columnsSortable} rows={longValues} mode="reduced" />
290
+ </SmallContainer>
188
291
  </ExampleContainer>
189
292
  <Title title="Margins" theme="light" level={2} />
190
293
  <ExampleContainer>
191
294
  <Title title="Xxsmall" theme="light" level={4} />
192
- <DxcResultsetTable columns={columns} rows={rows} margin={"xxsmall"}></DxcResultsetTable>
295
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xxsmall"} />
193
296
  </ExampleContainer>
194
297
  <ExampleContainer>
195
298
  <Title title="Xsmall" theme="light" level={4} />
196
- <DxcResultsetTable columns={columns} rows={rows} margin={"xsmall"}></DxcResultsetTable>
299
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xsmall"} />
197
300
  </ExampleContainer>
198
301
  <ExampleContainer>
199
302
  <Title title="Small" theme="light" level={4} />
200
- <DxcResultsetTable columns={columns} rows={rows} margin={"small"}></DxcResultsetTable>
303
+ <DxcResultsetTable columns={columns} rows={rows} margin={"small"} />
201
304
  </ExampleContainer>
202
305
  <ExampleContainer>
203
306
  <Title title="Medium" theme="light" level={4} />
204
- <DxcResultsetTable columns={columns} rows={rows} margin={"medium"}></DxcResultsetTable>
307
+ <DxcResultsetTable columns={columns} rows={rows} margin={"medium"} />
205
308
  </ExampleContainer>
206
309
  <ExampleContainer>
207
310
  <Title title="Large" theme="light" level={4} />
208
- <DxcResultsetTable columns={columns} rows={rows} margin={"large"}></DxcResultsetTable>
311
+ <DxcResultsetTable columns={columns} rows={rows} margin={"large"} />
209
312
  </ExampleContainer>
210
313
  <ExampleContainer>
211
314
  <Title title="Xlarge" theme="light" level={4} />
212
- <DxcResultsetTable columns={columns} rows={rows} margin={"xlarge"}></DxcResultsetTable>
315
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xlarge"} />
213
316
  </ExampleContainer>
214
- <ExampleContainer>
317
+ <ExampleContainer expanded>
215
318
  <Title title="Xxlarge" theme="light" level={4} />
216
- <DxcResultsetTable columns={columns} rows={rows} margin={"xxlarge"}></DxcResultsetTable>
217
- <hr />
319
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xxlarge"} />
218
320
  </ExampleContainer>
219
321
  </>
220
322
  );
221
323
 
324
+ const SmallContainer = styled.div`
325
+ width: 500px;
326
+ `;
327
+
222
328
  const ResultsetTableAsc = () => (
223
329
  <ExampleContainer>
224
330
  <Title title="Ascendant sorting" theme="light" level={4} />
225
- <DxcResultsetTable columns={columnsSortable} rows={rowsSortable}></DxcResultsetTable>
331
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
226
332
  </ExampleContainer>
227
333
  );
228
334
 
229
335
  export const AscendentSorting = ResultsetTableAsc.bind({});
230
336
  AscendentSorting.play = async ({ canvasElement }) => {
231
337
  const canvas = within(canvasElement);
232
- await userEvent.click(canvas.queryByText("Name"));
338
+ const idHeader = canvas.getAllByRole("button")[0];
339
+ await userEvent.click(idHeader);
233
340
  };
234
341
 
235
342
  const ResultsetTableDesc = () => (
236
343
  <ExampleContainer>
237
344
  <Title title="Descendant sorting" theme="light" level={4} />
238
- <DxcResultsetTable columns={columnsSortable} rows={rowsSortable}></DxcResultsetTable>
345
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
239
346
  </ExampleContainer>
240
347
  );
241
348
 
242
349
  export const DescendantSorting = ResultsetTableDesc.bind({});
243
350
  DescendantSorting.play = async ({ canvasElement }) => {
244
351
  const canvas = within(canvasElement);
245
- await userEvent.click(canvas.queryByText("Name"));
246
- await userEvent.click(canvas.queryByText("Name"));
352
+ const nameHeader = canvas.getAllByRole("button")[1];
353
+ await userEvent.click(nameHeader);
354
+ await userEvent.click(nameHeader);
247
355
  };
248
356
 
249
357
  const ResultsetTableMiddle = () => (
250
358
  <ExampleContainer>
251
359
  <Title title="Middle page" theme="light" level={4} />
252
- <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2}></DxcResultsetTable>
360
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
253
361
  </ExampleContainer>
254
362
  );
255
363
 
@@ -263,7 +371,7 @@ MiddlePage.play = async ({ canvasElement }) => {
263
371
  const ResultsetTableLast = () => (
264
372
  <ExampleContainer>
265
373
  <Title title="Last page" theme="light" level={4} />
266
- <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2}></DxcResultsetTable>
374
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
267
375
  </ExampleContainer>
268
376
  );
269
377
 
@@ -273,3 +381,21 @@ LastPage.play = async ({ canvasElement }) => {
273
381
  const nextButton = canvas.getAllByRole("button")[3];
274
382
  await userEvent.click(nextButton);
275
383
  };
384
+
385
+ const ResultsetActionsCellDropdown = () => (
386
+ <ExampleContainer>
387
+ <Title title="Dropdown Action" theme="light" level={4} />
388
+ <DxcResultsetTable columns={columns} rows={rowsIcon} itemsPerPage={2} />
389
+ <Title title="Custom theme actions cell" theme="light" level={4} />
390
+ <HalstackProvider advancedTheme={advancedTheme}>
391
+ <DxcResultsetTable columns={columns} rows={rowsIcon} itemsPerPage={2} />
392
+ </HalstackProvider>
393
+ </ExampleContainer>
394
+ );
395
+
396
+ export const DropdownAction = ResultsetActionsCellDropdown.bind({});
397
+ DropdownAction.play = async ({ canvasElement }) => {
398
+ const canvas = within(canvasElement);
399
+ const dropdown = canvas.getAllByRole("button")[5];
400
+ await userEvent.click(dropdown);
401
+ };