@dxc-technology/halstack-react 0.0.0-d0735cc → 0.0.0-d123a22

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 (480) hide show
  1. package/BackgroundColorContext.d.ts +1 -10
  2. package/BackgroundColorContext.js +5 -22
  3. package/HalstackContext.d.ts +1240 -6
  4. package/HalstackContext.js +126 -111
  5. package/README.md +47 -0
  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 +1 -1
  9. package/accordion/Accordion.js +101 -159
  10. package/accordion/Accordion.stories.tsx +82 -148
  11. package/accordion/Accordion.test.d.ts +1 -0
  12. package/accordion/Accordion.test.js +24 -40
  13. package/accordion/types.d.ts +6 -17
  14. package/accordion-group/AccordionGroup.accessibility.test.d.ts +1 -0
  15. package/accordion-group/AccordionGroup.accessibility.test.js +82 -0
  16. package/accordion-group/AccordionGroup.d.ts +2 -2
  17. package/accordion-group/AccordionGroup.js +30 -98
  18. package/accordion-group/AccordionGroup.stories.tsx +94 -67
  19. package/accordion-group/AccordionGroup.test.d.ts +1 -0
  20. package/accordion-group/AccordionGroup.test.js +49 -106
  21. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  22. package/accordion-group/AccordionGroupAccordion.js +31 -0
  23. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  24. package/accordion-group/AccordionGroupContext.js +8 -0
  25. package/accordion-group/types.d.ts +12 -17
  26. package/action-icon/ActionIcon.accessibility.test.d.ts +1 -0
  27. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  28. package/action-icon/ActionIcon.d.ts +4 -0
  29. package/action-icon/ActionIcon.js +48 -0
  30. package/action-icon/ActionIcon.stories.tsx +41 -0
  31. package/action-icon/ActionIcon.test.d.ts +1 -0
  32. package/action-icon/ActionIcon.test.js +64 -0
  33. package/action-icon/types.d.ts +26 -0
  34. package/alert/Alert.accessibility.test.d.ts +1 -0
  35. package/alert/Alert.accessibility.test.js +95 -0
  36. package/alert/Alert.js +37 -127
  37. package/alert/Alert.stories.tsx +28 -0
  38. package/alert/Alert.test.d.ts +1 -0
  39. package/alert/Alert.test.js +28 -45
  40. package/alert/types.d.ts +5 -5
  41. package/badge/Badge.accessibility.test.d.ts +1 -0
  42. package/badge/Badge.accessibility.test.js +129 -0
  43. package/badge/Badge.d.ts +1 -1
  44. package/badge/Badge.js +142 -42
  45. package/badge/Badge.stories.tsx +210 -0
  46. package/badge/Badge.test.d.ts +1 -0
  47. package/badge/Badge.test.js +30 -0
  48. package/badge/types.d.ts +52 -3
  49. package/bleed/Bleed.js +13 -21
  50. package/bleed/Bleed.stories.tsx +1 -0
  51. package/bleed/types.d.ts +2 -2
  52. package/box/Box.accessibility.test.d.ts +1 -0
  53. package/box/Box.accessibility.test.js +33 -0
  54. package/box/Box.d.ts +1 -1
  55. package/box/Box.js +19 -60
  56. package/box/Box.stories.tsx +38 -51
  57. package/box/Box.test.d.ts +1 -0
  58. package/box/Box.test.js +1 -6
  59. package/box/types.d.ts +3 -14
  60. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  61. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  62. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  63. package/breadcrumbs/Breadcrumbs.js +79 -0
  64. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  65. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  66. package/breadcrumbs/Breadcrumbs.test.js +169 -0
  67. package/breadcrumbs/Item.d.ts +4 -0
  68. package/breadcrumbs/Item.js +52 -0
  69. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  70. package/breadcrumbs/dropdownTheme.js +62 -0
  71. package/breadcrumbs/types.d.ts +16 -0
  72. package/bulleted-list/BulletedList.accessibility.test.d.ts +1 -0
  73. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  74. package/bulleted-list/BulletedList.js +22 -53
  75. package/bulleted-list/BulletedList.stories.tsx +8 -93
  76. package/bulleted-list/types.d.ts +32 -5
  77. package/button/Button.accessibility.test.d.ts +1 -0
  78. package/button/Button.accessibility.test.js +127 -0
  79. package/button/Button.d.ts +1 -1
  80. package/button/Button.js +71 -106
  81. package/button/Button.stories.tsx +143 -101
  82. package/button/Button.test.d.ts +1 -0
  83. package/button/Button.test.js +19 -16
  84. package/button/types.d.ts +9 -5
  85. package/card/Card.accessibility.test.d.ts +1 -0
  86. package/card/Card.accessibility.test.js +36 -0
  87. package/card/Card.d.ts +1 -1
  88. package/card/Card.js +49 -89
  89. package/card/Card.stories.tsx +12 -42
  90. package/card/Card.test.d.ts +1 -0
  91. package/card/Card.test.js +10 -21
  92. package/card/types.d.ts +6 -11
  93. package/checkbox/Checkbox.accessibility.test.d.ts +1 -0
  94. package/checkbox/Checkbox.accessibility.test.js +87 -0
  95. package/checkbox/Checkbox.d.ts +2 -2
  96. package/checkbox/Checkbox.js +138 -183
  97. package/checkbox/Checkbox.stories.tsx +128 -94
  98. package/checkbox/Checkbox.test.d.ts +1 -0
  99. package/checkbox/Checkbox.test.js +159 -38
  100. package/checkbox/types.d.ts +11 -3
  101. package/chip/Chip.accessibility.test.d.ts +1 -0
  102. package/chip/Chip.accessibility.test.js +67 -0
  103. package/chip/Chip.js +45 -80
  104. package/chip/Chip.stories.tsx +107 -27
  105. package/chip/Chip.test.d.ts +1 -0
  106. package/chip/Chip.test.js +17 -32
  107. package/chip/types.d.ts +4 -4
  108. package/common/coreTokens.d.ts +237 -0
  109. package/common/coreTokens.js +184 -0
  110. package/common/utils.d.ts +1 -0
  111. package/common/utils.js +6 -12
  112. package/common/variables.d.ts +1392 -0
  113. package/common/variables.js +986 -1219
  114. package/container/Container.d.ts +4 -0
  115. package/container/Container.js +194 -0
  116. package/container/Container.stories.tsx +214 -0
  117. package/container/types.d.ts +74 -0
  118. package/contextual-menu/ContextualMenu.accessibility.test.d.ts +1 -0
  119. package/contextual-menu/ContextualMenu.accessibility.test.js +98 -0
  120. package/contextual-menu/ContextualMenu.d.ts +5 -0
  121. package/contextual-menu/ContextualMenu.js +88 -0
  122. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  123. package/contextual-menu/ContextualMenu.test.d.ts +1 -0
  124. package/contextual-menu/ContextualMenu.test.js +205 -0
  125. package/contextual-menu/GroupItem.d.ts +4 -0
  126. package/contextual-menu/GroupItem.js +67 -0
  127. package/contextual-menu/ItemAction.d.ts +4 -0
  128. package/contextual-menu/ItemAction.js +51 -0
  129. package/contextual-menu/MenuItem.d.ts +4 -0
  130. package/contextual-menu/MenuItem.js +29 -0
  131. package/contextual-menu/SingleItem.d.ts +4 -0
  132. package/contextual-menu/SingleItem.js +38 -0
  133. package/contextual-menu/types.d.ts +58 -0
  134. package/contextual-menu/types.js +5 -0
  135. package/date-input/Calendar.d.ts +4 -0
  136. package/date-input/Calendar.js +214 -0
  137. package/date-input/DateInput.accessibility.test.d.ts +1 -0
  138. package/date-input/DateInput.accessibility.test.js +230 -0
  139. package/date-input/DateInput.js +149 -299
  140. package/date-input/DateInput.stories.tsx +210 -56
  141. package/date-input/DateInput.test.d.ts +1 -0
  142. package/date-input/DateInput.test.js +700 -370
  143. package/date-input/DatePicker.d.ts +4 -0
  144. package/date-input/DatePicker.js +121 -0
  145. package/date-input/YearPicker.d.ts +4 -0
  146. package/date-input/YearPicker.js +100 -0
  147. package/date-input/types.d.ts +72 -15
  148. package/dialog/Dialog.accessibility.test.d.ts +1 -0
  149. package/dialog/Dialog.accessibility.test.js +69 -0
  150. package/dialog/Dialog.d.ts +1 -1
  151. package/dialog/Dialog.js +61 -106
  152. package/dialog/Dialog.stories.tsx +325 -167
  153. package/dialog/Dialog.test.d.ts +1 -0
  154. package/dialog/Dialog.test.js +350 -19
  155. package/dialog/types.d.ts +18 -25
  156. package/divider/Divider.accessibility.test.d.ts +1 -0
  157. package/divider/Divider.accessibility.test.js +33 -0
  158. package/divider/Divider.d.ts +4 -0
  159. package/divider/Divider.js +36 -0
  160. package/divider/Divider.stories.tsx +223 -0
  161. package/divider/Divider.test.d.ts +1 -0
  162. package/divider/Divider.test.js +38 -0
  163. package/divider/types.d.ts +21 -0
  164. package/divider/types.js +5 -0
  165. package/dropdown/Dropdown.accessibility.test.d.ts +1 -0
  166. package/dropdown/Dropdown.accessibility.test.js +184 -0
  167. package/dropdown/Dropdown.d.ts +1 -1
  168. package/dropdown/Dropdown.js +232 -303
  169. package/dropdown/Dropdown.stories.tsx +235 -57
  170. package/dropdown/Dropdown.test.d.ts +1 -0
  171. package/dropdown/Dropdown.test.js +604 -164
  172. package/dropdown/DropdownMenu.d.ts +4 -0
  173. package/dropdown/DropdownMenu.js +63 -0
  174. package/dropdown/DropdownMenuItem.d.ts +4 -0
  175. package/dropdown/DropdownMenuItem.js +71 -0
  176. package/dropdown/types.d.ts +35 -19
  177. package/file-input/FileInput.accessibility.test.d.ts +1 -0
  178. package/file-input/FileInput.accessibility.test.js +167 -0
  179. package/file-input/FileInput.d.ts +2 -2
  180. package/file-input/FileInput.js +240 -393
  181. package/file-input/FileInput.stories.tsx +123 -12
  182. package/file-input/FileInput.test.d.ts +1 -0
  183. package/file-input/FileInput.test.js +314 -367
  184. package/file-input/FileItem.d.ts +4 -14
  185. package/file-input/FileItem.js +56 -117
  186. package/file-input/types.d.ts +25 -8
  187. package/flex/Flex.d.ts +1 -1
  188. package/flex/Flex.js +40 -40
  189. package/flex/Flex.stories.tsx +35 -26
  190. package/flex/types.d.ts +84 -8
  191. package/footer/Footer.accessibility.test.d.ts +1 -0
  192. package/footer/Footer.accessibility.test.js +125 -0
  193. package/footer/Footer.d.ts +1 -1
  194. package/footer/Footer.js +73 -118
  195. package/footer/Footer.stories.tsx +99 -21
  196. package/footer/Footer.test.d.ts +1 -0
  197. package/footer/Footer.test.js +32 -56
  198. package/footer/Icons.d.ts +3 -2
  199. package/footer/Icons.js +53 -22
  200. package/footer/types.d.ts +26 -27
  201. package/grid/Grid.d.ts +7 -0
  202. package/grid/Grid.js +76 -0
  203. package/grid/Grid.stories.tsx +219 -0
  204. package/grid/types.d.ts +115 -0
  205. package/grid/types.js +5 -0
  206. package/header/Header.accessibility.test.d.ts +1 -0
  207. package/header/Header.accessibility.test.js +94 -0
  208. package/header/Header.d.ts +4 -3
  209. package/header/Header.js +90 -183
  210. package/header/Header.stories.tsx +133 -38
  211. package/header/Header.test.d.ts +1 -0
  212. package/header/Header.test.js +12 -25
  213. package/header/Icons.d.ts +2 -2
  214. package/header/Icons.js +5 -15
  215. package/header/types.d.ts +7 -21
  216. package/heading/Heading.accessibility.test.d.ts +1 -0
  217. package/heading/Heading.accessibility.test.js +33 -0
  218. package/heading/Heading.js +10 -32
  219. package/heading/Heading.test.d.ts +1 -0
  220. package/heading/Heading.test.js +64 -94
  221. package/heading/types.d.ts +7 -7
  222. package/icon/Icon.accessibility.test.d.ts +1 -0
  223. package/icon/Icon.accessibility.test.js +30 -0
  224. package/icon/Icon.d.ts +4 -0
  225. package/icon/Icon.js +33 -0
  226. package/icon/Icon.stories.tsx +28 -0
  227. package/icon/types.d.ts +4 -0
  228. package/icon/types.js +5 -0
  229. package/image/Image.accessibility.test.d.ts +1 -0
  230. package/image/Image.accessibility.test.js +56 -0
  231. package/image/Image.d.ts +4 -0
  232. package/image/Image.js +70 -0
  233. package/image/Image.stories.tsx +129 -0
  234. package/image/types.d.ts +72 -0
  235. package/image/types.js +5 -0
  236. package/inset/Inset.js +13 -21
  237. package/inset/Inset.stories.tsx +2 -1
  238. package/inset/types.d.ts +2 -2
  239. package/layout/ApplicationLayout.d.ts +5 -5
  240. package/layout/ApplicationLayout.js +36 -70
  241. package/layout/ApplicationLayout.stories.tsx +2 -1
  242. package/layout/Icons.d.ts +7 -5
  243. package/layout/Icons.js +41 -59
  244. package/layout/types.d.ts +5 -6
  245. package/link/Link.accessibility.test.d.ts +1 -0
  246. package/link/Link.accessibility.test.js +108 -0
  247. package/link/Link.js +32 -51
  248. package/link/Link.stories.tsx +64 -4
  249. package/link/Link.test.d.ts +1 -0
  250. package/link/Link.test.js +23 -43
  251. package/link/types.d.ts +14 -14
  252. package/main.d.ts +11 -5
  253. package/main.js +54 -59
  254. package/nav-tabs/NavTabs.accessibility.test.d.ts +1 -0
  255. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  256. package/nav-tabs/NavTabs.d.ts +7 -0
  257. package/nav-tabs/NavTabs.js +108 -0
  258. package/nav-tabs/NavTabs.stories.tsx +294 -0
  259. package/nav-tabs/NavTabs.test.d.ts +1 -0
  260. package/nav-tabs/NavTabs.test.js +77 -0
  261. package/nav-tabs/NavTabsContext.d.ts +3 -0
  262. package/nav-tabs/NavTabsContext.js +8 -0
  263. package/nav-tabs/Tab.js +117 -0
  264. package/{tabs-nav → nav-tabs}/types.d.ts +15 -16
  265. package/nav-tabs/types.js +5 -0
  266. package/number-input/NumberInput.accessibility.test.d.ts +1 -0
  267. package/number-input/NumberInput.accessibility.test.js +228 -0
  268. package/number-input/NumberInput.js +46 -36
  269. package/number-input/NumberInput.stories.tsx +42 -26
  270. package/number-input/NumberInput.test.d.ts +1 -0
  271. package/number-input/NumberInput.test.js +859 -376
  272. package/number-input/NumberInputContext.d.ts +3 -4
  273. package/number-input/NumberInputContext.js +3 -14
  274. package/number-input/types.d.ts +17 -5
  275. package/package.json +51 -54
  276. package/paginator/Paginator.accessibility.test.d.ts +1 -0
  277. package/paginator/Paginator.accessibility.test.js +79 -0
  278. package/paginator/Paginator.js +35 -68
  279. package/paginator/Paginator.stories.tsx +24 -0
  280. package/paginator/Paginator.test.d.ts +1 -0
  281. package/paginator/Paginator.test.js +252 -225
  282. package/paginator/types.d.ts +3 -3
  283. package/paragraph/Paragraph.accessibility.test.d.ts +1 -0
  284. package/paragraph/Paragraph.accessibility.test.js +28 -0
  285. package/paragraph/Paragraph.d.ts +3 -4
  286. package/paragraph/Paragraph.js +6 -22
  287. package/paragraph/Paragraph.stories.tsx +0 -17
  288. package/password-input/PasswordInput.accessibility.test.d.ts +1 -0
  289. package/password-input/PasswordInput.accessibility.test.js +153 -0
  290. package/password-input/PasswordInput.js +58 -127
  291. package/password-input/PasswordInput.stories.tsx +1 -33
  292. package/password-input/PasswordInput.test.d.ts +1 -0
  293. package/password-input/PasswordInput.test.js +159 -141
  294. package/password-input/types.d.ts +8 -7
  295. package/progress-bar/ProgressBar.accessibility.test.d.ts +1 -0
  296. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  297. package/progress-bar/ProgressBar.js +68 -92
  298. package/progress-bar/{ProgressBar.stories.jsx → ProgressBar.stories.tsx} +39 -4
  299. package/progress-bar/ProgressBar.test.d.ts +1 -0
  300. package/progress-bar/ProgressBar.test.js +71 -43
  301. package/progress-bar/types.d.ts +3 -3
  302. package/quick-nav/QuickNav.accessibility.test.d.ts +1 -0
  303. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  304. package/quick-nav/QuickNav.js +15 -39
  305. package/quick-nav/QuickNav.stories.tsx +112 -20
  306. package/quick-nav/types.d.ts +10 -10
  307. package/radio-group/Radio.d.ts +1 -1
  308. package/radio-group/Radio.js +59 -79
  309. package/radio-group/RadioGroup.accessibility.test.d.ts +1 -0
  310. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  311. package/radio-group/RadioGroup.js +71 -121
  312. package/radio-group/RadioGroup.stories.tsx +132 -18
  313. package/radio-group/RadioGroup.test.d.ts +1 -0
  314. package/radio-group/RadioGroup.test.js +518 -459
  315. package/radio-group/types.d.ts +10 -10
  316. package/resultset-table/Icons.d.ts +7 -0
  317. package/resultset-table/Icons.js +47 -0
  318. package/resultset-table/ResultsetTable.accessibility.test.d.ts +1 -0
  319. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  320. package/resultset-table/ResultsetTable.d.ts +7 -0
  321. package/resultset-table/ResultsetTable.js +171 -0
  322. package/{resultsetTable → resultset-table}/ResultsetTable.stories.tsx +168 -30
  323. package/resultset-table/ResultsetTable.test.d.ts +1 -0
  324. package/resultset-table/ResultsetTable.test.js +380 -0
  325. package/{resultsetTable → resultset-table}/types.d.ts +44 -11
  326. package/resultset-table/types.js +5 -0
  327. package/select/Listbox.d.ts +1 -1
  328. package/select/Listbox.js +40 -88
  329. package/select/Option.js +35 -56
  330. package/select/Select.accessibility.test.d.ts +1 -0
  331. package/select/Select.accessibility.test.js +228 -0
  332. package/select/Select.js +138 -181
  333. package/select/Select.stories.tsx +496 -204
  334. package/select/Select.test.d.ts +1 -0
  335. package/select/Select.test.js +1928 -1835
  336. package/select/types.d.ts +17 -18
  337. package/sidenav/Sidenav.accessibility.test.d.ts +1 -0
  338. package/sidenav/Sidenav.accessibility.test.js +59 -0
  339. package/sidenav/Sidenav.d.ts +2 -2
  340. package/sidenav/Sidenav.js +90 -157
  341. package/sidenav/Sidenav.stories.tsx +160 -63
  342. package/sidenav/Sidenav.test.d.ts +1 -0
  343. package/sidenav/Sidenav.test.js +4 -11
  344. package/{layout → sidenav}/SidenavContext.d.ts +1 -1
  345. package/{layout → sidenav}/SidenavContext.js +3 -9
  346. package/sidenav/types.d.ts +33 -30
  347. package/slider/Slider.accessibility.test.d.ts +1 -0
  348. package/slider/Slider.accessibility.test.js +104 -0
  349. package/slider/Slider.d.ts +2 -2
  350. package/slider/Slider.js +146 -181
  351. package/slider/Slider.stories.tsx +64 -61
  352. package/slider/Slider.test.d.ts +1 -0
  353. package/slider/Slider.test.js +195 -88
  354. package/slider/types.d.ts +7 -3
  355. package/spinner/Spinner.accessibility.test.d.ts +1 -0
  356. package/spinner/Spinner.accessibility.test.js +96 -0
  357. package/spinner/Spinner.js +34 -74
  358. package/spinner/{Spinner.stories.jsx → Spinner.stories.tsx} +53 -27
  359. package/spinner/Spinner.test.d.ts +1 -0
  360. package/spinner/Spinner.test.js +25 -34
  361. package/spinner/types.d.ts +3 -3
  362. package/status-light/StatusLight.accessibility.test.d.ts +1 -0
  363. package/status-light/StatusLight.accessibility.test.js +157 -0
  364. package/status-light/StatusLight.d.ts +4 -0
  365. package/status-light/StatusLight.js +51 -0
  366. package/status-light/StatusLight.stories.tsx +74 -0
  367. package/status-light/StatusLight.test.d.ts +1 -0
  368. package/status-light/StatusLight.test.js +25 -0
  369. package/status-light/types.d.ts +17 -0
  370. package/status-light/types.js +5 -0
  371. package/switch/Switch.accessibility.test.d.ts +1 -0
  372. package/switch/Switch.accessibility.test.js +98 -0
  373. package/switch/Switch.d.ts +2 -2
  374. package/switch/Switch.js +145 -129
  375. package/switch/Switch.stories.tsx +49 -60
  376. package/switch/Switch.test.d.ts +1 -0
  377. package/switch/Switch.test.js +137 -55
  378. package/switch/types.d.ts +7 -3
  379. package/table/DropdownTheme.js +62 -0
  380. package/table/Table.accessibility.test.d.ts +1 -0
  381. package/table/Table.accessibility.test.js +93 -0
  382. package/table/Table.d.ts +6 -2
  383. package/table/Table.js +78 -35
  384. package/table/Table.stories.tsx +663 -0
  385. package/table/Table.test.d.ts +1 -0
  386. package/table/Table.test.js +93 -7
  387. package/table/types.d.ts +34 -6
  388. package/tabs/Tab.d.ts +4 -0
  389. package/tabs/Tab.js +117 -0
  390. package/tabs/Tabs.accessibility.test.d.ts +1 -0
  391. package/tabs/Tabs.accessibility.test.js +56 -0
  392. package/tabs/Tabs.js +303 -141
  393. package/tabs/Tabs.stories.tsx +124 -6
  394. package/tabs/Tabs.test.d.ts +1 -0
  395. package/tabs/Tabs.test.js +212 -76
  396. package/tabs/types.d.ts +30 -20
  397. package/tag/Tag.accessibility.test.d.ts +1 -0
  398. package/tag/Tag.accessibility.test.js +69 -0
  399. package/tag/Tag.js +35 -67
  400. package/tag/Tag.stories.tsx +18 -8
  401. package/tag/Tag.test.d.ts +1 -0
  402. package/tag/Tag.test.js +17 -36
  403. package/tag/types.d.ts +9 -9
  404. package/text-input/Suggestion.js +40 -28
  405. package/text-input/Suggestions.d.ts +4 -0
  406. package/text-input/Suggestions.js +94 -0
  407. package/text-input/TextInput.accessibility.test.d.ts +1 -0
  408. package/text-input/TextInput.accessibility.test.js +321 -0
  409. package/text-input/TextInput.js +311 -512
  410. package/text-input/TextInput.stories.tsx +276 -276
  411. package/text-input/TextInput.test.d.ts +1 -0
  412. package/text-input/TextInput.test.js +1418 -1374
  413. package/text-input/types.d.ts +43 -16
  414. package/textarea/Textarea.accessibility.test.d.ts +1 -0
  415. package/textarea/Textarea.accessibility.test.js +155 -0
  416. package/textarea/Textarea.js +70 -115
  417. package/textarea/Textarea.stories.tsx +174 -0
  418. package/textarea/Textarea.test.d.ts +1 -0
  419. package/textarea/Textarea.test.js +151 -182
  420. package/textarea/types.d.ts +9 -5
  421. package/toggle-group/ToggleGroup.accessibility.test.d.ts +1 -0
  422. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  423. package/toggle-group/ToggleGroup.d.ts +2 -2
  424. package/toggle-group/ToggleGroup.js +92 -108
  425. package/toggle-group/ToggleGroup.stories.tsx +52 -7
  426. package/toggle-group/ToggleGroup.test.d.ts +1 -0
  427. package/toggle-group/ToggleGroup.test.js +68 -87
  428. package/toggle-group/types.d.ts +28 -19
  429. package/typography/Typography.accessibility.test.d.ts +1 -0
  430. package/typography/Typography.accessibility.test.js +339 -0
  431. package/typography/Typography.d.ts +2 -2
  432. package/typography/Typography.js +15 -123
  433. package/typography/Typography.stories.tsx +1 -1
  434. package/typography/types.d.ts +1 -1
  435. package/useTheme.d.ts +1144 -1
  436. package/useTheme.js +2 -9
  437. package/useTranslatedLabels.d.ts +84 -1
  438. package/useTranslatedLabels.js +1 -7
  439. package/utils/BaseTypography.d.ts +21 -0
  440. package/utils/BaseTypography.js +94 -0
  441. package/utils/FocusLock.d.ts +13 -0
  442. package/utils/FocusLock.js +124 -0
  443. package/wizard/Wizard.accessibility.test.d.ts +1 -0
  444. package/wizard/Wizard.accessibility.test.js +55 -0
  445. package/wizard/Wizard.js +29 -75
  446. package/wizard/Wizard.stories.tsx +39 -0
  447. package/wizard/Wizard.test.d.ts +1 -0
  448. package/wizard/Wizard.test.js +53 -80
  449. package/wizard/types.d.ts +10 -11
  450. package/card/ice-cream.jpg +0 -0
  451. package/common/OpenSans.css +0 -81
  452. package/common/RequiredComponent.js +0 -32
  453. package/common/fonts/OpenSans-Bold.ttf +0 -0
  454. package/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  455. package/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  456. package/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  457. package/common/fonts/OpenSans-Italic.ttf +0 -0
  458. package/common/fonts/OpenSans-Light.ttf +0 -0
  459. package/common/fonts/OpenSans-LightItalic.ttf +0 -0
  460. package/common/fonts/OpenSans-Regular.ttf +0 -0
  461. package/common/fonts/OpenSans-SemiBold.ttf +0 -0
  462. package/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  463. package/number-input/numberInputContextTypes.d.ts +0 -19
  464. package/paginator/Icons.js +0 -66
  465. package/resultsetTable/ResultsetTable.d.ts +0 -4
  466. package/resultsetTable/ResultsetTable.js +0 -254
  467. package/resultsetTable/ResultsetTable.test.js +0 -348
  468. package/select/Icons.d.ts +0 -10
  469. package/select/Icons.js +0 -93
  470. package/table/Table.stories.jsx +0 -277
  471. package/tabs-nav/NavTabs.d.ts +0 -8
  472. package/tabs-nav/NavTabs.js +0 -125
  473. package/tabs-nav/NavTabs.stories.tsx +0 -170
  474. package/tabs-nav/NavTabs.test.js +0 -82
  475. package/tabs-nav/Tab.js +0 -132
  476. package/textarea/Textarea.stories.jsx +0 -157
  477. /package/{resultsetTable → action-icon}/types.js +0 -0
  478. /package/{tabs-nav → breadcrumbs}/types.js +0 -0
  479. /package/{number-input/numberInputContextTypes.js → container/types.js} +0 -0
  480. /package/{tabs-nav → nav-tabs}/Tab.d.ts +0 -0
