@dxc-technology/halstack-react 0.0.0-ff5083e → 0.0.0-ff6c8bf

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 (403) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1240 -6
  4. package/HalstackContext.js +126 -111
  5. package/README.md +47 -0
  6. package/accordion/Accordion.accessibility.test.js +71 -0
  7. package/accordion/Accordion.d.ts +1 -1
  8. package/accordion/Accordion.js +105 -160
  9. package/accordion/Accordion.stories.tsx +82 -148
  10. package/accordion/Accordion.test.js +25 -41
  11. package/accordion/types.d.ts +6 -17
  12. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  13. package/accordion-group/AccordionGroup.d.ts +2 -2
  14. package/accordion-group/AccordionGroup.js +31 -98
  15. package/accordion-group/AccordionGroup.stories.tsx +94 -67
  16. package/accordion-group/AccordionGroup.test.js +52 -105
  17. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  18. package/accordion-group/AccordionGroupAccordion.js +31 -0
  19. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  20. package/accordion-group/AccordionGroupContext.js +8 -0
  21. package/accordion-group/types.d.ts +12 -17
  22. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  23. package/action-icon/ActionIcon.d.ts +4 -0
  24. package/action-icon/ActionIcon.js +48 -0
  25. package/action-icon/ActionIcon.stories.tsx +41 -0
  26. package/action-icon/ActionIcon.test.js +64 -0
  27. package/action-icon/types.d.ts +26 -0
  28. package/alert/Alert.accessibility.test.js +95 -0
  29. package/alert/Alert.js +37 -127
  30. package/alert/Alert.stories.tsx +28 -0
  31. package/alert/Alert.test.js +29 -46
  32. package/alert/types.d.ts +5 -5
  33. package/badge/Badge.accessibility.test.js +129 -0
  34. package/badge/Badge.d.ts +1 -1
  35. package/badge/Badge.js +142 -42
  36. package/badge/Badge.stories.tsx +210 -0
  37. package/badge/Badge.test.js +30 -0
  38. package/badge/types.d.ts +52 -3
  39. package/bleed/Bleed.js +13 -21
  40. package/bleed/Bleed.stories.tsx +64 -63
  41. package/bleed/types.d.ts +2 -2
  42. package/box/Box.accessibility.test.js +33 -0
  43. package/box/Box.d.ts +1 -1
  44. package/box/Box.js +19 -60
  45. package/box/Box.stories.tsx +38 -51
  46. package/box/Box.test.js +2 -7
  47. package/box/types.d.ts +3 -14
  48. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  49. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  50. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  51. package/breadcrumbs/Breadcrumbs.js +79 -0
  52. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  53. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  54. package/breadcrumbs/Breadcrumbs.test.js +169 -0
  55. package/breadcrumbs/Item.d.ts +4 -0
  56. package/breadcrumbs/Item.js +52 -0
  57. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  58. package/breadcrumbs/dropdownTheme.js +62 -0
  59. package/breadcrumbs/types.d.ts +16 -0
  60. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  61. package/bulleted-list/BulletedList.js +35 -63
  62. package/bulleted-list/BulletedList.stories.tsx +18 -106
  63. package/bulleted-list/types.d.ts +32 -5
  64. package/button/Button.accessibility.test.js +127 -0
  65. package/button/Button.d.ts +1 -1
  66. package/button/Button.js +64 -117
  67. package/button/Button.stories.tsx +151 -100
  68. package/button/Button.test.js +20 -17
  69. package/button/types.d.ts +12 -8
  70. package/card/Card.accessibility.test.js +36 -0
  71. package/card/Card.d.ts +1 -1
  72. package/card/Card.js +49 -89
  73. package/card/Card.stories.tsx +12 -42
  74. package/card/Card.test.js +11 -22
  75. package/card/types.d.ts +6 -11
  76. package/checkbox/Checkbox.accessibility.test.js +87 -0
  77. package/checkbox/Checkbox.d.ts +2 -2
  78. package/checkbox/Checkbox.js +139 -181
  79. package/checkbox/Checkbox.stories.tsx +128 -94
  80. package/checkbox/Checkbox.test.js +160 -39
  81. package/checkbox/types.d.ts +11 -3
  82. package/chip/Chip.accessibility.test.js +67 -0
  83. package/chip/Chip.js +45 -80
  84. package/chip/Chip.stories.tsx +107 -27
  85. package/chip/Chip.test.js +18 -33
  86. package/chip/types.d.ts +4 -4
  87. package/common/coreTokens.d.ts +237 -0
  88. package/common/coreTokens.js +184 -0
  89. package/common/utils.d.ts +1 -0
  90. package/common/utils.js +6 -12
  91. package/common/variables.d.ts +1392 -0
  92. package/common/variables.js +984 -1206
  93. package/container/Container.d.ts +4 -0
  94. package/container/Container.js +194 -0
  95. package/container/Container.stories.tsx +214 -0
  96. package/container/types.d.ts +74 -0
  97. package/contextual-menu/ContextualMenu.accessibility.test.js +97 -0
  98. package/contextual-menu/ContextualMenu.d.ts +5 -0
  99. package/contextual-menu/ContextualMenu.js +88 -0
  100. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  101. package/contextual-menu/ContextualMenu.test.js +205 -0
  102. package/contextual-menu/GroupItem.d.ts +4 -0
  103. package/contextual-menu/GroupItem.js +67 -0
  104. package/contextual-menu/ItemAction.d.ts +4 -0
  105. package/contextual-menu/ItemAction.js +51 -0
  106. package/contextual-menu/MenuItem.d.ts +4 -0
  107. package/contextual-menu/MenuItem.js +29 -0
  108. package/contextual-menu/SingleItem.d.ts +4 -0
  109. package/contextual-menu/SingleItem.js +38 -0
  110. package/contextual-menu/types.d.ts +58 -0
  111. package/date-input/Calendar.d.ts +4 -0
  112. package/date-input/Calendar.js +214 -0
  113. package/date-input/DateInput.accessibility.test.js +228 -0
  114. package/date-input/DateInput.js +149 -299
  115. package/date-input/DateInput.stories.tsx +210 -56
  116. package/date-input/DateInput.test.js +700 -371
  117. package/date-input/DatePicker.d.ts +4 -0
  118. package/date-input/DatePicker.js +121 -0
  119. package/date-input/YearPicker.d.ts +4 -0
  120. package/date-input/YearPicker.js +100 -0
  121. package/date-input/types.d.ts +72 -15
  122. package/dialog/Dialog.accessibility.test.js +69 -0
  123. package/dialog/Dialog.d.ts +1 -1
  124. package/dialog/Dialog.js +61 -106
  125. package/dialog/Dialog.stories.tsx +326 -167
  126. package/dialog/Dialog.test.js +287 -20
  127. package/dialog/types.d.ts +18 -25
  128. package/divider/Divider.accessibility.test.js +33 -0
  129. package/divider/Divider.d.ts +4 -0
  130. package/divider/Divider.js +36 -0
  131. package/divider/Divider.stories.tsx +223 -0
  132. package/divider/Divider.test.js +38 -0
  133. package/divider/types.d.ts +21 -0
  134. package/dropdown/Dropdown.accessibility.test.js +180 -0
  135. package/dropdown/Dropdown.d.ts +1 -1
  136. package/dropdown/Dropdown.js +233 -303
  137. package/dropdown/Dropdown.stories.tsx +235 -57
  138. package/dropdown/Dropdown.test.js +575 -165
  139. package/dropdown/DropdownMenu.d.ts +4 -0
  140. package/dropdown/DropdownMenu.js +63 -0
  141. package/dropdown/DropdownMenuItem.d.ts +4 -0
  142. package/dropdown/DropdownMenuItem.js +71 -0
  143. package/dropdown/types.d.ts +35 -19
  144. package/file-input/FileInput.accessibility.test.js +160 -0
  145. package/file-input/FileInput.d.ts +2 -2
  146. package/file-input/FileInput.js +241 -391
  147. package/file-input/FileInput.stories.tsx +123 -12
  148. package/file-input/FileInput.test.js +306 -367
  149. package/file-input/FileItem.d.ts +4 -14
  150. package/file-input/FileItem.js +56 -117
  151. package/file-input/types.d.ts +25 -8
  152. package/flex/Flex.d.ts +4 -0
  153. package/flex/Flex.js +57 -0
  154. package/flex/Flex.stories.tsx +112 -0
  155. package/flex/types.d.ts +97 -0
  156. package/footer/Footer.accessibility.test.js +125 -0
  157. package/footer/Footer.d.ts +1 -1
  158. package/footer/Footer.js +73 -118
  159. package/footer/Footer.stories.tsx +99 -21
  160. package/footer/Footer.test.js +33 -57
  161. package/footer/Icons.d.ts +3 -2
  162. package/footer/Icons.js +54 -23
  163. package/footer/types.d.ts +26 -27
  164. package/grid/Grid.d.ts +7 -0
  165. package/grid/Grid.js +76 -0
  166. package/grid/Grid.stories.tsx +219 -0
  167. package/grid/types.d.ts +115 -0
  168. package/grid/types.js +5 -0
  169. package/header/Header.accessibility.test.js +93 -0
  170. package/header/Header.d.ts +4 -3
  171. package/header/Header.js +90 -183
  172. package/header/Header.stories.tsx +133 -38
  173. package/header/Header.test.js +13 -26
  174. package/header/Icons.d.ts +2 -2
  175. package/header/Icons.js +5 -15
  176. package/header/types.d.ts +7 -21
  177. package/heading/Heading.accessibility.test.js +33 -0
  178. package/heading/Heading.js +10 -32
  179. package/heading/Heading.test.js +71 -88
  180. package/heading/types.d.ts +7 -7
  181. package/icon/Icon.accessibility.test.js +30 -0
  182. package/icon/Icon.d.ts +4 -0
  183. package/icon/Icon.js +33 -0
  184. package/icon/Icon.stories.tsx +28 -0
  185. package/icon/types.d.ts +4 -0
  186. package/icon/types.js +5 -0
  187. package/image/Image.accessibility.test.js +56 -0
  188. package/image/Image.d.ts +4 -0
  189. package/image/Image.js +70 -0
  190. package/image/Image.stories.tsx +129 -0
  191. package/image/types.d.ts +72 -0
  192. package/image/types.js +5 -0
  193. package/inset/Inset.js +13 -21
  194. package/inset/Inset.stories.tsx +5 -4
  195. package/inset/types.d.ts +2 -2
  196. package/layout/ApplicationLayout.d.ts +15 -6
  197. package/layout/ApplicationLayout.js +57 -119
  198. package/layout/ApplicationLayout.stories.tsx +81 -45
  199. package/layout/Icons.d.ts +7 -5
  200. package/layout/Icons.js +41 -59
  201. package/layout/types.d.ts +21 -32
  202. package/link/Link.accessibility.test.js +108 -0
  203. package/link/Link.js +32 -51
  204. package/link/Link.stories.tsx +76 -9
  205. package/link/Link.test.js +24 -44
  206. package/link/types.d.ts +14 -14
  207. package/main.d.ts +14 -12
  208. package/main.js +51 -88
  209. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  210. package/nav-tabs/NavTabs.d.ts +7 -0
  211. package/{tabs-nav → nav-tabs}/NavTabs.js +30 -62
  212. package/nav-tabs/NavTabs.stories.tsx +279 -0
  213. package/nav-tabs/NavTabs.test.js +77 -0
  214. package/nav-tabs/NavTabsContext.d.ts +3 -0
  215. package/nav-tabs/NavTabsContext.js +8 -0
  216. package/nav-tabs/Tab.js +117 -0
  217. package/{tabs-nav → nav-tabs}/types.d.ts +15 -16
  218. package/nav-tabs/types.js +5 -0
  219. package/number-input/NumberInput.accessibility.test.js +228 -0
  220. package/number-input/NumberInput.js +46 -36
  221. package/number-input/NumberInput.stories.tsx +42 -26
  222. package/number-input/NumberInput.test.js +860 -377
  223. package/number-input/NumberInputContext.d.ts +3 -4
  224. package/number-input/NumberInputContext.js +3 -14
  225. package/number-input/types.d.ts +17 -5
  226. package/package.json +51 -51
  227. package/paginator/Paginator.accessibility.test.js +79 -0
  228. package/paginator/Paginator.js +35 -68
  229. package/paginator/Paginator.stories.tsx +24 -0
  230. package/paginator/Paginator.test.js +280 -211
  231. package/paginator/types.d.ts +3 -3
  232. package/paragraph/Paragraph.accessibility.test.js +28 -0
  233. package/paragraph/Paragraph.d.ts +3 -4
  234. package/paragraph/Paragraph.js +7 -23
  235. package/paragraph/Paragraph.stories.tsx +1 -18
  236. package/password-input/PasswordInput.accessibility.test.js +153 -0
  237. package/password-input/PasswordInput.js +58 -127
  238. package/password-input/PasswordInput.stories.tsx +1 -33
  239. package/password-input/PasswordInput.test.js +160 -142
  240. package/password-input/types.d.ts +8 -7
  241. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  242. package/progress-bar/ProgressBar.js +68 -92
  243. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +39 -4
  244. package/progress-bar/ProgressBar.test.js +72 -44
  245. package/progress-bar/types.d.ts +3 -3
  246. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  247. package/quick-nav/QuickNav.js +24 -42
  248. package/quick-nav/QuickNav.stories.tsx +146 -27
  249. package/quick-nav/types.d.ts +10 -10
  250. package/radio-group/Radio.d.ts +1 -1
  251. package/radio-group/Radio.js +59 -76
  252. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  253. package/radio-group/RadioGroup.js +68 -114
  254. package/radio-group/RadioGroup.stories.tsx +132 -18
  255. package/radio-group/RadioGroup.test.js +518 -457
  256. package/radio-group/types.d.ts +10 -10
  257. package/resultset-table/Icons.d.ts +7 -0
  258. package/resultset-table/Icons.js +47 -0
  259. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  260. package/resultset-table/ResultsetTable.d.ts +7 -0
  261. package/resultset-table/ResultsetTable.js +171 -0
  262. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +168 -30
  263. package/resultset-table/ResultsetTable.test.js +381 -0
  264. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  265. package/resultset-table/types.js +5 -0
  266. package/select/Listbox.d.ts +1 -1
  267. package/select/Listbox.js +68 -65
  268. package/select/Option.js +35 -56
  269. package/select/Select.accessibility.test.js +228 -0
  270. package/select/Select.js +171 -214
  271. package/select/Select.stories.tsx +515 -190
  272. package/select/Select.test.js +1934 -1789
  273. package/select/types.d.ts +17 -21
  274. package/sidenav/Sidenav.accessibility.test.js +59 -0
  275. package/sidenav/Sidenav.d.ts +6 -5
  276. package/sidenav/Sidenav.js +132 -78
  277. package/sidenav/Sidenav.stories.tsx +246 -151
  278. package/sidenav/Sidenav.test.js +26 -45
  279. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  280. package/{layout → sidenav}/SidenavContext.js +3 -9
  281. package/sidenav/types.d.ts +52 -26
  282. package/slider/Slider.accessibility.test.js +104 -0
  283. package/slider/Slider.d.ts +2 -2
  284. package/slider/Slider.js +149 -181
  285. package/slider/Slider.stories.tsx +64 -61
  286. package/slider/Slider.test.js +185 -81
  287. package/slider/types.d.ts +7 -3
  288. package/spinner/Spinner.accessibility.test.js +96 -0
  289. package/spinner/Spinner.js +34 -74
  290. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  291. package/spinner/Spinner.test.js +26 -35
  292. package/spinner/types.d.ts +3 -3
  293. package/status-light/StatusLight.accessibility.test.js +157 -0
  294. package/status-light/StatusLight.d.ts +4 -0
  295. package/status-light/StatusLight.js +51 -0
  296. package/status-light/StatusLight.stories.tsx +74 -0
  297. package/status-light/StatusLight.test.js +25 -0
  298. package/status-light/types.d.ts +17 -0
  299. package/status-light/types.js +5 -0
  300. package/switch/Switch.accessibility.test.js +98 -0
  301. package/switch/Switch.d.ts +2 -2
  302. package/switch/Switch.js +145 -126
  303. package/switch/Switch.stories.tsx +49 -60
  304. package/switch/Switch.test.js +138 -56
  305. package/switch/types.d.ts +7 -3
  306. package/table/DropdownTheme.js +62 -0
  307. package/table/Table.accessibility.test.js +93 -0
  308. package/table/Table.d.ts +6 -2
  309. package/table/Table.js +78 -35
  310. package/table/Table.stories.tsx +663 -0
  311. package/table/Table.test.js +95 -8
  312. package/table/types.d.ts +34 -6
  313. package/tabs/Tab.d.ts +4 -0
  314. package/tabs/Tab.js +117 -0
  315. package/tabs/Tabs.accessibility.test.js +56 -0
  316. package/tabs/Tabs.js +303 -141
  317. package/tabs/Tabs.stories.tsx +124 -6
  318. package/tabs/Tabs.test.js +213 -77
  319. package/tabs/types.d.ts +30 -20
  320. package/tag/Tag.accessibility.test.js +69 -0
  321. package/tag/Tag.js +35 -67
  322. package/tag/Tag.stories.tsx +18 -8
  323. package/tag/Tag.test.js +18 -37
  324. package/tag/types.d.ts +9 -9
  325. package/text-input/Suggestion.js +40 -28
  326. package/text-input/Suggestions.d.ts +4 -0
  327. package/text-input/Suggestions.js +94 -0
  328. package/text-input/TextInput.accessibility.test.js +321 -0
  329. package/text-input/TextInput.js +316 -515
  330. package/text-input/TextInput.stories.tsx +276 -276
  331. package/text-input/TextInput.test.js +1419 -1375
  332. package/text-input/types.d.ts +43 -16
  333. package/textarea/Textarea.accessibility.test.js +155 -0
  334. package/textarea/Textarea.js +71 -113
  335. package/textarea/Textarea.stories.tsx +174 -0
  336. package/textarea/Textarea.test.js +152 -183
  337. package/textarea/types.d.ts +9 -5
  338. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  339. package/toggle-group/ToggleGroup.d.ts +2 -2
  340. package/toggle-group/ToggleGroup.js +94 -107
  341. package/toggle-group/ToggleGroup.stories.tsx +52 -7
  342. package/toggle-group/ToggleGroup.test.js +69 -88
  343. package/toggle-group/types.d.ts +28 -19
  344. package/typography/Typography.accessibility.test.js +339 -0
  345. package/typography/Typography.d.ts +2 -2
  346. package/typography/Typography.js +16 -124
  347. package/typography/Typography.stories.tsx +185 -162
  348. package/typography/types.d.ts +1 -1
  349. package/useTheme.d.ts +1144 -1
  350. package/useTheme.js +2 -9
  351. package/useTranslatedLabels.d.ts +84 -1
  352. package/useTranslatedLabels.js +1 -7
  353. package/utils/BaseTypography.d.ts +21 -0
  354. package/utils/BaseTypography.js +94 -0
  355. package/utils/FocusLock.d.ts +13 -0
  356. package/utils/FocusLock.js +124 -0
  357. package/wizard/Wizard.accessibility.test.js +55 -0
  358. package/wizard/Wizard.js +34 -87
  359. package/wizard/Wizard.stories.tsx +59 -1
  360. package/wizard/Wizard.test.js +54 -81
  361. package/wizard/types.d.ts +9 -9
  362. package/card/ice-cream.jpg +0 -0
  363. package/common/OpenSans.css +0 -81
  364. package/common/RequiredComponent.js +0 -32
  365. package/common/fonts/OpenSans-Bold.ttf +0 -0
  366. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  367. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  368. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  369. package/common/fonts/OpenSans-Italic.ttf +0 -0
  370. package/common/fonts/OpenSans-Light.ttf +0 -0
  371. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  372. package/common/fonts/OpenSans-Regular.ttf +0 -0
  373. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  374. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  375. package/number-input/numberInputContextTypes.d.ts +0 -19
  376. package/paginator/Icons.js +0 -66
  377. package/resultsetTable/ResultsetTable.d.ts +0 -4
  378. package/resultsetTable/ResultsetTable.js +0 -254
  379. package/resultsetTable/ResultsetTable.test.js +0 -306
  380. package/row/Row.d.ts +0 -3
  381. package/row/Row.js +0 -127
  382. package/row/Row.stories.tsx +0 -237
  383. package/row/types.d.ts +0 -28
  384. package/select/Icons.d.ts +0 -10
  385. package/select/Icons.js +0 -93
  386. package/stack/Stack.d.ts +0 -3
  387. package/stack/Stack.js +0 -97
  388. package/stack/Stack.stories.tsx +0 -164
  389. package/stack/types.d.ts +0 -24
  390. package/table/Table.stories.jsx +0 -277
  391. package/tabs-nav/NavTabs.d.ts +0 -8
  392. package/tabs-nav/NavTabs.stories.tsx +0 -170
  393. package/tabs-nav/NavTabs.test.js +0 -82
  394. package/tabs-nav/Tab.js +0 -132
  395. package/textarea/Textarea.stories.jsx +0 -157
  396. package/typography/typographyContextTypes.d.ts +0 -16
  397. /package/{resultsetTable → action-icon}/types.js +0 -0
  398. /package/{row → breadcrumbs}/types.js +0 -0
  399. /package/{stack → container}/types.js +0 -0
  400. /package/{tabs-nav → contextual-menu}/types.js +0 -0
  401. /package/{number-input/numberInputContextTypes.js → divider/types.js} +0 -0
  402. /package/{typography/typographyContextTypes.js → flex/types.js} +0 -0
  403. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
