@dxc-technology/halstack-react 0.0.0-ebb089f → 0.0.0-ec06b53

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 (459) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +47 -0
  3. package/HalstackContext.d.ts +12 -0
  4. package/HalstackContext.js +294 -0
  5. package/accordion/Accordion.d.ts +4 -0
  6. package/accordion/Accordion.js +245 -0
  7. package/accordion/Accordion.stories.tsx +306 -0
  8. package/accordion/Accordion.test.js +71 -0
  9. package/accordion/types.d.ts +69 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +149 -0
  13. package/accordion-group/AccordionGroup.stories.tsx +251 -0
  14. package/accordion-group/AccordionGroup.test.js +126 -0
  15. package/accordion-group/types.d.ts +79 -0
  16. package/accordion-group/types.js +5 -0
  17. package/alert/Alert.d.ts +4 -0
  18. package/{dist/alert → alert}/Alert.js +44 -154
  19. package/alert/Alert.stories.tsx +170 -0
  20. package/alert/Alert.test.js +92 -0
  21. package/alert/types.d.ts +49 -0
  22. package/alert/types.js +5 -0
  23. package/badge/Badge.d.ts +4 -0
  24. package/badge/Badge.js +61 -0
  25. package/badge/types.d.ts +5 -0
  26. package/badge/types.js +5 -0
  27. package/bleed/Bleed.d.ts +3 -0
  28. package/bleed/Bleed.js +51 -0
  29. package/bleed/Bleed.stories.tsx +341 -0
  30. package/bleed/types.d.ts +37 -0
  31. package/bleed/types.js +5 -0
  32. package/box/Box.d.ts +4 -0
  33. package/box/Box.js +116 -0
  34. package/box/Box.stories.tsx +132 -0
  35. package/box/Box.test.js +18 -0
  36. package/box/types.d.ts +44 -0
  37. package/box/types.js +5 -0
  38. package/bulleted-list/BulletedList.d.ts +7 -0
  39. package/bulleted-list/BulletedList.js +123 -0
  40. package/bulleted-list/BulletedList.stories.tsx +200 -0
  41. package/bulleted-list/types.d.ts +11 -0
  42. package/bulleted-list/types.js +5 -0
  43. package/button/Button.d.ts +4 -0
  44. package/button/Button.js +156 -0
  45. package/button/Button.stories.tsx +283 -0
  46. package/button/Button.test.js +35 -0
  47. package/button/types.d.ts +53 -0
  48. package/button/types.js +5 -0
  49. package/card/Card.d.ts +4 -0
  50. package/card/Card.js +161 -0
  51. package/card/Card.stories.tsx +201 -0
  52. package/card/Card.test.js +50 -0
  53. package/card/ice-cream.jpg +0 -0
  54. package/card/types.d.ts +68 -0
  55. package/card/types.js +5 -0
  56. package/checkbox/Checkbox.d.ts +4 -0
  57. package/checkbox/Checkbox.js +250 -0
  58. package/checkbox/Checkbox.stories.tsx +208 -0
  59. package/checkbox/Checkbox.test.js +155 -0
  60. package/checkbox/types.d.ts +68 -0
  61. package/checkbox/types.js +5 -0
  62. package/chip/Chip.d.ts +4 -0
  63. package/chip/Chip.js +161 -0
  64. package/chip/Chip.stories.tsx +119 -0
  65. package/chip/Chip.test.js +56 -0
  66. package/chip/types.d.ts +45 -0
  67. package/chip/types.js +5 -0
  68. package/{dist/common → common}/OpenSans.css +0 -0
  69. package/{dist/common → common}/RequiredComponent.js +3 -11
  70. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  71. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  72. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  73. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  74. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  75. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  76. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  77. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  78. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  79. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  80. package/{dist/common → common}/utils.js +0 -0
  81. package/{dist/common → common}/variables.js +363 -425
  82. package/date-input/Calendar.d.ts +4 -0
  83. package/date-input/Calendar.js +258 -0
  84. package/date-input/DateInput.d.ts +4 -0
  85. package/date-input/DateInput.js +227 -0
  86. package/date-input/DateInput.stories.tsx +151 -0
  87. package/date-input/DateInput.test.js +752 -0
  88. package/date-input/DatePicker.d.ts +4 -0
  89. package/date-input/DatePicker.js +160 -0
  90. package/date-input/YearPicker.d.ts +4 -0
  91. package/date-input/YearPicker.js +115 -0
  92. package/date-input/types.d.ts +160 -0
  93. package/date-input/types.js +5 -0
  94. package/dialog/Dialog.d.ts +4 -0
  95. package/dialog/Dialog.js +162 -0
  96. package/dialog/Dialog.stories.tsx +267 -0
  97. package/dialog/Dialog.test.js +70 -0
  98. package/dialog/types.d.ts +44 -0
  99. package/dialog/types.js +5 -0
  100. package/dropdown/Dropdown.d.ts +4 -0
  101. package/dropdown/Dropdown.js +391 -0
  102. package/dropdown/Dropdown.stories.tsx +312 -0
  103. package/dropdown/Dropdown.test.js +585 -0
  104. package/dropdown/DropdownMenu.d.ts +4 -0
  105. package/dropdown/DropdownMenu.js +80 -0
  106. package/dropdown/DropdownMenuItem.d.ts +4 -0
  107. package/dropdown/DropdownMenuItem.js +92 -0
  108. package/dropdown/types.d.ts +100 -0
  109. package/dropdown/types.js +5 -0
  110. package/file-input/FileInput.d.ts +4 -0
  111. package/file-input/FileInput.js +551 -0
  112. package/file-input/FileInput.stories.tsx +535 -0
  113. package/file-input/FileInput.test.js +498 -0
  114. package/file-input/FileItem.d.ts +4 -0
  115. package/file-input/FileItem.js +161 -0
  116. package/file-input/types.d.ts +129 -0
  117. package/file-input/types.js +5 -0
  118. package/flex/Flex.d.ts +4 -0
  119. package/flex/Flex.js +69 -0
  120. package/flex/Flex.stories.tsx +103 -0
  121. package/flex/types.d.ts +32 -0
  122. package/flex/types.js +5 -0
  123. package/footer/Footer.d.ts +4 -0
  124. package/footer/Footer.js +185 -0
  125. package/footer/Footer.stories.tsx +137 -0
  126. package/footer/Footer.test.js +109 -0
  127. package/footer/Icons.d.ts +2 -0
  128. package/{dist/footer → footer}/Icons.js +16 -16
  129. package/footer/types.d.ts +66 -0
  130. package/footer/types.js +5 -0
  131. package/header/Header.d.ts +7 -0
  132. package/header/Header.js +305 -0
  133. package/header/Header.stories.tsx +172 -0
  134. package/header/Header.test.js +79 -0
  135. package/header/Icons.d.ts +2 -0
  136. package/{dist/header → header}/Icons.js +9 -34
  137. package/header/types.d.ts +48 -0
  138. package/header/types.js +5 -0
  139. package/heading/Heading.d.ts +4 -0
  140. package/{dist/heading → heading}/Heading.js +25 -96
  141. package/heading/Heading.stories.tsx +54 -0
  142. package/heading/Heading.test.js +186 -0
  143. package/heading/types.d.ts +33 -0
  144. package/heading/types.js +5 -0
  145. package/inset/Inset.d.ts +3 -0
  146. package/inset/Inset.js +51 -0
  147. package/inset/Inset.stories.tsx +229 -0
  148. package/inset/types.d.ts +37 -0
  149. package/inset/types.js +5 -0
  150. package/layout/ApplicationLayout.d.ts +20 -0
  151. package/layout/ApplicationLayout.js +171 -0
  152. package/layout/ApplicationLayout.stories.tsx +162 -0
  153. package/layout/Icons.d.ts +5 -0
  154. package/{dist/layout → layout}/Icons.js +19 -8
  155. package/layout/SidenavContext.d.ts +5 -0
  156. package/layout/SidenavContext.js +19 -0
  157. package/layout/types.d.ts +42 -0
  158. package/layout/types.js +5 -0
  159. package/link/Link.d.ts +4 -0
  160. package/link/Link.js +136 -0
  161. package/link/Link.stories.tsx +193 -0
  162. package/link/Link.test.js +83 -0
  163. package/link/types.d.ts +54 -0
  164. package/link/types.js +5 -0
  165. package/main.d.ts +44 -0
  166. package/{dist/main.js → main.js} +114 -104
  167. package/number-input/NumberInput.d.ts +4 -0
  168. package/number-input/NumberInput.js +76 -0
  169. package/number-input/NumberInput.stories.tsx +115 -0
  170. package/number-input/NumberInput.test.js +542 -0
  171. package/number-input/NumberInputContext.d.ts +4 -0
  172. package/{dist/number-input → number-input}/NumberInputContext.js +5 -2
  173. package/number-input/numberInputContextTypes.d.ts +19 -0
  174. package/number-input/numberInputContextTypes.js +5 -0
  175. package/number-input/types.d.ts +124 -0
  176. package/number-input/types.js +5 -0
  177. package/package.json +36 -33
  178. package/{dist/paginator → paginator}/Icons.js +9 -9
  179. package/paginator/Paginator.d.ts +4 -0
  180. package/paginator/Paginator.js +171 -0
  181. package/paginator/Paginator.stories.tsx +63 -0
  182. package/paginator/Paginator.test.js +308 -0
  183. package/paginator/types.d.ts +38 -0
  184. package/paginator/types.js +5 -0
  185. package/paragraph/Paragraph.d.ts +6 -0
  186. package/paragraph/Paragraph.js +38 -0
  187. package/paragraph/Paragraph.stories.tsx +44 -0
  188. package/password-input/PasswordInput.d.ts +4 -0
  189. package/{dist/password-input → password-input}/PasswordInput.js +40 -77
  190. package/password-input/PasswordInput.stories.tsx +131 -0
  191. package/password-input/PasswordInput.test.js +181 -0
  192. package/password-input/types.d.ts +110 -0
  193. package/password-input/types.js +5 -0
  194. package/progress-bar/ProgressBar.d.ts +4 -0
  195. package/progress-bar/ProgressBar.js +176 -0
  196. package/progress-bar/ProgressBar.stories.jsx +60 -0
  197. package/progress-bar/ProgressBar.test.js +110 -0
  198. package/progress-bar/types.d.ts +36 -0
  199. package/progress-bar/types.js +5 -0
  200. package/quick-nav/QuickNav.d.ts +4 -0
  201. package/quick-nav/QuickNav.js +117 -0
  202. package/quick-nav/QuickNav.stories.tsx +342 -0
  203. package/quick-nav/types.d.ts +21 -0
  204. package/quick-nav/types.js +5 -0
  205. package/radio-group/Radio.d.ts +4 -0
  206. package/radio-group/Radio.js +156 -0
  207. package/radio-group/RadioGroup.d.ts +4 -0
  208. package/radio-group/RadioGroup.js +283 -0
  209. package/radio-group/RadioGroup.stories.tsx +101 -0
  210. package/radio-group/RadioGroup.test.js +722 -0
  211. package/radio-group/types.d.ts +114 -0
  212. package/radio-group/types.js +5 -0
  213. package/resultsetTable/Icons.d.ts +7 -0
  214. package/resultsetTable/Icons.js +51 -0
  215. package/resultsetTable/ResultsetTable.d.ts +4 -0
  216. package/resultsetTable/ResultsetTable.js +195 -0
  217. package/resultsetTable/ResultsetTable.stories.tsx +300 -0
  218. package/resultsetTable/ResultsetTable.test.js +330 -0
  219. package/resultsetTable/types.d.ts +67 -0
  220. package/resultsetTable/types.js +5 -0
  221. package/select/Icons.d.ts +10 -0
  222. package/select/Icons.js +93 -0
  223. package/select/Listbox.d.ts +4 -0
  224. package/select/Listbox.js +198 -0
  225. package/select/Option.d.ts +4 -0
  226. package/select/Option.js +110 -0
  227. package/select/Select.d.ts +4 -0
  228. package/select/Select.js +645 -0
  229. package/select/Select.stories.tsx +627 -0
  230. package/select/Select.test.js +2233 -0
  231. package/select/types.d.ts +210 -0
  232. package/select/types.js +5 -0
  233. package/sidenav/Sidenav.d.ts +10 -0
  234. package/sidenav/Sidenav.js +268 -0
  235. package/sidenav/Sidenav.stories.tsx +180 -0
  236. package/sidenav/Sidenav.test.js +44 -0
  237. package/sidenav/types.d.ts +73 -0
  238. package/sidenav/types.js +5 -0
  239. package/slider/Slider.d.ts +4 -0
  240. package/slider/Slider.js +343 -0
  241. package/slider/Slider.stories.tsx +183 -0
  242. package/slider/Slider.test.js +250 -0
  243. package/slider/types.d.ts +86 -0
  244. package/slider/types.js +5 -0
  245. package/spinner/Spinner.d.ts +4 -0
  246. package/spinner/Spinner.js +250 -0
  247. package/spinner/Spinner.stories.jsx +103 -0
  248. package/spinner/Spinner.test.js +64 -0
  249. package/spinner/types.d.ts +32 -0
  250. package/spinner/types.js +5 -0
  251. package/switch/Switch.d.ts +4 -0
  252. package/switch/Switch.js +262 -0
  253. package/switch/Switch.stories.tsx +138 -0
  254. package/switch/Switch.test.js +225 -0
  255. package/switch/types.d.ts +66 -0
  256. package/switch/types.js +5 -0
  257. package/table/Table.d.ts +4 -0
  258. package/{dist/table → table}/Table.js +12 -26
  259. package/table/Table.stories.jsx +277 -0
  260. package/table/Table.test.js +26 -0
  261. package/table/types.d.ts +21 -0
  262. package/table/types.js +5 -0
  263. package/tabs/Tab.d.ts +4 -0
  264. package/tabs/Tab.js +135 -0
  265. package/tabs/Tabs.d.ts +4 -0
  266. package/tabs/Tabs.js +467 -0
  267. package/tabs/Tabs.stories.tsx +186 -0
  268. package/tabs/Tabs.test.js +351 -0
  269. package/tabs/types.d.ts +92 -0
  270. package/tabs/types.js +5 -0
  271. package/tabs-nav/NavTabs.d.ts +8 -0
  272. package/tabs-nav/NavTabs.js +125 -0
  273. package/tabs-nav/NavTabs.stories.tsx +170 -0
  274. package/tabs-nav/NavTabs.test.js +82 -0
  275. package/tabs-nav/Tab.d.ts +4 -0
  276. package/tabs-nav/Tab.js +130 -0
  277. package/tabs-nav/types.d.ts +53 -0
  278. package/tabs-nav/types.js +5 -0
  279. package/tag/Tag.d.ts +4 -0
  280. package/tag/Tag.js +183 -0
  281. package/tag/Tag.stories.tsx +142 -0
  282. package/tag/Tag.test.js +60 -0
  283. package/tag/types.d.ts +69 -0
  284. package/tag/types.js +5 -0
  285. package/text-input/Icons.d.ts +8 -0
  286. package/text-input/Icons.js +60 -0
  287. package/text-input/Suggestion.d.ts +4 -0
  288. package/text-input/Suggestion.js +57 -0
  289. package/text-input/Suggestions.d.ts +4 -0
  290. package/text-input/Suggestions.js +134 -0
  291. package/text-input/TextInput.d.ts +4 -0
  292. package/text-input/TextInput.js +677 -0
  293. package/text-input/TextInput.stories.tsx +481 -0
  294. package/text-input/TextInput.test.js +1624 -0
  295. package/text-input/types.d.ts +197 -0
  296. package/text-input/types.js +5 -0
  297. package/textarea/Textarea.d.ts +4 -0
  298. package/{dist/textarea → textarea}/Textarea.js +50 -142
  299. package/textarea/Textarea.stories.jsx +157 -0
  300. package/textarea/Textarea.test.js +437 -0
  301. package/textarea/types.d.ts +137 -0
  302. package/textarea/types.js +5 -0
  303. package/toggle-group/ToggleGroup.d.ts +4 -0
  304. package/{dist/toggle-group → toggle-group}/ToggleGroup.js +36 -148
  305. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  306. package/toggle-group/ToggleGroup.test.js +156 -0
  307. package/toggle-group/types.d.ts +105 -0
  308. package/toggle-group/types.js +5 -0
  309. package/typography/Typography.d.ts +4 -0
  310. package/typography/Typography.js +131 -0
  311. package/typography/Typography.stories.tsx +198 -0
  312. package/typography/types.d.ts +18 -0
  313. package/typography/types.js +5 -0
  314. package/useTheme.d.ts +2 -0
  315. package/{dist/useTheme.js → useTheme.js} +2 -2
  316. package/useTranslatedLabels.d.ts +2 -0
  317. package/useTranslatedLabels.js +20 -0
  318. package/wizard/Wizard.d.ts +4 -0
  319. package/wizard/Wizard.js +285 -0
  320. package/wizard/Wizard.stories.tsx +233 -0
  321. package/wizard/Wizard.test.js +141 -0
  322. package/wizard/types.d.ts +65 -0
  323. package/wizard/types.js +5 -0
  324. package/README.md +0 -66
  325. package/babel.config.js +0 -7
  326. package/dist/BackgroundColorContext.js +0 -46
  327. package/dist/ThemeContext.js +0 -250
  328. package/dist/V3Select/V3Select.js +0 -549
  329. package/dist/V3Select/index.d.ts +0 -27
  330. package/dist/V3Textarea/V3Textarea.js +0 -264
  331. package/dist/V3Textarea/index.d.ts +0 -27
  332. package/dist/accordion/Accordion.js +0 -353
  333. package/dist/accordion/index.d.ts +0 -28
  334. package/dist/accordion-group/AccordionGroup.js +0 -186
  335. package/dist/accordion-group/index.d.ts +0 -16
  336. package/dist/alert/index.d.ts +0 -51
  337. package/dist/badge/Badge.js +0 -63
  338. package/dist/box/Box.js +0 -156
  339. package/dist/box/index.d.ts +0 -25
  340. package/dist/button/Button.js +0 -238
  341. package/dist/button/Button.stories.js +0 -27
  342. package/dist/button/index.d.ts +0 -24
  343. package/dist/card/Card.js +0 -254
  344. package/dist/card/index.d.ts +0 -22
  345. package/dist/checkbox/Checkbox.js +0 -299
  346. package/dist/checkbox/index.d.ts +0 -24
  347. package/dist/chip/Chip.js +0 -265
  348. package/dist/chip/index.d.ts +0 -22
  349. package/dist/date/Date.js +0 -379
  350. package/dist/date/index.d.ts +0 -27
  351. package/dist/date-input/DateInput.js +0 -400
  352. package/dist/date-input/index.d.ts +0 -95
  353. package/dist/dialog/Dialog.js +0 -218
  354. package/dist/dialog/index.d.ts +0 -18
  355. package/dist/dropdown/Dropdown.js +0 -544
  356. package/dist/dropdown/index.d.ts +0 -26
  357. package/dist/file-input/FileInput.js +0 -644
  358. package/dist/file-input/FileItem.js +0 -287
  359. package/dist/file-input/index.d.ts +0 -81
  360. package/dist/footer/Footer.js +0 -421
  361. package/dist/footer/index.d.ts +0 -25
  362. package/dist/header/Header.js +0 -470
  363. package/dist/header/index.d.ts +0 -25
  364. package/dist/heading/index.d.ts +0 -17
  365. package/dist/input-text/Icons.js +0 -22
  366. package/dist/input-text/InputText.js +0 -705
  367. package/dist/input-text/index.d.ts +0 -36
  368. package/dist/layout/ApplicationLayout.js +0 -327
  369. package/dist/link/Link.js +0 -237
  370. package/dist/link/index.d.ts +0 -23
  371. package/dist/main.d.ts +0 -40
  372. package/dist/number-input/NumberInput.js +0 -136
  373. package/dist/number-input/index.d.ts +0 -113
  374. package/dist/paginator/Paginator.js +0 -305
  375. package/dist/paginator/index.d.ts +0 -20
  376. package/dist/password-input/index.d.ts +0 -94
  377. package/dist/progress-bar/ProgressBar.js +0 -242
  378. package/dist/progress-bar/index.d.ts +0 -18
  379. package/dist/radio/Radio.js +0 -209
  380. package/dist/radio/index.d.ts +0 -23
  381. package/dist/resultsetTable/ResultsetTable.js +0 -358
  382. package/dist/resultsetTable/index.d.ts +0 -19
  383. package/dist/select/Select.js +0 -1137
  384. package/dist/select/index.d.ts +0 -131
  385. package/dist/sidenav/Sidenav.js +0 -179
  386. package/dist/sidenav/index.d.ts +0 -13
  387. package/dist/slider/Slider.js +0 -404
  388. package/dist/slider/index.d.ts +0 -29
  389. package/dist/spinner/Spinner.js +0 -381
  390. package/dist/spinner/index.d.ts +0 -17
  391. package/dist/switch/Switch.js +0 -222
  392. package/dist/switch/index.d.ts +0 -24
  393. package/dist/table/index.d.ts +0 -13
  394. package/dist/tabs/Tabs.js +0 -343
  395. package/dist/tabs/index.d.ts +0 -19
  396. package/dist/tag/Tag.js +0 -282
  397. package/dist/tag/index.d.ts +0 -24
  398. package/dist/text-input/TextInput.js +0 -974
  399. package/dist/text-input/index.d.ts +0 -135
  400. package/dist/textarea/index.d.ts +0 -117
  401. package/dist/toggle/Toggle.js +0 -220
  402. package/dist/toggle/index.d.ts +0 -21
  403. package/dist/toggle-group/index.d.ts +0 -21
  404. package/dist/upload/Upload.js +0 -205
  405. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -135
  406. package/dist/upload/buttons-upload/Icons.js +0 -40
  407. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  408. package/dist/upload/dragAndDropArea/Icons.js +0 -39
  409. package/dist/upload/file-upload/FileToUpload.js +0 -189
  410. package/dist/upload/file-upload/Icons.js +0 -66
  411. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  412. package/dist/upload/index.d.ts +0 -15
  413. package/dist/upload/transaction/Icons.js +0 -160
  414. package/dist/upload/transaction/Transaction.js +0 -148
  415. package/dist/upload/transactions/Transactions.js +0 -138
  416. package/dist/wizard/Icons.js +0 -65
  417. package/dist/wizard/Wizard.js +0 -405
  418. package/dist/wizard/index.d.ts +0 -18
  419. package/test/Accordion.test.js +0 -33
  420. package/test/AccordionGroup.test.js +0 -125
  421. package/test/Alert.test.js +0 -53
  422. package/test/Box.test.js +0 -10
  423. package/test/Button.test.js +0 -18
  424. package/test/Card.test.js +0 -30
  425. package/test/Checkbox.test.js +0 -45
  426. package/test/Chip.test.js +0 -25
  427. package/test/Date.test.js +0 -395
  428. package/test/DateInput.test.js +0 -242
  429. package/test/Dialog.test.js +0 -23
  430. package/test/Dropdown.test.js +0 -145
  431. package/test/FileInput.test.js +0 -201
  432. package/test/Footer.test.js +0 -94
  433. package/test/Header.test.js +0 -34
  434. package/test/Heading.test.js +0 -83
  435. package/test/InputText.test.js +0 -239
  436. package/test/Link.test.js +0 -43
  437. package/test/NumberInput.test.js +0 -259
  438. package/test/Paginator.test.js +0 -181
  439. package/test/PasswordInput.test.js +0 -83
  440. package/test/ProgressBar.test.js +0 -35
  441. package/test/Radio.test.js +0 -37
  442. package/test/ResultsetTable.test.js +0 -330
  443. package/test/Select.test.js +0 -928
  444. package/test/Sidenav.test.js +0 -45
  445. package/test/Slider.test.js +0 -74
  446. package/test/Spinner.test.js +0 -32
  447. package/test/Switch.test.js +0 -45
  448. package/test/Table.test.js +0 -36
  449. package/test/Tabs.test.js +0 -109
  450. package/test/Tag.test.js +0 -32
  451. package/test/TextInput.test.js +0 -731
  452. package/test/Textarea.test.js +0 -193
  453. package/test/ToggleGroup.test.js +0 -85
  454. package/test/Upload.test.js +0 -60
  455. package/test/V3Select.test.js +0 -212
  456. package/test/V3TextArea.test.js +0 -51
  457. package/test/Wizard.test.js +0 -130
  458. package/test/mocks/pngMock.js +0 -1
  459. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,300 @@
