@dxc-technology/halstack-react 0.0.0-c6243ef → 0.0.0-c667373

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 (717) hide show
  1. package/BackgroundColorContext.d.ts +1 -0
  2. package/BackgroundColorContext.js +30 -0
  3. package/HalstackContext.d.ts +1280 -0
  4. package/HalstackContext.js +320 -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/bar-chart/BarChart.d.ts +4 -0
  56. package/bar-chart/BarChart.js +152 -0
  57. package/bar-chart/BarChart.stories.tsx +281 -0
  58. package/bar-chart/BarChart.test.d.ts +1 -0
  59. package/bar-chart/BarChart.test.js +194 -0
  60. package/bar-chart/theme.d.ts +3 -0
  61. package/bar-chart/theme.js +31 -0
  62. package/bar-chart/types.d.ts +118 -0
  63. package/bar-chart/types.js +5 -0
  64. package/bleed/Bleed.d.ts +3 -0
  65. package/bleed/Bleed.js +43 -0
  66. package/bleed/Bleed.stories.tsx +341 -0
  67. package/bleed/types.d.ts +37 -0
  68. package/bleed/types.js +5 -0
  69. package/box/Box.accessibility.test.d.ts +1 -0
  70. package/box/Box.accessibility.test.js +33 -0
  71. package/box/Box.d.ts +4 -0
  72. package/box/Box.js +75 -0
  73. package/box/Box.stories.tsx +119 -0
  74. package/box/Box.test.d.ts +1 -0
  75. package/box/Box.test.js +13 -0
  76. package/box/types.d.ts +32 -0
  77. package/box/types.js +5 -0
  78. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  79. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  80. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  81. package/breadcrumbs/Breadcrumbs.js +79 -0
  82. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  83. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  84. package/breadcrumbs/Breadcrumbs.test.js +168 -0
  85. package/breadcrumbs/Item.d.ts +4 -0
  86. package/breadcrumbs/Item.js +52 -0
  87. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  88. package/breadcrumbs/dropdownTheme.js +62 -0
  89. package/breadcrumbs/types.d.ts +40 -0
  90. package/breadcrumbs/types.js +5 -0
  91. package/bulleted-list/BulletedList.accessibility.test.d.ts +1 -0
  92. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  93. package/bulleted-list/BulletedList.d.ts +7 -0
  94. package/bulleted-list/BulletedList.js +92 -0
  95. package/bulleted-list/BulletedList.stories.tsx +115 -0
  96. package/bulleted-list/types.d.ts +38 -0
  97. package/bulleted-list/types.js +5 -0
  98. package/button/Button.accessibility.test.d.ts +1 -0
  99. package/button/Button.accessibility.test.js +127 -0
  100. package/button/Button.d.ts +4 -0
  101. package/button/Button.js +121 -0
  102. package/button/Button.stories.tsx +325 -0
  103. package/button/Button.test.d.ts +1 -0
  104. package/button/Button.test.js +38 -0
  105. package/button/types.d.ts +57 -0
  106. package/button/types.js +5 -0
  107. package/card/Card.accessibility.test.d.ts +1 -0
  108. package/card/Card.accessibility.test.js +36 -0
  109. package/card/Card.d.ts +4 -0
  110. package/card/Card.js +121 -0
  111. package/card/Card.stories.tsx +171 -0
  112. package/card/Card.test.d.ts +1 -0
  113. package/card/Card.test.js +39 -0
  114. package/card/types.d.ts +62 -0
  115. package/card/types.js +5 -0
  116. package/checkbox/Checkbox.accessibility.test.d.ts +1 -0
  117. package/checkbox/Checkbox.accessibility.test.js +87 -0
  118. package/checkbox/Checkbox.d.ts +4 -0
  119. package/checkbox/Checkbox.js +212 -0
  120. package/checkbox/Checkbox.stories.tsx +222 -0
  121. package/checkbox/Checkbox.test.d.ts +1 -0
  122. package/checkbox/Checkbox.test.js +199 -0
  123. package/checkbox/types.d.ts +72 -0
  124. package/checkbox/types.js +5 -0
  125. package/chip/Chip.accessibility.test.d.ts +1 -0
  126. package/chip/Chip.accessibility.test.js +67 -0
  127. package/chip/Chip.d.ts +4 -0
  128. package/chip/Chip.js +126 -0
  129. package/chip/Chip.stories.tsx +195 -0
  130. package/chip/Chip.test.d.ts +1 -0
  131. package/chip/Chip.test.js +41 -0
  132. package/chip/types.d.ts +45 -0
  133. package/chip/types.js +5 -0
  134. package/common/coreTokens.d.ts +236 -0
  135. package/common/coreTokens.js +183 -0
  136. package/common/utils.d.ts +1 -0
  137. package/{dist/common → common}/utils.js +6 -12
  138. package/common/variables.d.ts +1432 -0
  139. package/common/variables.js +1298 -0
  140. package/container/Container.d.ts +4 -0
  141. package/container/Container.js +194 -0
  142. package/container/Container.stories.tsx +214 -0
  143. package/container/types.d.ts +176 -0
  144. package/container/types.js +5 -0
  145. package/contextual-menu/ContextualMenu.accessibility.test.d.ts +1 -0
  146. package/contextual-menu/ContextualMenu.accessibility.test.js +98 -0
  147. package/contextual-menu/ContextualMenu.d.ts +5 -0
  148. package/contextual-menu/ContextualMenu.js +136 -0
  149. package/contextual-menu/ContextualMenu.stories.tsx +231 -0
  150. package/contextual-menu/ContextualMenu.test.d.ts +1 -0
  151. package/contextual-menu/ContextualMenu.test.js +247 -0
  152. package/contextual-menu/GroupItem.d.ts +4 -0
  153. package/contextual-menu/GroupItem.js +67 -0
  154. package/contextual-menu/ItemAction.d.ts +4 -0
  155. package/contextual-menu/ItemAction.js +88 -0
  156. package/contextual-menu/MenuItem.d.ts +4 -0
  157. package/contextual-menu/MenuItem.js +29 -0
  158. package/contextual-menu/SingleItem.d.ts +4 -0
  159. package/contextual-menu/SingleItem.js +38 -0
  160. package/contextual-menu/types.d.ts +65 -0
  161. package/contextual-menu/types.js +5 -0
  162. package/date-input/Calendar.d.ts +4 -0
  163. package/date-input/Calendar.js +230 -0
  164. package/date-input/DateInput.accessibility.test.d.ts +1 -0
  165. package/date-input/DateInput.accessibility.test.js +229 -0
  166. package/date-input/DateInput.d.ts +4 -0
  167. package/date-input/DateInput.js +228 -0
  168. package/date-input/DateInput.stories.tsx +291 -0
  169. package/date-input/DateInput.test.d.ts +1 -0
  170. package/date-input/DateInput.test.js +808 -0
  171. package/date-input/DatePicker.d.ts +4 -0
  172. package/date-input/DatePicker.js +121 -0
  173. package/date-input/YearPicker.d.ts +4 -0
  174. package/date-input/YearPicker.js +105 -0
  175. package/date-input/types.d.ts +164 -0
  176. package/date-input/types.js +5 -0
  177. package/dialog/Dialog.accessibility.test.d.ts +1 -0
  178. package/dialog/Dialog.accessibility.test.js +69 -0
  179. package/dialog/Dialog.d.ts +4 -0
  180. package/dialog/Dialog.js +93 -0
  181. package/dialog/Dialog.stories.tsx +369 -0
  182. package/dialog/Dialog.test.d.ts +1 -0
  183. package/dialog/Dialog.test.js +370 -0
  184. package/dialog/types.d.ts +36 -0
  185. package/dialog/types.js +5 -0
  186. package/divider/Divider.accessibility.test.d.ts +1 -0
  187. package/divider/Divider.accessibility.test.js +33 -0
  188. package/divider/Divider.d.ts +4 -0
  189. package/divider/Divider.js +36 -0
  190. package/divider/Divider.stories.tsx +224 -0
  191. package/divider/Divider.test.d.ts +1 -0
  192. package/divider/Divider.test.js +38 -0
  193. package/divider/types.d.ts +21 -0
  194. package/divider/types.js +5 -0
  195. package/dropdown/Dropdown.accessibility.test.d.ts +1 -0
  196. package/dropdown/Dropdown.accessibility.test.js +183 -0
  197. package/dropdown/Dropdown.d.ts +4 -0
  198. package/dropdown/Dropdown.js +320 -0
  199. package/dropdown/Dropdown.stories.tsx +427 -0
  200. package/dropdown/Dropdown.test.d.ts +1 -0
  201. package/dropdown/Dropdown.test.js +628 -0
  202. package/dropdown/DropdownMenu.d.ts +4 -0
  203. package/dropdown/DropdownMenu.js +63 -0
  204. package/dropdown/DropdownMenuItem.d.ts +4 -0
  205. package/dropdown/DropdownMenuItem.js +71 -0
  206. package/dropdown/types.d.ts +96 -0
  207. package/dropdown/types.js +5 -0
  208. package/file-input/FileInput.accessibility.test.d.ts +1 -0
  209. package/file-input/FileInput.accessibility.test.js +167 -0
  210. package/file-input/FileInput.d.ts +4 -0
  211. package/file-input/FileInput.js +438 -0
  212. package/file-input/FileInput.stories.tsx +618 -0
  213. package/file-input/FileInput.test.d.ts +1 -0
  214. package/file-input/FileInput.test.js +404 -0
  215. package/file-input/FileItem.d.ts +4 -0
  216. package/file-input/FileItem.js +125 -0
  217. package/file-input/types.d.ts +125 -0
  218. package/file-input/types.js +5 -0
  219. package/flex/Flex.d.ts +4 -0
  220. package/flex/Flex.js +57 -0
  221. package/flex/Flex.stories.tsx +112 -0
  222. package/flex/types.d.ts +97 -0
  223. package/flex/types.js +5 -0
  224. package/footer/Footer.accessibility.test.d.ts +1 -0
  225. package/footer/Footer.accessibility.test.js +125 -0
  226. package/footer/Footer.d.ts +4 -0
  227. package/footer/Footer.js +140 -0
  228. package/footer/Footer.stories.tsx +208 -0
  229. package/footer/Footer.test.d.ts +1 -0
  230. package/footer/Footer.test.js +85 -0
  231. package/footer/Icons.d.ts +3 -0
  232. package/footer/Icons.js +108 -0
  233. package/footer/types.d.ts +64 -0
  234. package/footer/types.js +5 -0
  235. package/grid/Grid.d.ts +7 -0
  236. package/grid/Grid.js +76 -0
  237. package/grid/Grid.stories.tsx +221 -0
  238. package/grid/types.d.ts +115 -0
  239. package/grid/types.js +5 -0
  240. package/header/Header.accessibility.test.d.ts +1 -0
  241. package/header/Header.accessibility.test.js +94 -0
  242. package/header/Header.d.ts +8 -0
  243. package/header/Header.js +210 -0
  244. package/header/Header.stories.tsx +267 -0
  245. package/header/Header.test.d.ts +1 -0
  246. package/header/Header.test.js +66 -0
  247. package/header/Icons.d.ts +2 -0
  248. package/header/Icons.js +24 -0
  249. package/header/types.d.ts +33 -0
  250. package/header/types.js +5 -0
  251. package/heading/Heading.accessibility.test.d.ts +1 -0
  252. package/heading/Heading.accessibility.test.js +33 -0
  253. package/heading/Heading.d.ts +4 -0
  254. package/{dist/heading → heading}/Heading.js +34 -115
  255. package/heading/Heading.stories.tsx +54 -0
  256. package/heading/Heading.test.d.ts +1 -0
  257. package/heading/Heading.test.js +156 -0
  258. package/heading/types.d.ts +33 -0
  259. package/heading/types.js +5 -0
  260. package/icon/Icon.accessibility.test.d.ts +1 -0
  261. package/icon/Icon.accessibility.test.js +30 -0
  262. package/icon/Icon.d.ts +4 -0
  263. package/icon/Icon.js +33 -0
  264. package/icon/Icon.stories.tsx +28 -0
  265. package/icon/types.d.ts +4 -0
  266. package/icon/types.js +5 -0
  267. package/image/Image.accessibility.test.d.ts +1 -0
  268. package/image/Image.accessibility.test.js +56 -0
  269. package/image/Image.d.ts +4 -0
  270. package/image/Image.js +70 -0
  271. package/image/Image.stories.tsx +129 -0
  272. package/image/types.d.ts +72 -0
  273. package/image/types.js +5 -0
  274. package/inset/Inset.d.ts +3 -0
  275. package/inset/Inset.js +43 -0
  276. package/inset/Inset.stories.tsx +230 -0
  277. package/inset/types.d.ts +37 -0
  278. package/inset/types.js +5 -0
  279. package/layout/ApplicationLayout.d.ts +20 -0
  280. package/layout/ApplicationLayout.js +137 -0
  281. package/layout/ApplicationLayout.stories.tsx +162 -0
  282. package/layout/Icons.d.ts +7 -0
  283. package/layout/Icons.js +48 -0
  284. package/layout/types.d.ts +41 -0
  285. package/layout/types.js +5 -0
  286. package/link/Link.accessibility.test.d.ts +1 -0
  287. package/link/Link.accessibility.test.js +108 -0
  288. package/link/Link.d.ts +4 -0
  289. package/link/Link.js +117 -0
  290. package/link/Link.stories.tsx +253 -0
  291. package/link/Link.test.d.ts +1 -0
  292. package/link/Link.test.js +63 -0
  293. package/link/types.d.ts +54 -0
  294. package/link/types.js +5 -0
  295. package/main.d.ts +50 -0
  296. package/{dist/main.js → main.js} +146 -149
  297. package/nav-tabs/NavTabs.accessibility.test.d.ts +1 -0
  298. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  299. package/nav-tabs/NavTabs.d.ts +7 -0
  300. package/nav-tabs/NavTabs.js +108 -0
  301. package/nav-tabs/NavTabs.stories.tsx +294 -0
  302. package/nav-tabs/NavTabs.test.d.ts +1 -0
  303. package/nav-tabs/NavTabs.test.js +77 -0
  304. package/nav-tabs/NavTabsContext.d.ts +3 -0
  305. package/nav-tabs/NavTabsContext.js +8 -0
  306. package/nav-tabs/Tab.d.ts +4 -0
  307. package/nav-tabs/Tab.js +117 -0
  308. package/nav-tabs/types.d.ts +52 -0
  309. package/nav-tabs/types.js +5 -0
  310. package/number-input/NumberInput.accessibility.test.d.ts +1 -0
  311. package/number-input/NumberInput.accessibility.test.js +227 -0
  312. package/number-input/NumberInput.d.ts +4 -0
  313. package/number-input/NumberInput.js +89 -0
  314. package/number-input/NumberInput.stories.tsx +126 -0
  315. package/number-input/NumberInput.test.d.ts +1 -0
  316. package/number-input/NumberInput.test.js +988 -0
  317. package/number-input/NumberInputContext.d.ts +3 -0
  318. package/number-input/NumberInputContext.js +8 -0
  319. package/number-input/types.d.ts +136 -0
  320. package/number-input/types.js +5 -0
  321. package/package.json +70 -56
  322. package/paginator/Paginator.accessibility.test.d.ts +1 -0
  323. package/paginator/Paginator.accessibility.test.js +78 -0
  324. package/paginator/Paginator.d.ts +4 -0
  325. package/paginator/Paginator.js +138 -0
  326. package/paginator/Paginator.stories.tsx +87 -0
  327. package/paginator/Paginator.test.d.ts +1 -0
  328. package/paginator/Paginator.test.js +334 -0
  329. package/paginator/types.d.ts +38 -0
  330. package/paginator/types.js +5 -0
  331. package/paragraph/Paragraph.accessibility.test.d.ts +1 -0
  332. package/paragraph/Paragraph.accessibility.test.js +28 -0
  333. package/paragraph/Paragraph.d.ts +5 -0
  334. package/paragraph/Paragraph.js +22 -0
  335. package/paragraph/Paragraph.stories.tsx +27 -0
  336. package/password-input/PasswordInput.accessibility.test.d.ts +1 -0
  337. package/password-input/PasswordInput.accessibility.test.js +152 -0
  338. package/password-input/PasswordInput.d.ts +4 -0
  339. package/password-input/PasswordInput.js +100 -0
  340. package/password-input/PasswordInput.stories.tsx +108 -0
  341. package/password-input/PasswordInput.test.d.ts +1 -0
  342. package/password-input/PasswordInput.test.js +197 -0
  343. package/password-input/types.d.ts +111 -0
  344. package/password-input/types.js +5 -0
  345. package/progress-bar/ProgressBar.accessibility.test.d.ts +1 -0
  346. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  347. package/progress-bar/ProgressBar.d.ts +4 -0
  348. package/progress-bar/ProgressBar.js +146 -0
  349. package/progress-bar/ProgressBar.stories.tsx +93 -0
  350. package/progress-bar/ProgressBar.test.d.ts +1 -0
  351. package/progress-bar/ProgressBar.test.js +93 -0
  352. package/progress-bar/types.d.ts +37 -0
  353. package/progress-bar/types.js +5 -0
  354. package/quick-nav/QuickNav.accessibility.test.d.ts +1 -0
  355. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  356. package/quick-nav/QuickNav.d.ts +4 -0
  357. package/quick-nav/QuickNav.js +94 -0
  358. package/quick-nav/QuickNav.stories.tsx +356 -0
  359. package/quick-nav/types.d.ts +21 -0
  360. package/quick-nav/types.js +5 -0
  361. package/radio-group/Radio.d.ts +4 -0
  362. package/radio-group/Radio.js +121 -0
  363. package/radio-group/RadioGroup.accessibility.test.d.ts +1 -0
  364. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  365. package/radio-group/RadioGroup.d.ts +4 -0
  366. package/radio-group/RadioGroup.js +233 -0
  367. package/radio-group/RadioGroup.stories.tsx +214 -0
  368. package/radio-group/RadioGroup.test.d.ts +1 -0
  369. package/radio-group/RadioGroup.test.js +754 -0
  370. package/radio-group/types.d.ts +114 -0
  371. package/radio-group/types.js +5 -0
  372. package/resultset-table/Icons.d.ts +7 -0
  373. package/resultset-table/Icons.js +47 -0
  374. package/resultset-table/ResultsetTable.accessibility.test.d.ts +1 -0
  375. package/resultset-table/ResultsetTable.accessibility.test.js +284 -0
  376. package/resultset-table/ResultsetTable.d.ts +7 -0
  377. package/resultset-table/ResultsetTable.js +195 -0
  378. package/resultset-table/ResultsetTable.stories.tsx +413 -0
  379. package/resultset-table/ResultsetTable.test.d.ts +1 -0
  380. package/resultset-table/ResultsetTable.test.js +450 -0
  381. package/resultset-table/types.d.ts +101 -0
  382. package/resultset-table/types.js +5 -0
  383. package/select/Listbox.d.ts +4 -0
  384. package/select/Listbox.js +151 -0
  385. package/select/Option.d.ts +4 -0
  386. package/select/Option.js +89 -0
  387. package/select/Select.accessibility.test.d.ts +1 -0
  388. package/select/Select.accessibility.test.js +227 -0
  389. package/select/Select.d.ts +4 -0
  390. package/select/Select.js +602 -0
  391. package/select/Select.stories.tsx +928 -0
  392. package/select/Select.test.d.ts +1 -0
  393. package/select/Select.test.js +2168 -0
  394. package/select/types.d.ts +209 -0
  395. package/select/types.js +5 -0
  396. package/sidenav/Sidenav.accessibility.test.d.ts +1 -0
  397. package/sidenav/Sidenav.accessibility.test.js +59 -0
  398. package/sidenav/Sidenav.d.ts +10 -0
  399. package/sidenav/Sidenav.js +201 -0
  400. package/sidenav/Sidenav.stories.tsx +277 -0
  401. package/sidenav/Sidenav.test.d.ts +1 -0
  402. package/sidenav/Sidenav.test.js +37 -0
  403. package/sidenav/SidenavContext.d.ts +5 -0
  404. package/sidenav/SidenavContext.js +13 -0
  405. package/sidenav/types.d.ts +76 -0
  406. package/sidenav/types.js +5 -0
  407. package/slider/Slider.accessibility.test.d.ts +1 -0
  408. package/slider/Slider.accessibility.test.js +103 -0
  409. package/slider/Slider.d.ts +4 -0
  410. package/slider/Slider.js +283 -0
  411. package/slider/Slider.stories.tsx +180 -0
  412. package/slider/Slider.test.d.ts +1 -0
  413. package/slider/Slider.test.js +256 -0
  414. package/slider/types.d.ts +86 -0
  415. package/slider/types.js +5 -0
  416. package/spinner/Spinner.accessibility.test.d.ts +1 -0
  417. package/spinner/Spinner.accessibility.test.js +96 -0
  418. package/spinner/Spinner.d.ts +4 -0
  419. package/spinner/Spinner.js +191 -0
  420. package/spinner/Spinner.stories.tsx +129 -0
  421. package/spinner/Spinner.test.d.ts +1 -0
  422. package/spinner/Spinner.test.js +55 -0
  423. package/spinner/types.d.ts +32 -0
  424. package/spinner/types.js +5 -0
  425. package/status-light/StatusLight.accessibility.test.d.ts +1 -0
  426. package/status-light/StatusLight.accessibility.test.js +157 -0
  427. package/status-light/StatusLight.d.ts +4 -0
  428. package/status-light/StatusLight.js +51 -0
  429. package/status-light/StatusLight.stories.tsx +74 -0
  430. package/status-light/StatusLight.test.d.ts +1 -0
  431. package/status-light/StatusLight.test.js +25 -0
  432. package/status-light/types.d.ts +17 -0
  433. package/status-light/types.js +5 -0
  434. package/switch/Switch.accessibility.test.d.ts +1 -0
  435. package/switch/Switch.accessibility.test.js +98 -0
  436. package/switch/Switch.d.ts +4 -0
  437. package/switch/Switch.js +211 -0
  438. package/switch/Switch.stories.tsx +149 -0
  439. package/switch/Switch.test.d.ts +1 -0
  440. package/switch/Switch.test.js +180 -0
  441. package/switch/types.d.ts +66 -0
  442. package/switch/types.js +5 -0
  443. package/table/DropdownTheme.js +62 -0
  444. package/table/Table.accessibility.test.d.ts +1 -0
  445. package/table/Table.accessibility.test.js +92 -0
  446. package/table/Table.d.ts +8 -0
  447. package/table/Table.js +161 -0
  448. package/table/Table.stories.tsx +663 -0
  449. package/table/Table.test.d.ts +1 -0
  450. package/table/Table.test.js +111 -0
  451. package/table/types.d.ts +49 -0
  452. package/table/types.js +5 -0
  453. package/tabs/Tab.d.ts +4 -0
  454. package/tabs/Tab.js +117 -0
  455. package/tabs/Tabs.accessibility.test.d.ts +1 -0
  456. package/tabs/Tabs.accessibility.test.js +56 -0
  457. package/tabs/Tabs.d.ts +4 -0
  458. package/tabs/Tabs.js +373 -0
  459. package/tabs/Tabs.stories.tsx +230 -0
  460. package/tabs/Tabs.test.d.ts +1 -0
  461. package/tabs/Tabs.test.js +276 -0
  462. package/tabs/types.d.ts +92 -0
  463. package/tabs/types.js +5 -0
  464. package/tag/Tag.accessibility.test.d.ts +1 -0
  465. package/tag/Tag.accessibility.test.js +69 -0
  466. package/tag/Tag.d.ts +4 -0
  467. package/tag/Tag.js +151 -0
  468. package/tag/Tag.stories.tsx +152 -0
  469. package/tag/Tag.test.d.ts +1 -0
  470. package/tag/Tag.test.js +41 -0
  471. package/tag/types.d.ts +69 -0
  472. package/tag/types.js +5 -0
  473. package/text-input/Suggestion.d.ts +4 -0
  474. package/text-input/Suggestion.js +67 -0
  475. package/text-input/Suggestions.d.ts +4 -0
  476. package/text-input/Suggestions.js +94 -0
  477. package/text-input/TextInput.accessibility.test.d.ts +1 -0
  478. package/text-input/TextInput.accessibility.test.js +320 -0
  479. package/text-input/TextInput.d.ts +4 -0
  480. package/text-input/TextInput.js +571 -0
  481. package/text-input/TextInput.stories.tsx +477 -0
  482. package/text-input/TextInput.test.d.ts +1 -0
  483. package/text-input/TextInput.test.js +1755 -0
  484. package/text-input/types.d.ts +205 -0
  485. package/text-input/types.js +5 -0
  486. package/textarea/Textarea.accessibility.test.d.ts +1 -0
  487. package/textarea/Textarea.accessibility.test.js +155 -0
  488. package/textarea/Textarea.d.ts +4 -0
  489. package/textarea/Textarea.js +235 -0
  490. package/textarea/Textarea.stories.tsx +174 -0
  491. package/textarea/Textarea.test.d.ts +1 -0
  492. package/textarea/Textarea.test.js +406 -0
  493. package/textarea/types.d.ts +141 -0
  494. package/textarea/types.js +5 -0
  495. package/toggle-group/ToggleGroup.accessibility.test.d.ts +1 -0
  496. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  497. package/toggle-group/ToggleGroup.d.ts +4 -0
  498. package/toggle-group/ToggleGroup.js +199 -0
  499. package/toggle-group/ToggleGroup.stories.tsx +218 -0
  500. package/toggle-group/ToggleGroup.test.d.ts +1 -0
  501. package/toggle-group/ToggleGroup.test.js +137 -0
  502. package/toggle-group/types.d.ts +114 -0
  503. package/toggle-group/types.js +5 -0
  504. package/tooltip/Tooltip.accessibility.test.d.ts +1 -0
  505. package/tooltip/Tooltip.accessibility.test.js +144 -0
  506. package/tooltip/Tooltip.d.ts +4 -0
  507. package/tooltip/Tooltip.js +50 -0
  508. package/tooltip/Tooltip.stories.tsx +111 -0
  509. package/tooltip/Tooltip.test.d.ts +1 -0
  510. package/tooltip/Tooltip.test.js +112 -0
  511. package/tooltip/types.d.ts +16 -0
  512. package/tooltip/types.js +5 -0
  513. package/typography/Typography.accessibility.test.d.ts +1 -0
  514. package/typography/Typography.accessibility.test.js +339 -0
  515. package/typography/Typography.d.ts +4 -0
  516. package/typography/Typography.js +23 -0
  517. package/typography/Typography.stories.tsx +196 -0
  518. package/typography/Typography.test.js +23 -0
  519. package/typography/types.d.ts +18 -0
  520. package/typography/types.js +5 -0
  521. package/useTheme.d.ts +1168 -0
  522. package/{dist/useTheme.js → useTheme.js} +4 -11
  523. package/useTranslatedLabels.d.ts +96 -0
  524. package/useTranslatedLabels.js +14 -0
  525. package/utils/BaseTypography.d.ts +21 -0
  526. package/utils/BaseTypography.js +98 -0
  527. package/utils/FocusLock.d.ts +13 -0
  528. package/utils/FocusLock.js +125 -0
  529. package/wizard/Wizard.accessibility.test.d.ts +1 -0
  530. package/wizard/Wizard.accessibility.test.js +55 -0
  531. package/wizard/Wizard.d.ts +4 -0
  532. package/wizard/Wizard.js +239 -0
  533. package/wizard/Wizard.stories.tsx +272 -0
  534. package/wizard/Wizard.test.d.ts +1 -0
  535. package/wizard/Wizard.test.js +114 -0
  536. package/wizard/types.d.ts +64 -0
  537. package/wizard/types.js +5 -0
  538. package/babel.config.js +0 -8
  539. package/dist/BackgroundColorContext.js +0 -46
  540. package/dist/ThemeContext.js +0 -248
  541. package/dist/accordion/Accordion.js +0 -353
  542. package/dist/accordion-group/AccordionGroup.js +0 -186
  543. package/dist/alert/Alert.js +0 -403
  544. package/dist/alert/index.d.ts +0 -51
  545. package/dist/badge/Badge.js +0 -63
  546. package/dist/box/Box.js +0 -156
  547. package/dist/button/Button.js +0 -238
  548. package/dist/card/Card.js +0 -254
  549. package/dist/checkbox/Checkbox.js +0 -300
  550. package/dist/checkbox/Checkbox.stories.js +0 -144
  551. package/dist/checkbox/readme.md +0 -116
  552. package/dist/chip/Chip.js +0 -265
  553. package/dist/common/OpenSans.css +0 -81
  554. package/dist/common/RequiredComponent.js +0 -40
  555. package/dist/common/fonts/OpenSans-Bold.ttf +0 -0
  556. package/dist/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  557. package/dist/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  558. package/dist/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  559. package/dist/common/fonts/OpenSans-Italic.ttf +0 -0
  560. package/dist/common/fonts/OpenSans-Light.ttf +0 -0
  561. package/dist/common/fonts/OpenSans-LightItalic.ttf +0 -0
  562. package/dist/common/fonts/OpenSans-Regular.ttf +0 -0
  563. package/dist/common/fonts/OpenSans-SemiBold.ttf +0 -0
  564. package/dist/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  565. package/dist/common/variables.js +0 -1569
  566. package/dist/date/Date.js +0 -379
  567. package/dist/date/Date.stories.js +0 -205
  568. package/dist/date/readme.md +0 -73
  569. package/dist/dialog/Dialog.js +0 -218
  570. package/dist/dropdown/Dropdown.js +0 -544
  571. package/dist/file-input/FileInput.js +0 -644
  572. package/dist/file-input/FileItem.js +0 -280
  573. package/dist/file-input/index.d.ts +0 -81
  574. package/dist/footer/Footer.js +0 -395
  575. package/dist/footer/dxc_logo.svg +0 -15
  576. package/dist/footer/readme.md +0 -41
  577. package/dist/header/Header.js +0 -403
  578. package/dist/header/Header.stories.js +0 -176
  579. package/dist/header/close_icon.svg +0 -1
  580. package/dist/header/dxc_logo_black.svg +0 -8
  581. package/dist/header/hamb_menu_black.svg +0 -1
  582. package/dist/header/hamb_menu_white.svg +0 -1
  583. package/dist/header/readme.md +0 -33
  584. package/dist/input-text/InputText.js +0 -707
  585. package/dist/input-text/error.svg +0 -1
  586. package/dist/input-text/readme.md +0 -91
  587. package/dist/layout/ApplicationLayout.js +0 -331
  588. package/dist/layout/facebook.svg +0 -45
  589. package/dist/layout/linkedin.svg +0 -50
  590. package/dist/layout/twitter.svg +0 -53
  591. package/dist/link/Link.js +0 -237
  592. package/dist/link/readme.md +0 -51
  593. package/dist/main.d.ts +0 -8
  594. package/dist/new-date/NewDate.js +0 -400
  595. package/dist/new-date/index.d.ts +0 -95
  596. package/dist/new-select/NewSelect.js +0 -836
  597. package/dist/new-select/index.d.ts +0 -53
  598. package/dist/new-textarea/NewTextarea.js +0 -369
  599. package/dist/new-textarea/index.d.ts +0 -117
  600. package/dist/number/Number.js +0 -136
  601. package/dist/number/NumberContext.js +0 -16
  602. package/dist/number/index.d.ts +0 -113
  603. package/dist/paginator/Paginator.js +0 -289
  604. package/dist/paginator/images/next.svg +0 -3
  605. package/dist/paginator/images/nextPage.svg +0 -3
  606. package/dist/paginator/images/previous.svg +0 -3
  607. package/dist/paginator/images/previousPage.svg +0 -3
  608. package/dist/paginator/readme.md +0 -50
  609. package/dist/password-input/PasswordInput.js +0 -198
  610. package/dist/password-input/index.d.ts +0 -94
  611. package/dist/progress-bar/ProgressBar.js +0 -242
  612. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  613. package/dist/progress-bar/readme.md +0 -63
  614. package/dist/radio/Radio.js +0 -209
  615. package/dist/radio/Radio.stories.js +0 -166
  616. package/dist/radio/readme.md +0 -70
  617. package/dist/resultsetTable/ResultsetTable.js +0 -358
  618. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  619. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  620. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  621. package/dist/select/Select.js +0 -549
  622. package/dist/sidenav/Sidenav.js +0 -179
  623. package/dist/slider/Slider.js +0 -394
  624. package/dist/slider/Slider.stories.js +0 -241
  625. package/dist/slider/readme.md +0 -64
  626. package/dist/spinner/Spinner.js +0 -381
  627. package/dist/spinner/Spinner.stories.js +0 -183
  628. package/dist/spinner/readme.md +0 -65
  629. package/dist/switch/Switch.js +0 -222
  630. package/dist/switch/Switch.stories.js +0 -134
  631. package/dist/switch/readme.md +0 -133
  632. package/dist/table/Table.js +0 -132
  633. package/dist/tabs/Tabs.js +0 -343
  634. package/dist/tabs/Tabs.stories.js +0 -130
  635. package/dist/tabs/readme.md +0 -78
  636. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  637. package/dist/tabs-for-sections/readme.md +0 -78
  638. package/dist/tag/Tag.js +0 -282
  639. package/dist/text-input/TextInput.js +0 -971
  640. package/dist/text-input/index.d.ts +0 -135
  641. package/dist/textarea/Textarea.js +0 -264
  642. package/dist/toggle/Toggle.js +0 -220
  643. package/dist/toggle/Toggle.stories.js +0 -297
  644. package/dist/toggle/readme.md +0 -80
  645. package/dist/toggle-group/ToggleGroup.js +0 -327
  646. package/dist/upload/Upload.js +0 -205
  647. package/dist/upload/Upload.stories.js +0 -72
  648. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -139
  649. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  650. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  651. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  652. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  653. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  654. package/dist/upload/file-upload/FileToUpload.js +0 -184
  655. package/dist/upload/file-upload/audio-icon.svg +0 -4
  656. package/dist/upload/file-upload/close.svg +0 -4
  657. package/dist/upload/file-upload/file-icon.svg +0 -4
  658. package/dist/upload/file-upload/video-icon.svg +0 -4
  659. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  660. package/dist/upload/readme.md +0 -37
  661. package/dist/upload/transaction/Transaction.js +0 -175
  662. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  663. package/dist/upload/transaction/audio-icon.svg +0 -4
  664. package/dist/upload/transaction/error-icon.svg +0 -4
  665. package/dist/upload/transaction/file-icon-err.svg +0 -4
  666. package/dist/upload/transaction/file-icon.svg +0 -4
  667. package/dist/upload/transaction/image-icon-err.svg +0 -4
  668. package/dist/upload/transaction/image-icon.svg +0 -4
  669. package/dist/upload/transaction/success-icon.svg +0 -4
  670. package/dist/upload/transaction/video-icon-err.svg +0 -4
  671. package/dist/upload/transaction/video-icon.svg +0 -4
  672. package/dist/upload/transactions/Transactions.js +0 -138
  673. package/dist/wizard/Wizard.js +0 -411
  674. package/dist/wizard/invalid_icon.svg +0 -5
  675. package/dist/wizard/valid_icon.svg +0 -5
  676. package/dist/wizard/validation-wrong.svg +0 -6
  677. package/test/Accordion.test.js +0 -33
  678. package/test/AccordionGroup.test.js +0 -125
  679. package/test/Alert.test.js +0 -53
  680. package/test/Box.test.js +0 -10
  681. package/test/Button.test.js +0 -18
  682. package/test/Card.test.js +0 -30
  683. package/test/Checkbox.test.js +0 -45
  684. package/test/Chip.test.js +0 -25
  685. package/test/Date.test.js +0 -393
  686. package/test/Dialog.test.js +0 -23
  687. package/test/Dropdown.test.js +0 -145
  688. package/test/FileInput.test.js +0 -201
  689. package/test/Footer.test.js +0 -99
  690. package/test/Header.test.js +0 -39
  691. package/test/Heading.test.js +0 -35
  692. package/test/InputText.test.js +0 -240
  693. package/test/Link.test.js +0 -43
  694. package/test/NewDate.test.js +0 -232
  695. package/test/NewTextarea.test.js +0 -195
  696. package/test/Number.test.js +0 -257
  697. package/test/Paginator.test.js +0 -177
  698. package/test/PasswordInput.test.js +0 -83
  699. package/test/ProgressBar.test.js +0 -35
  700. package/test/Radio.test.js +0 -37
  701. package/test/ResultsetTable.test.js +0 -329
  702. package/test/Select.test.js +0 -212
  703. package/test/Sidenav.test.js +0 -45
  704. package/test/Slider.test.js +0 -82
  705. package/test/Spinner.test.js +0 -32
  706. package/test/Switch.test.js +0 -45
  707. package/test/Table.test.js +0 -36
  708. package/test/Tabs.test.js +0 -109
  709. package/test/TabsForSections.test.js +0 -34
  710. package/test/Tag.test.js +0 -32
  711. package/test/TextArea.test.js +0 -52
  712. package/test/TextInput.test.js +0 -732
  713. package/test/ToggleGroup.test.js +0 -85
  714. package/test/Upload.test.js +0 -60
  715. package/test/Wizard.test.js +0 -130
  716. package/test/mocks/pngMock.js +0 -1
  717. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,174 @@