@@ -1,18 +1,31 @@
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";
8
+ import { disabledRules } from "../../test/accessibility/rules/specific/resultset-table/disabledRules";
9
+ import preview from "../../.storybook/preview";
7
10
 
8
11
  export default {
9
12
  title: "Resultset Table",
10
13
  component: DxcResultsetTable,
14
+ parameters: {
15
+ a11y: {
16
+ config: {
17
+ rules: [
18
+ ...disabledRules.map((ruleId) => ({ id: ruleId, reviewOnFail: true })),
19
+ ...preview?.parameters?.a11y?.config?.rules,
20
+ ],
21
+ },
22
+ },
23
+ },
11
24
  };
12
25
 
13
26
  const deleteIcon = (
14
27
  <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" />
28
+ <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
29
  <path d="M0 0h24v24H0z" fill="none" />
17
30
  </svg>
18
31
  );
@@ -28,17 +41,77 @@ const rows = [
28
41
  [{ displayValue: "006" }, { displayValue: "Cris" }, { displayValue: "Paris" }],
29
42
  ];
30
43
 
44
+ const advancedTheme = {
45
+ table: {
46
+ actionIconColor: "#1B75BB",
47
+ hoverActionIconColor: "#1B75BB",
48
+ activeActionIconColor: "#1B75BB",
49
+ focusActionIconColor: "#1B75BB",
50
+ disabledActionIconColor: "#666666",
51
+ hoverButtonBackgroundColor: "#cccccc",
52
+ },
53
+ };
54
+
55
+ const actions = [
56
+ {
57
+ title: "icon",
58
+ onClick: (value?) => {
59
+ console.log(value);
60
+ },
61
+ options: [
62
+ {
63
+ value: "1",
64
+ label: "Amazon with a very long text",
65
+ },
66
+ {
67
+ value: "2",
68
+ label: "Ebay",
69
+ },
70
+ {
71
+ value: "3",
72
+ label: "Apple",
73
+ },
74
+ ],
75
+ },
76
+ {
77
+ icon: "filled_edit",
78
+ title: "icon",
79
+ onClick: () => {},
80
+ },
81
+ {
82
+ icon: deleteIcon,
83
+ title: "icon",
84
+ onClick: () => {},
85
+ disabled: true,
86
+ },
87
+ {
88
+ icon: deleteIcon,
89
+ title: "icon",
90
+ onClick: () => {},
91
+ },
92
+ ];
93
+
31
94
  const rowsIcon = [
32
95
  [
33
96
  { displayValue: "001", sortValue: "001" },
34
97
  { displayValue: "Peter" },
35
- { displayValue: <DxcButton icon={deleteIcon} /> },
98
+ {
99
+ displayValue: <DxcResultsetTable.ActionsCell actions={actions} />,
100
+ },
101
+ ],
102
+ [
103
+ { displayValue: "002", sortValue: "002" },
104
+ { displayValue: "Louis" },
105
+ {
106
+ displayValue: <DxcResultsetTable.ActionsCell actions={actions} />,
107
+ },
36
108
  ],
37
- [{ displayValue: "002", sortValue: "002" }, { displayValue: "Louis" }, { displayValue: "" }],
38
109
  [
39
110
  { displayValue: "003", sortValue: "003" },
40
111
  { displayValue: "Mark" },
41
- { displayValue: <DxcButton icon={deleteIcon} /> },
112
+ {
113
+ displayValue: <DxcResultsetTable.ActionsCell actions={actions} />,
114
+ },
42
115
  ],
43
116
  ];