@@ -0,0 +1,77 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _react = _interopRequireDefault(require("react"));
5
+ var _react2 = require("@testing-library/react");
6
+ var _NavTabs = _interopRequireDefault(require("./NavTabs"));
7
+ describe("Tabs component tests", function () {
8
+ test("Tabs render with correct labels and attributes", function () {
9
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NavTabs["default"], null, /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
10
+ href: "/test1",
11
+ active: true
12
+ }, "Tab 1"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
13
+ href: "/test2",
14
+ disabled: true
15
+ }, "Tab 2"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
16
+ href: "/test3"
17
+ }, "Tab 3"))),
18
+ getByText = _render.getByText,
19
+ getAllByRole = _render.getAllByRole,
20
+ getByRole = _render.getByRole;
21
+ expect(getByRole("tablist")).toBeTruthy();
22
+ expect(getByRole("tablist").getAttribute("aria-label")).toBe("Navigation tabs");
23
+ expect(getByText("Tab 1")).toBeTruthy();
24
+ expect(getByText("Tab 2")).toBeTruthy();
25
+ expect(getByText("Tab 3")).toBeTruthy();
26
+ var tabs = getAllByRole("tab");
27
+ tabs.forEach(function (tab, index) {
28
+ expect(tab.getAttribute("aria-selected")).toBe((index === 0).toString());
29
+ });
30
+ var anchors = getAllByRole("tab");
31
+ expect(anchors.length).toBe(3);
32
+ expect(anchors[0].getAttribute("href")).toBe("/test1");
33
+ expect(anchors[1].getAttribute("href")).toBeFalsy();
34
+ expect(anchors[2].getAttribute("href")).toBe("/test3");
35
+ expect(anchors[0].getAttribute("tabindex")).toBe("0");
36
+ expect(anchors[1].getAttribute("tabindex")).toBe("-1");
37
+ expect(anchors[2].getAttribute("tabindex")).toBe("-1");
38
+ });
39
+ test("Tabs render with correct labels, badges and icons", function () {
40
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NavTabs["default"], null, /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
41
+ href: "/test1",
42
+ active: true,
43
+ notificationNumber: 10
44
+ }, "Tab 1"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
45
+ href: "/test2",
46
+ disabled: true,
47
+ notificationNumber: 20
48
+ }, "Tab 2"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
49
+ href: "/test3",
50
+ notificationNumber: 1000,
51
+ icon: "Settings"
52
+ }, "Tab 3"))),
53
+ getByText = _render2.getByText,
54
+ queryByText = _render2.queryByText;
55
+ expect(getByText("10")).toBeTruthy();
56
+ expect(queryByText("20")).toBeFalsy();
57
+ expect(getByText("+99")).toBeTruthy();
58
+ });
59
+ test("Tabs render with correct tab index", function () {
60
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NavTabs["default"], {
61
+ tabIndex: 3
62
+ }, /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
63
+ href: "/test1"
64
+ }, "Tab 1"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
65
+ href: "/test2",
66
+ disabled: true
67
+ }, "Tab 2"), /*#__PURE__*/_react["default"].createElement(_NavTabs["default"].Tab, {
68
+ href: "/test3",
69
+ active: true
70
+ }, "Tab 3"))),
71
+ getAllByRole = _render3.getAllByRole;
72
+ var tabs = getAllByRole("tab");
73
+ expect(tabs[0].getAttribute("tabindex")).toBe("-1");
74
+ expect(tabs[1].getAttribute("tabindex")).toBe("-1");
75
+ expect(tabs[2].getAttribute("tabindex")).toBe("3");
76
+ });
77
+ });
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ import { NavTabsContextProps } from "./types";
3
+ export declare const NavTabsContext: import("react").Context<NavTabsContextProps>;
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.NavTabsContext = void 0;
7
+ var _react = require("react");
8
+ var NavTabsContext = exports.NavTabsContext = /*#__PURE__*/(0, _react.createContext)(null);
@@ -0,0 +1,117 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
10
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
12
+ var _react = _interopRequireWildcard(require("react"));
13
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
14
+ var _Badge = _interopRequireDefault(require("../badge/Badge"));
15
+ var _Flex = _interopRequireDefault(require("../flex/Flex"));
16
+ var _BaseTypography = _interopRequireDefault(require("../utils/BaseTypography"));
17
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
18
+ var _NavTabsContext = require("./NavTabsContext");
19
+ var _Icon = _interopRequireDefault(require("../icon/Icon"));
20
+ var _templateObject, _templateObject2, _templateObject3;
21
+ var _excluded = ["href", "active", "icon", "disabled", "notificationNumber", "children"];
22
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
23
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
24
+ var DxcTab = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, _ref2) {
25
+ var href = _ref.href,
26
+ _ref$active = _ref.active,
27
+ active = _ref$active === void 0 ? false : _ref$active,
28
+ icon = _ref.icon,
29
+ _ref$disabled = _ref.disabled,
30
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
31
+ _ref$notificationNumb = _ref.notificationNumber,
32
+ notificationNumber = _ref$notificationNumb === void 0 ? false : _ref$notificationNumb,
33
+ children = _ref.children,
34
+ otherProps = (0, _objectWithoutProperties2["default"])(_ref, _excluded);
35
+ var tabRef = (0, _react.useRef)();
36
+ var colorsTheme = (0, _useTheme["default"])();
37
+ var _useContext = (0, _react.useContext)(_NavTabsContext.NavTabsContext),
38
+ iconPosition = _useContext.iconPosition,
39
+ tabIndex = _useContext.tabIndex,
40
+ focusedLabel = _useContext.focusedLabel;
41
+ (0, _react.useEffect)(function () {
42
+ var _tabRef$current;
43
+ focusedLabel === children.toString() && (tabRef === null || tabRef === void 0 ? void 0 : (_tabRef$current = tabRef.current) === null || _tabRef$current === void 0 ? void 0 : _tabRef$current.focus());
44
+ }, [focusedLabel]);
45
+ var handleOnKeyDown = function handleOnKeyDown(event) {
46
+ var _tabRef$current2;
47
+ switch (event.key) {
48
+ case " ":
49
+ case "Enter":
50
+ event.preventDefault();
51
+ tabRef === null || tabRef === void 0 ? void 0 : (_tabRef$current2 = tabRef.current) === null || _tabRef$current2 === void 0 ? void 0 : _tabRef$current2.click();
52
+ break;
53
+ }
54
+ };
55
+ return /*#__PURE__*/_react["default"].createElement(TabContainer, {
56
+ active: active
57
+ }, /*#__PURE__*/_react["default"].createElement(Tab, (0, _extends2["default"])({
58
+ href: !disabled ? href : undefined,
59
+ disabled: disabled,
60
+ active: active,
61
+ iconPosition: iconPosition,
62
+ hasIcon: icon != null ? true : false,
63
+ ref: function ref(anchorRef) {
64
+ tabRef.current = anchorRef;
65
+ if (_ref2) {
66
+ if (typeof _ref2 === "function") _ref2(anchorRef);else _ref2.current = anchorRef;
67
+ }
68
+ },
69
+ onKeyDown: handleOnKeyDown,
70
+ tabIndex: active ? tabIndex : -1,
71
+ role: "tab",
72
+ "aria-selected": active,
73
+ "aria-disabled": disabled
74
+ }, otherProps), icon && /*#__PURE__*/_react["default"].createElement(TabIconContainer, {
75
+ iconPosition: iconPosition,
76
+ active: active,
77
+ disabled: disabled
78
+ }, typeof icon === "string" ? /*#__PURE__*/_react["default"].createElement(_Icon["default"], {
79
+ icon: icon
80
+ }) : icon), /*#__PURE__*/_react["default"].createElement(_Flex["default"], {
81
+ alignItems: "center",
82
+ gap: "0.5rem"
83
+ }, /*#__PURE__*/_react["default"].createElement(_BaseTypography["default"], {
84
+ color: disabled ? colorsTheme.navTabs.disabledFontColor : active ? colorsTheme.navTabs.selectedFontColor : colorsTheme.navTabs.unselectedFontColor,
85
+ fontFamily: colorsTheme.navTabs.fontFamily,
86
+ fontSize: colorsTheme.navTabs.fontSize,
87
+ fontStyle: colorsTheme.navTabs.fontStyle,
88
+ fontWeight: colorsTheme.navTabs.fontWeight,
89
+ textAlign: "center",
90
+ letterSpacing: "0.025em",
91
+ lineHeight: "1.715em"
92
+ }, children), notificationNumber && !disabled && /*#__PURE__*/_react["default"].createElement(_Badge["default"], {
93
+ mode: "notification",
94
+ size: "small",
95
+ label: typeof notificationNumber === "number" && notificationNumber
96
+ }))));
97
+ });
98
+ var TabContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n align-items: stretch;\n border-bottom: 2px solid ", ";\n padding: 0.5rem;\n"])), function (props) {
99
+ return props.active ? props.theme.selectedUnderlineColor : "transparent";
100
+ });
101
+ var Tab = _styledComponents["default"].a(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n flex-direction: ", ";\n justify-content: center;\n align-items: center;\n gap: ", ";\n height: ", ";\n min-width: 176px;\n min-height: 44px;\n padding: 0.375rem;\n border-radius: 4px;\n background: ", ";\n text-decoration-color: transparent;\n text-decoration-line: none;\n cursor: ", ";\n\n ", "\n"])), function (props) {
102
+ return props.hasIcon && props.iconPosition === "top" ? "column" : "row";
103
+ }, function (props) {
104
+ return props.hasIcon && props.iconPosition === "top" ? "0.375rem" : "0.625rem";
105
+ }, function (props) {
106
+ return props.hasIcon && props.iconPosition === "top" ? "78px" : "100%";
107
+ }, function (props) {
108
+ return props.active ? props.theme.selectedBackgroundColor : props.theme.unselectedBackgroundColor;
109
+ }, function (props) {
110
+ return props.disabled ? "not-allowed" : "pointer";
111
+ }, function (props) {
112
+ return !props.disabled && "\n :hover {\n background: ".concat(props.theme.hoverBackgroundColor, ";\n }\n :focus {\n outline: 2px solid ").concat(props.theme.focusOutline, ";\n }\n :active {\n background: ").concat(props.theme.pressedBackgroundColor, ";\n outline: 2px solid #33aaff};\n }\n ");
113
+ });
114
+ var TabIconContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n font-size: 24px;\n color: ", ";\n svg {\n height: 24px;\n width: 24px;\n }\n"])), function (props) {
115
+ return props.active ? props.theme.selectedIconColor : props.disabled ? props.theme.disabledIconColor : props.theme.unselectedIconColor;
116
+ });
117
+ var _default = exports["default"] = DxcTab;
@@ -1,6 +1,11 @@
1
1
  /// <reference types="react" />
2
- declare type SVG = React.SVGProps<SVGSVGElement>;
3
- export declare type TabProps = {
2
+ type SVG = React.ReactNode & React.SVGProps<SVGSVGElement>;
3
+ export type NavTabsContextProps = {
4
+ iconPosition: "top" | "left";
5
+ tabIndex: number;
6
+ focusedLabel: string;
7
+ };
8
+ export type TabProps = {
4
9
  /**
5
10
  * Whether the tab is active or not.
6
11
  */
@@ -14,7 +19,7 @@ export declare type TabProps = {
14
19
  */
15
20
  href?: string;
16
21
  /**
17
- * Element or path used as the icon that will be displayed in the tab.
22
+ * Material Symbol name or SVG element used as the icon that will be displayed in the tab.
18
23
  */
19
24
  icon?: string | SVG;
20
25
  /**
@@ -26,28 +31,22 @@ export declare type TabProps = {
26
31
  */
27
32
  notificationNumber?: boolean | number;
28
33
  /**
29
- * Content of the tab.
34
+ * Tab text label.
30
35
  */
31
36
  children: string;
32
37
  };
33
- export declare type NavTabsProps = {
38
+ type Props = {
34
39
  /**
35
40
  * Whether the icon should appear above or to the left of the label.
36
41
  */
37
42
  iconPosition?: "top" | "left";
38
43
  /**
39
- * Value of the tabindex for each tab.
44
+ * Contains one or more DxcNavTabs.Tab.
40
45
  */
41
- tabIndex?: number;
46
+ children: React.ReactNode;
42
47
  /**
43
- * Content of the tabs nav.
48
+ * Value of the tabindex attribute applied to each tab.
44
49
  */
45
- children: React.ReactNode;
46
- };
47
- export declare type NavTabsContextProps = {
48
- iconPosition: "top" | "left";
49
- tabIndex: number;
50
- hasIcons: boolean;
51
- focusedLabel: string;
50
+ tabIndex?: number;
52
51
  };
53
- export {};
52
+ export default Props;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,228 @@
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 _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
7
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
8
+ var _react = _interopRequireDefault(require("react"));
9
+ var _react2 = require("@testing-library/react");
10
+ var _axeHelper = require("../../test/accessibility/axe-helper.js");
11
+ var _NumberInput = _interopRequireDefault(require("./NumberInput"));
12
+ // Mocking DOMRect for Radix Primitive Popover
13
+ global.globalThis = global;
14
+ global.DOMRect = {
15
+ fromRect: function fromRect() {
16
+ return {
17
+ top: 0,
18
+ left: 0,
19
+ bottom: 0,
20
+ right: 0,
21
+ width: 0,
22
+ height: 0
23
+ };
24
+ }
25
+ };
26
+ global.ResizeObserver = /*#__PURE__*/function () {
27
+ function ResizeObserver() {
28
+ (0, _classCallCheck2["default"])(this, ResizeObserver);
29
+ }
30
+ (0, _createClass2["default"])(ResizeObserver, [{
31
+ key: "observe",
32
+ value: function observe() {}
33
+ }, {
34
+ key: "unobserve",
35
+ value: function unobserve() {}
36
+ }, {
37
+ key: "disconnect",
38
+ value: function disconnect() {}
39
+ }]);
40
+ return ResizeObserver;
41
+ }();
42
+ describe("Number input component accessibility tests", function () {
43
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
44
+ var _render, container, results;
45
+ return _regenerator["default"].wrap(function _callee$(_context) {
46
+ while (1) switch (_context.prev = _context.next) {
47
+ case 0:
48
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
49
+ label: "Number input label",
50
+ helperText: "Helper text",
51
+ placeholder: "Placeholder",
52
+ defaultValue: "10",
53
+ margin: "medium",
54
+ min: 0,
55
+ max: 100,
56
+ suffix: "Suffix",
57
+ prefix: "Prefix",
58
+ name: "Name",
59
+ size: "medium",
60
+ step: 1
61
+ })), container = _render.container;
62
+ _context.next = 3;
63
+ return (0, _axeHelper.axe)(container);
64
+ case 3:
65
+ results = _context.sent;
66
+ expect(results).toHaveNoViolations();
67
+ case 5:
68
+ case "end":
69
+ return _context.stop();
70
+ }
71
+ }, _callee);
72
+ })));
73
+ it("Should not have basic accessibility issues for optional mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
74
+ var _render2, container, results;
75
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
76
+ while (1) switch (_context2.prev = _context2.next) {
77
+ case 0:
78
+ _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
79
+ label: "Number input label",
80
+ helperText: "Helper text",
81
+ placeholder: "Placeholder",
82
+ defaultValue: "10",
83
+ margin: "medium",
84
+ min: 0,
85
+ max: 100,
86
+ suffix: "Suffix",
87
+ prefix: "Prefix",
88
+ name: "Name",
89
+ size: "medium",
90
+ step: 1,
91
+ optional: true
92
+ })), container = _render2.container;
93
+ _context2.next = 3;
94
+ return (0, _axeHelper.axe)(container);
95
+ case 3:
96
+ results = _context2.sent;
97
+ expect(results).toHaveNoViolations();
98
+ case 5:
99
+ case "end":
100
+ return _context2.stop();
101
+ }
102
+ }, _callee2);
103
+ })));
104
+ it("Should not have basic accessibility issues for error mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
105
+ var _render3, container, results;
106
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
107
+ while (1) switch (_context3.prev = _context3.next) {
108
+ case 0:
109
+ _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
110
+ label: "Number input label",
111
+ helperText: "Helper text",
112
+ placeholder: "Placeholder",
113
+ defaultValue: "10",
114
+ margin: "medium",
115
+ min: 0,
116
+ max: 100,
117
+ suffix: "Suffix",
118
+ prefix: "Prefix",
119
+ name: "Name",
120
+ error: "Input error",
121
+ size: "medium",
122
+ step: 1
123
+ })), container = _render3.container;
124
+ _context3.next = 3;
125
+ return (0, _axeHelper.axe)(container);
126
+ case 3:
127
+ results = _context3.sent;
128
+ expect(results).toHaveNoViolations();
129
+ case 5:
130
+ case "end":
131
+ return _context3.stop();
132
+ }
133
+ }, _callee3);
134
+ })));
135
+ it("Should not have basic accessibility issues for disabled mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4() {
136
+ var _render4, container, results;
137
+ return _regenerator["default"].wrap(function _callee4$(_context4) {
138
+ while (1) switch (_context4.prev = _context4.next) {
139
+ case 0:
140
+ _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
141
+ label: "Number input label",
142
+ helperText: "Helper text",
143
+ placeholder: "Placeholder",
144
+ defaultValue: "10",
145
+ margin: "medium",
146
+ min: 0,
147
+ max: 100,
148
+ suffix: "Suffix",
149
+ prefix: "Prefix",
150
+ name: "Name",
151
+ size: "medium",
152
+ step: 1,
153
+ disabled: true
154
+ })), container = _render4.container;
155
+ _context4.next = 3;
156
+ return (0, _axeHelper.axe)(container);
157
+ case 3:
158
+ results = _context4.sent;
159
+ expect(results).toHaveNoViolations();
160
+ case 5:
161
+ case "end":
162
+ return _context4.stop();
163
+ }
164
+ }, _callee4);
165
+ })));
166
+ it("Should not have basic accessibility issues for read-only mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee5() {
167
+ var _render5, container, results;
168
+ return _regenerator["default"].wrap(function _callee5$(_context5) {
169
+ while (1) switch (_context5.prev = _context5.next) {
170
+ case 0:
171
+ _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
172
+ label: "Number input label",
173
+ helperText: "Helper text",
174
+ placeholder: "Placeholder",
175
+ defaultValue: "10",
176
+ margin: "medium",
177
+ min: 0,
178
+ max: 100,
179
+ suffix: "Suffix",
180
+ prefix: "Prefix",
181
+ name: "Name",
182
+ size: "medium",
183
+ step: 1,
184
+ readOnly: true
185
+ })), container = _render5.container;
186
+ _context5.next = 3;
187
+ return (0, _axeHelper.axe)(container);
188
+ case 3:
189
+ results = _context5.sent;
190
+ expect(results).toHaveNoViolations();
191
+ case 5:
192
+ case "end":
193
+ return _context5.stop();
194
+ }
195
+ }, _callee5);
196
+ })));
197
+ it("Should not have basic accessibility issues for autocomplete mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee6() {
198
+ var _render6, container, results;
199
+ return _regenerator["default"].wrap(function _callee6$(_context6) {
200
+ while (1) switch (_context6.prev = _context6.next) {
201
+ case 0:
202
+ _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_NumberInput["default"], {
203
+ label: "Number input label",
204
+ helperText: "Helper text",
205
+ placeholder: "Placeholder",
206
+ defaultValue: "10",
207
+ margin: "medium",
208
+ min: 0,
209
+ max: 100,
210
+ suffix: "Suffix",
211
+ prefix: "Prefix",
212
+ name: "Name",
213
+ size: "medium",
214
+ step: 1,
215
+ autocomplete: "on"
216
+ })), container = _render6.container;
217
+ _context6.next = 3;
218
+ return (0, _axeHelper.axe)(container);
219
+ case 3:
220
+ results = _context6.sent;
221
+ expect(results).toHaveNoViolations();
222
+ case 5:
223
+ case "end":
224
+ return _context6.stop();
225
+ }
226
+ }, _callee6);
227
+ })));
228
+ });
@@ -1,54 +1,66 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
-
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
8
  exports["default"] = void 0;