1
+ import React from "react";
2
+ import DxcTextarea from "./Textarea";
3
+ import Title from "../../.storybook/components/Title";
4
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
+ import { HalstackProvider } from "../HalstackContext";
6
+
7
+ export default {
8
+ title: "Textarea",
9
+ component: DxcTextarea,
10
+ };
11
+
12
+ const opinionatedTheme = {
13
+ textarea: {
14
+ fontColor: "#000000",
15
+ hoverBorderColor: "#a46ede",
16
+ },
17
+ };
18
+
19
+ export const Chromatic = () => (
20
+ <>
21
+ <ExampleContainer pseudoState="pseudo-hover">
22
+ <Title title="Hovered" theme="light" level={4} />
23
+ <DxcTextarea label="Hovered" />
24
+ </ExampleContainer>
25
+ <ExampleContainer pseudoState="pseudo-focus">
26
+ <Title title="Focused" theme="light" level={4} />
27
+ <DxcTextarea label="Focused" />
28
+ </ExampleContainer>
29
+ <ExampleContainer>
30
+ <Title title="Disabled" theme="light" level={4} />
31
+ <DxcTextarea label="Disabled" optional helperText="Sample text" placeholder="Enter your text here..." disabled />
32
+ </ExampleContainer>
33
+ <ExampleContainer>
34
+ <Title title="Disabled with value" theme="light" level={4} />
35
+ <DxcTextarea label="Disabled" defaultValue="Example text" disabled />
36
+ </ExampleContainer>
37
+ <ExampleContainer>
38
+ <Title title="Read only" theme="light" level={4} />
39
+ <DxcTextarea label="Label" readOnly defaultValue="Example text" verticalGrow="manual" />
40
+ </ExampleContainer>
41
+ <ExampleContainer pseudoState="pseudo-hover">
42
+ <Title title="Hovered read only" theme="light" level={4} />
43
+ <DxcTextarea label="Label" readOnly defaultValue="Example text" verticalGrow="manual" />
44
+ </ExampleContainer>
45
+ <ExampleContainer>
46
+ <Title title="With error" theme="light" level={4} />
47
+ <DxcTextarea
48
+ label="Textarea with error"
49
+ helperText="Helper text"
50
+ placeholder="Enter your text here..."
51
+ error="Error message."
52
+ />
53
+ </ExampleContainer>
54
+ <ExampleContainer pseudoState="pseudo-hover">
55
+ <Title title="Hovered with error" theme="light" level={4} />
56
+ <DxcTextarea
57
+ label="Hovered textarea with error"
58
+ helperText="Helper text"
59
+ placeholder="Enter your text here..."
60
+ error="Error message."
61
+ />
62
+ </ExampleContainer>
63
+ <ExampleContainer>
64
+ <Title title="Helper text and optional with value" theme="light" level={4} />
65
+ <DxcTextarea label="Helper & optional" defaultValue="Some text" helperText="Sample text" optional />
66
+ </ExampleContainer>
67
+ <ExampleContainer>
68
+ <Title title="Resizable" theme="light" level={4} />
69
+ <DxcTextarea label="With resizer" helperText="Helper text" verticalGrow="manual" />
70
+ </ExampleContainer>
71
+ <ExampleContainer>
72
+ <Title title="Grow manual" theme="light" level={4} />
73
+ <DxcTextarea
74
+ label="Manual vertical grow"
75
+ verticalGrow="manual"
76
+ defaultValue="Long textttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttt"
77
+ />
78
+ </ExampleContainer>
79
+ <Title title="Sizes" theme="light" level={2} />
80
+ <ExampleContainer>
81
+ <DxcTextarea label="Small" size="small" />
82
+ </ExampleContainer>
83
+ <ExampleContainer>
84
+ <DxcTextarea label="Medium" size="medium" />
85
+ </ExampleContainer>
86
+ <ExampleContainer>
87
+ <DxcTextarea label="Large" size="large" />
88
+ </ExampleContainer>
89
+ <ExampleContainer>
90
+ <DxcTextarea label="Fill parent" size="fillParent" />
91
+ </ExampleContainer>
92
+ <Title title="Margins" theme="light" level={2} />
93
+ <ExampleContainer>
94
+ <Title title="Xxsmall margin" theme="light" level={4} />
95
+ <DxcTextarea label="Xxsmall" margin="xxsmall" />
96
+ </ExampleContainer>
97
+ <ExampleContainer>
98
+ <Title title="Xsmall margin" theme="light" level={4} />
99
+ <DxcTextarea label="xsmall" margin="xsmall" />
100
+ </ExampleContainer>
101
+ <ExampleContainer>
102
+ <Title title="Small margin" theme="light" level={4} />
103
+ <DxcTextarea label="small" margin="small" />
104
+ </ExampleContainer>
105
+ <ExampleContainer>
106
+ <Title title="Medium margin" theme="light" level={4} />
107
+ <DxcTextarea label="medium" margin="medium" />
108
+ </ExampleContainer>
109
+ <ExampleContainer>
110
+ <Title title="Large margin" theme="light" level={4} />
111
+ <DxcTextarea label="Large" margin="large" />
112
+ </ExampleContainer>
113
+ <ExampleContainer>
114
+ <Title title="Xlarge margin" theme="light" level={4} />
115
+ <DxcTextarea label="Xlarge" margin="xlarge" />
116
+ </ExampleContainer>
117
+ <ExampleContainer>
118
+ <Title title="Xxlarge margin" theme="light" level={4} />
119
+ <DxcTextarea label="Xxlarge" margin="xxlarge" />
120
+ </ExampleContainer>
121
+ <Title title="Opinionated theme" theme="light" level={2} />
122
+ <ExampleContainer pseudoState="pseudo-hover">
123
+ <Title title="Hovered" theme="light" level={4} />
124
+ <HalstackProvider theme={opinionatedTheme}>
125
+ <DxcTextarea label="Hovered" helperText="Sample text" placeholder="Placeholder" />
126
+ </HalstackProvider>
127
+ </ExampleContainer>
128
+ <ExampleContainer pseudoState="pseudo-focus">
129
+ <Title title="Focused" theme="light" level={4} />
130
+ <HalstackProvider theme={opinionatedTheme}>
131
+ <DxcTextarea label="Focused" helperText="Sample text" />
132
+ </HalstackProvider>
133
+ </ExampleContainer>
134
+ <ExampleContainer>
135
+ <Title title="Disabled" theme="light" level={4} />
136
+ <HalstackProvider theme={opinionatedTheme}>
137
+ <DxcTextarea
138
+ label="Disabled"
139
+ optional
140
+ helperText="Sample text"
141
+ placeholder="Enter your text here..."
142
+ disabled
143
+ />
144
+ </HalstackProvider>
145
+ </ExampleContainer>
146
+ <ExampleContainer>
147
+ <Title title="Disabled with value" theme="light" level={4} />
148
+ <HalstackProvider theme={opinionatedTheme}>
149
+ <DxcTextarea label="Disabled" helperText="Sample text" defaultValue="Example text" disabled />
150
+ </HalstackProvider>
151
+ </ExampleContainer>
152
+ <ExampleContainer>
153
+ <Title title="With error" theme="light" level={4} />
154
+ <HalstackProvider theme={opinionatedTheme}>
155
+ <DxcTextarea
156
+ label="Textarea with error"
157
+ helperText="Helper text"
158
+ placeholder="Enter your text here..."
159
+ error="Error message."
160
+ />
161
+ </HalstackProvider>
162
+ </ExampleContainer>
163
+ <ExampleContainer>
164
+ <Title title="Grow manual" theme="light" level={4} />{" "}
165
+ <HalstackProvider theme={opinionatedTheme}>
166
+ <DxcTextarea
167
+ label="Manual vertical grow"
168
+ verticalGrow="manual"
169
+ defaultValue="Long textttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttt"
170
+ />
171
+ </HalstackProvider>
172
+ </ExampleContainer>
173
+ </>
174
+ );
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,406 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
5
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
6
+ var _react = _interopRequireDefault(require("react"));
7
+ var _react2 = require("@testing-library/react");
8
+ var _userEvent = _interopRequireDefault(require("@testing-library/user-event"));
9
+ var _Textarea = _interopRequireDefault(require("./Textarea"));
10
+ describe("Textarea component tests", function () {
11
+ test("Renders with correct label", function () {
12
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
13
+ label: "Example label"
14
+ })),
15
+ getByText = _render.getByText;
16
+ expect(getByText("Example label")).toBeTruthy();
17
+ });
18
+ test("Renders with correct label and helper text", function () {
19
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
20
+ label: "Example label",
21
+ helperText: "Example helper text"
22
+ })),
23
+ getByText = _render2.getByText;
24
+ expect(getByText("Example label")).toBeTruthy();
25
+ expect(getByText("Example helper text")).toBeTruthy();
26
+ });
27
+ test("Renders with correct label and optional", function () {
28
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
29
+ label: "Example label",
30
+ helperText: "Example helper text",
31
+ optional: true
32
+ })),
33
+ getByText = _render3.getByText,
34
+ getByRole = _render3.getByRole;
35
+ var textarea = getByRole("textbox");
36
+ expect(getByText("Example label")).toBeTruthy();
37
+ expect(getByText("(Optional)")).toBeTruthy();
38
+ expect(getByText("Example helper text")).toBeTruthy();
39
+ expect(textarea.getAttribute("aria-required")).toBe("false");
40
+ });
41
+ test("Renders with correct placeholder", function () {
42
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
43
+ placeholder: "Placeholder"
44
+ })),
45
+ getByRole = _render4.getByRole;
46
+ var textarea = getByRole("textbox");
47
+ expect(textarea.getAttribute("placeholder")).toBe("Placeholder");
48
+ });
49
+ test("Renders with error message and correct aria attributes", function () {
50
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
51
+ label: "Example label",
52
+ error: "Error message."
53
+ })),
54
+ getByText = _render5.getByText,
55
+ getByLabelText = _render5.getByLabelText;
56
+ var textarea = getByLabelText("Example label");
57
+ var errorMessage = getByText("Error message.");
58
+ expect(errorMessage).toBeTruthy();
59
+ expect(textarea.getAttribute("aria-errormessage")).toBe(errorMessage.id);
60
+ expect(textarea.getAttribute("aria-invalid")).toBe("true");
61
+ expect(errorMessage.getAttribute("aria-live")).toBe("assertive");
62
+ });
63
+ test("Renders with correct default rows", function () {
64
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
65
+ label: "Example label",
66
+ rows: 10
67
+ })),
68
+ getByLabelText = _render6.getByLabelText;
69
+ var textarea = getByLabelText("Example label");
70
+ expect(textarea.rows).toBe(10);
71
+ });
72
+ test("Renders with correct accessibility attributes", function () {
73
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
74
+ label: "Example label"
75
+ })),
76
+ getByLabelText = _render7.getByLabelText;
77
+ var textarea = getByLabelText("Example label");
78
+ expect(textarea.getAttribute("aria-invalid")).toBe("false");
79
+ expect(textarea.getAttribute("aria-describedBy")).toBeNull();
80
+ expect(textarea.getAttribute("aria-required")).toBe("true");
81
+ });
82
+ test("Renders with correct initial value", function () {
83
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
84
+ label: "Example label",
85
+ placeholder: "Placeholder",
86
+ defaultValue: "Example text"
87
+ })),
88
+ getByLabelText = _render8.getByLabelText;
89
+ var textarea = getByLabelText("Example label");
90
+ expect(textarea.value).toBe("Example text");
91
+ });
92
+ test("Disabled textarea can not be modified", function () {
93
+ var onChange = jest.fn();
94
+ var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
95
+ label: "Example label",
96
+ onChange: onChange,
97
+ disabled: true
98
+ })),
99
+ getByLabelText = _render9.getByLabelText;
100
+ var textarea = getByLabelText("Example label");
101
+ _userEvent["default"].type(textarea, "Test");
102
+ expect(onChange).not.toHaveBeenCalled();
103
+ });
104
+ test("Read-only textarea does not trigger onChange function", function () {
105
+ var onChange = jest.fn();
106
+ var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
107
+ label: "Example label",
108
+ onChange: onChange,
109
+ readOnly: true
110
+ })),
111
+ getByLabelText = _render10.getByLabelText;
112
+ var textarea = getByLabelText("Example label");
113
+ _userEvent["default"].type(textarea, "Test");
114
+ expect(onChange).not.toHaveBeenCalled();
115
+ });
116
+ test("Read-only textarea sends its value on submit", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
117
+ var handlerOnSubmit, _render11, getByText, submit;
118
+ return _regenerator["default"].wrap(function _callee$(_context) {
119
+ while (1) switch (_context.prev = _context.next) {
120
+ case 0:
121
+ handlerOnSubmit = jest.fn(function (e) {
122
+ e.preventDefault();
123
+ var formData = new FormData(e.target);
124
+ var formProps = Object.fromEntries(formData);
125
+ expect(formProps).toStrictEqual({
126
+ data: "Comments"
127
+ });
128
+ });
129
+ _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement("form", {
130
+ onSubmit: handlerOnSubmit
131
+ }, /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
132
+ label: "Example label",
133
+ name: "data",
134
+ defaultValue: "Comments",
135
+ readOnly: true
136
+ }), /*#__PURE__*/_react["default"].createElement("button", {
137
+ type: "submit"
138
+ }, "Submit"))), getByText = _render11.getByText;
139
+ submit = getByText("Submit");
140
+ _context.next = 5;
141
+ return _userEvent["default"].click(submit);
142
+ case 5:
143
+ expect(handlerOnSubmit).toHaveBeenCalled();
144
+ case 6:
145
+ case "end":
146
+ return _context.stop();
147
+ }
148
+ }, _callee);
149
+ })));
150
+ test("Not optional constraint (onBlur)", function () {
151
+ var onChange = jest.fn();
152
+ var onBlur = jest.fn();
153
+ var _render12 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
154
+ label: "Example label",
155
+ placeholder: "Placeholder",
156
+ onChange: onChange,
157
+ onBlur: onBlur
158
+ })),
159
+ getByLabelText = _render12.getByLabelText;
160
+ var textarea = getByLabelText("Example label");
161
+ _react2.fireEvent.focus(textarea);
162
+ _react2.fireEvent.blur(textarea);
163
+ expect(onBlur).toHaveBeenCalled();
164
+ expect(onBlur).toHaveBeenCalledWith({
165
+ value: "",
166
+ error: "This field is required. Please, enter a value."
167
+ });
168
+ _react2.fireEvent.change(textarea, {
169
+ target: {
170
+ value: "Test"
171
+ }
172
+ });
173
+ _react2.fireEvent.blur(textarea);
174
+ expect(onBlur).toHaveBeenCalled();
175
+ expect(onBlur).toHaveBeenCalledWith({
176
+ value: "Test"
177
+ });
178
+ });
179
+ test("Not optional constraint (onChange)", function () {
180
+ var onChange = jest.fn();
181
+ var _render13 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
182
+ label: "Example label",
183
+ placeholder: "Placeholder",
184
+ onChange: onChange
185
+ })),
186
+ getByLabelText = _render13.getByLabelText;
187
+ var textarea = getByLabelText("Example label");
188
+ _react2.fireEvent.focus(textarea);
189
+ _react2.fireEvent.change(textarea, {
190
+ target: {
191
+ value: "Test"
192
+ }
193
+ });
194
+ expect(onChange).toHaveBeenCalled();
195
+ expect(onChange).toHaveBeenCalledWith({
196
+ value: "Test"
197
+ });
198
+ _userEvent["default"].clear(textarea);
199
+ expect(onChange).toHaveBeenCalled();
200
+ expect(onChange).toHaveBeenCalledWith({
201
+ value: "",
202
+ error: "This field is required. Please, enter a value."
203
+ });
204
+ });
205
+ test("Pattern constraint", function () {
206
+ var onChange = jest.fn();
207
+ var onBlur = jest.fn();
208
+ var _render14 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
209
+ label: "Example label",
210
+ placeholder: "Placeholder",
211
+ onChange: onChange,
212
+ onBlur: onBlur,
213
+ margin: {
214
+ left: "medium",
215
+ right: "medium"
216
+ },
217
+ pattern: "^.*(?=.*[a-zA-Z])(?=.*\\d)(?=.*[!&$%&? \"]).*$"
218
+ })),
219
+ getByLabelText = _render14.getByLabelText;
220
+ var textarea = getByLabelText("Example label");
221
+ _react2.fireEvent.change(textarea, {
222
+ target: {
223
+ value: "pattern test"
224
+ }
225
+ });
226
+ expect(onChange).toHaveBeenCalled();
227
+ expect(onChange).toHaveBeenCalledWith({
228
+ value: "pattern test",
229
+ error: "Please match the format requested."
230
+ });
231
+ _react2.fireEvent.blur(textarea);
232
+ expect(onBlur).toHaveBeenCalled();
233
+ expect(onBlur).toHaveBeenCalledWith({
234
+ value: "pattern test",
235
+ error: "Please match the format requested."
236
+ });
237
+ _userEvent["default"].clear(textarea);
238
+ _react2.fireEvent.change(textarea, {
239
+ target: {
240
+ value: "pattern4&"
241
+ }
242
+ });
243
+ expect(onChange).toHaveBeenCalled();
244
+ expect(onChange).toHaveBeenCalledWith({
245
+ value: "pattern4&"
246
+ });
247
+ _react2.fireEvent.blur(textarea);
248
+ expect(onBlur).toHaveBeenCalled();
249
+ expect(onBlur).toHaveBeenCalledWith({
250
+ value: "pattern4&"
251
+ });
252
+ });
253
+ test("Length constraint", function () {
254
+ var onChange = jest.fn();
255
+ var onBlur = jest.fn();
256
+ var _render15 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
257
+ label: "Example label",
258
+ placeholder: "Placeholder",
259
+ onChange: onChange,
260
+ onBlur: onBlur,
261
+ margin: {
262
+ left: "medium",
263
+ right: "medium"
264
+ },
265
+ minLength: 5,
266
+ maxLength: 10
267
+ })),
268
+ getByLabelText = _render15.getByLabelText;
269
+ var textarea = getByLabelText("Example label");
270
+ _react2.fireEvent.change(textarea, {
271
+ target: {
272
+ value: "test"
273
+ }
274
+ });
275
+ expect(onChange).toHaveBeenCalled();
276
+ expect(onChange).toHaveBeenCalledWith({
277
+ value: "test",
278
+ error: "Min length 5, max length 10."
279
+ });
280
+ _react2.fireEvent.blur(textarea);
281
+ expect(onBlur).toHaveBeenCalled();
282
+ expect(onBlur).toHaveBeenCalledWith({
283
+ value: "test",
284
+ error: "Min length 5, max length 10."
285
+ });
286
+ _userEvent["default"].clear(textarea);
287
+ _react2.fireEvent.change(textarea, {
288
+ target: {
289
+ value: "length"
290
+ }
291
+ });
292
+ expect(onChange).toHaveBeenCalled();
293
+ expect(onChange).toHaveBeenCalledWith({
294
+ value: "length"
295
+ });
296
+ _react2.fireEvent.blur(textarea);
297
+ expect(onBlur).toHaveBeenCalled();
298
+ expect(onBlur).toHaveBeenCalledWith({
299
+ value: "length"
300
+ });
301
+ });
302
+ test("Pattern and length constraints", function () {
303
+ var onChange = jest.fn();
304
+ var onBlur = jest.fn();
305
+ var _render16 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
306
+ label: "Example label",
307
+ placeholder: "Placeholder",
308
+ onChange: onChange,
309
+ onBlur: onBlur,
310
+ margin: {
311
+ left: "medium",
312
+ right: "medium"
313
+ },
314
+ pattern: "^.*(?=.*[a-zA-Z])(?=.*\\d)(?=.*[!&$%&? \"]).*$",
315
+ minLength: 5,
316
+ maxLength: 10
317
+ })),
318
+ getByLabelText = _render16.getByLabelText;
319
+ var textarea = getByLabelText("Example label");
320
+ _react2.fireEvent.change(textarea, {
321
+ target: {
322
+ value: "test"
323
+ }
324
+ });
325
+ expect(onChange).toHaveBeenCalled();
326
+ expect(onChange).toHaveBeenCalledWith({
327
+ value: "test",
328
+ error: "Min length 5, max length 10."
329
+ });
330
+ _react2.fireEvent.blur(textarea);
331
+ expect(onBlur).toHaveBeenCalled();
332
+ expect(onBlur).toHaveBeenCalledWith({
333
+ value: "test",
334
+ error: "Min length 5, max length 10."
335
+ });
336
+ _react2.fireEvent.change(textarea, {
337
+ target: {
338
+ value: "tests"
339
+ }
340
+ });
341
+ expect(onChange).toHaveBeenCalled();
342
+ expect(onChange).toHaveBeenCalledWith({
343
+ value: "tests",
344
+ error: "Please match the format requested."
345
+ });
346
+ _react2.fireEvent.blur(textarea);
347
+ expect(onBlur).toHaveBeenCalled();
348
+ expect(onBlur).toHaveBeenCalledWith({
349
+ value: "tests",
350
+ error: "Please match the format requested."
351
+ });
352
+ _react2.fireEvent.change(textarea, {
353
+ target: {
354
+ value: "tests4&"
355
+ }
356
+ });
357
+ expect(onChange).toHaveBeenCalled();
358
+ expect(onChange).toHaveBeenCalledWith({
359
+ value: "tests4&"
360
+ });
361
+ _react2.fireEvent.blur(textarea);
362
+ expect(onBlur).toHaveBeenCalled();
363
+ expect(onBlur).toHaveBeenCalledWith({
364
+ value: "tests4&"
365
+ });
366
+ });
367
+ test("onBlur function is called correctly", function () {
368
+ var onBlur = jest.fn();
369
+ var _render17 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
370
+ label: "Example label",
371
+ onBlur: onBlur
372
+ })),
373
+ getByLabelText = _render17.getByLabelText;
374
+ var textarea = getByLabelText("Example label");
375
+ _react2.fireEvent.change(textarea, {
376
+ target: {
377
+ value: "Blur test"
378
+ }
379
+ });
380
+ _react2.fireEvent.blur(textarea);
381
+ expect(onBlur).toHaveBeenCalled();
382
+ expect(onBlur).toHaveBeenCalledWith({
383
+ value: "Blur test"
384
+ });
385
+ });
386
+ test("onChange function is called correctly", function () {
387
+ var onChange = jest.fn();
388
+ var _render18 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Textarea["default"], {
389
+ label: "Example label",
390
+ value: "Test value",
391
+ onChange: onChange
392
+ })),
393
+ getByLabelText = _render18.getByLabelText;
394
+ var textarea = getByLabelText("Example label");
395
+ _react2.fireEvent.change(textarea, {
396
+ target: {
397
+ value: "Controlled test"
398
+ }
399
+ });
400
+ expect(onChange).toHaveBeenCalled();
401
+ expect(onChange).toHaveBeenCalledWith({
402
+ value: "Controlled test"
403
+ });
404
+ expect(textarea.value).toBe("Test value");
405
+ });
406
+ });