44
117
 
@@ -48,6 +121,24 @@ const columnsSortable = [
48
121
  { displayValue: "City", isSortable: false },
49
122
  ];
50
123
 
124
+ const longValues = [
125
+ [
126
+ { displayValue: "000000000000000001", sortValue: "000000000000000001" },
127
+ { displayValue: "Peter Larsson González", sortValue: "Peter" },
128
+ { displayValue: "Miami: The city that never sleeps", sortValue: "Miami" },
129
+ ],
130
+ [
131
+ { displayValue: "002", sortValue: "002" },
132
+ { displayValue: "Louis", sortValue: "Louis" },
133
+ { displayValue: "London", sortValue: "London" },
134
+ ],
135
+ [
136
+ { displayValue: "003", sortValue: "003" },
137
+ { displayValue: "Aida", sortValue: "Aida" },
138
+ { displayValue: "Wroclaw", sortValue: "Wroclaw" },
139
+ ],
140
+ ];
141
+
51
142
  const rowsSortable = [
52
143
  [
53
144
  { displayValue: "001", sortValue: "001" },
@@ -167,89 +258,118 @@ export const Chromatic = () => (
167
258
  <>
168
259
  <ExampleContainer>
169
260
  <Title title="Sortable table" theme="light" level={4} />
170
- <DxcResultsetTable columns={columnsSortable} rows={rowsSortable}></DxcResultsetTable>
261
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
171
262
  </ExampleContainer>
172
263
  <ExampleContainer>
173
264
  <Title title="With action" theme="light" level={4} />
174
- <DxcResultsetTable columns={columns} rows={rowsIcon}></DxcResultsetTable>
265
+ <DxcResultsetTable columns={columns} rows={rowsIcon} />
175
266
  </ExampleContainer>
176
267
  <ExampleContainer>
177
268
  <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>
269
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} itemsPerPageOptions={[2, 3]} />
184
270
  </ExampleContainer>
185
271
  <ExampleContainer>
186
272
  <Title title="Scroll resultset table" theme="light" level={4} />
187
- <DxcResultsetTable columns={longColumns} rows={longRows}></DxcResultsetTable>
273
+ <DxcResultsetTable columns={longColumns} rows={longRows} />
274
+ </ExampleContainer>
275
+ <ExampleContainer>
276
+ <Title title="Without paginator" theme="light" level={4} />
277
+ <DxcResultsetTable columns={columns} rows={rows} hidePaginator />
278
+ </ExampleContainer>
279
+ <ExampleContainer>
280
+ <SmallContainer>
281
+ <Title title="Small container and text overflow" theme="light" level={4} />
282
+ <DxcResultsetTable columns={columnsSortable} rows={longValues} />
283
+ </SmallContainer>
284
+ </ExampleContainer>
285
+ <ExampleContainer>
286
+ <Title title="Reduced sortable table" theme="light" level={4} />
287
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} mode="reduced" />
288
+ </ExampleContainer>
289
+ {/* PENDING SMALL ICON VERSION */}
290
+ <ExampleContainer>
291
+ <Title title="Reduced with items per page option" theme="light" level={4} />
292
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} itemsPerPageOptions={[2, 3]} mode="reduced" />
293
+ </ExampleContainer>
294
+ <ExampleContainer>
295
+ <Title title="Reduced scroll resultset table" theme="light" level={4} />
296
+ <DxcResultsetTable columns={longColumns} rows={longRows} mode="reduced" />
297
+ </ExampleContainer>
298
+ <ExampleContainer>
299
+ <SmallContainer>
300
+ <Title title="Reduced small container and text overflow" theme="light" level={4} />
301
+ <DxcResultsetTable columns={columnsSortable} rows={longValues} mode="reduced" />
302
+ </SmallContainer>
188
303
  </ExampleContainer>
189
304
  <Title title="Margins" theme="light" level={2} />
190
305
  <ExampleContainer>
191
306
  <Title title="Xxsmall" theme="light" level={4} />
192
- <DxcResultsetTable columns={columns} rows={rows} margin={"xxsmall"}></DxcResultsetTable>
307
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xxsmall"} />
193
308
  </ExampleContainer>
194
309
  <ExampleContainer>
195
310
  <Title title="Xsmall" theme="light" level={4} />
196
- <DxcResultsetTable columns={columns} rows={rows} margin={"xsmall"}></DxcResultsetTable>
311
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xsmall"} />
197
312
  </ExampleContainer>
198
313
  <ExampleContainer>
199
314
  <Title title="Small" theme="light" level={4} />
200
- <DxcResultsetTable columns={columns} rows={rows} margin={"small"}></DxcResultsetTable>
315
+ <DxcResultsetTable columns={columns} rows={rows} margin={"small"} />
201
316
  </ExampleContainer>
202
317
  <ExampleContainer>
203
318
  <Title title="Medium" theme="light" level={4} />
204
- <DxcResultsetTable columns={columns} rows={rows} margin={"medium"}></DxcResultsetTable>
319
+ <DxcResultsetTable columns={columns} rows={rows} margin={"medium"} />
205
320
  </ExampleContainer>
206
321
  <ExampleContainer>
207
322
  <Title title="Large" theme="light" level={4} />
208
- <DxcResultsetTable columns={columns} rows={rows} margin={"large"}></DxcResultsetTable>
323
+ <DxcResultsetTable columns={columns} rows={rows} margin={"large"} />
209
324
  </ExampleContainer>
210
325
  <ExampleContainer>
211
326
  <Title title="Xlarge" theme="light" level={4} />
212
- <DxcResultsetTable columns={columns} rows={rows} margin={"xlarge"}></DxcResultsetTable>
327
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xlarge"} />
213
328
  </ExampleContainer>
214
- <ExampleContainer>
329
+ <ExampleContainer expanded>
215
330
  <Title title="Xxlarge" theme="light" level={4} />
216
- <DxcResultsetTable columns={columns} rows={rows} margin={"xxlarge"}></DxcResultsetTable>
217
- <hr />
331
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xxlarge"} />
218
332
  </ExampleContainer>
219
333
  </>
220
334
  );
221
335
 
336
+ const SmallContainer = styled.div`
337
+ width: 500px;
338
+ `;
339
+
222
340
  const ResultsetTableAsc = () => (
223
341
  <ExampleContainer>
224
342
  <Title title="Ascendant sorting" theme="light" level={4} />
225
- <DxcResultsetTable columns={columnsSortable} rows={rowsSortable}></DxcResultsetTable>
343
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
226
344
  </ExampleContainer>
227
345
  );