1
+ import React from "react";
2
+ import DxcResultsetTable from "./ResultsetTable";
3
+ import DxcButton from "../button/Button";
4
+ import Title from "../../.storybook/components/Title";
5
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+ import { userEvent, within } from "@storybook/testing-library";
7
+ import styled from "styled-components";
8
+
9
+ export default {
10
+ title: "Resultset Table",
11
+ component: DxcResultsetTable,
12
+ };
13
+
14
+ const deleteIcon = (
15
+ <svg xmlns="http://www.w3.org/2000/svg" height="24" viewBox="0 0 24 24" width="24">
16
+ <path d="M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zM19 4h-3.5l-1-1h-5l-1 1H5v2h14V4z" />
17
+ <path d="M0 0h24v24H0z" fill="none" />
18
+ </svg>
19
+ );
20
+
21
+ const columns = [{ displayValue: "Id" }, { displayValue: "Name" }, { displayValue: "City" }];
22
+
23
+ const rows = [
24
+ [{ displayValue: "001" }, { displayValue: "Peter" }, { displayValue: "Miami" }],
25
+ [{ displayValue: "002" }, { displayValue: "Louis" }, { displayValue: "London" }],
26
+ [{ displayValue: "003" }, { displayValue: "Lana" }, { displayValue: "Amsterdam" }],
27
+ [{ displayValue: "004" }, { displayValue: "Rick" }, { displayValue: "London" }],
28
+ [{ displayValue: "005" }, { displayValue: "Mark" }, { displayValue: "Miami" }],
29
+ [{ displayValue: "006" }, { displayValue: "Cris" }, { displayValue: "Paris" }],
30
+ ];
31
+
32
+ const rowsIcon = [
33
+ [
34
+ { displayValue: "001", sortValue: "001" },
35
+ { displayValue: "Peter" },
36
+ { displayValue: <DxcButton icon={deleteIcon} /> },
37
+ ],
38
+ [{ displayValue: "002", sortValue: "002" }, { displayValue: "Louis" }, { displayValue: "" }],
39
+ [
40
+ { displayValue: "003", sortValue: "003" },
41
+ { displayValue: "Mark" },
42
+ { displayValue: <DxcButton icon={deleteIcon} /> },
43
+ ],
44
+ ];
45
+
46
+ const columnsSortable = [
47
+ { displayValue: "Id", isSortable: true },
48
+ { displayValue: "Name", isSortable: true },
49
+ { displayValue: "City", isSortable: false },
50
+ ];
51
+
52
+ const longValues = [
53
+ [
54
+ { displayValue: "000000000000000001", sortValue: "000000000000000001" },
55
+ { displayValue: "Peter Larsson González", sortValue: "Peter" },
56
+ { displayValue: "Miami: The city that never sleeps", sortValue: "Miami" },
57
+ ],
58
+ [
59
+ { displayValue: "002", sortValue: "002" },
60
+ { displayValue: "Louis", sortValue: "Louis" },
61
+ { displayValue: "London", sortValue: "London" },
62
+ ],
63
+ [
64
+ { displayValue: "003", sortValue: "003" },
65
+ { displayValue: "Aida", sortValue: "Aida" },
66
+ { displayValue: "Wroclaw", sortValue: "Wroclaw" },
67
+ ],
68
+ ];
69
+
70
+ const rowsSortable = [
71
+ [
72
+ { displayValue: "001", sortValue: "001" },
73
+ { displayValue: "Peter", sortValue: "Peter" },
74
+ { displayValue: "Miami", sortValue: "Miami" },
75
+ ],
76
+ [
77
+ { displayValue: "002", sortValue: "002" },
78
+ { displayValue: "Louis", sortValue: "Louis" },
79
+ { displayValue: "London", sortValue: "London" },
80
+ ],
81
+ [
82
+ { displayValue: "003", sortValue: "003" },
83
+ { displayValue: "Aida", sortValue: "Aida" },
84
+ { displayValue: "Wroclaw", sortValue: "Wroclaw" },
85
+ ],
86
+ [
87
+ { displayValue: "004", sortValue: "004" },
88
+ { displayValue: "Lana", sortValue: "Lana" },
89
+ { displayValue: "Amsterdam", sortValue: "Amsterdam" },
90
+ ],
91
+ ];
92
+
93
+ const longColumns = [
94
+ { displayValue: "Column1" },
95
+ { displayValue: "Column2" },
96
+ { displayValue: "Column3" },
97
+ { displayValue: "Column4" },
98
+ { displayValue: "Column5" },
99
+ { displayValue: "Column6" },
100
+ { displayValue: "Column7" },
101
+ { displayValue: "Column8" },
102
+ { displayValue: "Column9" },
103
+ { displayValue: "Column10" },
104
+ { displayValue: "Column11" },
105
+ { displayValue: "Column12" },
106
+ { displayValue: "Column13" },
107
+ { displayValue: "Column14" },
108
+ { displayValue: "Column15" },
109
+ { displayValue: "Column16" },
110
+ { displayValue: "Column17" },
111
+ { displayValue: "Column18" },
112
+ { displayValue: "Column19" },
113
+ { displayValue: "Column20" },
114
+ ];
115
+
116
+ const longRows = [
117
+ [
118
+ { displayValue: "001", sortValue: "001" },
119
+ { displayValue: "Peter", sortValue: "Peter" },
120
+ { displayValue: "Miami", sortValue: "Miami" },
121
+ { displayValue: "001", sortValue: "001" },
122
+ { displayValue: "Peter", sortValue: "Peter" },
123
+ { displayValue: "Miami", sortValue: "Miami" },
124
+ { displayValue: "Miami", sortValue: "Miami" },
125
+ { displayValue: "001", sortValue: "001" },
126
+ { displayValue: "Peter", sortValue: "Peter" },
127
+ { displayValue: "Miami", sortValue: "Miami" },
128
+ { displayValue: "002", sortValue: "002" },
129
+ { displayValue: "Louis", sortValue: "Louis" },
130
+ { displayValue: "London", sortValue: "London" },
131
+ { displayValue: "002", sortValue: "002" },
132
+ { displayValue: "Louis", sortValue: "Louis" },
133
+ { displayValue: "London", sortValue: "London" },
134
+ { displayValue: "002", sortValue: "002" },
135
+ { displayValue: "Louis", sortValue: "Louis" },
136
+ { displayValue: "London", sortValue: "London" },
137
+ { displayValue: "London", sortValue: "London" },
138
+ ],
139
+ [
140
+ { displayValue: "002", sortValue: "002" },
141
+ { displayValue: "Louis", sortValue: "Louis" },
142
+ { displayValue: "London", sortValue: "London" },
143
+ { displayValue: "002", sortValue: "002" },
144
+ { displayValue: "Louis", sortValue: "Louis" },
145
+ { displayValue: "London", sortValue: "London" },
146
+ { displayValue: "002", sortValue: "002" },
147
+ { displayValue: "Louis", sortValue: "Louis" },
148
+ { displayValue: "London", sortValue: "London" },
149
+ { displayValue: "London", sortValue: "London" },
150
+ { displayValue: "002", sortValue: "002" },
151
+ { displayValue: "Louis", sortValue: "Louis" },
152
+ { displayValue: "London", sortValue: "London" },
153
+ { displayValue: "002", sortValue: "002" },
154
+ { displayValue: "Louis", sortValue: "Louis" },
155
+ { displayValue: "London", sortValue: "London" },
156
+ { displayValue: "002", sortValue: "002" },
157
+ { displayValue: "Louis", sortValue: "Louis" },
158
+ { displayValue: "London", sortValue: "London" },
159
+ { displayValue: "London", sortValue: "London" },
160
+ ],
161
+ [
162
+ { displayValue: "002", sortValue: "002" },
163
+ { displayValue: "Louis", sortValue: "Louis" },
164
+ { displayValue: "London", sortValue: "London" },
165
+ { displayValue: "002", sortValue: "002" },
166
+ { displayValue: "Louis", sortValue: "Louis" },
167
+ { displayValue: "London", sortValue: "London" },
168
+ { displayValue: "002", sortValue: "002" },
169
+ { displayValue: "Louis", sortValue: "Louis" },
170
+ { displayValue: "London", sortValue: "London" },
171
+ { displayValue: "London", sortValue: "London" },
172
+ { displayValue: "002", sortValue: "002" },
173
+ { displayValue: "Louis", sortValue: "Louis" },
174
+ { displayValue: "London", sortValue: "London" },
175
+ { displayValue: "002", sortValue: "002" },
176
+ { displayValue: "Louis", sortValue: "Louis" },
177
+ { displayValue: "London", sortValue: "London" },
178
+ { displayValue: "002", sortValue: "002" },
179
+ { displayValue: "Louis", sortValue: "Louis" },
180
+ { displayValue: "London", sortValue: "London" },
181
+ { displayValue: "London", sortValue: "London" },
182
+ ],
183
+ ];
184
+
185
+ export const Chromatic = () => (
186
+ <>
187
+ <ExampleContainer>
188
+ <Title title="Sortable table" theme="light" level={4} />
189
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
190
+ </ExampleContainer>
191
+ <ExampleContainer>
192
+ <Title title="With action" theme="light" level={4} />
193
+ <DxcResultsetTable columns={columns} rows={rowsIcon} />
194
+ </ExampleContainer>
195
+ <ExampleContainer>
196
+ <Title title="With items per page option" theme="light" level={4} />
197
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} itemsPerPageOptions={[2, 3]} />
198
+ </ExampleContainer>
199
+ <ExampleContainer>
200
+ <Title title="Scroll resultset table" theme="light" level={4} />
201
+ <DxcResultsetTable columns={longColumns} rows={longRows} />
202
+ </ExampleContainer>
203
+ <ExampleContainer>
204
+ <SmallContainer>
205
+ <Title title="Small container and text overflow" theme="light" level={4} />
206
+ <DxcResultsetTable columns={columnsSortable} rows={longValues} />
207
+ </SmallContainer>
208
+ </ExampleContainer>
209
+ <Title title="Margins" theme="light" level={2} />
210
+ <ExampleContainer>
211
+ <Title title="Xxsmall" theme="light" level={4} />
212
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xxsmall"} />
213
+ </ExampleContainer>
214
+ <ExampleContainer>
215
+ <Title title="Xsmall" theme="light" level={4} />
216
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xsmall"} />
217
+ </ExampleContainer>
218
+ <ExampleContainer>
219
+ <Title title="Small" theme="light" level={4} />
220
+ <DxcResultsetTable columns={columns} rows={rows} margin={"small"} />
221
+ </ExampleContainer>
222
+ <ExampleContainer>
223
+ <Title title="Medium" theme="light" level={4} />
224
+ <DxcResultsetTable columns={columns} rows={rows} margin={"medium"} />
225
+ </ExampleContainer>
226
+ <ExampleContainer>
227
+ <Title title="Large" theme="light" level={4} />
228
+ <DxcResultsetTable columns={columns} rows={rows} margin={"large"} />
229
+ </ExampleContainer>
230
+ <ExampleContainer>
231
+ <Title title="Xlarge" theme="light" level={4} />
232
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xlarge"} />
233
+ </ExampleContainer>
234
+ <ExampleContainer expanded>
235
+ <Title title="Xxlarge" theme="light" level={4} />
236
+ <DxcResultsetTable columns={columns} rows={rows} margin={"xxlarge"} />
237
+ </ExampleContainer>
238
+ </>
239
+ );
240
+
241
+ const SmallContainer = styled.div`
242
+ width: 500px;
243
+ `;
244
+
245
+ const ResultsetTableAsc = () => (
246
+ <ExampleContainer>
247
+ <Title title="Ascendant sorting" theme="light" level={4} />
248
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
249
+ </ExampleContainer>
250
+ );
251
+
252
+ export const AscendentSorting = ResultsetTableAsc.bind({});
253
+ AscendentSorting.play = async ({ canvasElement }) => {
254
+ const canvas = within(canvasElement);
255
+ const idHeader = canvas.getAllByRole("button")[0];
256
+ await userEvent.click(idHeader);
257
+ };
258
+
259
+ const ResultsetTableDesc = () => (
260
+ <ExampleContainer>
261
+ <Title title="Descendant sorting" theme="light" level={4} />
262
+ <DxcResultsetTable columns={columnsSortable} rows={rowsSortable} />
263
+ </ExampleContainer>
264
+ );
265
+
266
+ export const DescendantSorting = ResultsetTableDesc.bind({});
267
+ DescendantSorting.play = async ({ canvasElement }) => {
268
+ const canvas = within(canvasElement);
269
+ const nameHeader = canvas.getAllByRole("button")[1];
270
+ await userEvent.click(nameHeader);
271
+ await userEvent.click(nameHeader);
272
+ };
273
+
274
+ const ResultsetTableMiddle = () => (
275
+ <ExampleContainer>
276
+ <Title title="Middle page" theme="light" level={4} />
277
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
278
+ </ExampleContainer>
279
+ );
280
+
281
+ export const MiddlePage = ResultsetTableMiddle.bind({});
282
+ MiddlePage.play = async ({ canvasElement }) => {
283
+ const canvas = within(canvasElement);
284
+ const nextButton = canvas.getAllByRole("button")[2];
285
+ await userEvent.click(nextButton);
286
+ };
287
+
288
+ const ResultsetTableLast = () => (
289
+ <ExampleContainer>
290
+ <Title title="Last page" theme="light" level={4} />
291
+ <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={2} />
292
+ </ExampleContainer>
293
+ );
294
+
295
+ export const LastPage = ResultsetTableLast.bind({});
296
+ LastPage.play = async ({ canvasElement }) => {
297
+ const canvas = within(canvasElement);
298
+ const nextButton = canvas.getAllByRole("button")[3];
299
+ await userEvent.click(nextButton);
300
+ };
@@ -0,0 +1,330 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
6
+
7
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
8
+
9
+ var _react = _interopRequireDefault(require("react"));
10
+
11
+ var _react2 = require("@testing-library/react");
12
+
13
+ var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
14
+
15
+ var _ResultsetTable = _interopRequireDefault(require("./ResultsetTable"));
16
+
17
+ // Mocking DOMRect for Radix Primitive Popover
18
+ global.globalThis = global;
19
+
20
+ global.ResizeObserver = /*#__PURE__*/function () {
21
+ function ResizeObserver(cb) {
22
+ (0, _classCallCheck2["default"])(this, ResizeObserver);
23
+ this.cb = cb;
24
+ }
25
+
26
+ (0, _createClass2["default"])(ResizeObserver, [{
27
+ key: "observe",
28
+ value: function observe() {
29
+ this.cb([{
30
+ borderBoxSize: {
31
+ inlineSize: 0,
32
+ blockSize: 0
33
+ }
34
+ }]);
35
+ }
36
+ }, {
37
+ key: "unobserve",
38
+ value: function unobserve() {}
39
+ }]);
40
+ return ResizeObserver;
41
+ }();
42
+
43
+ global.DOMRect = {
44
+ fromRect: function fromRect() {
45
+ return {
46
+ top: 0,
47
+ left: 0,
48
+ bottom: 0,
49
+ right: 0,
50
+ width: 0,
51
+ height: 0
52
+ };
53
+ }
54
+ };
55
+ var columns = [{
56
+ displayValue: "Id",
57
+ isSortable: false
58
+ }, {
59
+ displayValue: "Name",
60
+ isSortable: true
61
+ }, {
62
+ displayValue: "City",
63
+ isSortable: false
64
+ }];
65
+ var rows = [[{
66
+ displayValue: "001",
67
+ sortValue: "001"
68
+ }, {
69
+ displayValue: "Peter",
70
+ sortValue: "Peter"
71
+ }, {
72
+ displayValue: "Oviedo",
73
+ sortValue: "Oviedo"
74
+ }], [{
75
+ displayValue: "002",
76
+ sortValue: "002"
77
+ }, {
78
+ displayValue: "Louis",
79
+ sortValue: "Louis"
80
+ }, {
81
+ displayValue: "Oviedo",
82
+ sortValue: "Oviedo"
83
+ }], [{
84
+ displayValue: "003",
85
+ sortValue: "003"
86
+ }, {
87
+ displayValue: "Lana",
88
+ sortValue: "Lana"
89
+ }, {
90
+ displayValue: "Albacete",
91
+ sortValue: "Albacete"
92
+ }], [{
93
+ displayValue: "004",
94
+ sortValue: "004"
95
+ }, {
96
+ displayValue: "Rick",
97
+ sortValue: "Rick"
98
+ }, {
99
+ displayValue: "Albacete",
100
+ sortValue: "Albacete"
101
+ }], [{
102
+ displayValue: "005",
103
+ sortValue: "005"
104
+ }, {
105
+ displayValue: "Mark",
106
+ sortValue: "Mark"
107
+ }, {
108
+ displayValue: "Madrid",
109
+ sortValue: "Madrid"
110
+ }], [{
111
+ displayValue: "006",
112
+ sortValue: "006"
113
+ }, {
114
+ displayValue: "Cris",
115
+ sortValue: "Cris"
116
+ }, {
117
+ displayValue: "Barcelona",
118
+ sortValue: "Barcelona"
119
+ }], [{
120
+ displayValue: "007",
121
+ sortValue: "007"
122
+ }, {
123
+ displayValue: "Susan",
124
+ sortValue: "Susan"
125
+ }, {
126
+ displayValue: "Madrid",
127
+ sortValue: "Madrid"
128
+ }], [{
129
+ displayValue: "008",
130
+ sortValue: "008"
131
+ }, {
132
+ displayValue: "Tina",
133
+ sortValue: "Tina"
134
+ }, {
135
+ displayValue: "Barcelona",
136
+ sortValue: "Barcelona"
137
+ }], [{
138
+ displayValue: "009",
139
+ sortValue: "009"
140
+ }, {
141
+ displayValue: "Kevin",
142
+ sortValue: "Kevin"
143
+ }, {
144
+ displayValue: "Oviedo",
145
+ sortValue: "Oviedo"
146
+ }], [{
147
+ displayValue: "010",
148
+ sortValue: "010"
149
+ }, {
150
+ displayValue: "Cosmin",
151
+ sortValue: "Cosmin"
152
+ }, {
153
+ displayValue: "Barcelona",
154
+ sortValue: "Barcelona"
155
+ }]];
156
+ var rows2 = [[{
157
+ displayValue: "546",
158
+ sortValue: "465"
159
+ }, {
160
+ displayValue: "OtherValue",
161
+ sortValue: "OtherValue"
162
+ }, {
163
+ displayValue: "OtherValue",
164
+ sortValue: "OtherValue"
165
+ }], [{
166
+ displayValue: "978",
167
+ sortValue: "465"
168
+ }, {
169
+ displayValue: "OtherValue",
170
+ sortValue: "OtherValue"
171
+ }, {
172
+ displayValue: "OtherValue",
173
+ sortValue: "OtherValue"
174
+ }, {
175
+ displayValue: ""
176
+ }], [{
177
+ displayValue: "678",
178
+ sortValue: "344"
179
+ }, {
180
+ displayValue: "OtherValue",
181
+ sortValue: "OtherValue"
182
+ }, {
183
+ displayValue: "OtherValue",
184
+ sortValue: "OtherValue"
185
+ }]];
186
+ describe("Resultset table component tests", function () {
187
+ test("Resultset table rendered correctly", function () {
188
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
189
+ columns: columns,
190
+ rows: rows,
191
+ itemsPerPage: 3
192
+ })),
193
+ getByText = _render.getByText;
194
+
195
+ expect(getByText("Peter")).toBeTruthy();
196
+ });
197
+ test("Resultset table shows as many rows as itemsPerPage", function () {
198
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
199
+ columns: columns,
200
+ rows: rows,
201
+ itemsPerPage: 3
202
+ })),
203
+ getAllByRole = _render2.getAllByRole;
204
+
205
+ expect(getAllByRole("row").length - 1).toEqual(3);
206
+ });
207
+ test("Resultset table shows rows on second page", function () {
208
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
209
+ columns: columns,
210
+ rows: rows,
211
+ itemsPerPage: 3
212
+ })),
213
+ getByText = _render3.getByText,
214
+ getAllByRole = _render3.getAllByRole;
215
+
216
+ expect(getByText("Peter")).toBeTruthy();
217
+ expect(getByText("Louis")).toBeTruthy();
218
+ expect(getByText("Lana")).toBeTruthy();
219
+ expect(getAllByRole("row").length - 1).toEqual(3);
220
+ var nextButton = getAllByRole("button")[3];
221
+
222
+ _react2.fireEvent.click(nextButton);
223
+
224
+ expect(getByText("4 to 6 of 10")).toBeTruthy();
225
+ expect(getByText("Rick")).toBeTruthy();
226
+ expect(getByText("Mark")).toBeTruthy();
227
+ expect(getByText("Cris")).toBeTruthy();
228
+ expect(getAllByRole("row").length - 1).toEqual(3);
229
+ });
230
+ test("Resultset table goToPage works as expected", function () {
231
+ window.HTMLElement.prototype.scrollIntoView = function () {};
232
+
233
+ window.HTMLElement.prototype.scrollTo = function () {};
234
+
235
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
236
+ columns: columns,
237
+ showGoToPage: true,
238
+ rows: rows,
239
+ itemsPerPage: 3
240
+ })),
241
+ getByText = _render4.getByText,
242
+ getAllByRole = _render4.getAllByRole;
243
+
244
+ expect(getByText("Peter")).toBeTruthy();
245
+ expect(getByText("Louis")).toBeTruthy();
246
+ expect(getByText("Lana")).toBeTruthy();
247
+ expect(getAllByRole("row").length - 1).toEqual(3);
248
+ var goToPageSelect = getAllByRole("button")[3];
249
+
250
+ _userEvent["default"].click(goToPageSelect);
251
+
252
+ var goToPageOption = getByText("2");
253
+
254
+ _userEvent["default"].click(goToPageOption);
255
+
256
+ expect(getByText("4 to 6 of 10")).toBeTruthy();
257
+ expect(getByText("Rick")).toBeTruthy();
258
+ expect(getByText("Mark")).toBeTruthy();
259
+ expect(getByText("Cris")).toBeTruthy();
260
+ expect(getAllByRole("row").length - 1).toEqual(3);
261
+ });
262
+ test("Resultset table going to the last page shows only one row", function () {
263
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
264
+ columns: columns,
265
+ rows: rows,
266
+ itemsPerPage: 3
267
+ })),
268
+ getByText = _render5.getByText,
269
+ getAllByRole = _render5.getAllByRole;
270
+
271
+ var lastButton = getAllByRole("button")[4];
272
+
273
+ _react2.fireEvent.click(lastButton);
274
+
275
+ expect(getByText("10 to 10 of 10")).toBeTruthy();
276
+ expect(getAllByRole("row")).toHaveLength(2);
277
+ expect(getByText("Cosmin")).toBeTruthy();
278
+ });
279
+ test("Resultset table sort rows by column", function () {
280
+ var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
281
+ columns: columns,
282
+ rows: rows,
283
+ itemsPerPage: 3
284
+ }));
285
+ expect(component.queryByText("Peter")).toBeTruthy();
286
+
287
+ _react2.fireEvent.click(component.queryByText("Name"));
288
+
289
+ expect(component.queryByText("Tina")).not.toBeTruthy();
290
+ expect(component.queryByText("Cosmin")).toBeTruthy();
291
+
292
+ _react2.fireEvent.click(component.queryByText("Name"));
293
+
294
+ expect(component.queryByText("Tina")).toBeTruthy();
295
+ expect(component.queryByText("Cosmin")).not.toBeTruthy();
296
+ });
297
+ test("Resultset table change rows should go to first page", function () {
298
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
299
+ columns: columns,
300
+ rows: rows,
301
+ itemsPerPage: 3
302
+ })),
303
+ queryByText = _render6.queryByText,
304
+ rerender = _render6.rerender;
305
+
306
+ expect(queryByText("Peter")).toBeTruthy();
307
+ rerender( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
308
+ columns: columns,
309
+ rows: rows2,
310
+ itemsPerPage: 3
311
+ }));
312
+ expect(queryByText("1 to 3 of 3")).toBeTruthy();
313
+ });
314
+ test("Resultset table change itemsPerPage should go to first page", function () {
315
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_ResultsetTable["default"], {
316
+ columns: columns,
317
+ rows: rows,
318
+ itemsPerPage: 3,
319
+ itemsPerPageOptions: [2, 3]
320
+ })),
321
+ getAllByRole = _render7.getAllByRole;
322
+
323
+ var lastButton = getAllByRole("button")[4];
324
+ expect(getAllByRole("row").length - 1).toEqual(3);
325
+
326
+ _react2.fireEvent.click(lastButton);
327
+
328
+ expect(getAllByRole("row").length - 1).toEqual(1);
329
+ });
330
+ });
@@ -0,0 +1,67 @@
1
+ /// <reference types="react" />
2
+ export declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
3
+ export declare type Margin = {
4
+ top?: Space;
5
+ bottom?: Space;
6
+ left?: Space;
7
+ right?: Space;
8
+ };
9
+ declare type Column = {
10
+ /**
11
+ * Column display value.
12
+ */
13
+ displayValue: React.ReactNode;
14
+ /**
15
+ * Boolean value to indicate whether the column is sortable or not.
16
+ */
17
+ isSortable?: boolean;
18
+ };
19
+ declare type Row = {
20
+ /**
21
+ * Value to be displayed in the cell.
22
+ */
23
+ displayValue: React.ReactNode;
24
+ /**
25
+ * Value to be used when sorting the table by that
26
+ * column. If not indicated displayValue will be used for sorting.
27
+ */
28
+ sortValue?: string;
29
+ };
30
+ declare type Props = {
31
+ /**
32
+ * An array of objects representing the columns of the table.
33
+ */
34
+ columns: Column[];
35
+ /**
36
+ * An array of objects representing the rows of the table, you will have
37
+ * as many objects as columns in the table.
38
+ */
39
+ rows: Row[][];
40
+ /**
41
+ * If true, a select component for navigation between pages will be displayed.
42
+ */
43
+ showGoToPage?: boolean;
44
+ /**
45
+ * Number of items per page.
46
+ */
47
+ itemsPerPage?: number;
48
+ /**
49
+ * An array of numbers representing the items per page options.
50
+ */
51
+ itemsPerPageOptions?: number[];
52
+ /**
53
+ * This function will be called when the user selects an item per page
54
+ * option. The value selected will be passed as a parameter.
55
+ */
56
+ itemsPerPageFunction?: (newValue: number) => void;
57
+ /**
58
+ * Size of the margin to be applied to the component. You can pass an object with 'top',
59
+ * 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
60
+ */
61
+ margin?: Space | Margin;
62
+ /**
63
+ * Value of the tabindex attribute given to the sortable icon.
64
+ */
65
+ tabIndex?: number;
66
+ };
67
+ export default Props;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });