@dxc-technology/halstack-react 0.0.0-90f64ff → 0.0.0-910214a

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 (455) 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 +295 -0
  5. package/accordion/Accordion.d.ts +4 -0
  6. package/accordion/Accordion.js +226 -0
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +72 -0
  9. package/accordion/types.d.ts +68 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +168 -0
  13. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  14. package/accordion-group/AccordionGroup.test.js +151 -0
  15. package/accordion-group/types.d.ts +72 -0
  16. package/accordion-group/types.js +5 -0
  17. package/alert/Alert.d.ts +4 -0
  18. package/{dist/alert → alert}/Alert.js +47 -157
  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 +43 -0
  37. package/box/types.js +5 -0
  38. package/button/Button.d.ts +4 -0
  39. package/{dist/button → button}/Button.js +34 -98
  40. package/button/Button.stories.tsx +274 -0
  41. package/button/Button.test.js +35 -0
  42. package/button/types.d.ts +53 -0
  43. package/button/types.js +5 -0
  44. package/card/Card.d.ts +4 -0
  45. package/card/Card.js +161 -0
  46. package/card/Card.stories.tsx +201 -0
  47. package/card/Card.test.js +50 -0
  48. package/card/ice-cream.jpg +0 -0
  49. package/card/types.d.ts +67 -0
  50. package/card/types.js +5 -0
  51. package/checkbox/Checkbox.d.ts +4 -0
  52. package/{dist/checkbox → checkbox}/Checkbox.js +55 -98
  53. package/checkbox/Checkbox.stories.tsx +188 -0
  54. package/checkbox/Checkbox.test.js +78 -0
  55. package/checkbox/types.d.ts +64 -0
  56. package/checkbox/types.js +5 -0
  57. package/chip/Chip.d.ts +4 -0
  58. package/chip/Chip.js +161 -0
  59. package/chip/Chip.stories.tsx +119 -0
  60. package/chip/Chip.test.js +56 -0
  61. package/chip/types.d.ts +45 -0
  62. package/chip/types.js +5 -0
  63. package/{dist/common → common}/OpenSans.css +0 -0
  64. package/{dist/common → common}/RequiredComponent.js +3 -11
  65. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  66. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  67. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  68. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  69. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  70. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  71. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  72. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  73. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  74. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  75. package/{dist/common → common}/utils.js +0 -0
  76. package/{dist/common → common}/variables.js +518 -409
  77. package/date-input/DateInput.d.ts +4 -0
  78. package/date-input/DateInput.js +372 -0
  79. package/date-input/DateInput.stories.tsx +138 -0
  80. package/date-input/DateInput.test.js +479 -0
  81. package/date-input/types.d.ts +107 -0
  82. package/date-input/types.js +5 -0
  83. package/dialog/Dialog.d.ts +4 -0
  84. package/dialog/Dialog.js +138 -0
  85. package/dialog/Dialog.stories.tsx +212 -0
  86. package/dialog/Dialog.test.js +40 -0
  87. package/dialog/types.d.ts +43 -0
  88. package/dialog/types.js +5 -0
  89. package/dropdown/Dropdown.d.ts +4 -0
  90. package/{dist/dropdown → dropdown}/Dropdown.js +54 -207
  91. package/dropdown/Dropdown.stories.tsx +249 -0
  92. package/dropdown/Dropdown.test.js +189 -0
  93. package/dropdown/types.d.ts +80 -0
  94. package/dropdown/types.js +5 -0
  95. package/file-input/FileInput.d.ts +4 -0
  96. package/file-input/FileInput.js +593 -0
  97. package/file-input/FileInput.stories.tsx +507 -0
  98. package/file-input/FileInput.test.js +457 -0
  99. package/file-input/FileItem.d.ts +14 -0
  100. package/file-input/FileItem.js +186 -0
  101. package/file-input/types.d.ts +112 -0
  102. package/file-input/types.js +5 -0
  103. package/footer/Footer.d.ts +4 -0
  104. package/footer/Footer.js +185 -0
  105. package/footer/Footer.stories.tsx +130 -0
  106. package/footer/Footer.test.js +109 -0
  107. package/footer/Icons.d.ts +2 -0
  108. package/footer/Icons.js +77 -0
  109. package/footer/types.d.ts +65 -0
  110. package/footer/types.js +5 -0
  111. package/header/Header.d.ts +7 -0
  112. package/header/Header.js +303 -0
  113. package/header/Header.stories.tsx +172 -0
  114. package/header/Header.test.js +79 -0
  115. package/header/Icons.d.ts +2 -0
  116. package/header/Icons.js +34 -0
  117. package/header/types.d.ts +47 -0
  118. package/header/types.js +5 -0
  119. package/heading/Heading.d.ts +4 -0
  120. package/{dist/heading → heading}/Heading.js +31 -90
  121. package/heading/Heading.stories.tsx +54 -0
  122. package/heading/Heading.test.js +186 -0
  123. package/heading/types.d.ts +33 -0
  124. package/heading/types.js +5 -0
  125. package/inset/Inset.d.ts +3 -0
  126. package/inset/Inset.js +84 -0
  127. package/inset/Inset.stories.tsx +229 -0
  128. package/inset/types.d.ts +37 -0
  129. package/inset/types.js +5 -0
  130. package/layout/ApplicationLayout.d.ts +11 -0
  131. package/layout/ApplicationLayout.js +199 -0
  132. package/layout/ApplicationLayout.stories.tsx +126 -0
  133. package/layout/Icons.d.ts +5 -0
  134. package/layout/Icons.js +66 -0
  135. package/layout/SidenavContext.d.ts +5 -0
  136. package/layout/SidenavContext.js +19 -0
  137. package/layout/types.d.ts +52 -0
  138. package/layout/types.js +5 -0
  139. package/link/Link.d.ts +4 -0
  140. package/link/Link.js +136 -0
  141. package/link/Link.stories.tsx +186 -0
  142. package/link/Link.test.js +83 -0
  143. package/link/types.d.ts +54 -0
  144. package/link/types.js +5 -0
  145. package/list/List.d.ts +4 -0
  146. package/list/List.js +47 -0
  147. package/list/List.stories.tsx +95 -0
  148. package/list/types.d.ts +7 -0
  149. package/list/types.js +5 -0
  150. package/main.d.ts +47 -0
  151. package/{dist/main.js → main.js} +145 -103
  152. package/number-input/NumberInput.d.ts +4 -0
  153. package/number-input/NumberInput.js +76 -0
  154. package/number-input/NumberInput.stories.tsx +115 -0
  155. package/number-input/NumberInput.test.js +506 -0
  156. package/number-input/NumberInputContext.d.ts +4 -0
  157. package/{dist/number/NumberContext.js → number-input/NumberInputContext.js} +6 -3
  158. package/number-input/numberInputContextTypes.d.ts +19 -0
  159. package/number-input/numberInputContextTypes.js +5 -0
  160. package/number-input/types.d.ts +124 -0
  161. package/number-input/types.js +5 -0
  162. package/package.json +38 -27
  163. package/paginator/Icons.js +66 -0
  164. package/paginator/Paginator.d.ts +4 -0
  165. package/paginator/Paginator.js +171 -0
  166. package/paginator/Paginator.stories.tsx +63 -0
  167. package/paginator/Paginator.test.js +266 -0
  168. package/paginator/types.d.ts +38 -0
  169. package/paginator/types.js +5 -0
  170. package/password-input/PasswordInput.d.ts +4 -0
  171. package/{dist/password/Password.js → password-input/PasswordInput.js} +48 -82
  172. package/password-input/PasswordInput.stories.tsx +131 -0
  173. package/password-input/PasswordInput.test.js +180 -0
  174. package/password-input/types.d.ts +110 -0
  175. package/password-input/types.js +5 -0
  176. package/progress-bar/ProgressBar.d.ts +4 -0
  177. package/{dist/progress-bar → progress-bar}/ProgressBar.js +23 -95
  178. package/progress-bar/ProgressBar.stories.jsx +58 -0
  179. package/progress-bar/ProgressBar.test.js +65 -0
  180. package/progress-bar/types.d.ts +37 -0
  181. package/progress-bar/types.js +5 -0
  182. package/quick-nav/QuickNav.d.ts +4 -0
  183. package/quick-nav/QuickNav.js +112 -0
  184. package/quick-nav/QuickNav.stories.tsx +237 -0
  185. package/quick-nav/types.d.ts +21 -0
  186. package/quick-nav/types.js +5 -0
  187. package/radio-group/Radio.d.ts +4 -0
  188. package/radio-group/Radio.js +141 -0
  189. package/radio-group/RadioGroup.d.ts +4 -0
  190. package/radio-group/RadioGroup.js +282 -0
  191. package/radio-group/RadioGroup.stories.tsx +100 -0
  192. package/radio-group/RadioGroup.test.js +695 -0
  193. package/radio-group/types.d.ts +114 -0
  194. package/radio-group/types.js +5 -0
  195. package/resultsetTable/ResultsetTable.d.ts +4 -0
  196. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +43 -147
  197. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  198. package/resultsetTable/ResultsetTable.test.js +306 -0
  199. package/resultsetTable/types.d.ts +67 -0
  200. package/resultsetTable/types.js +5 -0
  201. package/row/Row.d.ts +3 -0
  202. package/row/Row.js +127 -0
  203. package/row/Row.stories.tsx +237 -0
  204. package/row/types.d.ts +28 -0
  205. package/row/types.js +5 -0
  206. package/select/Icons.d.ts +10 -0
  207. package/select/Icons.js +93 -0
  208. package/select/Listbox.d.ts +4 -0
  209. package/select/Listbox.js +152 -0
  210. package/select/Option.d.ts +4 -0
  211. package/select/Option.js +110 -0
  212. package/select/Select.d.ts +4 -0
  213. package/select/Select.js +645 -0
  214. package/select/Select.stories.tsx +594 -0
  215. package/select/Select.test.js +2120 -0
  216. package/select/types.d.ts +213 -0
  217. package/select/types.js +5 -0
  218. package/sidenav/Sidenav.d.ts +9 -0
  219. package/sidenav/Sidenav.js +147 -0
  220. package/sidenav/Sidenav.stories.tsx +182 -0
  221. package/sidenav/Sidenav.test.js +56 -0
  222. package/sidenav/types.d.ts +50 -0
  223. package/sidenav/types.js +5 -0
  224. package/slider/Slider.d.ts +4 -0
  225. package/slider/Slider.js +318 -0
  226. package/slider/Slider.stories.tsx +177 -0
  227. package/slider/Slider.test.js +150 -0
  228. package/slider/types.d.ts +82 -0
  229. package/slider/types.js +5 -0
  230. package/spinner/Spinner.d.ts +4 -0
  231. package/spinner/Spinner.js +250 -0
  232. package/spinner/Spinner.stories.jsx +103 -0
  233. package/spinner/Spinner.test.js +64 -0
  234. package/spinner/types.d.ts +32 -0
  235. package/spinner/types.js +5 -0
  236. package/stack/Stack.d.ts +3 -0
  237. package/stack/Stack.js +97 -0
  238. package/stack/Stack.stories.tsx +164 -0
  239. package/stack/types.d.ts +24 -0
  240. package/stack/types.js +5 -0
  241. package/switch/Switch.d.ts +4 -0
  242. package/switch/Switch.js +195 -0
  243. package/switch/Switch.stories.tsx +160 -0
  244. package/switch/Switch.test.js +98 -0
  245. package/switch/types.d.ts +62 -0
  246. package/switch/types.js +5 -0
  247. package/table/Table.d.ts +4 -0
  248. package/{dist/table → table}/Table.js +12 -26
  249. package/table/Table.stories.jsx +277 -0
  250. package/table/Table.test.js +26 -0
  251. package/table/types.d.ts +21 -0
  252. package/table/types.js +5 -0
  253. package/tabs/Tabs.d.ts +4 -0
  254. package/tabs/Tabs.js +211 -0
  255. package/tabs/Tabs.stories.tsx +112 -0
  256. package/tabs/Tabs.test.js +140 -0
  257. package/tabs/types.d.ts +82 -0
  258. package/tabs/types.js +5 -0
  259. package/tabs-nav/NavTabs.d.ts +8 -0
  260. package/tabs-nav/NavTabs.js +125 -0
  261. package/tabs-nav/NavTabs.stories.tsx +170 -0
  262. package/tabs-nav/NavTabs.test.js +82 -0
  263. package/tabs-nav/Tab.d.ts +4 -0
  264. package/tabs-nav/Tab.js +132 -0
  265. package/tabs-nav/types.d.ts +53 -0
  266. package/tabs-nav/types.js +5 -0
  267. package/tag/Tag.d.ts +4 -0
  268. package/tag/Tag.js +183 -0
  269. package/tag/Tag.stories.tsx +142 -0
  270. package/tag/Tag.test.js +60 -0
  271. package/tag/types.d.ts +69 -0
  272. package/tag/types.js +5 -0
  273. package/text/Text.d.ts +7 -0
  274. package/text/Text.js +30 -0
  275. package/text/Text.stories.tsx +19 -0
  276. package/text-input/Suggestion.d.ts +4 -0
  277. package/text-input/Suggestion.js +55 -0
  278. package/text-input/TextInput.d.ts +4 -0
  279. package/text-input/TextInput.js +770 -0
  280. package/text-input/TextInput.stories.tsx +474 -0
  281. package/text-input/TextInput.test.js +1712 -0
  282. package/text-input/types.d.ts +178 -0
  283. package/text-input/types.js +5 -0
  284. package/textarea/Textarea.d.ts +4 -0
  285. package/{dist/new-textarea/NewTextarea.js → textarea/Textarea.js} +88 -157
  286. package/textarea/Textarea.stories.jsx +157 -0
  287. package/textarea/Textarea.test.js +437 -0
  288. package/textarea/types.d.ts +137 -0
  289. package/textarea/types.js +5 -0
  290. package/toggle-group/ToggleGroup.d.ts +4 -0
  291. package/toggle-group/ToggleGroup.js +215 -0
  292. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  293. package/toggle-group/ToggleGroup.test.js +156 -0
  294. package/toggle-group/types.d.ts +105 -0
  295. package/toggle-group/types.js +5 -0
  296. package/useTheme.d.ts +2 -0
  297. package/{dist/useTheme.js → useTheme.js} +2 -2
  298. package/useTranslatedLabels.d.ts +2 -0
  299. package/useTranslatedLabels.js +20 -0
  300. package/wizard/Wizard.d.ts +4 -0
  301. package/wizard/Wizard.js +292 -0
  302. package/wizard/Wizard.stories.tsx +214 -0
  303. package/wizard/Wizard.test.js +141 -0
  304. package/wizard/types.d.ts +64 -0
  305. package/wizard/types.js +5 -0
  306. package/README.md +0 -66
  307. package/babel.config.js +0 -8
  308. package/dist/BackgroundColorContext.js +0 -46
  309. package/dist/ThemeContext.js +0 -240
  310. package/dist/accordion/Accordion.js +0 -353
  311. package/dist/accordion-group/AccordionGroup.js +0 -186
  312. package/dist/badge/Badge.js +0 -63
  313. package/dist/box/Box.js +0 -156
  314. package/dist/card/Card.js +0 -254
  315. package/dist/checkbox/Checkbox.stories.js +0 -144
  316. package/dist/checkbox/readme.md +0 -116
  317. package/dist/chip/Chip.js +0 -265
  318. package/dist/date/Date.js +0 -381
  319. package/dist/date/Date.stories.js +0 -205
  320. package/dist/date/readme.md +0 -73
  321. package/dist/dialog/Dialog.js +0 -218
  322. package/dist/footer/Footer.js +0 -395
  323. package/dist/footer/Footer.stories.js +0 -94
  324. package/dist/footer/dxc_logo.svg +0 -15
  325. package/dist/footer/readme.md +0 -41
  326. package/dist/header/Header.js +0 -403
  327. package/dist/header/Header.stories.js +0 -176
  328. package/dist/header/close_icon.svg +0 -1
  329. package/dist/header/dxc_logo_black.svg +0 -8
  330. package/dist/header/hamb_menu_black.svg +0 -1
  331. package/dist/header/hamb_menu_white.svg +0 -1
  332. package/dist/header/readme.md +0 -33
  333. package/dist/input-text/InputText.js +0 -707
  334. package/dist/input-text/InputText.stories.js +0 -209
  335. package/dist/input-text/error.svg +0 -1
  336. package/dist/input-text/readme.md +0 -91
  337. package/dist/layout/ApplicationLayout.js +0 -331
  338. package/dist/layout/facebook.svg +0 -45
  339. package/dist/layout/linkedin.svg +0 -50
  340. package/dist/layout/twitter.svg +0 -53
  341. package/dist/link/Link.js +0 -241
  342. package/dist/link/readme.md +0 -51
  343. package/dist/new-date/NewDate.js +0 -403
  344. package/dist/new-input-text/NewInputText.js +0 -961
  345. package/dist/number/Number.js +0 -138
  346. package/dist/paginator/Paginator.js +0 -289
  347. package/dist/paginator/images/next.svg +0 -3
  348. package/dist/paginator/images/nextPage.svg +0 -3
  349. package/dist/paginator/images/previous.svg +0 -3
  350. package/dist/paginator/images/previousPage.svg +0 -3
  351. package/dist/paginator/readme.md +0 -50
  352. package/dist/password/styles.css +0 -3
  353. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  354. package/dist/progress-bar/readme.md +0 -63
  355. package/dist/radio/Radio.js +0 -209
  356. package/dist/radio/Radio.stories.js +0 -166
  357. package/dist/radio/readme.md +0 -70
  358. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  359. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  360. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  361. package/dist/select/Select.js +0 -585
  362. package/dist/select/Select.stories.js +0 -235
  363. package/dist/select/readme.md +0 -72
  364. package/dist/sidenav/Sidenav.js +0 -177
  365. package/dist/slider/Slider.js +0 -319
  366. package/dist/slider/Slider.stories.js +0 -241
  367. package/dist/slider/readme.md +0 -64
  368. package/dist/spinner/Spinner.js +0 -381
  369. package/dist/spinner/Spinner.stories.js +0 -183
  370. package/dist/spinner/readme.md +0 -65
  371. package/dist/switch/Switch.js +0 -222
  372. package/dist/switch/Switch.stories.js +0 -134
  373. package/dist/switch/readme.md +0 -133
  374. package/dist/tabs/Tabs.js +0 -343
  375. package/dist/tabs/Tabs.stories.js +0 -130
  376. package/dist/tabs/readme.md +0 -78
  377. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  378. package/dist/tabs-for-sections/readme.md +0 -78
  379. package/dist/tag/Tag.js +0 -288
  380. package/dist/textarea/Textarea.js +0 -264
  381. package/dist/toggle/Toggle.js +0 -220
  382. package/dist/toggle/Toggle.stories.js +0 -297
  383. package/dist/toggle/readme.md +0 -80
  384. package/dist/toggle-group/ToggleGroup.js +0 -223
  385. package/dist/upload/Upload.js +0 -205
  386. package/dist/upload/Upload.stories.js +0 -72
  387. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -139
  388. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  389. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  390. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  391. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  392. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  393. package/dist/upload/file-upload/FileToUpload.js +0 -184
  394. package/dist/upload/file-upload/audio-icon.svg +0 -4
  395. package/dist/upload/file-upload/close.svg +0 -4
  396. package/dist/upload/file-upload/file-icon.svg +0 -4
  397. package/dist/upload/file-upload/video-icon.svg +0 -4
  398. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  399. package/dist/upload/readme.md +0 -37
  400. package/dist/upload/transaction/Transaction.js +0 -175
  401. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  402. package/dist/upload/transaction/audio-icon.svg +0 -4
  403. package/dist/upload/transaction/error-icon.svg +0 -4
  404. package/dist/upload/transaction/file-icon-err.svg +0 -4
  405. package/dist/upload/transaction/file-icon.svg +0 -4
  406. package/dist/upload/transaction/image-icon-err.svg +0 -4
  407. package/dist/upload/transaction/image-icon.svg +0 -4
  408. package/dist/upload/transaction/success-icon.svg +0 -4
  409. package/dist/upload/transaction/video-icon-err.svg +0 -4
  410. package/dist/upload/transaction/video-icon.svg +0 -4
  411. package/dist/upload/transactions/Transactions.js +0 -138
  412. package/dist/wizard/Wizard.js +0 -411
  413. package/dist/wizard/invalid_icon.svg +0 -5
  414. package/dist/wizard/valid_icon.svg +0 -5
  415. package/dist/wizard/validation-wrong.svg +0 -6
  416. package/test/Accordion.test.js +0 -33
  417. package/test/AccordionGroup.test.js +0 -125
  418. package/test/Alert.test.js +0 -53
  419. package/test/Box.test.js +0 -10
  420. package/test/Button.test.js +0 -18
  421. package/test/Card.test.js +0 -30
  422. package/test/Checkbox.test.js +0 -45
  423. package/test/Chip.test.js +0 -25
  424. package/test/Date.test.js +0 -393
  425. package/test/Dialog.test.js +0 -23
  426. package/test/Dropdown.test.js +0 -145
  427. package/test/Footer.test.js +0 -99
  428. package/test/Header.test.js +0 -39
  429. package/test/Heading.test.js +0 -35
  430. package/test/InputText.test.js +0 -240
  431. package/test/Link.test.js +0 -43
  432. package/test/NewDate.test.js +0 -203
  433. package/test/NewInputText.test.js +0 -817
  434. package/test/NewTextarea.test.js +0 -201
  435. package/test/Number.test.js +0 -241
  436. package/test/Paginator.test.js +0 -177
  437. package/test/Password.test.js +0 -76
  438. package/test/ProgressBar.test.js +0 -35
  439. package/test/Radio.test.js +0 -37
  440. package/test/ResultsetTable.test.js +0 -330
  441. package/test/Select.test.js +0 -189
  442. package/test/Sidenav.test.js +0 -45
  443. package/test/Slider.test.js +0 -82
  444. package/test/Spinner.test.js +0 -32
  445. package/test/Switch.test.js +0 -45
  446. package/test/Table.test.js +0 -36
  447. package/test/Tabs.test.js +0 -109
  448. package/test/TabsForSections.test.js +0 -34
  449. package/test/Tag.test.js +0 -32
  450. package/test/TextArea.test.js +0 -52
  451. package/test/ToggleGroup.test.js +0 -81
  452. package/test/Upload.test.js +0 -60
  453. package/test/Wizard.test.js +0 -130
  454. package/test/mocks/pngMock.js +0 -1
  455. package/test/mocks/svgMock.js +0 -1
@@ -1,76 +0,0 @@
1
- import React from "react";
2
- import { render } from "@testing-library/react";
3
- import userEvent from "@testing-library/user-event";
4
- import DxcPassword from "../src/password/Password";
5
-
6
- describe("Password component tests", () => {
7
- test("Password renders with label", () => {
8
- const { getByText } = render(<DxcPassword label="Password label" />);
9
- expect(getByText("Password label")).toBeTruthy();
10
- });
11
-
12
- test("Password renders with helper text", () => {
13
- const { getByText } = render(<DxcPassword helperText="Helper text" />);
14
- expect(getByText("Helper text")).toBeTruthy();
15
- });
16
-
17
- test("Password renders error", () => {
18
- const { getByText } = render(<DxcPassword error="Error message." />);
19
- expect(getByText("Error message.")).toBeTruthy();
20
- });
21
-
22
- test("onChange function is called correctly", () => {
23
- const onChange = jest.fn();
24
- const { getByRole } = render(<DxcPassword label="Password" onChange={onChange} />);
25
- const password = getByRole("textbox");
26
- userEvent.type(password, "Pa$$w0rd");
27
- expect(onChange).toHaveBeenCalledWith("P");
28
- expect(password.value).toBe("Pa$$w0rd");
29
- });
30
-
31
- test("Clear password value", () => {
32
- const onChange = jest.fn();
33
- const { getAllByRole, getByRole } = render(<DxcPassword label="Password" onChange={onChange} clearable />);
34
- const password = getByRole("textbox");
35
- userEvent.type(password, "Pa$$w0rd");
36
- expect(password.value).toBe("Pa$$w0rd");
37
- const clearButton = getAllByRole("button")[0];
38
- userEvent.click(clearButton);
39
- expect(password.value).toBe("");
40
- });
41
-
42
- test("Non clearable password has no clear icon", () => {
43
- const onChange = jest.fn();
44
- const { getAllByRole, getByRole } = render(<DxcPassword label="Password" onChange={onChange} />);
45
- const password = getByRole("textbox");
46
- userEvent.type(password, "Pa$$w0rd");
47
- expect(password.value).toBe("Pa$$w0rd");
48
- const buttons = getAllByRole("button");
49
- expect(buttons.length).toBe(1);
50
- });
51
-
52
- test("Show/hide password button works correctly", () => {
53
- const onChange = jest.fn();
54
- const { getAllByRole, getByRole } = render(<DxcPassword label="Password" clearable onChange={onChange} />);
55
- const password = getByRole("textbox");
56
- userEvent.type(password, "Pa$$w0rd");
57
- expect(password.value).toBe("Pa$$w0rd");
58
- expect(password.type).toBe("password");
59
- const showButton = getAllByRole("button")[1];
60
- userEvent.click(showButton);
61
- expect(password.type).toBe("text");
62
- });
63
-
64
- test("Password has correct accesibility attributes", () => {
65
- const { getByRole } = render(<DxcPassword label="Password" />);
66
- const password = getByRole("textbox");
67
- expect(password.getAttribute("aria-autocomplete")).toBeNull();
68
- expect(password.getAttribute("aria-controls")).toBeNull();
69
- const showButton = getByRole("button");
70
- expect(showButton.getAttribute("aria-expanded")).toBe("false");
71
- expect(showButton.getAttribute("aria-label")).toBe("Show");
72
- userEvent.click(showButton);
73
- expect(showButton.getAttribute("aria-expanded")).toBe("true");
74
- expect(showButton.getAttribute("aria-label")).toBe("Hide");
75
- });
76
- });
@@ -1,35 +0,0 @@
1
- import React from "react";
2
- import { render } from "@testing-library/react";
3
- import DxcProgressBar from "../src/progress-bar/ProgressBar";
4
-
5
- describe("ProgressBar component tests", () => {
6
- test("ProgressBar renders with label", () => {
7
- const { getByText } = render(<DxcProgressBar label="test-label"></DxcProgressBar>);
8
- expect(getByText("test-label")).toBeTruthy();
9
- });
10
-
11
- test("Overlay progressBar renders with label", () => {
12
- const { getByText } = render(<DxcProgressBar label="test-label" overlay></DxcProgressBar>);
13
- expect(getByText("test-label")).toBeTruthy();
14
- });
15
-
16
- test("ProgressBar renders with default value", () => {
17
- const { getByText } = render(<DxcProgressBar showValue></DxcProgressBar>);
18
- expect(getByText("100 %")).toBeTruthy();
19
- });
20
-
21
- test("Overlay progressBar renders with default value", () => {
22
- const { getByText } = render(<DxcProgressBar showValue overlay></DxcProgressBar>);
23
- expect(getByText("100 %")).toBeTruthy();
24
- });
25
-
26
- test("ProgressBar renders with value", () => {
27
- const { getByText } = render(<DxcProgressBar showValue value={25}></DxcProgressBar>);
28
- expect(getByText("25 %")).toBeTruthy();
29
- });
30
-
31
- test("Overlay progressBar renders with value", () => {
32
- const { getByText } = render(<DxcProgressBar showValue value={25} overlay></DxcProgressBar>);
33
- expect(getByText("25 %")).toBeTruthy();
34
- });
35
- });
@@ -1,37 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcRadio from "../src/radio/Radio";
4
-
5
- describe("Radio component tests", () => {
6
- test("Radio renders correctly", () => {
7
- const { getByText } = render(<DxcRadio label="Radio button" />);
8
- expect(getByText("Radio button")).toBeTruthy();
9
- });
10
- test("Calls correct function on click", () => {
11
- const onClick = jest.fn();
12
- const { getByText} = render(<DxcRadio label="Radio button" onClick={onClick} />);
13
- fireEvent.click(getByText("Radio button"));
14
-
15
- expect(onClick).toHaveBeenCalled();
16
- expect(onClick).toHaveBeenCalledWith(true);
17
- });
18
- test("Controlled Radio", () => {
19
- const onClick = jest.fn();
20
- const { getByText, getByRole } = render(<DxcRadio label="Radio button" checked={false} onClick={onClick} />);
21
- expect(getByRole("radio").checked).toBe(false);
22
- fireEvent.click(getByText("Radio button"));
23
- expect(onClick).toHaveBeenCalled();
24
- expect(onClick).toHaveBeenCalledWith(true);
25
- expect(getByRole("radio").checked).toBe(false);
26
- });
27
- test("Uncontrolled Radio", () => {
28
- const onClick = jest.fn();
29
- const { getByText, getByRole } = render(<DxcRadio label="Radio button" onClick={onClick} />);
30
- expect(getByRole("radio").checked).toBe(false);
31
- fireEvent.click(getByText("Radio button"));
32
- expect(onClick).toHaveBeenCalled();
33
- expect(onClick).toHaveBeenCalledWith(true);
34
- expect(getByRole("radio").checked).toBe(false);
35
- });
36
-
37
- });
@@ -1,330 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent, act } from "@testing-library/react";
3
- import userEvent from "@testing-library/user-event";
4
-
5
- import DxcResultsetTable from "../src/resultsetTable/ResultsetTable";
6
-
7
- const columns = [
8
- {
9
- displayValue: "Id",
10
- isSortable: false,
11
- },
12
- {
13
- displayValue: "Name",
14
- isSortable: true,
15
- },
16
- {
17
- displayValue: "City",
18
- isSortable: false,
19
- },
20
- ];
21
-
22
- const rows = [
23
- [
24
- {
25
- displayValue: "001",
26
- sortValue: "001",
27
- },
28
- {
29
- displayValue: "Peter",
30
- sortValue: "Peter",
31
- },
32
- {
33
- displayValue: "Oviedo",
34
- sortValue: "Oviedo",
35
- },
36
- ],
37
- [
38
- {
39
- displayValue: "002",
40
- sortValue: "002",
41
- },
42
- {
43
- displayValue: "Louis",
44
- sortValue: "Louis",
45
- },
46
- {
47
- displayValue: "Oviedo",
48
- sortValue: "Oviedo",
49
- },
50
- {
51
- displayValue: "",
52
- },
53
- ],
54
- [
55
- {
56
- displayValue: "003",
57
- sortValue: "003",
58
- },
59
- {
60
- displayValue: "Lana",
61
- sortValue: "Lana",
62
- },
63
- {
64
- displayValue: "Albacete",
65
- sortValue: "Albacete",
66
- },
67
- ],
68
- [
69
- {
70
- displayValue: "004",
71
- sortValue: "004",
72
- },
73
- {
74
- displayValue: "Rick",
75
- sortValue: "Rick",
76
- },
77
- {
78
- displayValue: "Albacete",
79
- sortValue: "Albacete",
80
- },
81
- ],
82
- [
83
- {
84
- displayValue: "005",
85
- sortValue: "005",
86
- },
87
- {
88
- displayValue: "Mark",
89
- sortValue: "Mark",
90
- },
91
- {
92
- displayValue: "Madrid",
93
- sortValue: "Madrid",
94
- },
95
- ],
96
- [
97
- {
98
- displayValue: "006",
99
- sortValue: "006",
100
- },
101
- {
102
- displayValue: "Cris",
103
- sortValue: "Cris",
104
- },
105
- {
106
- displayValue: "Barcelona",
107
- sortValue: "Barcelona",
108
- },
109
- {
110
- displayValue: "",
111
- },
112
- ],
113
- [
114
- {
115
- displayValue: "007",
116
- sortValue: "007",
117
- },
118
- {
119
- displayValue: "Susan",
120
- sortValue: "Susan",
121
- },
122
- {
123
- displayValue: "Madrid",
124
- sortValue: "Madrid",
125
- },
126
- ],
127
- [
128
- {
129
- displayValue: "008",
130
- sortValue: "008",
131
- },
132
- {
133
- displayValue: "Tina",
134
- sortValue: "Tina",
135
- },
136
- {
137
- displayValue: "Barcelona",
138
- sortValue: "Barcelona",
139
- },
140
- ],
141
- [
142
- {
143
- displayValue: "009",
144
- sortValue: "009",
145
- },
146
- {
147
- displayValue: "Kevin",
148
- sortValue: "Kevin",
149
- },
150
- {
151
- displayValue: "Oviedo",
152
- sortValue: "Oviedo",
153
- },
154
- {
155
- displayValue: "",
156
- },
157
- ],
158
- [
159
- {
160
- displayValue: "010",
161
- sortValue: "010",
162
- },
163
- {
164
- displayValue: "Cosmin",
165
- sortValue: "Cosmin",
166
- },
167
- {
168
- displayValue: "Barcelona",
169
- sortValue: "Barcelona",
170
- },
171
- {
172
- displayValue: "",
173
- },
174
- ],
175
- ];
176
-
177
- const rows2 = [
178
- [
179
- {
180
- displayValue: "546",
181
- sortValue: "465",
182
- },
183
- {
184
- displayValue: "OtherValue",
185
- sortValue: "OtherValue",
186
- },
187
- {
188
- displayValue: "OtherValue",
189
- sortValue: "OtherValue",
190
- },
191
- ],
192
- [
193
- {
194
- displayValue: "978",
195
- sortValue: "465",
196
- },
197
- {
198
- displayValue: "OtherValue",
199
- sortValue: "OtherValue",
200
- },
201
- {
202
- displayValue: "OtherValue",
203
- sortValue: "OtherValue",
204
- },
205
- {
206
- displayValue: "",
207
- },
208
- ],
209
- [
210
- {
211
- displayValue: "678",
212
- sortValue: "344",
213
- },
214
- {
215
- displayValue: "OtherValue",
216
- sortValue: "OtherValue",
217
- },
218
- {
219
- displayValue: "OtherValue",
220
- sortValue: "OtherValue",
221
- },
222
- ],
223
- ];
224
-
225
- describe("ResultsetTable component tests", () => {
226
- test("ResultsetTable rendered correctly", () => {
227
- const { getByText } = render(
228
- <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={3}></DxcResultsetTable>
229
- );
230
- expect(getByText("Peter")).toBeTruthy();
231
- });
232
- test("Resultsettable shows as many rows as itemsPerPage", () => {
233
- const { getAllByRole } = render(
234
- <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={3}></DxcResultsetTable>
235
- );
236
- expect(getAllByRole("row").length - 1).toEqual(3);
237
- });
238
-
239
- test("Resultsettable shows rows on second page", () => {
240
- const { getByText, getAllByRole } = render(
241
- <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={3}></DxcResultsetTable>
242
- );
243
- expect(getByText("Peter")).toBeTruthy();
244
- expect(getByText("Louis")).toBeTruthy();
245
- expect(getByText("Lana")).toBeTruthy();
246
- expect(getAllByRole("row").length - 1).toEqual(3);
247
- const nextButton = getAllByRole("button")[3];
248
- fireEvent.click(nextButton);
249
- expect(getByText("4 to 6 of 10")).toBeTruthy();
250
- // expect(getByText("Page: 2 of 4")).toBeTruthy();
251
- expect(getByText("Rick")).toBeTruthy();
252
- expect(getByText("Mark")).toBeTruthy();
253
- expect(getByText("Cris")).toBeTruthy();
254
- expect(getAllByRole("row").length - 1).toEqual(3);
255
- });
256
-
257
- test("Resultsettable goToPage works as expected", () => {
258
- const { getByText, getAllByRole, getByRole } = render(
259
- <DxcResultsetTable columns={columns} showGoToPage={true} rows={rows} itemsPerPage={3}></DxcResultsetTable>
260
- );
261
- expect(getByText("Peter")).toBeTruthy();
262
- expect(getByText("Louis")).toBeTruthy();
263
- expect(getByText("Lana")).toBeTruthy();
264
- expect(getAllByRole("row").length - 1).toEqual(3);
265
- const goToPageSelect = getAllByRole("button")[2];
266
- act(() => {
267
- userEvent.click(goToPageSelect);
268
- });
269
- const goToPageOption = getByRole("option", { name: /2/i });
270
- act(() => {
271
- userEvent.click(goToPageOption);
272
- });
273
-
274
- expect(getByText("4 to 6 of 10")).toBeTruthy();
275
- // expect(getByText("Page: 2 of 4")).toBeTruthy();
276
- expect(getByText("Rick")).toBeTruthy();
277
- expect(getByText("Mark")).toBeTruthy();
278
- expect(getByText("Cris")).toBeTruthy();
279
- expect(getAllByRole("row").length - 1).toEqual(3);
280
- });
281
-
282
- test("Resultsettable going to the last page shows only one row", () => {
283
- const { getByText, getAllByRole } = render(
284
- <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={3}></DxcResultsetTable>
285
- );
286
- debugger;
287
- const lastButton = getAllByRole("button")[4];
288
- fireEvent.click(lastButton);
289
- expect(getByText("10 to 10 of 10")).toBeTruthy();
290
- expect(getAllByRole("row")).toHaveLength(2);
291
- expect(getByText("Cosmin")).toBeTruthy();
292
- });
293
-
294
- test("Resultsettable sort rows by column", () => {
295
- const component = render(<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={3}></DxcResultsetTable>);
296
- expect(component.queryByText("Peter")).toBeTruthy();
297
- fireEvent.click(component.queryByText("Name"));
298
- expect(component.queryByText("Tina")).not.toBeTruthy();
299
- expect(component.queryByText("Cosmin")).toBeTruthy();
300
-
301
- fireEvent.click(component.queryByText("Name"));
302
- expect(component.queryByText("Tina")).toBeTruthy();
303
- expect(component.queryByText("Cosmin")).not.toBeTruthy();
304
- });
305
- test("Resultsettable change rows should go to first page", () => {
306
- const { queryByText, rerender } = render(
307
- <DxcResultsetTable columns={columns} rows={rows} itemsPerPage={3}></DxcResultsetTable>
308
- );
309
- expect(queryByText("Peter")).toBeTruthy();
310
- rerender(<DxcResultsetTable columns={columns} rows={rows2} itemsPerPage={3}></DxcResultsetTable>);
311
- expect(queryByText("1 to 3 of 3")).toBeTruthy();
312
- });
313
-
314
- test("Resultsettable change itemsPerPage should go to first page", () => {
315
- const { getAllByRole, queryByText, rerender } = render(
316
- <DxcResultsetTable
317
- columns={columns}
318
- rows={rows}
319
- itemsPerPage={3}
320
- itemsPerPageOptions={[2, 3]}
321
- ></DxcResultsetTable>
322
- );
323
- const lastButton = getAllByRole("button")[5];
324
- fireEvent.click(lastButton);
325
- expect(getAllByRole("row").length - 1).toEqual(1);
326
- rerender(<DxcResultsetTable columns={columns} rows={rows} itemsPerPage={6}></DxcResultsetTable>);
327
- expect(getAllByRole("row").length - 1).toEqual(6);
328
- expect(queryByText("Peter")).toBeTruthy();
329
- });
330
- });
@@ -1,189 +0,0 @@
1
- import React from "react";
2
- import { render, act } from "@testing-library/react";
3
- import userEvent from "@testing-library/user-event";
4
- import DxcSelect from "../src/select/Select";
5
-
6
- const optionsWithoutIcon = [
7
- {
8
- value: 1,
9
- label: "Amazon",
10
- },
11
- {
12
- value: 2,
13
- label: "Ebay",
14
- },
15
- {
16
- value: 3,
17
- label: "Apple",
18
- },
19
- ];
20
-
21
- const optionsWithIcons = [
22
- {
23
- value: 1,
24
- label: "Facebook",
25
- iconSrc: "/testIconFacebook",
26
- },
27
- {
28
- value: 2,
29
- label: "Twitter",
30
- iconSrc: "/testIconTwitter",
31
- },
32
- {
33
- value: 3,
34
- label: "Linkedin",
35
- iconSrc: "/testIconLinkedin",
36
- },
37
- ];
38
-
39
- describe("Select component tests", () => {
40
- test("Select renders with correct label", () => {
41
- const { getByText } = render(<DxcSelect label="test-select-label"></DxcSelect>);
42
- expect(getByText("test-select-label")).toBeTruthy();
43
- });
44
-
45
- test("Select renders options when select is clicked", () => {
46
- const { getByText, getByRole, queryByText } = render(
47
- <DxcSelect label="test-select-name" options={optionsWithoutIcon}></DxcSelect>
48
- );
49
- //Before are not shown
50
- expect(queryByText("Amazon")).toBeFalsy();
51
- expect(queryByText("Ebay")).toBeFalsy();
52
- expect(queryByText("Apple")).toBeFalsy();
53
- const select = getByRole("button");
54
- act(() => {
55
- userEvent.click(select);
56
- });
57
- expect(getByText("Amazon")).toBeTruthy();
58
- expect(getByText("Ebay")).toBeTruthy();
59
- expect(getByText("Apple")).toBeTruthy();
60
- });
61
-
62
- test("Select renders options with icons before", () => {
63
- const { getByRole, getAllByRole } = render(
64
- <DxcSelect label="test-select-name" options={optionsWithIcons}></DxcSelect>
65
- );
66
- const select = getByRole("button");
67
- act(() => {
68
- userEvent.click(select);
69
- });
70
- expect(getAllByRole("img")[0].getAttribute("src")).toEqual("/testIconFacebook");
71
- expect(getAllByRole("img")[1].getAttribute("src")).toEqual("/testIconTwitter");
72
- expect(getAllByRole("img")[2].getAttribute("src")).toEqual("/testIconLinkedin");
73
- });
74
-
75
- test("Select renders options with icons after", () => {
76
- const { getByRole, getAllByRole } = render(
77
- <DxcSelect label="test-select-name" options={optionsWithIcons} iconPosition="after"></DxcSelect>
78
- );
79
- const select = getByRole("button");
80
- act(() => {
81
- userEvent.click(select);
82
- });
83
- expect(getAllByRole("img")[0].getAttribute("src")).toEqual("/testIconFacebook");
84
- expect(getAllByRole("img")[1].getAttribute("src")).toEqual("/testIconTwitter");
85
- expect(getAllByRole("img")[2].getAttribute("src")).toEqual("/testIconLinkedin");
86
- });
87
-
88
- test("Select renders with a default value", () => {
89
- const { getByText } = render(
90
- <DxcSelect label="test-select-name" options={optionsWithoutIcon} value={1}></DxcSelect>
91
- );
92
- expect(getByText("Amazon")).toBeTruthy();
93
- });
94
-
95
- test("Select renders with multiple default values", () => {
96
- const { getByText } = render(
97
- <DxcSelect label="test-select-name" options={optionsWithoutIcon} value={[1, 2]} multiple></DxcSelect>
98
- );
99
- expect(getByText("Amazon, Ebay")).toBeTruthy();
100
- });
101
-
102
- test("Disabled select is not clickable", () => {
103
- const { getByText, queryByText } = render(
104
- <DxcSelect label="test-select-name" options={optionsWithoutIcon} disabled></DxcSelect>
105
- );
106
- expect(queryByText("Amazon")).toBeFalsy();
107
- expect(queryByText("Ebay")).toBeFalsy();
108
- expect(queryByText("Apple")).toBeFalsy();
109
- const select = getByText("test-select-name");
110
- act(() => {
111
- userEvent.click(select);
112
- });
113
- expect(queryByText("Amazon")).toBeFalsy();
114
- expect(queryByText("Ebay")).toBeFalsy();
115
- expect(queryByText("Apple")).toBeFalsy();
116
- });
117
-
118
- test("Controlled select with unique value", () => {
119
- const onChange = jest.fn();
120
- const { getByText, getAllByText } = render(
121
- <DxcSelect label="test-select-name" options={optionsWithoutIcon} value={1} onChange={onChange}></DxcSelect>
122
- );
123
- const select = getByText("Amazon");
124
- act(() => {
125
- userEvent.click(select);
126
- });
127
- const option2 = getByText("Ebay");
128
- act(() => {
129
- userEvent.click(option2);
130
- });
131
- expect(onChange).toHaveBeenCalledWith(2);
132
- //The value is not changed
133
- expect(getAllByText("Amazon").length).toBe(2);
134
- });
135
-
136
- test("Controlled select with multiple values", () => {
137
- const onChange = jest.fn();
138
- const { getByText } = render(
139
- <DxcSelect
140
- label="test-select-name"
141
- options={optionsWithoutIcon}
142
- value={[1, 2]}
143
- multiple
144
- onChange={onChange}
145
- ></DxcSelect>
146
- );
147
- const select = getByText("Amazon, Ebay");
148
- act(() => {
149
- userEvent.click(select);
150
- });
151
- const option3 = getByText("Apple");
152
- act(() => {
153
- userEvent.click(option3);
154
- });
155
- expect(onChange).toHaveBeenCalledWith([1, 2, 3]);
156
- //The value is not changed
157
- expect(getByText("Amazon, Ebay")).toBeTruthy();
158
- });
159
-
160
- test("Uncontrolled select with multiple values", () => {
161
- const onChange = jest.fn();
162
- const { getByText, getByRole } = render(
163
- <DxcSelect label="test-select-name" options={optionsWithoutIcon} multiple onChange={onChange}></DxcSelect>
164
- );
165
- const select = getByRole("button");
166
- act(() => {
167
- userEvent.click(select);
168
- });
169
- act(() => {
170
- userEvent.click(getByText("Amazon"));
171
- });
172
- expect(onChange).toHaveBeenCalledWith([1]);
173
- act(() => {
174
- userEvent.click(getByText("Ebay"));
175
- });
176
- expect(onChange).toHaveBeenCalledWith([1, 2]);
177
- expect(getByText("Amazon, Ebay")).toBeTruthy();
178
- act(() => {
179
- userEvent.click(getByText("Apple"));
180
- });
181
- expect(onChange).toHaveBeenCalledWith([1, 2, 3]);
182
- expect(getByText("Amazon, Ebay, Apple")).toBeTruthy();
183
- act(() => {
184
- userEvent.click(getByText("Amazon"));
185
- });
186
- expect(onChange).toHaveBeenCalledWith([2, 3]);
187
- expect(getByText("Ebay, Apple")).toBeTruthy();
188
- });
189
- });