228
346
 
229
347
  export const AscendentSorting = ResultsetTableAsc.bind({});
230
348
  AscendentSorting.play = async ({ canvasElement }) => {
231
349
  const canvas = within(canvasElement);
232
- await userEvent.click(canvas.queryByText("Name"));
350
+ const idHeader = canvas.getAllByRole("button")[0];
351
+ await userEvent.click(idHeader);
233
352
  };
234
353
 
235
354
  const ResultsetTableDesc = () => (
236
355
  <ExampleContainer>
237
356
  <Title title="Descendant sorting" theme="light" level={4} />
238
- <DxcResultsetTable columns={columnsSortable} rows={rowsSortable}></DxcResultsetTable>
357
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
239
358
  </ExampleContainer>
240
359
  );
241
360
 
242
361
  export const DescendantSorting = ResultsetTableDesc.bind({});
243
362
  DescendantSorting.play = async ({ canvasElement }) => {
244
363
  const canvas = within(canvasElement);
245
- await userEvent.click(canvas.queryByText("Name"));
246
- await userEvent.click(canvas.queryByText("Name"));
364
+ const nameHeader = canvas.getAllByRole("button")[1];
365
+ await userEvent.click(nameHeader);
366
+ await userEvent.click(nameHeader);
247
367
  };
248
368
 
249
369
  const ResultsetTableMiddle = () => (
250
370
  <ExampleContainer>
251
371
  <Title title="Middle page" theme="light" level={4} />
252
- <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2}></DxcResultsetTable>
372
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
253
373
  </ExampleContainer>
254
374
  );
255
375
 
@@ -263,7 +383,7 @@ MiddlePage.play = async ({ canvasElement }) => {
263
383
  const ResultsetTableLast = () => (
264
384
  <ExampleContainer>
265
385
  <Title title="Last page" theme="light" level={4} />
266
- <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2}></DxcResultsetTable>
386
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
267
387
  </ExampleContainer>
268
388
  );
269
389
 
@@ -273,3 +393,21 @@ LastPage.play = async ({ canvasElement }) => {
273
393
  const nextButton = canvas.getAllByRole("button")[3];
274
394
  await userEvent.click(nextButton);
275
395
  };
