@dxc-technology/halstack-react 0.0.0-f4bae62 → 0.0.0-f4dcdd7

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