@dxc-technology/halstack-react 0.0.0-bd24f1d → 0.0.0-bd47c58

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 (516) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +47 -0
  3. package/HalstackContext.d.ts +1344 -0
  4. package/HalstackContext.js +335 -0
  5. package/README.md +28 -47
  6. package/accordion/Accordion.d.ts +4 -0
  7. package/accordion/Accordion.js +222 -0
  8. package/accordion/Accordion.stories.tsx +297 -0
  9. package/accordion/Accordion.test.js +71 -0
  10. package/accordion/types.d.ts +57 -0
  11. package/accordion/types.js +5 -0
  12. package/accordion-group/AccordionGroup.d.ts +8 -0
  13. package/accordion-group/AccordionGroup.js +128 -0
  14. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  15. package/accordion-group/AccordionGroup.test.js +116 -0
  16. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  17. package/accordion-group/AccordionGroupAccordion.js +43 -0
  18. package/accordion-group/types.d.ts +67 -0
  19. package/accordion-group/types.js +5 -0
  20. package/alert/Alert.d.ts +4 -0
  21. package/{dist/alert → alert}/Alert.js +49 -163
  22. package/alert/Alert.stories.tsx +198 -0
  23. package/alert/Alert.test.js +92 -0
  24. package/alert/types.d.ts +49 -0
  25. package/alert/types.js +5 -0
  26. package/badge/Badge.d.ts +4 -0
  27. package/badge/Badge.js +61 -0
  28. package/badge/types.d.ts +5 -0
  29. package/badge/types.js +5 -0
  30. package/bleed/Bleed.d.ts +3 -0
  31. package/bleed/Bleed.js +51 -0
  32. package/bleed/Bleed.stories.tsx +342 -0
  33. package/bleed/types.d.ts +37 -0
  34. package/bleed/types.js +5 -0
  35. package/box/Box.d.ts +4 -0
  36. package/box/Box.js +97 -0
  37. package/box/Box.stories.tsx +119 -0
  38. package/box/Box.test.js +18 -0
  39. package/box/types.d.ts +32 -0
  40. package/box/types.js +5 -0
  41. package/bulleted-list/BulletedList.d.ts +7 -0
  42. package/bulleted-list/BulletedList.js +125 -0
  43. package/bulleted-list/BulletedList.stories.tsx +206 -0
  44. package/bulleted-list/types.d.ts +38 -0
  45. package/bulleted-list/types.js +5 -0
  46. package/button/Button.d.ts +4 -0
  47. package/button/Button.js +144 -0
  48. package/button/Button.stories.tsx +425 -0
  49. package/button/Button.test.js +46 -0
  50. package/button/types.d.ts +57 -0
  51. package/button/types.js +5 -0
  52. package/card/Card.d.ts +4 -0
  53. package/card/Card.js +143 -0
  54. package/card/Card.stories.tsx +171 -0
  55. package/card/Card.test.js +50 -0
  56. package/card/types.d.ts +62 -0
  57. package/card/types.js +5 -0
  58. package/checkbox/Checkbox.d.ts +4 -0
  59. package/checkbox/Checkbox.js +250 -0
  60. package/checkbox/Checkbox.stories.tsx +260 -0
  61. package/checkbox/Checkbox.test.js +155 -0
  62. package/checkbox/types.d.ts +68 -0
  63. package/checkbox/types.js +5 -0
  64. package/chip/Chip.d.ts +4 -0
  65. package/chip/Chip.js +140 -0
  66. package/chip/Chip.stories.tsx +214 -0
  67. package/chip/Chip.test.js +54 -0
  68. package/chip/types.d.ts +45 -0
  69. package/chip/types.js +5 -0
  70. package/common/OpenSans.css +69 -0
  71. package/common/coreTokens.d.ts +146 -0
  72. package/common/coreTokens.js +167 -0
  73. package/common/utils.d.ts +1 -0
  74. package/{dist/common → common}/utils.js +4 -4
  75. package/common/variables.d.ts +1490 -0
  76. package/common/variables.js +1369 -0
  77. package/date-input/Calendar.d.ts +4 -0
  78. package/date-input/Calendar.js +258 -0
  79. package/date-input/DateInput.d.ts +4 -0
  80. package/date-input/DateInput.js +269 -0
  81. package/date-input/DateInput.stories.tsx +304 -0
  82. package/date-input/DateInput.test.js +835 -0
  83. package/date-input/DatePicker.d.ts +4 -0
  84. package/date-input/DatePicker.js +146 -0
  85. package/date-input/Icons.d.ts +6 -0
  86. package/date-input/Icons.js +75 -0
  87. package/date-input/YearPicker.d.ts +4 -0
  88. package/date-input/YearPicker.js +126 -0
  89. package/date-input/types.d.ts +158 -0
  90. package/date-input/types.js +5 -0
  91. package/dialog/Dialog.d.ts +4 -0
  92. package/dialog/Dialog.js +131 -0
  93. package/dialog/Dialog.stories.tsx +195 -0
  94. package/dialog/Dialog.test.js +369 -0
  95. package/dialog/types.d.ts +31 -0
  96. package/dialog/types.js +5 -0
  97. package/dropdown/Dropdown.d.ts +4 -0
  98. package/dropdown/Dropdown.js +388 -0
  99. package/dropdown/Dropdown.stories.tsx +438 -0
  100. package/dropdown/Dropdown.test.js +586 -0
  101. package/dropdown/DropdownMenu.d.ts +4 -0
  102. package/dropdown/DropdownMenu.js +74 -0
  103. package/dropdown/DropdownMenuItem.d.ts +4 -0
  104. package/dropdown/DropdownMenuItem.js +79 -0
  105. package/dropdown/types.d.ts +100 -0
  106. package/dropdown/types.js +5 -0
  107. package/file-input/FileInput.d.ts +4 -0
  108. package/file-input/FileInput.js +547 -0
  109. package/file-input/FileInput.stories.tsx +618 -0
  110. package/file-input/FileInput.test.js +457 -0
  111. package/file-input/FileItem.d.ts +4 -0
  112. package/file-input/FileItem.js +162 -0
  113. package/file-input/types.d.ts +129 -0
  114. package/file-input/types.js +5 -0
  115. package/flex/Flex.d.ts +4 -0
  116. package/flex/Flex.js +71 -0
  117. package/flex/Flex.stories.tsx +112 -0
  118. package/flex/types.d.ts +97 -0
  119. package/flex/types.js +5 -0
  120. package/footer/Footer.d.ts +4 -0
  121. package/footer/Footer.js +165 -0
  122. package/footer/Footer.stories.tsx +151 -0
  123. package/footer/Footer.test.js +99 -0
  124. package/footer/Icons.d.ts +2 -0
  125. package/footer/Icons.js +77 -0
  126. package/footer/types.d.ts +64 -0
  127. package/footer/types.js +5 -0
  128. package/grid/Grid.d.ts +7 -0
  129. package/grid/Grid.js +91 -0
  130. package/grid/Grid.stories.tsx +219 -0
  131. package/grid/types.d.ts +115 -0
  132. package/grid/types.js +5 -0
  133. package/header/Header.d.ts +8 -0
  134. package/header/Header.js +276 -0
  135. package/header/Header.stories.tsx +251 -0
  136. package/header/Header.test.js +79 -0
  137. package/header/Icons.d.ts +2 -0
  138. package/header/Icons.js +34 -0
  139. package/header/types.d.ts +34 -0
  140. package/header/types.js +5 -0
  141. package/heading/Heading.d.ts +4 -0
  142. package/{dist/heading → heading}/Heading.js +32 -91
  143. package/heading/Heading.stories.tsx +54 -0
  144. package/heading/Heading.test.js +186 -0
  145. package/heading/types.d.ts +33 -0
  146. package/heading/types.js +5 -0
  147. package/image/Image.d.ts +4 -0
  148. package/image/Image.js +85 -0
  149. package/image/Image.stories.tsx +127 -0
  150. package/image/types.d.ts +72 -0
  151. package/image/types.js +5 -0
  152. package/inset/Inset.d.ts +3 -0
  153. package/inset/Inset.js +51 -0
  154. package/inset/Inset.stories.tsx +230 -0
  155. package/inset/types.d.ts +37 -0
  156. package/inset/types.js +5 -0
  157. package/layout/ApplicationLayout.d.ts +20 -0
  158. package/layout/ApplicationLayout.js +174 -0
  159. package/layout/ApplicationLayout.stories.tsx +162 -0
  160. package/layout/Icons.d.ts +5 -0
  161. package/layout/Icons.js +66 -0
  162. package/layout/SidenavContext.d.ts +5 -0
  163. package/layout/SidenavContext.js +19 -0
  164. package/layout/types.d.ts +41 -0
  165. package/layout/types.js +5 -0
  166. package/link/Link.d.ts +4 -0
  167. package/link/Link.js +136 -0
  168. package/link/Link.stories.tsx +253 -0
  169. package/link/Link.test.js +81 -0
  170. package/link/types.d.ts +54 -0
  171. package/link/types.js +5 -0
  172. package/main.d.ts +46 -0
  173. package/{dist/main.js → main.js} +143 -109
  174. package/nav-tabs/NavTabs.d.ts +8 -0
  175. package/nav-tabs/NavTabs.js +122 -0
  176. package/nav-tabs/NavTabs.stories.tsx +274 -0
  177. package/nav-tabs/NavTabs.test.js +82 -0
  178. package/nav-tabs/Tab.d.ts +4 -0
  179. package/nav-tabs/Tab.js +146 -0
  180. package/nav-tabs/types.d.ts +52 -0
  181. package/nav-tabs/types.js +5 -0
  182. package/number-input/NumberInput.d.ts +11 -0
  183. package/number-input/NumberInput.js +78 -0
  184. package/number-input/NumberInput.stories.tsx +115 -0
  185. package/number-input/NumberInput.test.js +725 -0
  186. package/number-input/types.d.ts +124 -0
  187. package/number-input/types.js +5 -0
  188. package/package.json +47 -40
  189. package/paginator/Icons.d.ts +5 -0
  190. package/paginator/Icons.js +54 -0
  191. package/paginator/Paginator.d.ts +4 -0
  192. package/paginator/Paginator.js +163 -0
  193. package/paginator/Paginator.stories.tsx +87 -0
  194. package/paginator/Paginator.test.js +318 -0
  195. package/paginator/types.d.ts +38 -0
  196. package/paginator/types.js +5 -0
  197. package/paragraph/Paragraph.d.ts +5 -0
  198. package/paragraph/Paragraph.js +38 -0
  199. package/paragraph/Paragraph.stories.tsx +44 -0
  200. package/password-input/Icons.d.ts +6 -0
  201. package/password-input/Icons.js +39 -0
  202. package/password-input/PasswordInput.d.ts +4 -0
  203. package/password-input/PasswordInput.js +119 -0
  204. package/password-input/PasswordInput.stories.tsx +132 -0
  205. package/password-input/PasswordInput.test.js +174 -0
  206. package/password-input/types.d.ts +110 -0
  207. package/password-input/types.js +5 -0
  208. package/progress-bar/ProgressBar.d.ts +4 -0
  209. package/progress-bar/ProgressBar.js +176 -0
  210. package/progress-bar/ProgressBar.stories.jsx +93 -0
  211. package/progress-bar/ProgressBar.test.js +110 -0
  212. package/progress-bar/types.d.ts +37 -0
  213. package/progress-bar/types.js +5 -0
  214. package/quick-nav/QuickNav.d.ts +4 -0
  215. package/quick-nav/QuickNav.js +117 -0
  216. package/quick-nav/QuickNav.stories.tsx +356 -0
  217. package/quick-nav/types.d.ts +21 -0
  218. package/quick-nav/types.js +5 -0
  219. package/radio-group/Radio.d.ts +4 -0
  220. package/radio-group/Radio.js +156 -0
  221. package/radio-group/RadioGroup.d.ts +4 -0
  222. package/radio-group/RadioGroup.js +281 -0
  223. package/radio-group/RadioGroup.stories.tsx +214 -0
  224. package/radio-group/RadioGroup.test.js +722 -0
  225. package/radio-group/types.d.ts +114 -0
  226. package/radio-group/types.js +5 -0
  227. package/resultsetTable/Icons.d.ts +7 -0
  228. package/resultsetTable/Icons.js +51 -0
  229. package/resultsetTable/ResultsetTable.d.ts +4 -0
  230. package/resultsetTable/ResultsetTable.js +195 -0
  231. package/resultsetTable/ResultsetTable.stories.tsx +300 -0
  232. package/resultsetTable/ResultsetTable.test.js +325 -0
  233. package/resultsetTable/types.d.ts +67 -0
  234. package/resultsetTable/types.js +5 -0
  235. package/select/Icons.d.ts +10 -0
  236. package/select/Icons.js +93 -0
  237. package/select/Listbox.d.ts +4 -0
  238. package/select/Listbox.js +169 -0
  239. package/select/Option.d.ts +4 -0
  240. package/select/Option.js +97 -0
  241. package/select/Select.d.ts +4 -0
  242. package/select/Select.js +666 -0
  243. package/select/Select.stories.tsx +971 -0
  244. package/select/Select.test.js +2228 -0
  245. package/select/types.d.ts +210 -0
  246. package/select/types.js +5 -0
  247. package/sidenav/Icons.d.ts +7 -0
  248. package/sidenav/Icons.js +51 -0
  249. package/sidenav/Sidenav.d.ts +10 -0
  250. package/sidenav/Sidenav.js +238 -0
  251. package/sidenav/Sidenav.stories.tsx +282 -0
  252. package/sidenav/Sidenav.test.js +44 -0
  253. package/sidenav/types.d.ts +76 -0
  254. package/sidenav/types.js +5 -0
  255. package/slider/Slider.d.ts +4 -0
  256. package/slider/Slider.js +342 -0
  257. package/slider/Slider.stories.tsx +240 -0
  258. package/slider/Slider.test.js +250 -0
  259. package/slider/types.d.ts +86 -0
  260. package/slider/types.js +5 -0
  261. package/spinner/Spinner.d.ts +4 -0
  262. package/spinner/Spinner.js +244 -0
  263. package/spinner/Spinner.stories.jsx +129 -0
  264. package/spinner/Spinner.test.js +64 -0
  265. package/spinner/types.d.ts +32 -0
  266. package/spinner/types.js +5 -0
  267. package/switch/Switch.d.ts +4 -0
  268. package/switch/Switch.js +262 -0
  269. package/switch/Switch.stories.tsx +171 -0
  270. package/switch/Switch.test.js +225 -0
  271. package/switch/types.d.ts +66 -0
  272. package/switch/types.js +5 -0
  273. package/table/Table.d.ts +4 -0
  274. package/{dist/table → table}/Table.js +14 -28
  275. package/table/Table.stories.jsx +356 -0
  276. package/table/Table.test.js +26 -0
  277. package/table/types.d.ts +21 -0
  278. package/table/types.js +5 -0
  279. package/tabs/Tab.d.ts +4 -0
  280. package/tabs/Tab.js +132 -0
  281. package/tabs/Tabs.d.ts +4 -0
  282. package/tabs/Tabs.js +461 -0
  283. package/tabs/Tabs.stories.tsx +226 -0
  284. package/tabs/Tabs.test.js +350 -0
  285. package/tabs/types.d.ts +92 -0
  286. package/tabs/types.js +5 -0
  287. package/tag/Tag.d.ts +4 -0
  288. package/tag/Tag.js +181 -0
  289. package/tag/Tag.stories.tsx +155 -0
  290. package/tag/Tag.test.js +60 -0
  291. package/tag/types.d.ts +69 -0
  292. package/tag/types.js +5 -0
  293. package/text-input/Icons.d.ts +8 -0
  294. package/text-input/Icons.js +60 -0
  295. package/text-input/Suggestion.d.ts +4 -0
  296. package/text-input/Suggestion.js +84 -0
  297. package/text-input/Suggestions.d.ts +4 -0
  298. package/text-input/Suggestions.js +134 -0
  299. package/text-input/TextInput.d.ts +4 -0
  300. package/text-input/TextInput.js +657 -0
  301. package/text-input/TextInput.stories.tsx +569 -0
  302. package/text-input/TextInput.test.js +1723 -0
  303. package/text-input/types.d.ts +197 -0
  304. package/text-input/types.js +5 -0
  305. package/textarea/Textarea.d.ts +4 -0
  306. package/{dist/new-textarea/NewTextarea.js → textarea/Textarea.js} +89 -159
  307. package/textarea/Textarea.stories.jsx +216 -0
  308. package/textarea/Textarea.test.js +435 -0
  309. package/textarea/types.d.ts +137 -0
  310. package/textarea/types.js +5 -0
  311. package/toggle-group/ToggleGroup.d.ts +4 -0
  312. package/toggle-group/ToggleGroup.js +241 -0
  313. package/toggle-group/ToggleGroup.stories.tsx +218 -0
  314. package/toggle-group/ToggleGroup.test.js +170 -0
  315. package/toggle-group/types.d.ts +114 -0
  316. package/toggle-group/types.js +5 -0
  317. package/typography/Typography.d.ts +4 -0
  318. package/typography/Typography.js +32 -0
  319. package/typography/Typography.stories.tsx +198 -0
  320. package/typography/types.d.ts +18 -0
  321. package/typography/types.js +5 -0
  322. package/useTheme.d.ts +1243 -0
  323. package/{dist/useTheme.js → useTheme.js} +3 -3
  324. package/useTranslatedLabels.d.ts +85 -0
  325. package/useTranslatedLabels.js +20 -0
  326. package/utils/BaseTypography.d.ts +21 -0
  327. package/utils/BaseTypography.js +108 -0
  328. package/utils/FocusLock.d.ts +13 -0
  329. package/utils/FocusLock.js +138 -0
  330. package/wizard/Wizard.d.ts +4 -0
  331. package/wizard/Wizard.js +285 -0
  332. package/wizard/Wizard.stories.tsx +253 -0
  333. package/wizard/Wizard.test.js +141 -0
  334. package/wizard/types.d.ts +64 -0
  335. package/wizard/types.js +5 -0
  336. package/babel.config.js +0 -8
  337. package/dist/BackgroundColorContext.js +0 -46
  338. package/dist/ThemeContext.js +0 -216
  339. package/dist/accordion/Accordion.js +0 -348
  340. package/dist/accordion/Accordion.stories.js +0 -207
  341. package/dist/accordion/readme.md +0 -96
  342. package/dist/accordion-group/AccordionGroup.js +0 -188
  343. package/dist/accordion-group/AccordionGroup.stories.js +0 -207
  344. package/dist/accordion-group/readme.md +0 -70
  345. package/dist/badge/Badge.js +0 -63
  346. package/dist/box/Box.js +0 -156
  347. package/dist/button/Button.js +0 -231
  348. package/dist/button/Button.stories.js +0 -224
  349. package/dist/button/readme.md +0 -93
  350. package/dist/card/Card.js +0 -254
  351. package/dist/checkbox/Checkbox.js +0 -300
  352. package/dist/checkbox/Checkbox.stories.js +0 -144
  353. package/dist/checkbox/readme.md +0 -116
  354. package/dist/chip/Chip.js +0 -265
  355. package/dist/common/OpenSans.css +0 -81
  356. package/dist/common/RequiredComponent.js +0 -40
  357. package/dist/common/variables.js +0 -1430
  358. package/dist/date/Date.js +0 -381
  359. package/dist/date/Date.stories.js +0 -205
  360. package/dist/date/readme.md +0 -73
  361. package/dist/dialog/Dialog.js +0 -218
  362. package/dist/dropdown/Dropdown.js +0 -504
  363. package/dist/dropdown/Dropdown.stories.js +0 -249
  364. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  365. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  366. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  367. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  368. package/dist/dropdown/readme.md +0 -69
  369. package/dist/footer/Footer.js +0 -395
  370. package/dist/footer/Footer.stories.js +0 -94
  371. package/dist/footer/dxc_logo.svg +0 -15
  372. package/dist/footer/readme.md +0 -41
  373. package/dist/header/Header.js +0 -423
  374. package/dist/header/Header.stories.js +0 -176
  375. package/dist/header/close_icon.svg +0 -1
  376. package/dist/header/dxc_logo_black.svg +0 -8
  377. package/dist/header/hamb_menu_black.svg +0 -1
  378. package/dist/header/hamb_menu_white.svg +0 -1
  379. package/dist/header/readme.md +0 -33
  380. package/dist/input-text/InputText.js +0 -707
  381. package/dist/input-text/InputText.stories.js +0 -209
  382. package/dist/input-text/error.svg +0 -1
  383. package/dist/input-text/readme.md +0 -91
  384. package/dist/layout/ApplicationLayout.js +0 -331
  385. package/dist/layout/facebook.svg +0 -45
  386. package/dist/layout/linkedin.svg +0 -50
  387. package/dist/layout/twitter.svg +0 -53
  388. package/dist/link/Link.js +0 -241
  389. package/dist/link/readme.md +0 -51
  390. package/dist/new-date/NewDate.js +0 -403
  391. package/dist/new-input-text/NewInputText.js +0 -961
  392. package/dist/number/Number.js +0 -138
  393. package/dist/number/NumberContext.js +0 -16
  394. package/dist/paginator/Paginator.js +0 -289
  395. package/dist/paginator/images/next.svg +0 -3
  396. package/dist/paginator/images/nextPage.svg +0 -3
  397. package/dist/paginator/images/previous.svg +0 -3
  398. package/dist/paginator/images/previousPage.svg +0 -3
  399. package/dist/paginator/readme.md +0 -50
  400. package/dist/password/Password.js +0 -200
  401. package/dist/password/styles.css +0 -3
  402. package/dist/progress-bar/ProgressBar.js +0 -206
  403. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  404. package/dist/progress-bar/readme.md +0 -63
  405. package/dist/radio/Radio.js +0 -209
  406. package/dist/radio/Radio.stories.js +0 -166
  407. package/dist/radio/readme.md +0 -70
  408. package/dist/resultsetTable/ResultsetTable.js +0 -358
  409. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  410. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  411. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  412. package/dist/select/Select.js +0 -585
  413. package/dist/select/Select.stories.js +0 -235
  414. package/dist/select/readme.md +0 -72
  415. package/dist/sidenav/Sidenav.js +0 -177
  416. package/dist/slider/Slider.js +0 -319
  417. package/dist/slider/Slider.stories.js +0 -241
  418. package/dist/slider/readme.md +0 -64
  419. package/dist/spinner/Spinner.js +0 -218
  420. package/dist/spinner/Spinner.stories.js +0 -183
  421. package/dist/spinner/readme.md +0 -65
  422. package/dist/switch/Switch.js +0 -222
  423. package/dist/switch/Switch.stories.js +0 -134
  424. package/dist/switch/readme.md +0 -133
  425. package/dist/tabs/Tabs.js +0 -343
  426. package/dist/tabs/Tabs.stories.js +0 -130
  427. package/dist/tabs/readme.md +0 -78
  428. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  429. package/dist/tabs-for-sections/readme.md +0 -78
  430. package/dist/tag/Tag.js +0 -288
  431. package/dist/textarea/Textarea.js +0 -264
  432. package/dist/toggle/Toggle.js +0 -220
  433. package/dist/toggle/Toggle.stories.js +0 -297
  434. package/dist/toggle/readme.md +0 -80
  435. package/dist/toggle-group/ToggleGroup.js +0 -223
  436. package/dist/upload/Upload.js +0 -205
  437. package/dist/upload/Upload.stories.js +0 -72
  438. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -139
  439. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  440. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  441. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  442. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  443. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  444. package/dist/upload/file-upload/FileToUpload.js +0 -184
  445. package/dist/upload/file-upload/audio-icon.svg +0 -4
  446. package/dist/upload/file-upload/close.svg +0 -4
  447. package/dist/upload/file-upload/file-icon.svg +0 -4
  448. package/dist/upload/file-upload/video-icon.svg +0 -4
  449. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  450. package/dist/upload/readme.md +0 -37
  451. package/dist/upload/transaction/Transaction.js +0 -175
  452. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  453. package/dist/upload/transaction/audio-icon.svg +0 -4
  454. package/dist/upload/transaction/error-icon.svg +0 -4
  455. package/dist/upload/transaction/file-icon-err.svg +0 -4
  456. package/dist/upload/transaction/file-icon.svg +0 -4
  457. package/dist/upload/transaction/image-icon-err.svg +0 -4
  458. package/dist/upload/transaction/image-icon.svg +0 -4
  459. package/dist/upload/transaction/success-icon.svg +0 -4
  460. package/dist/upload/transaction/video-icon-err.svg +0 -4
  461. package/dist/upload/transaction/video-icon.svg +0 -4
  462. package/dist/upload/transactions/Transactions.js +0 -138
  463. package/dist/wizard/Wizard.js +0 -411
  464. package/dist/wizard/invalid_icon.svg +0 -5
  465. package/dist/wizard/valid_icon.svg +0 -5
  466. package/dist/wizard/validation-wrong.svg +0 -6
  467. package/test/Accordion.test.js +0 -33
  468. package/test/AccordionGroup.test.js +0 -125
  469. package/test/Alert.test.js +0 -53
  470. package/test/Box.test.js +0 -10
  471. package/test/Button.test.js +0 -18
  472. package/test/Card.test.js +0 -30
  473. package/test/Checkbox.test.js +0 -45
  474. package/test/Chip.test.js +0 -25
  475. package/test/Date.test.js +0 -393
  476. package/test/Dialog.test.js +0 -23
  477. package/test/Dropdown.test.js +0 -145
  478. package/test/Footer.test.js +0 -99
  479. package/test/Header.test.js +0 -39
  480. package/test/Heading.test.js +0 -35
  481. package/test/InputText.test.js +0 -240
  482. package/test/Link.test.js +0 -43
  483. package/test/NewDate.test.js +0 -203
  484. package/test/NewInputText.test.js +0 -817
  485. package/test/NewTextarea.test.js +0 -201
  486. package/test/Number.test.js +0 -241
  487. package/test/Paginator.test.js +0 -177
  488. package/test/Password.test.js +0 -76
  489. package/test/ProgressBar.test.js +0 -35
  490. package/test/Radio.test.js +0 -37
  491. package/test/ResultsetTable.test.js +0 -330
  492. package/test/Select.test.js +0 -189
  493. package/test/Sidenav.test.js +0 -45
  494. package/test/Slider.test.js +0 -82
  495. package/test/Spinner.test.js +0 -27
  496. package/test/Switch.test.js +0 -45
  497. package/test/Table.test.js +0 -36
  498. package/test/Tabs.test.js +0 -109
  499. package/test/TabsForSections.test.js +0 -34
  500. package/test/Tag.test.js +0 -32
  501. package/test/TextArea.test.js +0 -52
  502. package/test/ToggleGroup.test.js +0 -81
  503. package/test/Upload.test.js +0 -60
  504. package/test/Wizard.test.js +0 -130
  505. package/test/mocks/pngMock.js +0 -1
  506. package/test/mocks/svgMock.js +0 -1
  507. /package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  508. /package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  509. /package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  510. /package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  511. /package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  512. /package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  513. /package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  514. /package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  515. /package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  516. /package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
@@ -1,817 +0,0 @@
1
- import React from "react";
2
- import { render, fireEvent, waitForElementToBeRemoved } from "@testing-library/react";
3
- import userEvent from "@testing-library/user-event";
4
-
5
- import DxcNewInputText from "../src/new-input-text/NewInputText";
6
-
7
- const countries = [
8
- "Afghanistan",
9
- "Albania",
10
- "Algeria",
11
- "Andorra",
12
- "Angola",
13
- "Antigua and Barbuda",
14
- "Bahamas",
15
- "Bahrain",
16
- "Bangladesh",
17
- "Barbados",
18
- "Cabo Verde",
19
- "Cambodia",
20
- "Cameroon",
21
- "Canada",
22
- "Cayman Islands, The",
23
- "Central African Republic",
24
- "Chad",
25
- "Democratic Republic of the Congo",
26
- "Dominican Republic",
27
- "Dominica",
28
- "Denmark",
29
- "Djibouti",
30
- ];
31
-
32
- describe("NewInputText component tests", () => {
33
- test("Renders with correct label", () => {
34
- const { getByText } = render(<DxcNewInputText label="Example label" />);
35
- expect(getByText("Example label")).toBeTruthy();
36
- });
37
- test("Renders with correct label and helper text", () => {
38
- const { getByText } = render(<DxcNewInputText label="Example label" helperText="Example helper text" />);
39
- expect(getByText("Example label")).toBeTruthy();
40
- expect(getByText("Example helper text")).toBeTruthy();
41
- });
42
- test("Renders with correct label and optional", () => {
43
- const { getByText } = render(<DxcNewInputText label="Example label" helperText="Example helper text" optional />);
44
- expect(getByText("Example label")).toBeTruthy();
45
- expect(getByText("(Optional)")).toBeTruthy();
46
- expect(getByText("Example helper text")).toBeTruthy();
47
- });
48
- test("Renders with correct placeholder", () => {
49
- const { getByRole } = render(<DxcNewInputText label="Example label" placeholder="Placeholder" />);
50
- const input = getByRole("textbox");
51
- expect(input.getAttribute("placeholder")).toBe("Placeholder");
52
- });
53
- test("Renders with error message", () => {
54
- const { getByText } = render(
55
- <DxcNewInputText label="Error label" placeholder="Placeholder" error="Error message." />
56
- );
57
- expect(getByText("Error message.")).toBeTruthy();
58
- });
59
- test("Input Strict - Pattern constraint", () => {
60
- const onChange = jest.fn();
61
- const onBlur = jest.fn();
62
- const { getByRole, getByText, queryByText } = render(
63
- <DxcNewInputText
64
- label="Input label"
65
- placeholder="Placeholder"
66
- onChange={onChange}
67
- onBlur={onBlur}
68
- margin={{ left: "medium", right: "medium" }}
69
- clearable
70
- pattern='^.*(?=.*[a-zA-Z])(?=.*\d)(?=.*[!&$%&? "]).*$'
71
- />
72
- );
73
- const input = getByRole("textbox");
74
- userEvent.type(input, "pattern test");
75
- fireEvent.blur(input);
76
- expect(getByText("Please match the format requested.")).toBeTruthy();
77
- userEvent.type(input, "pattern4&");
78
- fireEvent.blur(input);
79
- expect(queryByText("Please match the format requested.")).toBeFalsy();
80
- });
81
- test("Input Strict - Length constraint", () => {
82
- const onChange = jest.fn();
83
- const onBlur = jest.fn();
84
- const { getByRole, getByText, queryByText } = render(
85
- <DxcNewInputText
86
- label="Input label"
87
- placeholder="Placeholder"
88
- onChange={onChange}
89
- onBlur={onBlur}
90
- margin={{ left: "medium", right: "medium" }}
91
- clearable
92
- length={{ min: 5, max: 10 }}
93
- />
94
- );
95
- const input = getByRole("textbox");
96
- userEvent.type(input, "test");
97
- fireEvent.blur(input);
98
- expect(getByText("Min length 5, max length 10.")).toBeTruthy();
99
- userEvent.type(input, "test ");
100
- fireEvent.blur(input);
101
- expect(queryByText(/Min length /)).toBeFalsy();
102
- });
103
- test("Input Strict - Pattern and length constraints", () => {
104
- const onChange = jest.fn();
105
- const onBlur = jest.fn();
106
- const { getByRole, getByText, queryByText } = render(
107
- <DxcNewInputText
108
- label="Input label"
109
- placeholder="Placeholder"
110
- onChange={onChange}
111
- onBlur={onBlur}
112
- margin={{ left: "medium", right: "medium" }}
113
- clearable
114
- pattern='^.*(?=.*[a-zA-Z])(?=.*\d)(?=.*[!&$%&? "]).*$'
115
- length={{ min: 5, max: 10 }}
116
- />
117
- );
118
- const input = getByRole("textbox");
119
- userEvent.type(input, "test");
120
- fireEvent.blur(input);
121
- expect(getByText("Min length 5, max length 10.")).toBeTruthy();
122
- userEvent.type(input, "test ");
123
- fireEvent.blur(input);
124
- expect(getByText("Please match the format requested.")).toBeTruthy();
125
- userEvent.type(input, "test 4");
126
- fireEvent.blur(input);
127
- expect(queryByText("Please match the format requested.")).toBeFalsy();
128
- });
129
- test("Input Non Strict - Pattern constraint", () => {
130
- const onChange = jest.fn((value) => {
131
- expect(value).toBe("t");
132
- });
133
- const onBlur = jest.fn(({ value, error }) => {
134
- expect(value).toBe("t");
135
- expect(error).toBe("Please match the format requested.");
136
- });
137
- const { getByRole } = render(
138
- <DxcNewInputText
139
- label="Input label"
140
- placeholder="Placeholder"
141
- onChange={onChange}
142
- onBlur={onBlur}
143
- margin={{ left: "medium", right: "medium" }}
144
- clearable
145
- pattern='^.*(?=.*[a-zA-Z])(?=.*\d)(?=.*[!&$%&? "]).*$'
146
- />
147
- );
148
- const input = getByRole("textbox");
149
- userEvent.type(input, "t");
150
- fireEvent.blur(input);
151
- });
152
- test("Input Non Strict - Length constraint", () => {
153
- const onChange = jest.fn((value) => {
154
- expect(value).toBe("t");
155
- });
156
- const onBlur = jest.fn(({ value, error }) => {
157
- expect(value).toBe("t");
158
- expect(error).toBe("Min length 5, max length 10.");
159
- });
160
- const { getByRole } = render(
161
- <DxcNewInputText
162
- label="Input label"
163
- placeholder="Placeholder"
164
- onChange={onChange}
165
- onBlur={onBlur}
166
- margin={{ left: "medium", right: "medium" }}
167
- clearable
168
- length={{ min: 5, max: 10 }}
169
- />
170
- );
171
- const input = getByRole("textbox");
172
- userEvent.type(input, "t");
173
- fireEvent.blur(input);
174
- });
175
- test("Input Non Strict - Pattern and length constraints", () => {
176
- const onChange = jest.fn((value) => {
177
- expect(value).toBe("t");
178
- });
179
- const onBlur = jest.fn(({ value, error }) => {
180
- expect(value).toBe("t");
181
- expect(error).toBe("Min length 5, max length 10.");
182
- });
183
- const { getByRole } = render(
184
- <DxcNewInputText
185
- label="Input label"
186
- placeholder="Placeholder"
187
- onChange={onChange}
188
- onBlur={onBlur}
189
- margin={{ left: "medium", right: "medium" }}
190
- clearable
191
- length={{ min: 5, max: 10 }}
192
- />
193
- );
194
- const input = getByRole("textbox");
195
- userEvent.type(input, "t");
196
- fireEvent.blur(input);
197
- });
198
- test("onChange function is called correctly", () => {
199
- const onChange = jest.fn();
200
- const { getByRole } = render(<DxcNewInputText label="Input label" onChange={onChange} />);
201
- const input = getByRole("textbox");
202
- userEvent.type(input, "onchange event test");
203
- expect(input.value).toBe("onchange event test");
204
- expect(onChange).toHaveBeenCalled();
205
- expect(onChange).toHaveBeenCalledWith("onchange event test");
206
- });
207
- test("onBlur function is called correctly", () => {
208
- const onBlur = jest.fn();
209
- const onChange = jest.fn();
210
- const { getByRole } = render(<DxcNewInputText label="Input label" onChange={onChange} onBlur={onBlur} />);
211
- const input = getByRole("textbox");
212
- userEvent.type(input, "Test string");
213
- fireEvent.blur(input);
214
- expect(onBlur).toHaveBeenCalled();
215
- expect(onBlur).toHaveBeenCalledWith({ value: "Test string", error: null });
216
- });
217
- test("Uncontrolled input", () => {
218
- const onChange = jest.fn();
219
- const { getByRole } = render(<DxcNewInputText label="Input label" onChange={onChange} />);
220
- const input = getByRole("textbox");
221
- userEvent.type(input, "Uncontrolled test");
222
- expect(onChange).toHaveBeenCalled();
223
- expect(onChange).toHaveBeenCalledWith("Uncontrolled test");
224
- expect(input.value).toBe("Uncontrolled test");
225
- });
226
- test("Controlled input", () => {
227
- const onChange = jest.fn();
228
- const onBlur = jest.fn();
229
- const { getByRole } = render(
230
- <DxcNewInputText label="Input label" value="Test value" onChange={onChange} onBlur={onBlur} />
231
- );
232
- const input = getByRole("textbox");
233
- userEvent.type(input, "Example text");
234
- expect(onChange).toHaveBeenCalled();
235
- expect(input.value).toBe("Test value");
236
- fireEvent.blur(input);
237
- expect(onBlur).toHaveBeenCalled();
238
- expect(onBlur).toHaveBeenCalledWith({ value: "Test value", error: null });
239
- });
240
- test("Clear action onClick cleans the input", () => {
241
- const { getByRole } = render(<DxcNewInputText label="Input label" clearable />);
242
- const input = getByRole("textbox");
243
- userEvent.type(input, "Test");
244
- const closeAction = getByRole("button");
245
- userEvent.click(closeAction);
246
- expect(input.value).toBe("");
247
- });
248
- test("Disabled input (action must be shown but not clickable)", () => {
249
- const onClick = jest.fn();
250
- const action = {
251
- onClick: onClick,
252
- icon: (
253
- <svg
254
- data-testid="image"
255
- xmlns="http://www.w3.org/2000/svg"
256
- height="24px"
257
- viewBox="0 0 24 24"
258
- width="24px"
259
- fill="currentColor"
260
- >
261
- <path d="M0 0h24v24H0V0z" fill="none" />
262
- <path d="M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z" />
263
- </svg>
264
- ),
265
- };
266
- const { getByRole } = render(<DxcNewInputText label="Disabled input label" action={action} disabled />);
267
- const input = getByRole("textbox");
268
- expect(input.disabled).toBeTruthy();
269
- userEvent.click(getByRole("button"));
270
- expect(onClick).not.toHaveBeenCalled();
271
- });
272
- test("Disabled input (clear default action should not be displayed, even with text written on the input)", () => {
273
- const { getByRole, queryByRole } = render(
274
- <DxcNewInputText label="Disabled input label" value="Sample text" disabled clearable />
275
- );
276
- const input = getByRole("textbox");
277
- expect(input.disabled).toBeTruthy();
278
- expect(queryByRole("button")).toBeFalsy();
279
- });
280
- test("Disabled input (suffix and preffix must be displayed)", () => {
281
- const { getByRole, getByText } = render(
282
- <DxcNewInputText label="Disabled input label" value="Sample text" prefix="+34" suffix="USD" disabled />
283
- );
284
- const input = getByRole("textbox");
285
- expect(input.disabled).toBeTruthy();
286
- expect(getByText("+34")).toBeTruthy();
287
- expect(getByText("USD")).toBeTruthy();
288
- });
289
- test("Action prop: image displayed and onClick event", () => {
290
- const onClick = jest.fn();
291
- const action = {
292
- onClick: onClick,
293
- icon: (
294
- <svg
295
- data-testid="image"
296
- xmlns="http://www.w3.org/2000/svg"
297
- height="24px"
298
- viewBox="0 0 24 24"
299
- width="24px"
300
- fill="currentColor"
301
- >
302
- <path d="M0 0h24v24H0V0z" fill="none" />
303
- <path d="M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z" />
304
- </svg>
305
- ),
306
- };
307
- const { getByRole, getByTestId } = render(<DxcNewInputText label="Input label" action={action} />);
308
- expect(getByTestId("image")).toBeTruthy();
309
- userEvent.click(getByRole("button"));
310
- expect(onClick).toHaveBeenCalled();
311
- });
312
- test("Renders with correct prefix and suffix (text)", () => {
313
- const { getByText } = render(<DxcNewInputText label="Input label" prefix="+34" suffix="USD" />);
314
- expect(getByText("+34")).toBeTruthy();
315
- expect(getByText("USD")).toBeTruthy();
316
- });
317
- test("Renders with correct prefix (icon)", () => {
318
- const { getByTestId } = render(
319
- <DxcNewInputText
320
- label="Input label"
321
- prefix={
322
- <svg
323
- data-testid="image"
324
- version="1.1"
325
- x="0px"
326
- y="0px"
327
- width="24px"
328
- height="24px"
329
- viewBox="0 0 24 24"
330
- enable-background="new 0 0 24 24"
331
- >
332
- <g id="Bounding_Box">
333
- <rect fill="none" width="24" height="24" />
334
- </g>
335
- <g id="Master">
336
- <path d="M19,9.3V4h-3v2.6L12,3L2,12h3v8h5v-6h4v6h5v-8h3L19,9.3z M10,10c0-1.1,0.9-2,2-2s2,0.9,2,2H10z" />
337
- </g>
338
- </svg>
339
- }
340
- />
341
- );
342
- expect(getByTestId("image")).toBeTruthy();
343
- });
344
- test("Renders with correct suffix (icon)", () => {
345
- const { getByTestId } = render(
346
- <DxcNewInputText
347
- label="Input label"
348
- suffix={
349
- <svg
350
- data-testid="image"
351
- version="1.1"
352
- x="0px"
353
- y="0px"
354
- width="24px"
355
- height="24px"
356
- viewBox="0 0 24 24"
357
- enable-background="new 0 0 24 24"
358
- >
359
- <g id="Bounding_Box">
360
- <rect fill="none" width="24" height="24" />
361
- </g>
362
- <g id="Master">
363
- <path d="M19,9.3V4h-3v2.6L12,3L2,12h3v8h5v-6h4v6h5v-8h3L19,9.3z M10,10c0-1.1,0.9-2,2-2s2,0.9,2,2H10z" />
364
- </g>
365
- </svg>
366
- }
367
- />
368
- );
369
- expect(getByTestId("image")).toBeTruthy();
370
- });
371
- test("Input has correct accesibility attributes", () => {
372
- const onClick = jest.fn();
373
- const action = {
374
- onClick: onClick,
375
- icon: (
376
- <svg
377
- data-testid="image"
378
- xmlns="http://www.w3.org/2000/svg"
379
- height="24px"
380
- viewBox="0 0 24 24"
381
- width="24px"
382
- fill="currentColor"
383
- >
384
- <path d="M0 0h24v24H0V0z" fill="none" />
385
- <path d="M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z" />
386
- </svg>
387
- ),
388
- };
389
- const { getByRole, getAllByRole } = render(
390
- <DxcNewInputText label="Example label" clearable action={action} error="Error message." />
391
- );
392
- const input = getByRole("textbox");
393
- expect(input.getAttribute("aria-autocomplete")).toBeNull();
394
- expect(input.getAttribute("aria-controls")).toBeNull();
395
- expect(input.getAttribute("aria-expanded")).toBeNull();
396
- expect(input.getAttribute("aria-expanded")).toBeNull();
397
- userEvent.type(input, "Text");
398
- const clear = getAllByRole("button")[0];
399
- expect(clear.getAttribute("aria-label")).toBe("Clear");
400
- });
401
- test("Autosuggest has correct accesibility attributes", () => {
402
- const { getByRole, getAllByRole } = render(
403
- <DxcNewInputText label="Autocomplete Countries" suggestions={countries} />
404
- );
405
- const input = getByRole("combobox");
406
- const inputId = input.id;
407
- expect(input.getAttribute("aria-autocomplete")).toBe("list");
408
- expect(input.getAttribute("aria-controls")).toBe(inputId);
409
- expect(input.getAttribute("aria-expanded")).toBe("false");
410
- fireEvent.focus(input);
411
- const list = getByRole("listbox");
412
- expect(list.getAttribute("aria-label")).toBe("Autocomplete Countries");
413
- const options = getAllByRole("option");
414
- expect(options[0].getAttribute("aria-selected")).toBe("false");
415
- });
416
- });
417
-
418
- describe("NewInputText component synchronous autosuggest tests", () => {
419
- test("Autosuggest is displayed when the input gains focus", async () => {
420
- const onChange = jest.fn();
421
- const { getByRole, getByText } = render(
422
- <DxcNewInputText label="Autocomplete Countries" suggestions={countries} onChange={onChange} />
423
- );
424
- const input = getByRole("combobox");
425
- fireEvent.focus(input);
426
- const list = getByRole("listbox");
427
- expect(list).toBeTruthy();
428
- expect(getByText("Afghanistan")).toBeTruthy();
429
- expect(getByText("Albania")).toBeTruthy();
430
- expect(getByText("Algeria")).toBeTruthy();
431
- expect(getByText("Andorra")).toBeTruthy();
432
- });
433
- test("Autosuggest is displayed when the user clicks the input", async () => {
434
- const onChange = jest.fn();
435
- const { getByRole, getByText } = render(
436
- <DxcNewInputText label="Autocomplete Countries" suggestions={countries} onChange={onChange} />
437
- );
438
- const input = getByRole("combobox");
439
- userEvent.click(input);
440
- const list = getByRole("listbox");
441
- expect(list).toBeTruthy();
442
- expect(getByText("Afghanistan")).toBeTruthy();
443
- expect(getByText("Albania")).toBeTruthy();
444
- expect(getByText("Algeria")).toBeTruthy();
445
- expect(getByText("Andorra")).toBeTruthy();
446
- });
447
- test("Autosuggest is displayed while the user is writing (if closed previously, if open stays open)", async () => {
448
- const onChange = jest.fn();
449
- const { getByRole, queryByRole, getByText, getAllByText } = render(
450
- <DxcNewInputText label="Autocomplete Countries" suggestions={countries} onChange={onChange} />
451
- );
452
- const input = getByRole("combobox");
453
- fireEvent.focus(input);
454
- const list = getByRole("listbox");
455
- expect(list).toBeTruthy();
456
- fireEvent.keyDown(input, { key: "Esc", code: "Esc", keyCode: 27, charCode: 27 });
457
- expect(queryByRole("listbox")).toBeFalsy();
458
- userEvent.type(input, "B");
459
- expect(list).toBeTruthy();
460
- expect(getAllByText("B").length).toBe(4);
461
- expect(getByText("ahamas")).toBeTruthy();
462
- expect(getByText("ahrain")).toBeTruthy();
463
- expect(getByText("angladesh")).toBeTruthy();
464
- expect(getByText("arbados")).toBeTruthy();
465
- });
466
- test("Autosuggest is not displayed when prop suggestions is an empty array", async () => {
467
- const onChange = jest.fn();
468
- const { queryByRole } = render(
469
- <DxcNewInputText label="Autocomplete Countries" suggestions={[]} onChange={onChange} />
470
- );
471
- const input = queryByRole("textbox");
472
- fireEvent.focus(input);
473
- expect(queryByRole("listbox")).toBeFalsy();
474
- });
475
- test("Autosuggest shows 'No results found' message when there are no matches with the user's input", async () => {
476
- const onChange = jest.fn();
477
- const { getByRole, getByText } = render(
478
- <DxcNewInputText label="Autocomplete Countries" suggestions={countries} onChange={onChange} />
479
- );
480
- const input = getByRole("combobox");
481
- fireEvent.focus(input);
482
- const list = getByRole("listbox");
483
- expect(list).toBeTruthy();
484
- expect(getByText("Afghanistan")).toBeTruthy();
485
- userEvent.type(input, "x");
486
- expect(list).toBeTruthy();
487
- expect(getByText("No results found")).toBeTruthy();
488
- });
489
- test("Autosuggest uncontrolled suggestion selected", async () => {
490
- const onChange = jest.fn();
491
- const { getByRole, getByText, queryByRole } = render(
492
- <DxcNewInputText label="Autocomplete Countries" suggestions={countries} onChange={onChange} />
493
- );
494
- const input = getByRole("combobox");
495
- fireEvent.focus(input);
496
- userEvent.type(input, "Alba");
497
- expect(onChange).toHaveBeenCalled();
498
- expect(getByText("Alba")).toBeTruthy();
499
- expect(getByText("nia")).toBeTruthy();
500
- fireEvent.mouseDown(getByRole("option"));
501
- fireEvent.mouseUp(getByRole("option"));
502
- expect(input.value).toBe("Albania");
503
- expect(queryByRole("listbox")).toBeFalsy();
504
- });
505
- test("Autosuggest controlled suggestions selected", async () => {
506
- const onChange = jest.fn();
507
- const { getByRole, getByText, queryByRole } = render(
508
- <DxcNewInputText label="Autocomplete Countries" value="Andor" suggestions={countries} onChange={onChange} />
509
- );
510
- const input = getByRole("combobox");
511
- fireEvent.focus(input);
512
- expect(input.value).toBe("Andor");
513
- expect(getByText("Andor")).toBeTruthy();
514
- expect(getByText("ra")).toBeTruthy();
515
- fireEvent.mouseDown(getByRole("option"));
516
- fireEvent.mouseUp(getByRole("option"));
517
- expect(onChange).toHaveBeenCalledWith("Andorra");
518
- expect(queryByRole("listbox")).toBeFalsy();
519
- });
520
- test("Autosuggest Strict - Pattern constraint", async () => {
521
- const onChange = jest.fn();
522
- const { getByRole, getByText, queryByText } = render(
523
- <DxcNewInputText
524
- label="Autocomplete Countries"
525
- value="Andor"
526
- suggestions={countries}
527
- onChange={onChange}
528
- pattern='^.*(?=.*[a-zA-Z])(?=.*\d)(?=.*[!&$%&? "]).*$'
529
- />
530
- );
531
- const input = getByRole("combobox");
532
- fireEvent.focus(input);
533
- userEvent.type(input, "Andor");
534
- expect(getByText("Andor")).toBeTruthy();
535
- expect(getByText("ra")).toBeTruthy();
536
- fireEvent.mouseDown(getByRole("option"));
537
- fireEvent.mouseUp(getByRole("option"));
538
- expect(onChange).toHaveBeenCalledWith("Andorra");
539
- fireEvent.blur(input);
540
- expect(queryByText("Please match the format requested.")).toBeTruthy();
541
- });
542
- test("Autosuggest Strict - Length constraint", async () => {
543
- const onChange = jest.fn();
544
- const { getByRole, queryByText } = render(
545
- <DxcNewInputText
546
- label="Autocomplete Countries"
547
- value="Cha"
548
- suggestions={countries}
549
- onChange={onChange}
550
- length={{ min: 5, max: 10 }}
551
- />
552
- );
553
- const input = getByRole("combobox");
554
- fireEvent.focus(input);
555
- userEvent.type(input, "d");
556
- const option = getByRole("option");
557
- fireEvent.mouseDown(option);
558
- fireEvent.mouseUp(option);
559
- expect(onChange).toHaveBeenCalledWith("Chad");
560
- fireEvent.blur(input);
561
- expect(queryByText("Min length 5, max length 10.")).toBeTruthy();
562
- });
563
- test("Autosuggest keys: arrow down key opens autosuggest, active first option is selected with Enter and closes the autosuggest", async () => {
564
- Element.prototype.scrollTo = () => {};
565
- const onChange = jest.fn();
566
- const { getByRole, queryByRole } = render(
567
- <DxcNewInputText label="Autocomplete Countries" suggestions={countries} onChange={onChange} />
568
- );
569
- const input = getByRole("combobox");
570
- fireEvent.keyDown(input, { key: "ArrowDown", code: "ArrowDown", keyCode: 40, charCode: 40 });
571
- const list = getByRole("listbox");
572
- expect(list).toBeTruthy();
573
- fireEvent.keyDown(input, { key: "Enter", code: "Enter", keyCode: 13, charCode: 13 });
574
- expect(input.value).toBe("Afghanistan");
575
- expect(queryByRole("list")).toBeFalsy();
576
- });
577
- test("Autosuggest keys: arrow up key opens autosuggest, active last option is selected with Enter and closes the autosuggest", async () => {
578
- Element.prototype.scrollTo = () => {};
579
- const onChange = jest.fn();
580
- const { getByRole, queryByRole } = render(
581
- <DxcNewInputText label="Autocomplete Countries" suggestions={countries} onChange={onChange} />
582
- );
583
- const input = getByRole("combobox");
584
- fireEvent.keyDown(input, { key: "ArrowUp", code: "ArrowUp", keyCode: 38, charCode: 38 });
585
- const list = getByRole("listbox");
586
- expect(list).toBeTruthy();
587
- fireEvent.keyDown(input, { key: "Enter", code: "Enter", keyCode: 13, charCode: 13 });
588
- expect(input.value).toBe("Djibouti");
589
- expect(queryByRole("list")).toBeFalsy();
590
- });
591
- test("Autosuggest keys: Esc key closes the autosuggest and cleans the input", async () => {
592
- Element.prototype.scrollTo = () => {};
593
- const onChange = jest.fn();
594
- const { getByRole, queryByRole } = render(
595
- <DxcNewInputText label="Autocomplete Countries" suggestions={countries} onChange={onChange} />
596
- );
597
- const input = getByRole("combobox");
598
- fireEvent.focus(input);
599
- userEvent.type(input, "Bangla");
600
- const list = getByRole("listbox");
601
- expect(list).toBeTruthy();
602
- fireEvent.keyDown(input, { key: "Esc", code: "Esc", keyCode: 27, charCode: 27 });
603
- expect(input.value).toBe("");
604
- expect(queryByRole("listbox")).toBeFalsy();
605
- });
606
- test("Autosuggest keys: Enter, if no active suggestion closes the autosuggest", async () => {
607
- Element.prototype.scrollTo = () => {};
608
- const onChange = jest.fn();
609
- const { getByRole, queryByRole } = render(
610
- <DxcNewInputText label="Autocomplete Countries" suggestions={countries} onChange={onChange} />
611
- );
612
- const input = getByRole("combobox");
613
- fireEvent.focus(input);
614
- const list = getByRole("listbox");
615
- expect(list).toBeTruthy();
616
- fireEvent.keyDown(input, { key: "Enter", code: "Enter", keyCode: 27, charCode: 27 });
617
- expect(input.value).toBe("");
618
- expect(queryByRole("list")).toBeFalsy();
619
- });
620
- test("Autosuggest complex key secuence: write, arrow up two times, arrow down and select with Enter. Then, clean with Esc.", async () => {
621
- Element.prototype.scrollTo = () => {};
622
- const onChange = jest.fn();
623
- const { getByRole, queryByRole } = render(
624
- <DxcNewInputText label="Autocomplete Countries" suggestions={countries} onChange={onChange} />
625
- );
626
- const input = getByRole("combobox");
627
- fireEvent.focus(input);
628
- userEvent.type(input, "Ba");
629
- fireEvent.keyDown(input, { key: "ArrowUp", code: "ArrowUp", keyCode: 38, charCode: 38 });
630
- fireEvent.keyDown(input, { key: "ArrowUp", code: "ArrowUp", keyCode: 38, charCode: 38 });
631
- fireEvent.keyDown(input, { key: "ArrowDown", code: "ArrowDown", keyCode: 40, charCode: 40 });
632
- fireEvent.keyDown(input, { key: "Enter", code: "Enter", keyCode: 13, charCode: 13 });
633
- expect(input.value).toBe("Barbados");
634
- expect(queryByRole("listbox")).toBeFalsy();
635
- fireEvent.keyDown(input, { key: "Esc", code: "Esp", keyCode: 27, charCode: 27 });
636
- expect(input.value).toBe("");
637
- expect(queryByRole("listbox")).toBeFalsy();
638
- });
639
- });
640
-
641
- describe("NewInputText component asynchronous autosuggest tests", () => {
642
- test("Autosuggest 'Searching...' message is shown", async () => {
643
- const callbackFunc = jest.fn((newValue) => {
644
- const result = new Promise((resolve) =>
645
- setTimeout(() => {
646
- resolve(
647
- newValue ? countries.filter((option) => option.toUpperCase().includes(newValue.toUpperCase())) : countries
648
- );
649
- }, 1000)
650
- );
651
- return result;
652
- });
653
- const onChange = jest.fn();
654
- const { getByRole, getByText } = render(
655
- <DxcNewInputText label="Autosuggest Countries" suggestions={callbackFunc} onChange={onChange} />
656
- );
657
- const input = getByRole("combobox");
658
- fireEvent.focus(input);
659
- expect(getByRole("listbox")).toBeTruthy();
660
- await waitForElementToBeRemoved(() => getByText("Searching..."));
661
- expect(getByText("Afghanistan")).toBeTruthy();
662
- expect(getByText("Albania")).toBeTruthy();
663
- expect(getByText("Algeria")).toBeTruthy();
664
- expect(getByText("Andorra")).toBeTruthy();
665
- userEvent.type(input, "Ab");
666
- await waitForElementToBeRemoved(() => getByText("Searching..."));
667
- expect(getByText("Cabo Verde")).toBeTruthy();
668
- fireEvent.keyDown(input, { key: "ArrowUp", code: "ArrowUp", keyCode: 38, charCode: 38 });
669
- fireEvent.keyDown(input, { key: "Enter", code: "Enter", keyCode: 13, charCode: 13 });
670
- expect(input.value).toBe("Cabo Verde");
671
- });
672
- test("Autosuggest Esc key works while 'Searching...' message is shown", async () => {
673
- const callbackFunc = jest.fn((newValue) => {
674
- const result = new Promise((resolve) =>
675
- setTimeout(() => {
676
- resolve(
677
- newValue ? countries.filter((option) => option.toUpperCase().includes(newValue.toUpperCase())) : countries
678
- );
679
- }, 1000)
680
- );
681
- return result;
682
- });
683
- const onChange = jest.fn();
684
- const { getByRole, queryByText, queryByRole } = render(
685
- <DxcNewInputText label="Autosuggest Countries" suggestions={callbackFunc} onChange={onChange} />
686
- );
687
- const input = getByRole("combobox");
688
- fireEvent.focus(input);
689
- expect(getByRole("listbox")).toBeTruthy();
690
- userEvent.type(input, "Ab");
691
- fireEvent.keyDown(input, { key: "Esc", code: "Esc", keyCode: 27, charCode: 27 });
692
- expect(queryByRole("listbox")).toBeFalsy();
693
- expect(queryByText("Searching...")).toBeFalsy();
694
- expect(input.value).toBe("");
695
- });
696
- test("Autosuggest Esc + arrow down working while 'Searching...' message is shown", async () => {
697
- const callbackFunc = jest.fn((newValue) => {
698
- const result = new Promise((resolve) =>
699
- setTimeout(() => {
700
- resolve(
701
- newValue ? countries.filter((option) => option.toUpperCase().includes(newValue.toUpperCase())) : countries
702
- );
703
- }, 1000)
704
- );
705
- return result;
706
- });
707
- const onChange = jest.fn();
708
- const { getByRole, getByText, queryByText, queryByRole } = render(
709
- <DxcNewInputText label="Autosuggest Countries" suggestions={callbackFunc} onChange={onChange} />
710
- );
711
- const input = getByRole("combobox");
712
- fireEvent.focus(input);
713
- const list = getByRole("listbox");
714
- expect(list).toBeTruthy();
715
- userEvent.type(input, "Ab");
716
- fireEvent.keyDown(input, { key: "Esc", code: "Esc", keyCode: 27, charCode: 27 });
717
- expect(queryByRole("listbox")).toBeFalsy();
718
- expect(queryByText("Searching...")).toBeFalsy();
719
- expect(input.value).toBe("");
720
- fireEvent.keyDown(input, { key: "ArrowDown", code: "ArrowDown", keyCode: 40, charCode: 40 });
721
- expect(list).toBeTruthy();
722
- await waitForElementToBeRemoved(() => getByText("Searching..."));
723
- expect(getByText("Afghanistan")).toBeTruthy();
724
- expect(getByText("Albania")).toBeTruthy();
725
- expect(getByText("Algeria")).toBeTruthy();
726
- expect(getByText("Andorra")).toBeTruthy();
727
- });
728
- test("Asynchronous uncontrolled autosuggest test", async () => {
729
- const callbackFunc = jest.fn((newValue) => {
730
- const result = new Promise((resolve) =>
731
- setTimeout(() => {
732
- resolve(
733
- newValue ? countries.filter((option) => option.toUpperCase().includes(newValue.toUpperCase())) : countries
734
- );
735
- }, 1000)
736
- );
737
- return result;
738
- });
739
- const onChange = jest.fn();
740
- const { getByRole, getByText } = render(
741
- <DxcNewInputText label="Autosuggest Countries" onChange={onChange} suggestions={callbackFunc} />
742
- );
743
- const input = getByRole("combobox");
744
- fireEvent.focus(input);
745
- userEvent.type(input, "Den");
746
- await waitForElementToBeRemoved(() => getByText("Searching..."));
747
- expect(getByText("Denmark")).toBeTruthy();
748
- fireEvent.mouseDown(getByRole("option"));
749
- fireEvent.mouseUp(getByRole("option"));
750
- expect(onChange).toHaveBeenCalledWith("Denmark");
751
- expect(input.value).toBe("Denmark");
752
- });
753
- test("Asynchronous controlled autosuggest test", async () => {
754
- const callbackFunc = jest.fn((newValue) => {
755
- const result = new Promise((resolve) =>
756
- setTimeout(() => {
757
- resolve(
758
- newValue ? countries.filter((option) => option.toUpperCase().includes(newValue.toUpperCase())) : countries
759
- );
760
- }, 1000)
761
- );
762
- return result;
763
- });
764
- const onChange = jest.fn();
765
- const { getByRole, getByText, queryByRole } = render(
766
- <DxcNewInputText label="Autosuggest Countries" value="Denm" onChange={onChange} suggestions={callbackFunc} />
767
- );
768
- const input = getByRole("combobox");
769
- fireEvent.focus(input);
770
- await waitForElementToBeRemoved(() => getByText("Searching..."));
771
- expect(input.value).toBe("Denm");
772
- expect(getByText("Denmark")).toBeTruthy();
773
- fireEvent.mouseDown(getByRole("option"));
774
- fireEvent.mouseUp(getByRole("option"));
775
- expect(onChange).toHaveBeenCalledWith("Denmark");
776
- expect(queryByRole("listbox")).toBeFalsy();
777
- });
778
- test("Asynchronous autosuggest shows 'No results found' after finishing no matches search", async () => {
779
- const callbackFunc = jest.fn((newValue) => {
780
- const result = new Promise((resolve) =>
781
- setTimeout(() => {
782
- resolve(
783
- newValue ? countries.filter((option) => option.toUpperCase().includes(newValue.toUpperCase())) : countries
784
- );
785
- }, 1000)
786
- );
787
- return result;
788
- });
789
- const onChange = jest.fn();
790
- const { getByRole, getByText } = render(
791
- <DxcNewInputText label="Autosuggest Countries" onChange={onChange} suggestions={callbackFunc} />
792
- );
793
- const input = getByRole("combobox");
794
- fireEvent.focus(input);
795
- userEvent.type(input, "Example text");
796
- await waitForElementToBeRemoved(() => getByText("Searching..."));
797
- expect(getByText("No results found")).toBeTruthy();
798
- });
799
- test("Asynchronous autosuggest request failed, shows 'Error fetching data' message", async () => {
800
- const errorCallbackFunc = jest.fn(() => {
801
- const result = new Promise((resolve, reject) =>
802
- setTimeout(() => {
803
- reject("err");
804
- }, 1000)
805
- );
806
- return result;
807
- });
808
- const onChange = jest.fn();
809
- const { getByRole, getByText } = render(
810
- <DxcNewInputText label="Autosuggest Countries" onChange={onChange} suggestions={errorCallbackFunc} />
811
- );
812
- const input = getByRole("combobox");
813
- fireEvent.focus(input);
814
- await waitForElementToBeRemoved(() => getByText("Searching..."));
815
- expect(getByText("Error fetching data")).toBeTruthy();
816
- });
817
- });