396
+
397
+ const ResultsetActionsCellDropdown = () => (
398
+ <ExampleContainer>
399
+ <Title title="Dropdown Action" theme="light" level={4} />
400
+ <DxcResultsetTable columns={columns} rows={rowsIcon} itemsPerPage={2} />
401
+ <Title title="Custom theme actions cell" theme="light" level={4} />
402
+ <HalstackProvider advancedTheme={advancedTheme}>
403
+ <DxcResultsetTable columns={columns} rows={rowsIcon} itemsPerPage={2} />
404
+ </HalstackProvider>
405
+ </ExampleContainer>
406
+ );
407
+
408
+ export const DropdownAction = ResultsetActionsCellDropdown.bind({});
409
+ DropdownAction.play = async ({ canvasElement }) => {
410
+ const canvas = within(canvasElement);
411
+ const dropdown = canvas.getAllByRole("button")[5];
412
+ await userEvent.click(dropdown);
413
+ };
@@ -0,0 +1,381 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
5
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
6
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
7
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
8
+ var _react = _interopRequireDefault(require("react"));
9
+ var _react2 = require("@testing-library/react");
10
+ var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
11
+ var _ResultsetTable = _interopRequireDefault(require("./ResultsetTable.tsx"));
12
+ // Mocking DOMRect for Radix Primitive Popover
13
+ global.globalThis = global;
14
+ global.DOMRect = {
15
+ fromRect: function fromRect() {
16
+ return {
17
+ top: 0,
18
+ left: 0,
19
+ bottom: 0,
20
+ right: 0,
21
+ width: 0,
22
+ height: 0
23
+ };
24
+ }
25
+ };
26
+ global.ResizeObserver = /*#__PURE__*/function () {
27
+ function ResizeObserver() {
28
+ (0, _classCallCheck2["default"])(this, ResizeObserver);
29
+ }
30
+ (0, _createClass2["default"])(ResizeObserver, [{
31
+ key: "observe",
32
+ value: function observe() {}
33
+ }, {
34
+ key: "unobserve",
35
+ value: function unobserve() {}
36
+ }, {
37
+ key: "disconnect",
38
+ value: function disconnect() {}
39
+ }]);
40
+ return ResizeObserver;
41
+ }();
42
+ var icon = /*#__PURE__*/_react["default"].createElement("svg", {
43
+ xmlns: "http://www.w3.org/2000/svg",
44
+ height: "24px",
45
+ viewBox: "0 0 24 24",
46
+ width: "24px",
47
+ fill: "currentColor"
48
+ }, /*#__PURE__*/_react["default"].createElement("path", {
49
+ d: "M0 0h24v24H0V0zm0 0h24v24H0V0z",
50
+ fill: "none"
51
+ }), /*#__PURE__*/_react["default"].createElement("path", {
52
+ d: "M1 9l2 2c4.97-4.97 13.03-4.97 18 0l2-2C16.93 2.93 7.08 2.93 1 9zm8 8l3 3 3-3c-1.65-1.66-4.34-1.66-6 0zm-4-4l2 2c2.76-2.76 7.24-2.76 10 0l2-2C15.14 9.14 8.87 9.14 5 13z"
53
+ }));
54
+ var columns = [{
55
+ displayValue: "Id",
56
+ isSortable: false
57
+ }, {
58
+ displayValue: "Name",
59
+ isSortable: true
60
+ }, {
61
+ displayValue: "City",
62
+ isSortable: false
63
+ }];
64
+ var rows = [[{
65
+ displayValue: "001",
66
+ sortValue: "001"
67
+ }, {
68
+ displayValue: "Peter",
69
+ sortValue: "Peter"
70
+ }, {
71
+ displayValue: "Oviedo",
72
+ sortValue: "Oviedo"
73
+ }], [{
74
+ displayValue: "002",
75
+ sortValue: "002"
76
+ }, {
77
+ displayValue: "Louis",
78
+ sortValue: "Louis"
79
+ }, {
80
+ displayValue: "Oviedo",
81
+ sortValue: "Oviedo"
82
+ }], [{
83
+ displayValue: "003",
84
+ sortValue: "003"
85
+ }, {
86
+ displayValue: "Lana",
87
+ sortValue: "Lana"
88
+ }, {
89
+ displayValue: "Albacete",
90
+ sortValue: "Albacete"
91
+ }], [{
92
+ displayValue: "004",
93
+ sortValue: "004"
94
+ }, {
95
+ displayValue: "Rick",
96
+ sortValue: "Rick"
97
+ }, {
98
+ displayValue: "Albacete",
99
+ sortValue: "Albacete"
100
+ }], [{
101
+ displayValue: "005",
102
+ sortValue: "005"
103
+ }, {
104
+ displayValue: "Mark",
105
+ sortValue: "Mark"
106
+ }, {
107
+ displayValue: "Madrid",
108
+ sortValue: "Madrid"
109
+ }], [{
110
+ displayValue: "006",
111
+ sortValue: "006"
112
+ }, {
113
+ displayValue: "Cris",
114
+ sortValue: "Cris"
115
+ }, {
116
+ displayValue: "Barcelona",
117
+ sortValue: "Barcelona"
118
+ }], [{
119
+ displayValue: "007",
120
+ sortValue: "007"
121
+ }, {
122
+ displayValue: "Susan",
123
+ sortValue: "Susan"
124
+ }, {
125
+ displayValue: "Madrid",
126
+ sortValue: "Madrid"
127
+ }], [{
128
+ displayValue: "008",
129
+ sortValue: "008"
130
+ }, {
131
+ displayValue: "Tina",
132
+ sortValue: "Tina"
133
+ }, {
134
+ displayValue: "Barcelona",
135
+ sortValue: "Barcelona"
136
+ }], [{
137
+ displayValue: "009",
138
+ sortValue: "009"
139
+ }, {
140
+ displayValue: "Kevin",
141
+ sortValue: "Kevin"
142
+ }, {
143
+ displayValue: "Oviedo",
144
+ sortValue: "Oviedo"
145
+ }], [{
146
+ displayValue: "010",
147
+ sortValue: "010"
148
+ }, {
149
+ displayValue: "Cosmin",
150
+ sortValue: "Cosmin"
151
+ }, {
152
+ displayValue: "Barcelona",
153
+ sortValue: "Barcelona"
154
+ }]];
155
+ var rows2 = [[{
156
+ displayValue: "546",
157
+ sortValue: "465"
158
+ }, {
159
+ displayValue: "OtherValue",
160
+ sortValue: "OtherValue"
161
+ }, {
162
+ displayValue: "OtherValue",
163
+ sortValue: "OtherValue"
164
+ }], [{
165
+ displayValue: "978",
166
+ sortValue: "465"
167
+ }, {
168
+ displayValue: "OtherValue",
169
+ sortValue: "OtherValue"
170
+ }, {
171
+ displayValue: "OtherValue",
172
+ sortValue: "OtherValue"
173
+ }, {
174
+ displayValue: ""
175
+ }], [{
176
+ displayValue: "678",
177
+ sortValue: "344"
178
+ }, {
179
+ displayValue: "OtherValue",
180
+ sortValue: "OtherValue"
181
+ }, {
182
+ displayValue: "OtherValue",
183
+ sortValue: "OtherValue"
184
+ }]];
185
+ describe("Resultset table component tests", function () {
186
+ test("Resultset table rendered correctly", function () {
187
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
188
+ columns: columns,
189
+ rows: rows,
190
+ itemsPerPage: 3
191
+ })),
192
+ getByText = _render.getByText;
193
+ expect(getByText("Peter")).toBeTruthy();
194
+ });
195
+ test("Resultset table shows as many rows as itemsPerPage", function () {
196
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
197
+ columns: columns,
198
+ rows: rows,
199
+ itemsPerPage: 3
200
+ })),
201
+ getAllByRole = _render2.getAllByRole;
202
+ expect(getAllByRole("row").length - 1).toEqual(3);
203
+ });
204
+ test("Resultset table shows rows on second page", function () {
205
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
206
+ columns: columns,
207
+ rows: rows,
208
+ itemsPerPage: 3
209
+ })),
210
+ getByText = _render3.getByText,
211
+ getAllByRole = _render3.getAllByRole;
212
+ expect(getByText("Peter")).toBeTruthy();
213
+ expect(getByText("Louis")).toBeTruthy();
214
+ expect(getByText("Lana")).toBeTruthy();
215
+ expect(getAllByRole("row").length - 1).toEqual(3);
216
+ var nextButton = getAllByRole("button")[3];
217
+ _react2.fireEvent.click(nextButton);
218
+ expect(getByText("4 to 6 of 10")).toBeTruthy();
219
+ expect(getByText("Rick")).toBeTruthy();
220
+ expect(getByText("Mark")).toBeTruthy();
221
+ expect(getByText("Cris")).toBeTruthy();
222
+ expect(getAllByRole("row").length - 1).toEqual(3);
223
+ });
224
+ test("Resultset table goToPage works as expected", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
225
+ var _render4, getByText, getAllByRole, goToPageSelect, goToPageOption;
226
+ return _regenerator["default"].wrap(function _callee$(_context) {
227
+ while (1) switch (_context.prev = _context.next) {
228
+ case 0:
229
+ window.HTMLElement.prototype.scrollIntoView = function () {};
230
+ window.HTMLElement.prototype.scrollTo = function () {};
231
+ _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
232
+ columns: columns,
233
+ showGoToPage: true,
234
+ rows: rows,
235
+ itemsPerPage: 3
236
+ })), getByText = _render4.getByText, getAllByRole = _render4.getAllByRole;
237
+ expect(getByText("Peter")).toBeTruthy();
238
+ expect(getByText("Louis")).toBeTruthy();
239
+ expect(getByText("Lana")).toBeTruthy();
240
+ expect(getAllByRole("row").length - 1).toEqual(3);
241
+ goToPageSelect = getAllByRole("button")[3];
242
+ _context.next = 10;
243
+ return _userEvent["default"].click(goToPageSelect);
244
+ case 10:
245
+ goToPageOption = getByText("2");
246
+ _context.next = 13;
247
+ return _userEvent["default"].click(goToPageOption);
248
+ case 13:
249
+ expect(getByText("4 to 6 of 10")).toBeTruthy();
250
+ expect(getByText("Rick")).toBeTruthy();
251
+ expect(getByText("Mark")).toBeTruthy();
252
+ expect(getByText("Cris")).toBeTruthy();
253
+ expect(getAllByRole("row").length - 1).toEqual(3);
254
+ case 18:
255
+ case "end":
256
+ return _context.stop();
257
+ }
258
+ }, _callee);
259
+ })));
260
+ test("Resultset table going to the last page shows only one row", function () {
261
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
262
+ columns: columns,
263
+ rows: rows,
264
+ itemsPerPage: 3
265
+ })),
266
+ getByText = _render5.getByText,
267
+ getAllByRole = _render5.getAllByRole;
268
+ var lastButton = getAllByRole("button")[4];
269
+ _react2.fireEvent.click(lastButton);
270
+ expect(getByText("10 to 10 of 10")).toBeTruthy();
271
+ expect(getAllByRole("row")).toHaveLength(2);
272
+ expect(getByText("Cosmin")).toBeTruthy();
273
+ });
274
+ test("Resultset table sort rows by column", function () {
275
+ var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
276
+ columns: columns,
277
+ rows: rows,
278
+ itemsPerPage: 3
279
+ }));
280
+ expect(component.queryByText("Peter")).toBeTruthy();
281
+ _react2.fireEvent.click(component.queryByText("Name"));
282
+ expect(component.queryByText("Tina")).not.toBeTruthy();
283
+ expect(component.queryByText("Cosmin")).toBeTruthy();
284
+ _react2.fireEvent.click(component.queryByText("Name"));
285
+ expect(component.queryByText("Tina")).toBeTruthy();
286
+ expect(component.queryByText("Cosmin")).not.toBeTruthy();
287
+ });
288
+ test("Resultset table change rows should go to first page", function () {
289
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
290
+ columns: columns,
291
+ rows: rows,
292
+ itemsPerPage: 3
293
+ })),
294
+ queryByText = _render6.queryByText,
295
+ rerender = _render6.rerender;
296
+ expect(queryByText("Peter")).toBeTruthy();
297
+ rerender( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
298
+ columns: columns,
299
+ rows: rows2,
300
+ itemsPerPage: 3
301
+ }));
302
+ expect(queryByText("1 to 3 of 3")).toBeTruthy();
303
+ });
304
+ test("Resultset table change itemsPerPage should go to first page", function () {
305
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
306
+ columns: columns,
307
+ rows: rows,
308
+ itemsPerPage: 3,
309
+ itemsPerPageOptions: [2, 3]
310
+ })),
311
+ getAllByRole = _render7.getAllByRole;
312
+ var lastButton = getAllByRole("button")[4];
313
+ expect(getAllByRole("row").length - 1).toEqual(3);
314
+ _react2.fireEvent.click(lastButton);
315
+ expect(getAllByRole("row").length - 1).toEqual(1);
316
+ });
317
+ test("Resultset table may not use the paginator", function () {
318
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
319
+ columns: columns,
320
+ rows: rows,
321
+ hidePaginator: true
322
+ })),
323
+ getAllByRole = _render8.getAllByRole;
324
+ var nextButton = getAllByRole("button")[3];
325
+ expect(nextButton).not.toBeTruthy();
326
+ });
327
+ test("Resultset table with ActionsCell", function () {
328
+ var onSelectOption = jest.fn();
329
+ var onClick = jest.fn();
330
+ var actions = [{
331
+ icon: icon,
332
+ title: "icon1",
333
+ onClick: onSelectOption,
334
+ options: [{
335
+ value: "1",
336
+ label: "Amazon"
337
+ }, {
338
+ value: "2",
339
+ label: "Ebay"
340
+ }, {
341
+ value: "3",
342
+ label: "Aliexpress"
343
+ }]
344
+ }, {
345
+ icon: icon,
346
+ title: "icon2",
347
+ onClick: onClick
348
+ }];
349
+ var actionRows = [[{
350
+ displayValue: "001",
351
+ sortValue: "001"
352
+ }, {
353
+ displayValue: "Peter",
354
+ sortValue: "Peter"
355
+ }, {
356
+ displayValue: /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"].ActionsCell, {
357
+ actions: actions
358
+ }),
359
+ sortValue: "Actions"
360
+ }]];
361
+ var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
362
+ columns: columns,
363
+ rows: actionRows,
364
+ itemsPerPage: 3
365
+ })),
366
+ getAllByRole = _render9.getAllByRole,
367
+ getByRole = _render9.getByRole,
368
+ getByText = _render9.getByText;
369
+ var dropdown = getAllByRole("button")[2];
370
+ (0, _react2.act)(function () {
371
+ _userEvent["default"].click(dropdown);
372
+ });
373
+ expect(getByRole("menu")).toBeTruthy();
374
+ var option = getByText("Aliexpress");
375
+ _userEvent["default"].click(option);
376
+ expect(onSelectOption).toHaveBeenCalledWith("3");
377
+ var action = getAllByRole("button")[1];
378
+ _userEvent["default"].click(action);
379
+ expect(onClick).toHaveBeenCalled();
380
+ });
381
+ });