@dxc-technology/halstack-react 0.0.0-e792e0c → 0.0.0-e8505b7

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 (460) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +47 -0
  3. package/ThemeContext.d.ts +10 -0
  4. package/ThemeContext.js +243 -0
  5. package/accordion/Accordion.d.ts +4 -0
  6. package/accordion/Accordion.js +248 -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 +170 -0
  13. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  14. package/accordion-group/AccordionGroup.test.js +133 -0
  15. package/accordion-group/types.d.ts +68 -0
  16. package/accordion-group/types.js +5 -0
  17. package/alert/Alert.d.ts +4 -0
  18. package/alert/Alert.js +290 -0
  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 +59 -0
  25. package/badge/types.d.ts +4 -0
  26. package/badge/types.js +5 -0
  27. package/bleed/Bleed.d.ts +3 -0
  28. package/bleed/Bleed.js +84 -0
  29. package/bleed/Bleed.stories.tsx +342 -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 +126 -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/button/Button.js +171 -0
  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 +164 -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/checkbox/Checkbox.js +247 -0
  53. package/checkbox/Checkbox.stories.tsx +192 -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 +5 -19
  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/common/utils.js +22 -0
  76. package/common/variables.js +1373 -0
  77. package/date-input/DateInput.d.ts +4 -0
  78. package/date-input/DateInput.js +354 -0
  79. package/date-input/DateInput.stories.tsx +138 -0
  80. package/date-input/DateInput.test.js +492 -0
  81. package/date-input/types.d.ts +104 -0
  82. package/date-input/types.js +5 -0
  83. package/dialog/Dialog.d.ts +4 -0
  84. package/dialog/Dialog.js +166 -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/dropdown/Dropdown.js +395 -0
  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 +590 -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 +184 -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 +258 -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 +324 -0
  113. package/header/Header.stories.tsx +162 -0
  114. package/header/Header.test.js +63 -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/heading/Heading.js +159 -0
  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 +13 -0
  129. package/inset/types.js +5 -0
  130. package/layout/ApplicationLayout.d.ts +10 -0
  131. package/layout/ApplicationLayout.js +231 -0
  132. package/layout/ApplicationLayout.stories.tsx +171 -0
  133. package/layout/Icons.js +55 -0
  134. package/layout/types.d.ts +57 -0
  135. package/layout/types.js +5 -0
  136. package/link/Link.d.ts +3 -0
  137. package/link/Link.js +153 -0
  138. package/link/Link.stories.tsx +151 -0
  139. package/link/Link.test.js +91 -0
  140. package/link/types.d.ts +70 -0
  141. package/link/types.js +5 -0
  142. package/list/List.d.ts +4 -0
  143. package/list/List.js +47 -0
  144. package/list/List.stories.tsx +95 -0
  145. package/list/types.d.ts +7 -0
  146. package/list/types.js +5 -0
  147. package/main.d.ts +47 -0
  148. package/{dist/main.js → main.js} +177 -53
  149. package/number-input/NumberInput.d.ts +4 -0
  150. package/number-input/NumberInput.js +76 -0
  151. package/number-input/NumberInput.stories.tsx +115 -0
  152. package/number-input/NumberInput.test.js +508 -0
  153. package/number-input/NumberInputContext.d.ts +4 -0
  154. package/{dist/ThemeContext.js → number-input/NumberInputContext.js} +6 -2
  155. package/number-input/numberInputContextTypes.d.ts +19 -0
  156. package/number-input/numberInputContextTypes.js +5 -0
  157. package/number-input/types.d.ts +121 -0
  158. package/number-input/types.js +5 -0
  159. package/package.json +42 -24
  160. package/paginator/Icons.js +66 -0
  161. package/paginator/Paginator.d.ts +4 -0
  162. package/paginator/Paginator.js +192 -0
  163. package/paginator/Paginator.stories.tsx +63 -0
  164. package/paginator/Paginator.test.js +266 -0
  165. package/paginator/types.d.ts +38 -0
  166. package/paginator/types.js +5 -0
  167. package/password-input/PasswordInput.d.ts +4 -0
  168. package/password-input/PasswordInput.js +163 -0
  169. package/password-input/PasswordInput.stories.tsx +131 -0
  170. package/password-input/PasswordInput.test.js +183 -0
  171. package/password-input/types.d.ts +107 -0
  172. package/password-input/types.js +5 -0
  173. package/progress-bar/ProgressBar.d.ts +4 -0
  174. package/progress-bar/ProgressBar.js +170 -0
  175. package/progress-bar/ProgressBar.stories.jsx +58 -0
  176. package/progress-bar/ProgressBar.test.js +65 -0
  177. package/progress-bar/types.d.ts +37 -0
  178. package/progress-bar/types.js +5 -0
  179. package/quick-nav/QuickNav.d.ts +4 -0
  180. package/quick-nav/QuickNav.js +66 -0
  181. package/quick-nav/QuickNav.stories.tsx +237 -0
  182. package/quick-nav/types.d.ts +21 -0
  183. package/quick-nav/types.js +5 -0
  184. package/radio/Radio.d.ts +4 -0
  185. package/radio/Radio.js +174 -0
  186. package/radio/Radio.stories.tsx +192 -0
  187. package/radio/Radio.test.js +71 -0
  188. package/radio/types.d.ts +54 -0
  189. package/radio/types.js +5 -0
  190. package/radio-group/Radio.d.ts +4 -0
  191. package/radio-group/Radio.js +141 -0
  192. package/radio-group/RadioGroup.d.ts +4 -0
  193. package/radio-group/RadioGroup.js +280 -0
  194. package/radio-group/RadioGroup.stories.tsx +100 -0
  195. package/radio-group/RadioGroup.test.js +695 -0
  196. package/radio-group/types.d.ts +114 -0
  197. package/radio-group/types.js +5 -0
  198. package/resultsetTable/ResultsetTable.d.ts +4 -0
  199. package/resultsetTable/ResultsetTable.js +254 -0
  200. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  201. package/resultsetTable/ResultsetTable.test.js +306 -0
  202. package/resultsetTable/types.d.ts +67 -0
  203. package/resultsetTable/types.js +5 -0
  204. package/row/Row.d.ts +3 -0
  205. package/row/Row.js +127 -0
  206. package/row/Row.stories.tsx +237 -0
  207. package/row/types.d.ts +28 -0
  208. package/row/types.js +5 -0
  209. package/select/Icons.d.ts +10 -0
  210. package/select/Icons.js +93 -0
  211. package/select/Option.d.ts +4 -0
  212. package/select/Option.js +110 -0
  213. package/select/Select.d.ts +4 -0
  214. package/select/Select.js +740 -0
  215. package/select/Select.stories.tsx +582 -0
  216. package/select/Select.test.js +2016 -0
  217. package/select/types.d.ts +191 -0
  218. package/select/types.js +5 -0
  219. package/sidenav/Sidenav.d.ts +9 -0
  220. package/sidenav/Sidenav.js +136 -0
  221. package/sidenav/Sidenav.stories.tsx +182 -0
  222. package/sidenav/Sidenav.test.js +56 -0
  223. package/sidenav/types.d.ts +50 -0
  224. package/sidenav/types.js +5 -0
  225. package/slider/Slider.d.ts +4 -0
  226. package/slider/Slider.js +317 -0
  227. package/slider/Slider.stories.tsx +177 -0
  228. package/slider/Slider.test.js +129 -0
  229. package/slider/types.d.ts +78 -0
  230. package/slider/types.js +5 -0
  231. package/spinner/Spinner.d.ts +4 -0
  232. package/spinner/Spinner.js +250 -0
  233. package/spinner/Spinner.stories.jsx +103 -0
  234. package/spinner/Spinner.test.js +64 -0
  235. package/spinner/types.d.ts +32 -0
  236. package/spinner/types.js +5 -0
  237. package/stack/Stack.d.ts +3 -0
  238. package/stack/Stack.js +97 -0
  239. package/stack/Stack.stories.tsx +164 -0
  240. package/stack/types.d.ts +24 -0
  241. package/stack/types.js +5 -0
  242. package/switch/Switch.d.ts +4 -0
  243. package/switch/Switch.js +192 -0
  244. package/switch/Switch.stories.tsx +160 -0
  245. package/switch/Switch.test.js +98 -0
  246. package/switch/types.d.ts +62 -0
  247. package/switch/types.js +5 -0
  248. package/table/Table.d.ts +4 -0
  249. package/table/Table.js +118 -0
  250. package/table/Table.stories.jsx +277 -0
  251. package/table/Table.test.js +26 -0
  252. package/table/types.d.ts +21 -0
  253. package/table/types.js +5 -0
  254. package/tabs/Tabs.d.ts +4 -0
  255. package/tabs/Tabs.js +213 -0
  256. package/tabs/Tabs.stories.tsx +120 -0
  257. package/tabs/Tabs.test.js +123 -0
  258. package/tabs/types.d.ts +78 -0
  259. package/tabs/types.js +5 -0
  260. package/tag/Tag.d.ts +4 -0
  261. package/tag/Tag.js +186 -0
  262. package/tag/Tag.stories.tsx +142 -0
  263. package/tag/Tag.test.js +60 -0
  264. package/tag/types.d.ts +69 -0
  265. package/tag/types.js +5 -0
  266. package/text/Text.d.ts +7 -0
  267. package/text/Text.js +30 -0
  268. package/text/Text.stories.tsx +19 -0
  269. package/text-input/TextInput.d.ts +4 -0
  270. package/text-input/TextInput.js +798 -0
  271. package/text-input/TextInput.stories.tsx +474 -0
  272. package/text-input/TextInput.test.js +1725 -0
  273. package/text-input/types.d.ts +163 -0
  274. package/text-input/types.js +5 -0
  275. package/textarea/Textarea.d.ts +4 -0
  276. package/textarea/Textarea.js +286 -0
  277. package/textarea/Textarea.stories.jsx +157 -0
  278. package/textarea/Textarea.test.js +437 -0
  279. package/textarea/types.d.ts +134 -0
  280. package/textarea/types.js +5 -0
  281. package/toggle-group/ToggleGroup.d.ts +4 -0
  282. package/toggle-group/ToggleGroup.js +214 -0
  283. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  284. package/toggle-group/ToggleGroup.test.js +125 -0
  285. package/toggle-group/types.d.ts +97 -0
  286. package/toggle-group/types.js +5 -0
  287. package/useTheme.d.ts +2 -0
  288. package/useTheme.js +22 -0
  289. package/wizard/Wizard.d.ts +4 -0
  290. package/wizard/Wizard.js +286 -0
  291. package/wizard/Wizard.stories.tsx +214 -0
  292. package/wizard/Wizard.test.js +141 -0
  293. package/wizard/types.d.ts +64 -0
  294. package/wizard/types.js +5 -0
  295. package/README.md +0 -66
  296. package/babel.config.js +0 -4
  297. package/dist/accordion/Accordion.js +0 -264
  298. package/dist/accordion/Accordion.stories.js +0 -207
  299. package/dist/accordion/readme.md +0 -96
  300. package/dist/alert/Alert.js +0 -302
  301. package/dist/alert/Alert.stories.js +0 -158
  302. package/dist/alert/close.svg +0 -4
  303. package/dist/alert/error.svg +0 -4
  304. package/dist/alert/info.svg +0 -4
  305. package/dist/alert/readme.md +0 -43
  306. package/dist/alert/success.svg +0 -4
  307. package/dist/alert/warning.svg +0 -4
  308. package/dist/box/Box.js +0 -148
  309. package/dist/button/Button.js +0 -183
  310. package/dist/button/Button.stories.js +0 -224
  311. package/dist/button/readme.md +0 -93
  312. package/dist/card/Card.js +0 -217
  313. package/dist/checkbox/Checkbox.js +0 -224
  314. package/dist/checkbox/Checkbox.stories.js +0 -144
  315. package/dist/checkbox/readme.md +0 -116
  316. package/dist/chip/Chip.js +0 -171
  317. package/dist/common/services/example-service.js +0 -10
  318. package/dist/common/services/example-service.test.js +0 -12
  319. package/dist/common/utils.js +0 -42
  320. package/dist/common/variables.js +0 -307
  321. package/dist/date/Date.js +0 -357
  322. package/dist/date/Date.stories.js +0 -205
  323. package/dist/date/calendar.svg +0 -1
  324. package/dist/date/calendar_dark.svg +0 -1
  325. package/dist/date/readme.md +0 -73
  326. package/dist/dialog/Dialog.js +0 -197
  327. package/dist/dialog/Dialog.stories.js +0 -217
  328. package/dist/dialog/readme.md +0 -32
  329. package/dist/dropdown/Dropdown.js +0 -412
  330. package/dist/dropdown/Dropdown.stories.js +0 -249
  331. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  332. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  333. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  334. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  335. package/dist/dropdown/readme.md +0 -69
  336. package/dist/footer/Footer.js +0 -346
  337. package/dist/footer/Footer.stories.js +0 -94
  338. package/dist/footer/dxc_logo_wht.png +0 -0
  339. package/dist/footer/readme.md +0 -41
  340. package/dist/header/Header.js +0 -354
  341. package/dist/header/Header.stories.js +0 -176
  342. package/dist/header/close_icon.svg +0 -1
  343. package/dist/header/dxc_logo_black.png +0 -0
  344. package/dist/header/dxc_logo_white.png +0 -0
  345. package/dist/header/hamb_menu_black.svg +0 -1
  346. package/dist/header/hamb_menu_white.svg +0 -1
  347. package/dist/header/readme.md +0 -33
  348. package/dist/heading/Heading.js +0 -159
  349. package/dist/input-text/InputText.js +0 -519
  350. package/dist/input-text/InputText.stories.js +0 -209
  351. package/dist/input-text/error.svg +0 -1
  352. package/dist/input-text/readme.md +0 -91
  353. package/dist/link/Link.js +0 -136
  354. package/dist/link/readme.md +0 -51
  355. package/dist/paginator/Paginator.js +0 -178
  356. package/dist/paginator/images/next.svg +0 -3
  357. package/dist/paginator/images/nextPage.svg +0 -3
  358. package/dist/paginator/images/previous.svg +0 -3
  359. package/dist/paginator/images/previousPage.svg +0 -3
  360. package/dist/paginator/readme.md +0 -50
  361. package/dist/progress-bar/ProgressBar.js +0 -189
  362. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  363. package/dist/progress-bar/readme.md +0 -63
  364. package/dist/radio/Radio.js +0 -191
  365. package/dist/radio/Radio.stories.js +0 -166
  366. package/dist/radio/readme.md +0 -70
  367. package/dist/resultsetTable/ResultsetTable.js +0 -334
  368. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  369. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  370. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  371. package/dist/select/Select.js +0 -442
  372. package/dist/select/Select.stories.js +0 -235
  373. package/dist/select/readme.md +0 -72
  374. package/dist/sidenav/Sidenav.js +0 -237
  375. package/dist/sidenav/arrow_icon.svg +0 -3
  376. package/dist/slider/Slider.js +0 -258
  377. package/dist/slider/Slider.stories.js +0 -241
  378. package/dist/slider/readme.md +0 -64
  379. package/dist/spinner/Spinner.js +0 -196
  380. package/dist/spinner/Spinner.stories.js +0 -183
  381. package/dist/spinner/readme.md +0 -65
  382. package/dist/switch/Switch.js +0 -197
  383. package/dist/switch/Switch.stories.js +0 -134
  384. package/dist/switch/readme.md +0 -133
  385. package/dist/table/Table.js +0 -84
  386. package/dist/tabs/Tabs.js +0 -170
  387. package/dist/tabs/Tabs.stories.js +0 -130
  388. package/dist/tabs/readme.md +0 -78
  389. package/dist/tabs-for-sections/TabsForSections.js +0 -107
  390. package/dist/tabs-for-sections/readme.md +0 -78
  391. package/dist/tag/Tag.js +0 -217
  392. package/dist/textarea/Textarea.js +0 -226
  393. package/dist/toggle/Toggle.js +0 -223
  394. package/dist/toggle/Toggle.stories.js +0 -297
  395. package/dist/toggle/readme.md +0 -80
  396. package/dist/upload/Upload.js +0 -200
  397. package/dist/upload/Upload.stories.js +0 -72
  398. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -125
  399. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  400. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  401. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -282
  402. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  403. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  404. package/dist/upload/file-upload/FileToUpload.js +0 -158
  405. package/dist/upload/file-upload/audio-icon.svg +0 -4
  406. package/dist/upload/file-upload/close.svg +0 -4
  407. package/dist/upload/file-upload/file-icon.svg +0 -4
  408. package/dist/upload/file-upload/video-icon.svg +0 -4
  409. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  410. package/dist/upload/readme.md +0 -37
  411. package/dist/upload/transaction/Transaction.js +0 -155
  412. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  413. package/dist/upload/transaction/audio-icon.svg +0 -4
  414. package/dist/upload/transaction/error-icon.svg +0 -4
  415. package/dist/upload/transaction/file-icon-err.svg +0 -4
  416. package/dist/upload/transaction/file-icon.svg +0 -4
  417. package/dist/upload/transaction/image-icon-err.svg +0 -4
  418. package/dist/upload/transaction/image-icon.svg +0 -4
  419. package/dist/upload/transaction/success-icon.svg +0 -4
  420. package/dist/upload/transaction/video-icon-err.svg +0 -4
  421. package/dist/upload/transaction/video-icon.svg +0 -4
  422. package/dist/upload/transactions/Transactions.js +0 -120
  423. package/dist/wizard/Wizard.js +0 -320
  424. package/dist/wizard/invalid_icon.svg +0 -6
  425. package/dist/wizard/valid_icon.svg +0 -6
  426. package/dist/wizard/validation-wrong.svg +0 -6
  427. package/test/Accordion.test.js +0 -33
  428. package/test/Alert.test.js +0 -53
  429. package/test/Box.test.js +0 -10
  430. package/test/Button.test.js +0 -18
  431. package/test/Card.test.js +0 -30
  432. package/test/Checkbox.test.js +0 -45
  433. package/test/Chip.test.js +0 -25
  434. package/test/Date.test.js +0 -393
  435. package/test/Dialog.test.js +0 -23
  436. package/test/Dropdown.test.js +0 -130
  437. package/test/Footer.test.js +0 -99
  438. package/test/Header.test.js +0 -39
  439. package/test/Heading.test.js +0 -35
  440. package/test/InputText.test.js +0 -236
  441. package/test/Link.test.js +0 -25
  442. package/test/Paginator.test.js +0 -165
  443. package/test/ProgressBar.test.js +0 -35
  444. package/test/Radio.test.js +0 -37
  445. package/test/ResultsetTable.test.js +0 -282
  446. package/test/Select.test.js +0 -191
  447. package/test/Sidenav.test.js +0 -87
  448. package/test/Slider.test.js +0 -65
  449. package/test/Spinner.test.js +0 -27
  450. package/test/Switch.test.js +0 -45
  451. package/test/Table.test.js +0 -36
  452. package/test/Tabs.test.js +0 -88
  453. package/test/TabsForSections.test.js +0 -34
  454. package/test/Tag.test.js +0 -32
  455. package/test/TextArea.test.js +0 -52
  456. package/test/Toggle.test.js +0 -43
  457. package/test/Upload.test.js +0 -60
  458. package/test/Wizard.test.js +0 -130
  459. package/test/mocks/pngMock.js +0 -1
  460. package/test/mocks/svgMock.js +0 -1
package/test/Date.test.js DELETED
@@ -1,393 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcDate from "../src/date/Date";
4
-
5
- const defaultFormat = "DD-MM-YYYY";
6
-
7
- describe("Date component general tests", () => {
8
- test("Date renders correctly", () => {
9
- const { getByPlaceholderText } = render(<DxcDate label="Birthdate" placeholder />);
10
- // const input = getByPlaceholderText('DD-MM-YYYY');
11
- expect(getByPlaceholderText(defaultFormat)).toBeTruthy();
12
- });
13
- });
14
-
15
- describe("Controlled Date Component", () => {
16
- const date = new Date("2020-10-16 00:00:00");
17
-
18
- test("Changing the input value and after this deleting its content input´s value should be ''", () => {
19
- const onChange = jest.fn((returnedValue) => {
20
- expect(returnedValue.dateValue).toBeNull();
21
- expect(returnedValue.stringValue).toBe("something");
22
- });
23
-
24
- const { getByRole, getByPlaceholderText, rerender } = render(
25
- <DxcDate label="Birthdate" value="30-03-1981" onChange={onChange} placeholder />
26
- );
27
- const input = getByPlaceholderText(defaultFormat);
28
-
29
- fireEvent.change(input, { target: { value: "something" } });
30
- expect(onChange).toHaveBeenCalled();
31
- fireEvent.blur(input);
32
- rerender(<DxcDate label="Birthdate" value="" placeholder />);
33
- // expect(getByRole("textbox").value).toBe('');
34
- });
35
-
36
- test("The input´s value is the same as the one received as a parameter (Default format)", () => {
37
- const { getByRole, getByPlaceholderText } = render(<DxcDate label="Birthdate" value="30/03/1981" placeholder />);
38
- // const input = getByRole("textbox");
39
- const input = getByPlaceholderText(defaultFormat);
40
- expect(input.value).toBe("30/03/1981");
41
- });
42
-
43
- test("The input´s value is the same as the one received as a parameter (Custom format)", () => {
44
- const { getByRole, getByPlaceholderText } = render(
45
- <DxcDate label="Birthdate" format="dd/MM/yy" value="30/03/81" placeholder />
46
- );
47
- // const input = getByRole("textbox");
48
- const input = getByPlaceholderText("DD/MM/YY");
49
- expect(input.value).toBe("30/03/81");
50
- });
51
-
52
- test("Calendar´s value is the same as the input´s date if it´s right (Depending on the format)", () => {
53
- const { getByRole, getByText } = render(<DxcDate label="Birthdate" value="16-10-2020" />);
54
- fireEvent.click(getByRole("img"));
55
- expect(getByText("Fri, Oct 16")).toBeTruthy();
56
- });
57
-
58
- test("Calendar´s value is the same as the input´s date if it´s right after changing the input value", () => {
59
- const { getByRole, getByText, rerender, getByPlaceholderText } = render(
60
- <DxcDate label="Birthdate" value="30-03-1981" placeholder />
61
- );
62
- // const input = getByRole("textbox");
63
- const input = getByPlaceholderText(defaultFormat);
64
- fireEvent.change(input, { target: { value: "10-02-2020" } });
65
-
66
- rerender(<DxcDate label="Birthdate" value="10-02-2020" />);
67
- const calendarButton = getByRole("img");
68
- fireEvent.click(calendarButton);
69
- expect(getByText("Mon, Feb 10")).toBeTruthy();
70
- });
71
-
72
- test("onChange function is called when the user types something in the input", () => {
73
- const onChange = jest.fn((returnedValue) => {
74
- expect(returnedValue.dateValue).toBeNull();
75
- expect(returnedValue.stringValue).toBe("something");
76
- });
77
-
78
- const { getByRole, getByPlaceholderText } = render(
79
- <DxcDate label="Birthdate" value="30-03-1981" onChange={onChange} placeholder />
80
- );
81
- // const input = getByRole("textbox");
82
- const input = getByPlaceholderText(defaultFormat);
83
-
84
- fireEvent.change(input, { target: { value: "something" } });
85
- expect(onChange).toHaveBeenCalled();
86
- });
87
-
88
- test("onChange function is called when the user types in the input a valid date(based on its format), the object received as a parameter in the onChange function is what should be(DEFAULT FORMAT)", () => {
89
- const onChange = jest.fn((returnedValue) => {
90
- expect(returnedValue.dateValue.getTime()).toBe(date.getTime());
91
- expect(returnedValue.stringValue).toBe("16-10-2020");
92
- });
93
-
94
- const { getByRole, getByPlaceholderText } = render(
95
- <DxcDate label="Birthdate" value="30-03-1981" onChange={onChange} placeholder />
96
- );
97
- // const input = getByRole("textbox");
98
- const input = getByPlaceholderText(defaultFormat);
99
- fireEvent.change(input, { target: { value: "16-10-2020" } });
100
- expect(onChange).toHaveBeenCalled();
101
- });
102
-
103
- test("onChange function is called when the user types in the input a valid date(based on its format), the object received as a parameter in the onChange function is what should be(CUSTOM FORMAT)", () => {
104
- const onChange = jest.fn((returnedValue) => {
105
- expect(returnedValue.dateValue.getTime()).toBe(date.getTime());
106
- expect(returnedValue.stringValue).toBe("16-10-20");
107
- });
108
-
109
- const { getByRole, getByPlaceholderText } = render(
110
- <DxcDate label="Birthdate" format="dd-MM-yy" value="30-03-81" onChange={onChange} placeholder />
111
- );
112
- // const input = getByRole("textbox");
113
- const input = getByPlaceholderText("DD-MM-YY");
114
-
115
- fireEvent.change(input, { target: { value: "16-10-20" } });
116
- expect(onChange).toHaveBeenCalled();
117
- });
118
-
119
- test("onChange function is called when the user types in the input an invalid date(based on its format), the object received as a parameter in the onChange function is what should be(stringValue with the written string, and null as dateValue)(DEFAULT FORMAT)", () => {
120
- const onChange = jest.fn((returnedValue) => {
121
- expect(returnedValue.dateValue).toBeNull();
122
- expect(returnedValue.stringValue).toBe("11-15-2020");
123
- });
124
-
125
- const { getByRole, getByPlaceholderText } = render(
126
- <DxcDate label="Birthdate" value="30-03-1981" onChange={onChange} placeholder />
127
- );
128
- // const input = getByRole("textbox");
129
- const input = getByPlaceholderText(defaultFormat);
130
-
131
- fireEvent.change(input, { target: { value: "11-15-2020" } });
132
- expect(onChange).toHaveBeenCalled();
133
- });
134
-
135
- test("onChange function is called when the user types in the input an invalid date(based on its format), the object received as a parameter in the onChange function is what should be(stringValue with the written string, and null as dateValue)(CUSTOM FORMAT)", () => {
136
- const onChange = jest.fn((returnedValue) => {
137
- expect(returnedValue.dateValue).toBeNull();
138
- expect(returnedValue.stringValue).toBe("15/11/2020");
139
- });
140
-
141
- const { getByRole, getByPlaceholderText } = render(
142
- <DxcDate label="Birthdate" value="03/30/1981" format="MM/dd/yyyy" onChange={onChange} placeholder />
143
- );
144
- // const input = getByRole("textbox");
145
- const input = getByPlaceholderText("MM/DD/YYYY");
146
-
147
- fireEvent.change(input, { target: { value: "15/11/2020" } });
148
- expect(onChange).toHaveBeenCalled();
149
- });
150
-
151
- test("onChange function is called when the user selects from the calendar", () => {
152
- const onChange = jest.fn();
153
-
154
- const component = render(<DxcDate label="Birthdate" value="01-02-2020" onChange={onChange} />);
155
- const calendarButton = component.getByRole("img");
156
- fireEvent.click(calendarButton);
157
- const dayButton = component.getByRole("button", { name: "10" });
158
- fireEvent.click(dayButton);
159
- expect(dayButton).toBeTruthy();
160
- expect(onChange).toHaveBeenCalled();
161
- });
162
-
163
- test("onChange function is called when the user selects from the calendar, the dateValue received by the onChange function is the selected date", () => {
164
- const onChange = jest.fn((returnedValue) => {
165
- expect(returnedValue.dateValue.getTime()).toBe(date.getTime());
166
- });
167
-
168
- const component = render(<DxcDate label="Birthdate" value="30-10-2020" onChange={onChange} />);
169
- const calendarButton = component.getByRole("img");
170
- fireEvent.click(calendarButton);
171
- const dayButton = component.getByRole("button", { name: "16" });
172
- fireEvent.click(dayButton);
173
- expect(dayButton).toBeTruthy();
174
- });
175
-
176
- test("onChange function is called when the user selects from the calendar, the stringValue received by the onChange function is the date with the correct format (DEFAULT FORMAT)", () => {
177
- const onChange = jest.fn((returnedValue) => {
178
- expect(returnedValue.stringValue).toBe("16-10-2020");
179
- });
180
-
181
- const component = render(<DxcDate label="Birthdate" value="01-10-2020" onChange={onChange} />);
182
- const calendarButton = component.getByRole("img");
183
- fireEvent.click(calendarButton);
184
- const dayButton = component.getByRole("button", { name: "16" });
185
- fireEvent.click(dayButton);
186
- expect(dayButton).toBeTruthy();
187
- });
188
-
189
- test("onChange function is called when the user selects from the calendar, the stringValue received by the onChange function is the date with the correct format (CUSTOM FORMAT)", () => {
190
- const onChange = jest.fn((returnedValue) => {
191
- expect(returnedValue.stringValue).toBe("2020/10/16");
192
- });
193
-
194
- const component = render(<DxcDate label="Birthdate" format="yyyy/MM/dd" value="2020/10/01" onChange={onChange} />);
195
- const calendarButton = component.getByRole("img");
196
- fireEvent.click(calendarButton);
197
- const dayButton = component.getByRole("button", { name: "16" });
198
- fireEvent.click(dayButton);
199
- expect(dayButton).toBeTruthy();
200
- });
201
-
202
- test("Check selected date on calendar is the same date as the one on the input", () => {
203
- const component = render(<DxcDate label="Birthdate" value="01-10-2020" />);
204
- const calendarButton = component.getByRole("img");
205
- fireEvent.click(calendarButton);
206
- const dayButton = component.getByRole("button", { name: "1" });
207
- expect(dayButton.classList.contains("MuiPickersDay-daySelected")).toBe(true);
208
- });
209
- test("onBlur function is called", () => {
210
- const onBlur = jest.fn();
211
- const { getByRole, getByPlaceholderText } = render(
212
- <DxcDate label="Birthdate" value="30-03-81" onBlur={onBlur} placeholder />
213
- );
214
- // const input = getByRole("textbox");
215
- const input = getByPlaceholderText(defaultFormat);
216
-
217
- fireEvent.blur(input);
218
- expect(onBlur).toHaveBeenCalled();
219
- });
220
- test("onBlur function is called and the parameter received is what should be(DEFAULT FORMAT)", () => {
221
- const onBlur = jest.fn((returnedValue) => {
222
- expect(returnedValue).toBe("30-03-81");
223
- });
224
- const { getByRole, getByPlaceholderText } = render(
225
- <DxcDate label="Birthdate" value="30-03-81" onBlur={onBlur} placeholder />
226
- );
227
- // const input = getByRole("textbox");
228
- const input = getByPlaceholderText(defaultFormat);
229
-
230
- fireEvent.blur(input);
231
- expect(onBlur).toHaveBeenCalled();
232
- });
233
- test("onBlur function is called and the parameter received is what should be(CUSTOM FORMAT)", () => {
234
- const onBlur = jest.fn((returnedValue) => {
235
- expect(returnedValue).toBe("30/03/81");
236
- });
237
- const { getByRole, getByPlaceholderText } = render(
238
- <DxcDate label="Birthdate" format="dd/MM/yy" value="30/03/81" onBlur={onBlur} placeholder />
239
- );
240
- // const input = getByRole("textbox");
241
- const input = getByPlaceholderText("DD/MM/YY");
242
-
243
- fireEvent.blur(input);
244
- expect(onBlur).toHaveBeenCalled();
245
- });
246
- });
247
-
248
- describe("Uncontrolled Date Component", () => {
249
- const date = new Date("2020-10-16 00:00:00");
250
-
251
- test("Calendar´s value is the same as the input´s date if it´s right after changing the input value", () => {
252
- const { getByRole, getByText, rerender, getByPlaceholderText } = render(<DxcDate label="Birthdate" placeholder />);
253
- // const input = getByRole("textbox");
254
- const input = getByPlaceholderText(defaultFormat);
255
-
256
- fireEvent.change(input, { target: { value: "10-02-2020" } });
257
-
258
- rerender(<DxcDate label="Birthdate" value="10-02-2020" />);
259
- const calendarButton = getByRole("img");
260
- fireEvent.click(calendarButton);
261
- expect(getByText("Mon, Feb 10")).toBeTruthy();
262
- });
263
-
264
- test("onChange function is called when the user types something in the input", () => {
265
- const onChange = jest.fn((returnedValue) => {
266
- expect(returnedValue.dateValue).toBeNull();
267
- expect(returnedValue.stringValue).toBe("something");
268
- });
269
-
270
- const { getByRole, getByPlaceholderText } = render(<DxcDate label="Birthdate" onChange={onChange} placeholder />);
271
- // const input = getByRole("textbox");
272
- const input = getByPlaceholderText(defaultFormat);
273
-
274
- fireEvent.change(input, { target: { value: "something" } });
275
- expect(onChange).toHaveBeenCalled();
276
- });
277
- test("onChange function is called when the user types in the input a valid date(based on its format), the object received as a parameter in the onChange function is what should be(DEFAULT FORMAT)", () => {
278
- const onChange = jest.fn((returnedValue) => {
279
- expect(returnedValue.dateValue.getTime()).toBe(date.getTime());
280
- expect(returnedValue.stringValue).toBe("16-10-2020");
281
- });
282
-
283
- const { getByRole, getByPlaceholderText } = render(<DxcDate label="Birthdate" onChange={onChange} placeholder />);
284
- // const input = getByRole("textbox");
285
- const input = getByPlaceholderText(defaultFormat);
286
-
287
- fireEvent.change(input, { target: { value: "16-10-2020" } });
288
- expect(onChange).toHaveBeenCalled();
289
- });
290
- test("onChange function is called when the user types in the input a valid date(based on its format), the object received as a parameter in the onChange function is what should be(CUSTOM FORMAT)", () => {
291
- const onChange = jest.fn((returnedValue) => {
292
- expect(returnedValue.dateValue.getTime()).toBe(date.getTime());
293
- expect(returnedValue.stringValue).toBe("16-10-20");
294
- });
295
-
296
- const { getByRole, getByPlaceholderText } = render(
297
- <DxcDate label="Birthdate" format="dd-MM-yy" onChange={onChange} placeholder />
298
- );
299
- // const input = getByRole("textbox");
300
- const input = getByPlaceholderText("DD-MM-YY");
301
-
302
- fireEvent.change(input, { target: { value: "16-10-20" } });
303
- expect(onChange).toHaveBeenCalled();
304
- });
305
-
306
- test("onChange function is called when the user types in the input an invalid date(based on its format), the object received as a parameter in the onChange function is what should be(stringValue with the written string, and null as dateValue)(DEFAULT FORMAT)", () => {
307
- const onChange = jest.fn((returnedValue) => {
308
- expect(returnedValue.dateValue).toBeNull();
309
- expect(returnedValue.stringValue).toBe("11-15-2020");
310
- });
311
-
312
- const { getByRole, getByPlaceholderText } = render(<DxcDate label="Birthdate" onChange={onChange} placeholder />);
313
- // const input = getByRole("textbox");
314
- const input = getByPlaceholderText(defaultFormat);
315
-
316
- fireEvent.change(input, { target: { value: "11-15-2020" } });
317
- expect(onChange).toHaveBeenCalled();
318
- });
319
-
320
- test("onChange function is called when the user types in the input an invalid date(based on its format), the object received as a parameter in the onChange function is what should be(stringValue with the written string, and null as dateValue)(CUSTOM FORMAT)", () => {
321
- const onChange = jest.fn((returnedValue) => {
322
- expect(returnedValue.dateValue).toBeNull();
323
- expect(returnedValue.stringValue).toBe("15/11/2020");
324
- });
325
-
326
- const { getByRole, getByPlaceholderText } = render(
327
- <DxcDate label="Birthdate" format="MM/dd/yyyy" onChange={onChange} placeholder />
328
- );
329
- // const input = getByRole("textbox");
330
- const input = getByPlaceholderText("MM/DD/YYYY");
331
-
332
- fireEvent.change(input, { target: { value: "15/11/2020" } });
333
- expect(onChange).toHaveBeenCalled();
334
- });
335
- test("onChange function is called when the user selects from the calendar", () => {
336
- const onChange = jest.fn();
337
-
338
- const component = render(<DxcDate label="Birthdate" onChange={onChange} />);
339
- const calendarButton = component.getByRole("img");
340
- fireEvent.click(calendarButton);
341
- const dayButton = component.getByRole("button", { name: "10" });
342
- fireEvent.click(dayButton);
343
- expect(dayButton).toBeTruthy();
344
- expect(onChange).toHaveBeenCalled();
345
- });
346
-
347
- test("Check selected date on calendar is the same date as the one on the input", () => {
348
- const component = render(<DxcDate label="Birthdate" placeholder />);
349
- // const input = component.getByRole("textbox");
350
- const input = component.getByPlaceholderText(defaultFormat);
351
-
352
- fireEvent.change(input, { target: { value: "10-02-2020" } });
353
- const calendarButton = component.getByRole("img");
354
- fireEvent.click(calendarButton);
355
- const dayButton = component.getByRole("button", { name: "10" });
356
- expect(dayButton.classList.contains("MuiPickersDay-daySelected")).toBe(true);
357
- });
358
- test("onBlur function is called", () => {
359
- const onBlur = jest.fn();
360
- const { getByRole, getByPlaceholderText } = render(<DxcDate label="Birthdate" onBlur={onBlur} placeholder />);
361
- // const input = getByRole("textbox");
362
- const input = getByPlaceholderText(defaultFormat);
363
-
364
- fireEvent.blur(input);
365
- expect(onBlur).toHaveBeenCalled();
366
- });
367
- test("onBlur function is called and the parameter received is what should be(DEFAULT FORMAT)", () => {
368
- const onBlur = jest.fn((returnedValue) => {
369
- expect(returnedValue).toBe("10-02-2020");
370
- });
371
- const { getByRole, getByPlaceholderText } = render(<DxcDate label="Birthdate" onBlur={onBlur} placeholder />);
372
- // const input = getByRole("textbox");
373
- const input = getByPlaceholderText("DD-MM-YYYY");
374
-
375
- fireEvent.change(input, { target: { value: "10-02-2020" } });
376
- fireEvent.blur(input);
377
- expect(onBlur).toHaveBeenCalled();
378
- });
379
- test("onBlur function is called and the parameter received is what should be(CUSTOM FORMAT)", () => {
380
- const onBlur = jest.fn((returnedValue) => {
381
- expect(returnedValue).toBe("10/02/20");
382
- });
383
- const { getByRole, getByPlaceholderText } = render(
384
- <DxcDate label="Birthdate" format="dd/MM/yy" onBlur={onBlur} placeholder />
385
- );
386
- // const input = getByRole("textbox");
387
- const input = getByPlaceholderText("DD/MM/YY");
388
-
389
- fireEvent.change(input, { target: { value: "10/02/20" } });
390
- fireEvent.blur(input);
391
- expect(onBlur).toHaveBeenCalled();
392
- });
393
- });
@@ -1,23 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent } from "@testing-library/react";
3
- import DxcDialog from "../src/dialog/Dialog";
4
-
5
- describe("Dialog component tests", () => {
6
- test("Dialog renders with correct text", () => {
7
- const { getByText } = render(<DxcDialog>dialog-text</DxcDialog>);
8
- expect(getByText("dialog-text")).toBeTruthy();
9
- });
10
-
11
- test("Dialog renders without close button", () => {
12
- const { queryByRole } = render(<DxcDialog isCloseVisible={false}>dialog-text</DxcDialog>);
13
- expect(queryByRole("button")).toBeFalsy();
14
- });
15
-
16
- test("Calls correct function onCloseClick", () => {
17
- const onCloseClick = jest.fn();
18
- const { getByRole } = render(<DxcDialog onCloseClick={onCloseClick}>dialog-text</DxcDialog>);
19
- const closeButton = getByRole("button");
20
- fireEvent.click(closeButton);
21
- expect(onCloseClick).toHaveBeenCalled();
22
- });
23
- });
@@ -1,130 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent, act } from "@testing-library/react";
3
- import DxcDropdown from "../src/dropdown/Dropdown";
4
-
5
- global.document.createRange = () => ({
6
- setStart: () => {},
7
- setEnd: () => {},
8
- commonAncestorContainer: {
9
- nodeName: "BODY",
10
- ownerDocument: document,
11
- },
12
- });
13
-
14
- describe("Dropdown component tests", () => {
15
- test("Dropdown renders with correct label", () => {
16
- const { getByText } = render(<DxcDropdown label="dropdown-test"></DxcDropdown>);
17
- expect(getByText("dropdown-test")).toBeTruthy();
18
- });
19
-
20
- test("Dropdown renders with correct icon before", () => {
21
- const { getAllByRole } = render(<DxcDropdown iconSrc="/testIcon" label="dropdown-test"></DxcDropdown>);
22
- const image = getAllByRole("img")[0];
23
- expect(image.getAttribute("src")).toEqual("/testIcon");
24
- });
25
-
26
- test("Dropdown renders with correct icon after", () => {
27
- const { getAllByRole } = render(
28
- <DxcDropdown iconSrc="/testIcon" iconPosition="after" label="dropdown-test"></DxcDropdown>
29
- );
30
- const image = getAllByRole("img")[0];
31
- expect(image.getAttribute("src")).toEqual("/testIcon");
32
- });
33
-
34
- test("onClick shows and hides option", () => {
35
- const options = [
36
- {
37
- value: 1,
38
- label: "option-test",
39
- },
40
- ];
41
- const { queryByText } = render(<DxcDropdown options={options} label="dropdown-test"></DxcDropdown>);
42
- const dropdown = queryByText("dropdown-test");
43
- //Before clicked is not showed
44
- expect(queryByText("option-test")).toBeFalsy();
45
- act(() => {
46
- fireEvent.click(dropdown);
47
- });
48
- expect(queryByText("option-test")).toBeTruthy();
49
- });
50
-
51
- test("Dropdown renders with correct icon before option", () => {
52
- const options = [
53
- {
54
- value: 1,
55
- label: "option-test",
56
- iconSrc: "/testIcon",
57
- },
58
- ];
59
- const { getByText, getAllByRole } = render(<DxcDropdown options={options} label="dropdown-test"></DxcDropdown>);
60
- const dropdown = getByText("dropdown-test");
61
- act(() => {
62
- fireEvent.click(dropdown);
63
- });
64
- expect(getAllByRole("img")[1].getAttribute("src")).toEqual("/testIcon");
65
- });
66
-
67
- test("Dropdown renders with correct icon after option", () => {
68
- const options = [
69
- {
70
- value: 1,
71
- label: "option-test",
72
- iconSrc: "/testIcon",
73
- },
74
- ];
75
- const { getByText, getAllByRole } = render(
76
- <DxcDropdown options={options} optionsIconPosition="after" label="dropdown-test"></DxcDropdown>
77
- );
78
- const dropdown = getByText("dropdown-test");
79
- act(() => {
80
- fireEvent.click(dropdown);
81
- });
82
- expect(getAllByRole("img")[1].getAttribute("src")).toEqual("/testIcon");
83
- });
84
-
85
- test("Dropdown renders with caret hidden", () => {
86
- const { queryByRole } = render(<DxcDropdown caretHidden={true} label="dropdown-test"></DxcDropdown>);
87
- expect(queryByRole("img")).toBeFalsy();
88
- });
89
-
90
- test("onSelectOption fuction is called correctly", () => {
91
- const onSelectOption = jest.fn((i) => i);
92
- const options = [
93
- {
94
- value: 1,
95
- label: "option-test",
96
- },
97
- ];
98
- const { getByText } = render(
99
- <DxcDropdown options={options} onSelectOption={onSelectOption} label="dropdown-test"></DxcDropdown>
100
- );
101
- const dropdown = getByText("dropdown-test");
102
- act(() => {
103
- fireEvent.click(dropdown);
104
- });
105
- const option = getByText("option-test");
106
- act(() => {
107
- fireEvent.click(option);
108
- });
109
- expect(onSelectOption).toHaveBeenCalledWith(1);
110
- });
111
-
112
- test("expandOnHover shows and hides the option correctly", () => {
113
- const options = [
114
- {
115
- value: 1,
116
- label: "option-test",
117
- },
118
- ];
119
- const { queryByText } = render(
120
- <DxcDropdown options={options} expandOnHover={true} label="dropdown-test"></DxcDropdown>
121
- );
122
- const dropdown = queryByText("dropdown-test");
123
- //Verify that is not showed before
124
- expect(queryByText("option-test")).toBeFalsy();
125
- act(() => {
126
- fireEvent.mouseOver(dropdown);
127
- });
128
- expect(queryByText("option-test")).toBeTruthy();
129
- });
130
- });
@@ -1,99 +0,0 @@
1
- import React from "react";
2
- import { render } from "@testing-library/react";
3
- import DxcFooter from "../src/footer/Footer";
4
- import icon from "../../app/src/images/linkedin.svg";
5
-
6
- describe("Footer component tests", () => {
7
- test("Footer renders with default logo", () => {
8
- const { getByRole } = render(<DxcFooter></DxcFooter>);
9
- expect(getByRole("img")).toBeTruthy();
10
- });
11
-
12
- test("Footer renders with logo", () => {
13
- const { getByRole } = render(<DxcFooter logoSrc={icon}></DxcFooter>);
14
- expect(getByRole("img")).toBeTruthy();
15
- });
16
-
17
- test("Footer renders with social links", () => {
18
- const social = [
19
- {
20
- href: "https://www.test.com/test",
21
- logoSrc: icon,
22
- },
23
- ];
24
- const { getByRole } = render(<DxcFooter socialLinks={social}></DxcFooter>);
25
- const socialIcon = getByRole("link");
26
- expect(socialIcon.getAttribute("href")).toBe("https://www.test.com/test");
27
- });
28
-
29
- test("Footer renders with bottom links", () => {
30
- const bottom = [
31
- {
32
- href: "https://www.test.com/test",
33
- text: "bottom-link-text",
34
- },
35
- ];
36
- const { getByText } = render(<DxcFooter bottomLinks={bottom}></DxcFooter>);
37
- const link = getByText("bottom-link-text");
38
- expect(link.getAttribute("href")).toBe("https://www.test.com/test");
39
- });
40
-
41
- test("Footer renders with copyright text", () => {
42
- const { getByText } = render(<DxcFooter copyright="test-copyright"></DxcFooter>);
43
- expect(getByText("test-copyright")).toBeTruthy();
44
- });
45
-
46
- test("Footer renders with correct children", () => {
47
- //We need to force the offsetWidth value
48
- Object.defineProperty(HTMLElement.prototype, "offsetWidth", { configurable: true, value: 1024 });
49
-
50
- const { getByText } = render(
51
- <DxcFooter>
52
- <p>footer-child-text</p>
53
- </DxcFooter>
54
- );
55
-
56
- expect(getByText("footer-child-text")).toBeTruthy();
57
- });
58
-
59
- test("Footer renders without children in mobile", () => {
60
- //425 is mobile width
61
- Object.defineProperty(HTMLElement.prototype, "offsetWidth", { configurable: true, value: 425 });
62
-
63
- const { queryByText } = render(
64
- <DxcFooter>
65
- <p>footer-child-text</p>
66
- </DxcFooter>
67
- );
68
-
69
- expect(queryByText("footer-child-text")).toBeFalsy();
70
- });
71
-
72
- test("Footer is fully rendered", () => {
73
- Object.defineProperty(HTMLElement.prototype, "offsetWidth", { configurable: true, value: 1024 });
74
-
75
- const social = [
76
- {
77
- href: "https://www.test.com/social",
78
- logoSrc: icon,
79
- },
80
- ];
81
- const bottom = [
82
- {
83
- href: "https://www.test.com/bottom",
84
- text: "bottom-link-text",
85
- },
86
- ];
87
- const { getAllByRole, getByText } = render(
88
- <DxcFooter socialLinks={social} bottomLinks={bottom} copyright="test-copyright">
89
- <p>footer-child-text</p>
90
- </DxcFooter>
91
- );
92
- const socialIcon = getAllByRole("link")[0];
93
- expect(socialIcon.getAttribute("href")).toBe("https://www.test.com/social");
94
- const bottomLink = getByText("bottom-link-text");
95
- expect(bottomLink.getAttribute("href")).toBe("https://www.test.com/bottom");
96
- expect(getByText("test-copyright")).toBeTruthy();
97
- expect(getByText("footer-child-text")).toBeTruthy();
98
- });
99
- });