9
-
10
9
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
11
-
12
- var _react = _interopRequireDefault(require("react"));
13
-
10
+ var _react = _interopRequireWildcard(require("react"));
14
11
  var _styledComponents = _interopRequireDefault(require("styled-components"));
15
-
16
12
  var _TextInput = _interopRequireDefault(require("../text-input/TextInput"));
17
-
18
- var _NumberInputContext = _interopRequireDefault(require("./NumberInputContext"));
19
-
13
+ var _NumberInputContext = require("./NumberInputContext");
20
14
  var _templateObject;
21
-
15
+ function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
16
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
22
17
  var DxcNumberInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
23
18
  var label = _ref.label,
24
- name = _ref.name,
25
- defaultValue = _ref.defaultValue,
26
- value = _ref.value,
27
- helperText = _ref.helperText,
28
- placeholder = _ref.placeholder,
29
- disabled = _ref.disabled,
30
- optional = _ref.optional,
31
- prefix = _ref.prefix,
32
- suffix = _ref.suffix,
33
- min = _ref.min,
34
- max = _ref.max,
35
- _ref$step = _ref.step,
36
- step = _ref$step === void 0 ? 1 : _ref$step,
37
- onChange = _ref.onChange,
38
- onBlur = _ref.onBlur,
39
- error = _ref.error,
40
- autocomplete = _ref.autocomplete,
41
- margin = _ref.margin,
42
- size = _ref.size,
43
- tabIndex = _ref.tabIndex;
44
- return /*#__PURE__*/_react["default"].createElement(_NumberInputContext["default"].Provider, {
19
+ name = _ref.name,
20
+ defaultValue = _ref.defaultValue,
21
+ value = _ref.value,
22
+ helperText = _ref.helperText,
23
+ placeholder = _ref.placeholder,
24
+ disabled = _ref.disabled,
25
+ optional = _ref.optional,
26
+ readOnly = _ref.readOnly,
27
+ prefix = _ref.prefix,
28
+ suffix = _ref.suffix,
29
+ min = _ref.min,
30
+ max = _ref.max,
31
+ _ref$step = _ref.step,
32
+ step = _ref$step === void 0 ? 1 : _ref$step,
33
+ onChange = _ref.onChange,
34
+ onBlur = _ref.onBlur,
35
+ error = _ref.error,
36
+ autocomplete = _ref.autocomplete,
37
+ margin = _ref.margin,
38
+ size = _ref.size,
39
+ tabIndex = _ref.tabIndex;
40
+ var numberInputRef = _react["default"].useRef(null);
41
+ (0, _react.useEffect)(function () {
42
+ var _numberInputRef$curre;
43
+ var input = (_numberInputRef$curre = numberInputRef.current) === null || _numberInputRef$curre === void 0 ? void 0 : _numberInputRef$curre.getElementsByTagName("input")[0];
44
+ var preventDefault = function preventDefault(event) {
45
+ event.preventDefault();
46
+ };
47
+ input === null || input === void 0 ? void 0 : input.addEventListener("wheel", preventDefault, {
48
+ passive: false
49
+ });
50
+ return function () {
51
+ input === null || input === void 0 ? void 0 : input.removeEventListener("wheel", preventDefault);
52
+ };
53
+ }, []);
54
+ return /*#__PURE__*/_react["default"].createElement(_NumberInputContext.NumberInputContext.Provider, {
45
55
  value: {
46
56
  typeNumber: "number",
47
57
  minNumber: min,
48
58
  maxNumber: max,
49
59
  stepNumber: step
50
60
  }
51
- }, /*#__PURE__*/_react["default"].createElement(NumberInputContainer, null, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
61
+ }, /*#__PURE__*/_react["default"].createElement(NumberInputContainer, {
62
+ ref: numberInputRef
63
+ }, /*#__PURE__*/_react["default"].createElement(_TextInput["default"], {
52
64
  label: label,
53
65
  name: name,
54
66
  defaultValue: defaultValue,
@@ -57,6 +69,7 @@ var DxcNumberInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, r
57
69
  placeholder: placeholder,
58
70
  disabled: disabled,
59
71
  optional: optional,
72
+ readOnly: readOnly,
60
73
  prefix: prefix,
61
74
  suffix: suffix,
62
75
  error: error,
@@ -69,8 +82,5 @@ var DxcNumberInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, r
69
82
  ref: ref
70
83
  })));
71
84
  });
72
-
73
85
  var NumberInputContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n // Chrome, Safari, Edge, Opera\n input::-webkit-outer-spin-button,\n input::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n }\n\n // Firefox\n input[type=\"number\"] {\n -moz-appearance: textfield;\n }\n"])));
74
-
75
- var _default = DxcNumberInput;
76
- exports["default"] = _default;
86
+ var _default = exports["default"] = DxcNumberInput;