@dxc-technology/halstack-react 0.0.0-e9d5d69 → 0.0.0-ea9b3a2

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 (607) hide show
  1. package/BackgroundColorContext.d.ts +1 -0
  2. package/BackgroundColorContext.js +30 -0
  3. package/HalstackContext.d.ts +1249 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +28 -47
  6. package/accordion/Accordion.accessibility.test.js +71 -0
  7. package/accordion/Accordion.d.ts +4 -0
  8. package/accordion/Accordion.js +169 -0
  9. package/accordion/Accordion.stories.tsx +251 -0
  10. package/accordion/Accordion.test.js +56 -0
  11. package/accordion/types.d.ts +57 -0
  12. package/accordion/types.js +5 -0
  13. package/accordion-group/AccordionGroup.accessibility.test.js +88 -0
  14. package/accordion-group/AccordionGroup.d.ts +7 -0
  15. package/accordion-group/AccordionGroup.js +101 -0
  16. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  17. package/accordion-group/AccordionGroup.test.js +98 -0
  18. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  19. package/accordion-group/AccordionGroupAccordion.js +31 -0
  20. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  21. package/accordion-group/AccordionGroupContext.js +8 -0
  22. package/accordion-group/types.d.ts +67 -0
  23. package/accordion-group/types.js +5 -0
  24. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  25. package/action-icon/ActionIcon.d.ts +4 -0
  26. package/action-icon/ActionIcon.js +48 -0
  27. package/action-icon/ActionIcon.stories.tsx +41 -0
  28. package/action-icon/ActionIcon.test.js +64 -0
  29. package/action-icon/types.d.ts +26 -0
  30. package/action-icon/types.js +5 -0
  31. package/alert/Alert.accessibility.test.js +95 -0
  32. package/alert/Alert.d.ts +4 -0
  33. package/alert/Alert.js +200 -0
  34. package/alert/Alert.stories.tsx +198 -0
  35. package/alert/Alert.test.js +75 -0
  36. package/alert/types.d.ts +49 -0
  37. package/alert/types.js +5 -0
  38. package/badge/Badge.accessibility.test.js +129 -0
  39. package/badge/Badge.d.ts +4 -0
  40. package/badge/Badge.js +161 -0
  41. package/badge/Badge.stories.tsx +210 -0
  42. package/badge/Badge.test.js +30 -0
  43. package/badge/types.d.ts +54 -0
  44. package/badge/types.js +5 -0
  45. package/bleed/Bleed.d.ts +3 -0
  46. package/bleed/Bleed.js +43 -0
  47. package/bleed/Bleed.stories.tsx +342 -0
  48. package/bleed/types.d.ts +37 -0
  49. package/bleed/types.js +5 -0
  50. package/box/Box.accessibility.test.js +33 -0
  51. package/box/Box.d.ts +4 -0
  52. package/box/Box.js +75 -0
  53. package/box/Box.stories.tsx +119 -0
  54. package/box/Box.test.js +13 -0
  55. package/box/types.d.ts +32 -0
  56. package/box/types.js +5 -0
  57. package/bulleted-list/BulletedList.accessibility.test.js +107 -0
  58. package/bulleted-list/BulletedList.d.ts +7 -0
  59. package/bulleted-list/BulletedList.js +92 -0
  60. package/bulleted-list/BulletedList.stories.tsx +115 -0
  61. package/bulleted-list/types.d.ts +38 -0
  62. package/bulleted-list/types.js +5 -0
  63. package/button/Button.accessibility.test.js +127 -0
  64. package/button/Button.d.ts +4 -0
  65. package/button/Button.js +121 -0
  66. package/button/Button.stories.tsx +325 -0
  67. package/button/Button.test.js +38 -0
  68. package/button/types.d.ts +57 -0
  69. package/button/types.js +5 -0
  70. package/card/Card.accessibility.test.js +36 -0
  71. package/card/Card.d.ts +4 -0
  72. package/card/Card.js +120 -0
  73. package/card/Card.stories.tsx +171 -0
  74. package/card/Card.test.js +39 -0
  75. package/card/types.d.ts +62 -0
  76. package/card/types.js +5 -0
  77. package/checkbox/Checkbox.accessibility.test.js +87 -0
  78. package/checkbox/Checkbox.d.ts +4 -0
  79. package/checkbox/Checkbox.js +215 -0
  80. package/checkbox/Checkbox.stories.tsx +222 -0
  81. package/checkbox/Checkbox.test.js +199 -0
  82. package/checkbox/types.d.ts +72 -0
  83. package/checkbox/types.js +5 -0
  84. package/chip/Chip.accessibility.test.js +67 -0
  85. package/chip/Chip.d.ts +4 -0
  86. package/chip/Chip.js +124 -0
  87. package/chip/Chip.stories.tsx +195 -0
  88. package/chip/Chip.test.js +41 -0
  89. package/chip/types.d.ts +45 -0
  90. package/chip/types.js +5 -0
  91. package/common/coreTokens.d.ts +237 -0
  92. package/common/coreTokens.js +184 -0
  93. package/common/utils.d.ts +1 -0
  94. package/common/utils.js +16 -0
  95. package/common/variables.d.ts +1395 -0
  96. package/common/variables.js +1267 -0
  97. package/container/Container.d.ts +4 -0
  98. package/container/Container.js +194 -0
  99. package/container/Container.stories.tsx +214 -0
  100. package/container/types.d.ts +74 -0
  101. package/container/types.js +5 -0
  102. package/contextual-menu/ContextualMenu.accessibility.test.js +86 -0
  103. package/contextual-menu/ContextualMenu.d.ts +7 -0
  104. package/contextual-menu/ContextualMenu.js +71 -0
  105. package/contextual-menu/ContextualMenu.stories.tsx +182 -0
  106. package/contextual-menu/ContextualMenu.test.js +71 -0
  107. package/contextual-menu/MenuItemAction.d.ts +4 -0
  108. package/contextual-menu/MenuItemAction.js +46 -0
  109. package/contextual-menu/types.d.ts +22 -0
  110. package/contextual-menu/types.js +5 -0
  111. package/date-input/Calendar.d.ts +4 -0
  112. package/date-input/Calendar.js +214 -0
  113. package/date-input/DateInput.accessibility.test.js +216 -0
  114. package/date-input/DateInput.d.ts +4 -0
  115. package/date-input/DateInput.js +223 -0
  116. package/date-input/DateInput.stories.tsx +285 -0
  117. package/date-input/DateInput.test.js +808 -0
  118. package/date-input/DatePicker.d.ts +4 -0
  119. package/date-input/DatePicker.js +115 -0
  120. package/date-input/Icons.d.ts +6 -0
  121. package/date-input/Icons.js +58 -0
  122. package/date-input/YearPicker.d.ts +4 -0
  123. package/date-input/YearPicker.js +100 -0
  124. package/date-input/types.d.ts +164 -0
  125. package/date-input/types.js +5 -0
  126. package/dialog/Dialog.accessibility.test.js +69 -0
  127. package/dialog/Dialog.d.ts +4 -0
  128. package/dialog/Dialog.js +104 -0
  129. package/dialog/Dialog.stories.tsx +365 -0
  130. package/dialog/Dialog.test.js +307 -0
  131. package/dialog/types.d.ts +36 -0
  132. package/dialog/types.js +5 -0
  133. package/divider/Divider.accessibility.test.js +33 -0
  134. package/divider/Divider.d.ts +4 -0
  135. package/divider/Divider.js +36 -0
  136. package/divider/Divider.stories.tsx +223 -0
  137. package/divider/Divider.test.js +38 -0
  138. package/divider/types.d.ts +21 -0
  139. package/divider/types.js +5 -0
  140. package/dropdown/Dropdown.accessibility.test.js +180 -0
  141. package/dropdown/Dropdown.d.ts +4 -0
  142. package/dropdown/Dropdown.js +319 -0
  143. package/dropdown/Dropdown.stories.tsx +427 -0
  144. package/dropdown/Dropdown.test.js +599 -0
  145. package/dropdown/DropdownMenu.d.ts +4 -0
  146. package/dropdown/DropdownMenu.js +63 -0
  147. package/dropdown/DropdownMenuItem.d.ts +4 -0
  148. package/dropdown/DropdownMenuItem.js +70 -0
  149. package/dropdown/types.d.ts +96 -0
  150. package/dropdown/types.js +5 -0
  151. package/file-input/FileInput.accessibility.test.js +160 -0
  152. package/file-input/FileInput.d.ts +4 -0
  153. package/file-input/FileInput.js +443 -0
  154. package/file-input/FileInput.stories.tsx +618 -0
  155. package/file-input/FileInput.test.js +382 -0
  156. package/file-input/FileItem.d.ts +4 -0
  157. package/file-input/FileItem.js +121 -0
  158. package/file-input/types.d.ts +129 -0
  159. package/file-input/types.js +5 -0
  160. package/flex/Flex.d.ts +4 -0
  161. package/flex/Flex.js +57 -0
  162. package/flex/Flex.stories.tsx +112 -0
  163. package/flex/types.d.ts +97 -0
  164. package/flex/types.js +5 -0
  165. package/footer/Footer.accessibility.test.js +117 -0
  166. package/footer/Footer.d.ts +4 -0
  167. package/footer/Footer.js +140 -0
  168. package/footer/Footer.stories.tsx +196 -0
  169. package/footer/Footer.test.js +85 -0
  170. package/footer/Icons.d.ts +3 -0
  171. package/footer/Icons.js +136 -0
  172. package/footer/types.d.ts +64 -0
  173. package/footer/types.js +5 -0
  174. package/grid/Grid.d.ts +7 -0
  175. package/grid/Grid.js +76 -0
  176. package/grid/Grid.stories.tsx +219 -0
  177. package/grid/types.d.ts +115 -0
  178. package/grid/types.js +5 -0
  179. package/header/Header.accessibility.test.js +84 -0
  180. package/header/Header.d.ts +8 -0
  181. package/header/Header.js +209 -0
  182. package/header/Header.stories.tsx +251 -0
  183. package/header/Header.test.js +66 -0
  184. package/header/Icons.d.ts +2 -0
  185. package/header/Icons.js +29 -0
  186. package/header/types.d.ts +33 -0
  187. package/header/types.js +5 -0
  188. package/heading/Heading.accessibility.test.js +33 -0
  189. package/heading/Heading.d.ts +4 -0
  190. package/heading/Heading.js +137 -0
  191. package/heading/Heading.stories.tsx +54 -0
  192. package/heading/Heading.test.js +169 -0
  193. package/heading/types.d.ts +33 -0
  194. package/heading/types.js +5 -0
  195. package/icon/Icon.accessibility.test.js +30 -0
  196. package/icon/Icon.d.ts +4 -0
  197. package/icon/Icon.js +33 -0
  198. package/icon/Icon.stories.tsx +28 -0
  199. package/icon/types.d.ts +4 -0
  200. package/icon/types.js +5 -0
  201. package/image/Image.accessibility.test.js +56 -0
  202. package/image/Image.d.ts +4 -0
  203. package/image/Image.js +70 -0
  204. package/image/Image.stories.tsx +129 -0
  205. package/image/types.d.ts +72 -0
  206. package/image/types.js +5 -0
  207. package/inset/Inset.d.ts +3 -0
  208. package/inset/Inset.js +43 -0
  209. package/inset/Inset.stories.tsx +230 -0
  210. package/inset/types.d.ts +37 -0
  211. package/inset/types.js +5 -0
  212. package/layout/ApplicationLayout.d.ts +20 -0
  213. package/layout/ApplicationLayout.js +134 -0
  214. package/layout/ApplicationLayout.stories.tsx +162 -0
  215. package/layout/Icons.d.ts +8 -0
  216. package/layout/Icons.js +56 -0
  217. package/layout/types.d.ts +41 -0
  218. package/layout/types.js +5 -0
  219. package/link/Link.accessibility.test.js +112 -0
  220. package/link/Link.d.ts +4 -0
  221. package/link/Link.js +117 -0
  222. package/link/Link.stories.tsx +253 -0
  223. package/link/Link.test.js +63 -0
  224. package/link/types.d.ts +54 -0
  225. package/link/types.js +5 -0
  226. package/main.d.ts +49 -0
  227. package/{dist/main.js → main.js} +177 -99
  228. package/nav-tabs/NavTabs.accessibility.test.js +52 -0
  229. package/nav-tabs/NavTabs.d.ts +7 -0
  230. package/nav-tabs/NavTabs.js +93 -0
  231. package/nav-tabs/NavTabs.stories.tsx +276 -0
  232. package/nav-tabs/NavTabs.test.js +76 -0
  233. package/nav-tabs/NavTabsContext.d.ts +3 -0
  234. package/nav-tabs/NavTabsContext.js +8 -0
  235. package/nav-tabs/Tab.d.ts +4 -0
  236. package/nav-tabs/Tab.js +118 -0
  237. package/nav-tabs/types.d.ts +52 -0
  238. package/nav-tabs/types.js +5 -0
  239. package/number-input/NumberInput.accessibility.test.js +228 -0
  240. package/number-input/NumberInput.d.ts +4 -0
  241. package/number-input/NumberInput.js +86 -0
  242. package/number-input/NumberInput.stories.tsx +131 -0
  243. package/number-input/NumberInput.test.js +989 -0
  244. package/number-input/NumberInputContext.d.ts +3 -0
  245. package/number-input/NumberInputContext.js +8 -0
  246. package/number-input/types.d.ts +136 -0
  247. package/number-input/types.js +5 -0
  248. package/package.json +65 -50
  249. package/paginator/Icons.d.ts +5 -0
  250. package/paginator/Icons.js +40 -0
  251. package/paginator/Paginator.accessibility.test.js +79 -0
  252. package/paginator/Paginator.d.ts +4 -0
  253. package/paginator/Paginator.js +135 -0
  254. package/paginator/Paginator.stories.tsx +87 -0
  255. package/paginator/Paginator.test.js +335 -0
  256. package/paginator/types.d.ts +38 -0
  257. package/paginator/types.js +5 -0
  258. package/paragraph/Paragraph.accessibility.test.js +28 -0
  259. package/paragraph/Paragraph.d.ts +5 -0
  260. package/paragraph/Paragraph.js +22 -0
  261. package/paragraph/Paragraph.stories.tsx +27 -0
  262. package/password-input/Icons.d.ts +6 -0
  263. package/password-input/Icons.js +35 -0
  264. package/password-input/PasswordInput.accessibility.test.js +153 -0
  265. package/password-input/PasswordInput.d.ts +4 -0
  266. package/password-input/PasswordInput.js +97 -0
  267. package/password-input/PasswordInput.stories.tsx +99 -0
  268. package/password-input/PasswordInput.test.js +198 -0
  269. package/password-input/types.d.ts +111 -0
  270. package/password-input/types.js +5 -0
  271. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  272. package/progress-bar/ProgressBar.d.ts +4 -0
  273. package/progress-bar/ProgressBar.js +144 -0
  274. package/progress-bar/ProgressBar.stories.tsx +93 -0
  275. package/progress-bar/ProgressBar.test.js +93 -0
  276. package/progress-bar/types.d.ts +37 -0
  277. package/progress-bar/types.js +5 -0
  278. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  279. package/quick-nav/QuickNav.d.ts +4 -0
  280. package/quick-nav/QuickNav.js +94 -0
  281. package/quick-nav/QuickNav.stories.tsx +356 -0
  282. package/quick-nav/types.d.ts +21 -0
  283. package/quick-nav/types.js +5 -0
  284. package/radio-group/Radio.d.ts +4 -0
  285. package/radio-group/Radio.js +124 -0
  286. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  287. package/radio-group/RadioGroup.d.ts +4 -0
  288. package/radio-group/RadioGroup.js +235 -0
  289. package/radio-group/RadioGroup.stories.tsx +214 -0
  290. package/radio-group/RadioGroup.test.js +756 -0
  291. package/radio-group/types.d.ts +114 -0
  292. package/radio-group/types.js +5 -0
  293. package/resultset-table/Icons.d.ts +7 -0
  294. package/resultset-table/Icons.js +47 -0
  295. package/resultset-table/ResultsetTable.accessibility.test.js +274 -0
  296. package/resultset-table/ResultsetTable.d.ts +7 -0
  297. package/resultset-table/ResultsetTable.js +170 -0
  298. package/resultset-table/ResultsetTable.stories.tsx +401 -0
  299. package/resultset-table/ResultsetTable.test.js +381 -0
  300. package/resultset-table/types.d.ts +100 -0
  301. package/resultset-table/types.js +5 -0
  302. package/select/Icons.d.ts +10 -0
  303. package/select/Icons.js +89 -0
  304. package/select/Listbox.d.ts +4 -0
  305. package/select/Listbox.js +143 -0
  306. package/select/Option.d.ts +4 -0
  307. package/select/Option.js +87 -0
  308. package/select/Select.accessibility.test.js +217 -0
  309. package/select/Select.d.ts +4 -0
  310. package/select/Select.js +590 -0
  311. package/select/Select.stories.tsx +970 -0
  312. package/select/Select.test.js +2370 -0
  313. package/select/types.d.ts +209 -0
  314. package/select/types.js +5 -0
  315. package/sidenav/Icons.d.ts +7 -0
  316. package/sidenav/Icons.js +47 -0
  317. package/sidenav/Sidenav.accessibility.test.js +59 -0
  318. package/sidenav/Sidenav.d.ts +10 -0
  319. package/sidenav/Sidenav.js +197 -0
  320. package/sidenav/Sidenav.stories.tsx +281 -0
  321. package/sidenav/Sidenav.test.js +37 -0
  322. package/sidenav/SidenavContext.d.ts +5 -0
  323. package/sidenav/SidenavContext.js +13 -0
  324. package/sidenav/types.d.ts +76 -0
  325. package/sidenav/types.js +5 -0
  326. package/slider/Slider.accessibility.test.js +104 -0
  327. package/slider/Slider.d.ts +4 -0
  328. package/slider/Slider.js +285 -0
  329. package/slider/Slider.test.js +254 -0
  330. package/slider/types.d.ts +86 -0
  331. package/slider/types.js +5 -0
  332. package/spinner/Spinner.accessibility.test.js +96 -0
  333. package/spinner/Spinner.d.ts +4 -0
  334. package/spinner/Spinner.js +206 -0
  335. package/spinner/Spinner.stories.tsx +129 -0
  336. package/spinner/Spinner.test.js +55 -0
  337. package/spinner/types.d.ts +32 -0
  338. package/spinner/types.js +5 -0
  339. package/status-light/StatusLight.accessibility.test.js +157 -0
  340. package/status-light/StatusLight.d.ts +4 -0
  341. package/status-light/StatusLight.js +51 -0
  342. package/status-light/StatusLight.stories.tsx +74 -0
  343. package/status-light/StatusLight.test.js +25 -0
  344. package/status-light/types.d.ts +17 -0
  345. package/status-light/types.js +5 -0
  346. package/switch/Switch.accessibility.test.js +89 -0
  347. package/switch/Switch.d.ts +4 -0
  348. package/switch/Switch.js +214 -0
  349. package/switch/Switch.stories.tsx +137 -0
  350. package/switch/Switch.test.js +180 -0
  351. package/switch/types.d.ts +66 -0
  352. package/switch/types.js +5 -0
  353. package/table/DropdownTheme.js +62 -0
  354. package/table/Table.accessibility.test.js +82 -0
  355. package/table/Table.d.ts +8 -0
  356. package/table/Table.js +161 -0
  357. package/table/Table.stories.tsx +651 -0
  358. package/table/Table.test.js +113 -0
  359. package/table/types.d.ts +49 -0
  360. package/table/types.js +5 -0
  361. package/tabs/Tab.d.ts +4 -0
  362. package/tabs/Tab.js +116 -0
  363. package/tabs/Tabs.accessibility.test.js +56 -0
  364. package/tabs/Tabs.d.ts +4 -0
  365. package/tabs/Tabs.js +384 -0
  366. package/tabs/Tabs.stories.tsx +226 -0
  367. package/tabs/Tabs.test.js +294 -0
  368. package/tabs/types.d.ts +92 -0
  369. package/tabs/types.js +5 -0
  370. package/tag/Tag.accessibility.test.js +69 -0
  371. package/tag/Tag.d.ts +4 -0
  372. package/tag/Tag.js +151 -0
  373. package/tag/Tag.stories.tsx +152 -0
  374. package/tag/Tag.test.js +41 -0
  375. package/tag/types.d.ts +69 -0
  376. package/tag/types.js +5 -0
  377. package/text-input/Suggestion.d.ts +4 -0
  378. package/text-input/Suggestion.js +67 -0
  379. package/text-input/Suggestions.d.ts +4 -0
  380. package/text-input/Suggestions.js +86 -0
  381. package/text-input/TextInput.accessibility.test.js +321 -0
  382. package/text-input/TextInput.d.ts +4 -0
  383. package/text-input/TextInput.js +567 -0
  384. package/text-input/TextInput.stories.tsx +465 -0
  385. package/text-input/TextInput.test.js +1756 -0
  386. package/text-input/types.d.ts +205 -0
  387. package/text-input/types.js +5 -0
  388. package/textarea/Textarea.accessibility.test.js +155 -0
  389. package/textarea/Textarea.d.ts +4 -0
  390. package/textarea/Textarea.js +234 -0
  391. package/textarea/Textarea.stories.tsx +174 -0
  392. package/textarea/Textarea.test.js +406 -0
  393. package/textarea/types.d.ts +141 -0
  394. package/textarea/types.js +5 -0
  395. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  396. package/toggle-group/ToggleGroup.d.ts +4 -0
  397. package/toggle-group/ToggleGroup.js +201 -0
  398. package/toggle-group/ToggleGroup.stories.tsx +218 -0
  399. package/toggle-group/ToggleGroup.test.js +137 -0
  400. package/toggle-group/types.d.ts +114 -0
  401. package/toggle-group/types.js +5 -0
  402. package/typography/Typography.accessibility.test.js +339 -0
  403. package/typography/Typography.d.ts +4 -0
  404. package/typography/Typography.js +23 -0
  405. package/typography/Typography.stories.tsx +198 -0
  406. package/typography/types.d.ts +18 -0
  407. package/typography/types.js +5 -0
  408. package/useTheme.d.ts +1148 -0
  409. package/useTheme.js +15 -0
  410. package/useTranslatedLabels.d.ts +85 -0
  411. package/useTranslatedLabels.js +14 -0
  412. package/utils/BaseTypography.d.ts +21 -0
  413. package/utils/BaseTypography.js +94 -0
  414. package/utils/FocusLock.d.ts +13 -0
  415. package/utils/FocusLock.js +124 -0
  416. package/wizard/Wizard.accessibility.test.js +55 -0
  417. package/wizard/Wizard.d.ts +4 -0
  418. package/wizard/Wizard.js +250 -0
  419. package/wizard/Wizard.stories.tsx +253 -0
  420. package/wizard/Wizard.test.js +114 -0
  421. package/wizard/types.d.ts +64 -0
  422. package/wizard/types.js +5 -0
  423. package/babel.config.js +0 -4
  424. package/dist/ThemeContext.js +0 -15
  425. package/dist/accordion/Accordion.js +0 -268
  426. package/dist/accordion/Accordion.stories.js +0 -207
  427. package/dist/accordion/readme.md +0 -96
  428. package/dist/alert/Alert.js +0 -304
  429. package/dist/alert/Alert.stories.js +0 -158
  430. package/dist/alert/close.svg +0 -4
  431. package/dist/alert/error.svg +0 -4
  432. package/dist/alert/info.svg +0 -4
  433. package/dist/alert/readme.md +0 -43
  434. package/dist/alert/success.svg +0 -4
  435. package/dist/alert/warning.svg +0 -4
  436. package/dist/box/Box.js +0 -148
  437. package/dist/button/Button.js +0 -202
  438. package/dist/button/Button.stories.js +0 -224
  439. package/dist/button/readme.md +0 -93
  440. package/dist/card/Card.js +0 -217
  441. package/dist/checkbox/Checkbox.js +0 -240
  442. package/dist/checkbox/Checkbox.stories.js +0 -144
  443. package/dist/checkbox/readme.md +0 -116
  444. package/dist/chip/Chip.js +0 -208
  445. package/dist/common/OpenSans.css +0 -81
  446. package/dist/common/RequiredComponent.js +0 -46
  447. package/dist/common/fonts/OpenSans-Bold.ttf +0 -0
  448. package/dist/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  449. package/dist/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  450. package/dist/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  451. package/dist/common/fonts/OpenSans-Italic.ttf +0 -0
  452. package/dist/common/fonts/OpenSans-Light.ttf +0 -0
  453. package/dist/common/fonts/OpenSans-LightItalic.ttf +0 -0
  454. package/dist/common/fonts/OpenSans-Regular.ttf +0 -0
  455. package/dist/common/fonts/OpenSans-SemiBold.ttf +0 -0
  456. package/dist/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  457. package/dist/common/services/example-service.js +0 -10
  458. package/dist/common/services/example-service.test.js +0 -12
  459. package/dist/common/utils.js +0 -42
  460. package/dist/common/variables.js +0 -434
  461. package/dist/date/Date.js +0 -356
  462. package/dist/date/Date.stories.js +0 -205
  463. package/dist/date/calendar.svg +0 -1
  464. package/dist/date/calendar_dark.svg +0 -1
  465. package/dist/date/readme.md +0 -73
  466. package/dist/dialog/Dialog.js +0 -197
  467. package/dist/dialog/Dialog.stories.js +0 -217
  468. package/dist/dialog/readme.md +0 -32
  469. package/dist/dropdown/Dropdown.js +0 -449
  470. package/dist/dropdown/Dropdown.stories.js +0 -249
  471. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  472. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  473. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  474. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  475. package/dist/dropdown/readme.md +0 -69
  476. package/dist/footer/Footer.js +0 -371
  477. package/dist/footer/Footer.stories.js +0 -94
  478. package/dist/footer/dxc_logo_wht.png +0 -0
  479. package/dist/footer/readme.md +0 -41
  480. package/dist/header/Header.js +0 -373
  481. package/dist/header/Header.stories.js +0 -176
  482. package/dist/header/close_icon.svg +0 -1
  483. package/dist/header/dxc_logo_black.png +0 -0
  484. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  485. package/dist/header/dxc_logo_white.png +0 -0
  486. package/dist/header/hamb_menu_black.svg +0 -1
  487. package/dist/header/hamb_menu_white.svg +0 -1
  488. package/dist/header/readme.md +0 -33
  489. package/dist/heading/Heading.js +0 -153
  490. package/dist/input-text/InputText.js +0 -570
  491. package/dist/input-text/InputText.stories.js +0 -209
  492. package/dist/input-text/error.svg +0 -1
  493. package/dist/input-text/readme.md +0 -91
  494. package/dist/layout/ApplicationLayout.js +0 -335
  495. package/dist/layout/facebook.svg +0 -45
  496. package/dist/layout/linkedin.svg +0 -50
  497. package/dist/layout/twitter.svg +0 -53
  498. package/dist/link/Link.js +0 -189
  499. package/dist/link/readme.md +0 -51
  500. package/dist/paginator/Paginator.js +0 -196
  501. package/dist/paginator/images/next.svg +0 -3
  502. package/dist/paginator/images/nextPage.svg +0 -3
  503. package/dist/paginator/images/previous.svg +0 -3
  504. package/dist/paginator/images/previousPage.svg +0 -3
  505. package/dist/paginator/readme.md +0 -50
  506. package/dist/progress-bar/ProgressBar.js +0 -185
  507. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  508. package/dist/progress-bar/readme.md +0 -63
  509. package/dist/radio/Radio.js +0 -195
  510. package/dist/radio/Radio.stories.js +0 -166
  511. package/dist/radio/readme.md +0 -70
  512. package/dist/resultsetTable/ResultsetTable.js +0 -333
  513. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  514. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  515. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  516. package/dist/select/Select.js +0 -473
  517. package/dist/select/Select.stories.js +0 -235
  518. package/dist/select/readme.md +0 -72
  519. package/dist/sidenav/Sidenav.js +0 -128
  520. package/dist/slider/Slider.js +0 -266
  521. package/dist/slider/Slider.stories.js +0 -241
  522. package/dist/slider/readme.md +0 -64
  523. package/dist/spinner/Spinner.js +0 -193
  524. package/dist/spinner/Spinner.stories.js +0 -183
  525. package/dist/spinner/readme.md +0 -65
  526. package/dist/switch/Switch.js +0 -199
  527. package/dist/switch/Switch.stories.js +0 -134
  528. package/dist/switch/readme.md +0 -133
  529. package/dist/table/Table.js +0 -105
  530. package/dist/tabs/Tabs.js +0 -185
  531. package/dist/tabs/Tabs.stories.js +0 -130
  532. package/dist/tabs/readme.md +0 -78
  533. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  534. package/dist/tabs-for-sections/readme.md +0 -78
  535. package/dist/tag/Tag.js +0 -249
  536. package/dist/textarea/Textarea.js +0 -227
  537. package/dist/toggle/Toggle.js +0 -223
  538. package/dist/toggle/Toggle.stories.js +0 -297
  539. package/dist/toggle/readme.md +0 -80
  540. package/dist/toggle-group/ToggleGroup.js +0 -226
  541. package/dist/toggle-group/readme.md +0 -82
  542. package/dist/upload/Upload.js +0 -200
  543. package/dist/upload/Upload.stories.js +0 -72
  544. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -122
  545. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  546. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  547. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -279
  548. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  549. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  550. package/dist/upload/file-upload/FileToUpload.js +0 -158
  551. package/dist/upload/file-upload/audio-icon.svg +0 -4
  552. package/dist/upload/file-upload/close.svg +0 -4
  553. package/dist/upload/file-upload/file-icon.svg +0 -4
  554. package/dist/upload/file-upload/video-icon.svg +0 -4
  555. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  556. package/dist/upload/readme.md +0 -37
  557. package/dist/upload/transaction/Transaction.js +0 -155
  558. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  559. package/dist/upload/transaction/audio-icon.svg +0 -4
  560. package/dist/upload/transaction/error-icon.svg +0 -4
  561. package/dist/upload/transaction/file-icon-err.svg +0 -4
  562. package/dist/upload/transaction/file-icon.svg +0 -4
  563. package/dist/upload/transaction/image-icon-err.svg +0 -4
  564. package/dist/upload/transaction/image-icon.svg +0 -4
  565. package/dist/upload/transaction/success-icon.svg +0 -4
  566. package/dist/upload/transaction/video-icon-err.svg +0 -4
  567. package/dist/upload/transaction/video-icon.svg +0 -4
  568. package/dist/upload/transactions/Transactions.js +0 -120
  569. package/dist/wizard/Wizard.js +0 -340
  570. package/dist/wizard/invalid_icon.svg +0 -6
  571. package/dist/wizard/valid_icon.svg +0 -6
  572. package/dist/wizard/validation-wrong.svg +0 -6
  573. package/test/Accordion.test.js +0 -33
  574. package/test/Alert.test.js +0 -53
  575. package/test/Box.test.js +0 -10
  576. package/test/Button.test.js +0 -18
  577. package/test/Card.test.js +0 -30
  578. package/test/Checkbox.test.js +0 -45
  579. package/test/Chip.test.js +0 -25
  580. package/test/Date.test.js +0 -393
  581. package/test/Dialog.test.js +0 -23
  582. package/test/Dropdown.test.js +0 -130
  583. package/test/Footer.test.js +0 -99
  584. package/test/Header.test.js +0 -39
  585. package/test/Heading.test.js +0 -35
  586. package/test/InputText.test.js +0 -236
  587. package/test/Link.test.js +0 -33
  588. package/test/Paginator.test.js +0 -165
  589. package/test/ProgressBar.test.js +0 -35
  590. package/test/Radio.test.js +0 -37
  591. package/test/ResultsetTable.test.js +0 -282
  592. package/test/Select.test.js +0 -191
  593. package/test/Sidenav.test.js +0 -45
  594. package/test/Slider.test.js +0 -82
  595. package/test/Spinner.test.js +0 -27
  596. package/test/Switch.test.js +0 -45
  597. package/test/Table.test.js +0 -36
  598. package/test/Tabs.test.js +0 -88
  599. package/test/TabsForSections.test.js +0 -34
  600. package/test/Tag.test.js +0 -32
  601. package/test/TextArea.test.js +0 -52
  602. package/test/Toggle.test.js +0 -43
  603. package/test/ToggleGroup.test.js +0 -81
  604. package/test/Upload.test.js +0 -60
  605. package/test/Wizard.test.js +0 -130
  606. package/test/mocks/pngMock.js +0 -1
  607. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,222 @@
1
+ import React from "react";
2
+ import DxcCheckbox from "./Checkbox";
3
+ import Title from "../../.storybook/components/Title";
4
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
+ import styled from "styled-components";
6
+ import { HalstackProvider } from "../HalstackContext";
7
+
8
+ export default {
9
+ title: "Checkbox",
10
+ component: DxcCheckbox,
11
+ };
12
+
13
+ const opinionatedTheme = {
14
+ checkbox: {
15
+ baseColor: "#0067b3",
16
+ checkColor: "#ffffff",
17
+ fontColor: "#000000",
18
+ },
19
+ };
20
+
21
+ const Checkbox = () => (
22
+ <>
23
+ <ExampleContainer>
24
+ <Title title="Default" theme="light" level={4} />
25
+ <DxcCheckbox label="Checkbox" />
26
+ </ExampleContainer>
27
+ <ExampleContainer>
28
+ <Title title="Checked" theme="light" level={4} />
29
+ <DxcCheckbox label="Checkbox" defaultChecked />
30
+ </ExampleContainer>
31
+ <ExampleContainer>
32
+ <Title title="Disabled" theme="light" level={4} />
33
+ <DxcCheckbox label="Checkbox" disabled />
34
+ </ExampleContainer>
35
+ <ExampleContainer>
36
+ <Title title="Disabled, checked and optional" theme="light" level={4} />
37
+ <DxcCheckbox label="Checkbox" disabled defaultChecked optional />
38
+ </ExampleContainer>
39
+ <ExampleContainer>
40
+ <Title title="Read-only" theme="light" level={4} />
41
+ <DxcCheckbox label="Checkbox" readOnly />
42
+ </ExampleContainer>
43
+ <ExampleContainer pseudoState="pseudo-hover">
44
+ <Title title="Hovered read-only" theme="light" level={4} />
45
+ <DxcCheckbox label="Checkbox" readOnly />
46
+ </ExampleContainer>
47
+ <ExampleContainer>
48
+ <Title title="Read-only, checked and optional" theme="light" level={4} />
49
+ <DxcCheckbox label="Checkbox" readOnly defaultChecked optional />
50
+ </ExampleContainer>
51
+ <ExampleContainer pseudoState="pseudo-hover">
52
+ <Title title="Hovered read-only and checked" theme="light" level={4} />
53
+ <DxcCheckbox label="Checkbox" readOnly defaultChecked optional />
54
+ </ExampleContainer>
55
+ <ExampleContainer pseudoState="pseudo-focus">
56
+ <Title title="Focused" theme="light" level={4} />
57
+ <DxcCheckbox label="Focused" />
58
+ </ExampleContainer>
59
+ <ExampleContainer pseudoState="pseudo-hover">
60
+ <Title title="Hovered" theme="light" level={4} />
61
+ <DxcCheckbox label="Hovered" />
62
+ </ExampleContainer>
63
+ <ExampleContainer pseudoState="pseudo-hover">
64
+ <Title title="Hovered and checked" theme="light" level={4} />
65
+ <DxcCheckbox label="Hovered" defaultChecked />
66
+ </ExampleContainer>
67
+ <ExampleContainer>
68
+ <Title title="Optional" theme="light" level={4} />
69
+ <DxcCheckbox label="Checkbox" optional />
70
+ </ExampleContainer>
71
+ <ExampleContainer>
72
+ <Title title="Label after" theme="light" level={4} />
73
+ <DxcCheckbox label="Checkbox" labelPosition="after" />
74
+ </ExampleContainer>
75
+ <ExampleContainer>
76
+ <Title title="Checked with label after" theme="light" level={4} />
77
+ <DxcCheckbox label="Checkbox" defaultChecked labelPosition="after" />
78
+ </ExampleContainer>
79
+ <ExampleContainer>
80
+ <Title title="Optional with label after" theme="light" level={4} />
81
+ <DxcCheckbox label="Checkbox" optional labelPosition="after" />
82
+ </ExampleContainer>
83
+ <ExampleContainer>
84
+ <Title title="Disabled and optional with label after" theme="light" level={4} />
85
+ <DxcCheckbox label="Checkbox" disabled labelPosition="after" optional />
86
+ </ExampleContainer>
87
+ <Title title="Sizes" theme="light" level={2} />
88
+ <ExampleContainer>
89
+ <DxcCheckbox label="Small" size="small" />
90
+ </ExampleContainer>
91
+ <ExampleContainer>
92
+ <DxcCheckbox label="Medium" size="medium" />
93
+ </ExampleContainer>
94
+ <ExampleContainer>
95
+ <DxcCheckbox label="Large" size="large" />
96
+ </ExampleContainer>
97
+ <ExampleContainer>
98
+ <DxcCheckbox label="FitContent" size="fitContent" />
99
+ </ExampleContainer>
100
+ <ExampleContainer>
101
+ <DxcCheckbox label="FillParent" size="fillParent" />
102
+ </ExampleContainer>
103
+ <Title title="Margins" theme="light" level={2} />
104
+ <ExampleContainer>
105
+ <Title title="Xxsmall" theme="light" level={4} />
106
+ <DxcCheckbox label="Xxsmall" margin="xxsmall" />
107
+ </ExampleContainer>
108
+ <ExampleContainer>
109
+ <Title title="Xsmall" theme="light" level={4} />
110
+ <DxcCheckbox label="Xsmall" margin="xsmall" />
111
+ </ExampleContainer>
112
+ <ExampleContainer>
113
+ <Title title="Small" theme="light" level={4} />
114
+ <DxcCheckbox label="Small" margin="small" />
115
+ </ExampleContainer>
116
+ <ExampleContainer>
117
+ <Title title="Medium" theme="light" level={4} />
118
+ <DxcCheckbox label="Medium" margin="medium" />
119
+ </ExampleContainer>
120
+ <ExampleContainer>
121
+ <Title title="Large" theme="light" level={4} />
122
+ <DxcCheckbox label="Large" margin="large" />
123
+ </ExampleContainer>
124
+ <ExampleContainer>
125
+ <Title title="Xlarge" theme="light" level={4} />
126
+ <DxcCheckbox label="Xlarge" margin="xlarge" />
127
+ </ExampleContainer>
128
+ <ExampleContainer>
129
+ <Title title="Xxlarge" theme="light" level={4} />
130
+ <DxcCheckbox label="Xxlarge" margin="xxlarge" />
131
+ </ExampleContainer>
132
+ <ExampleContainer>
133
+ <Title title="Overflow container" theme="light" level={4} />
134
+ <ScrollableContainer id="scroll-container">
135
+ <DxcCheckbox label="Checkbox" defaultChecked />
136
+ <DxcCheckbox label="Checkbox" defaultChecked />
137
+ <DxcCheckbox label="Checkbox" />
138
+ <DxcCheckbox label="Checkbox" defaultChecked />
139
+ <DxcCheckbox label="Checkbox" />
140
+ <DxcCheckbox label="Checkbox" />
141
+ <DxcCheckbox label="Checkbox" />
142
+ <DxcCheckbox label="Checkbox" defaultChecked />
143
+ </ScrollableContainer>
144
+ </ExampleContainer>
145
+ <ExampleContainer>
146
+ <Title title="Label overflow" theme="light" level={4} />
147
+ <SmallContainer>
148
+ <DxcCheckbox label="Very long label to check its overflowing" defaultChecked />
149
+ <DxcCheckbox label="Very long label to check its overflowing" labelPosition="after" />
150
+ </SmallContainer>
151
+ </ExampleContainer>
152
+ <Title title="Opinionated theme" theme="light" level={2} />
153
+ <ExampleContainer>
154
+ <Title title="Default" theme="light" level={4} />
155
+ <HalstackProvider theme={opinionatedTheme}>
156
+ <DxcCheckbox label="Checkbox" />
157
+ </HalstackProvider>
158
+ </ExampleContainer>
159
+ <ExampleContainer>
160
+ <Title title="Checked" theme="light" level={4} />
161
+ <HalstackProvider theme={opinionatedTheme}>
162
+ <DxcCheckbox label="Checkbox" defaultChecked />
163
+ </HalstackProvider>
164
+ </ExampleContainer>
165
+ <ExampleContainer>
166
+ <Title title="Disabled" theme="light" level={4} />
167
+ <HalstackProvider theme={opinionatedTheme}>
168
+ <DxcCheckbox label="Checkbox" disabled />
169
+ </HalstackProvider>
170
+ </ExampleContainer>
171
+ <ExampleContainer>
172
+ <Title title="Disabled checked" theme="light" level={4} />
173
+ <HalstackProvider theme={opinionatedTheme}>
174
+ <DxcCheckbox label="Checkbox" defaultChecked disabled />
175
+ </HalstackProvider>
176
+ </ExampleContainer>
177
+ <ExampleContainer pseudoState="pseudo-focus">
178
+ <Title title="Focused" theme="light" level={4} />
179
+ <HalstackProvider theme={opinionatedTheme}>
180
+ <DxcCheckbox label="Focused" />
181
+ </HalstackProvider>
182
+ </ExampleContainer>
183
+ <ExampleContainer pseudoState="pseudo-hover">
184
+ <Title title="Hovered" theme="light" level={4} />
185
+ <HalstackProvider theme={opinionatedTheme}>
186
+ <DxcCheckbox label="Hovered" />
187
+ </HalstackProvider>
188
+ </ExampleContainer>
189
+ <ExampleContainer pseudoState="pseudo-hover">
190
+ <Title title="Hovered and checked" theme="light" level={4} />
191
+ <HalstackProvider theme={opinionatedTheme}>
192
+ <DxcCheckbox label="Hovered" defaultChecked />
193
+ </HalstackProvider>
194
+ </ExampleContainer>
195
+ </>
196
+ );
197
+
198
+ export const Chromatic = Checkbox.bind({});
199
+
200
+ Chromatic.play = async () => {
201
+ const listEl = document.getElementById("scroll-container");
202
+ listEl?.scrollTo?.({ top: 50 });
203
+ };
204
+
205
+ const ScrollableContainer = styled.div`
206
+ display: flex;
207
+ flex-direction: column;
208
+ gap: 14px;
209
+ width: 200px;
210
+ height: 200px;
211
+ border: 1px solid #000;
212
+ padding: 14px;
213
+ overflow: auto;
214
+ `;
215
+
216
+ const SmallContainer = styled.div`
217
+ display: flex;
218
+ flex-direction: column;
219
+ gap: 14px;
220
+ width: 150px;
221
+ height: 150px;
222
+ `;
@@ -0,0 +1,199 @@
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 _Checkbox = _interopRequireDefault(require("./Checkbox.tsx"));
10
+ describe("Checkbox component tests", function () {
11
+ test("Checkbox renders with correct aria-labelledby and aria-required", function () {
12
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
13
+ label: "Checkbox"
14
+ })),
15
+ getByText = _render.getByText,
16
+ getByRole = _render.getByRole;
17
+ var labelId = getByText("Checkbox").getAttribute("id");
18
+ expect(getByRole("checkbox").getAttribute("aria-labelledby")).toBe(labelId);
19
+ expect(getByRole("checkbox").getAttribute("aria-required")).toBe("true");
20
+ expect(getByRole("checkbox").getAttribute("aria-readonly")).toBe("false");
21
+ expect(getByRole("checkbox").getAttribute("aria-disabled")).toBe("false");
22
+ });
23
+ test("Optional checkbox renders with correct aria-required", function () {
24
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
25
+ label: "Checkbox",
26
+ optional: true
27
+ })),
28
+ getByRole = _render2.getByRole;
29
+ expect(getByRole("checkbox").getAttribute("aria-required")).toBe("false");
30
+ });
31
+ test("Calls correct function onChange", function () {
32
+ var onChange = jest.fn();
33
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
34
+ label: "Checkbox",
35
+ onChange: onChange
36
+ })),
37
+ getByText = _render3.getByText;
38
+ _react2.fireEvent.click(getByText("Checkbox"));
39
+ expect(onChange).toHaveBeenCalled();
40
+ });
41
+ test("Read-only checkbox does not trigger onChange function", function () {
42
+ var onChange = jest.fn();
43
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
44
+ label: "Checkbox",
45
+ onChange: onChange,
46
+ readOnly: true
47
+ })),
48
+ getByRole = _render4.getByRole;
49
+ var checkbox = getByRole("checkbox");
50
+ expect(checkbox.getAttribute("aria-readonly")).toBe("true");
51
+ _react2.fireEvent.click(checkbox);
52
+ expect(onChange).not.toHaveBeenCalled();
53
+ });
54
+ test("Read-only checkbox sends its value on submit", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
55
+ var handlerOnSubmit, _render5, getByText, submit;
56
+ return _regenerator["default"].wrap(function _callee$(_context) {
57
+ while (1) switch (_context.prev = _context.next) {
58
+ case 0:
59
+ handlerOnSubmit = jest.fn(function (e) {
60
+ e.preventDefault();
61
+ var formData = new FormData(e.target);
62
+ var formProps = Object.fromEntries(formData);
63
+ expect(formProps).toStrictEqual({
64
+ data: "checked"
65
+ });
66
+ });
67
+ _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement("form", {
68
+ onSubmit: handlerOnSubmit
69
+ }, /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
70
+ label: "Checkbox",
71
+ name: "data",
72
+ value: "checked",
73
+ readOnly: true,
74
+ defaultChecked: true
75
+ }), /*#__PURE__*/_react["default"].createElement("button", {
76
+ type: "submit"
77
+ }, "Submit"))), getByText = _render5.getByText;
78
+ submit = getByText("Submit");
79
+ _context.next = 5;
80
+ return _userEvent["default"].click(submit);
81
+ case 5:
82
+ expect(handlerOnSubmit).toHaveBeenCalled();
83
+ case 6:
84
+ case "end":
85
+ return _context.stop();
86
+ }
87
+ }, _callee);
88
+ })));
89
+ test("Read-only checkbox doesn't change its value with Space key", function () {
90
+ var onChange = jest.fn();
91
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
92
+ label: "Checkbox",
93
+ onChange: onChange,
94
+ readOnly: true
95
+ })),
96
+ getByRole = _render6.getByRole;
97
+ var checkbox = getByRole("checkbox");
98
+ _userEvent["default"].tab();
99
+ expect(document.activeElement === checkbox).toBeTruthy();
100
+ _react2.fireEvent.keyDown(checkbox, {
101
+ key: " ",
102
+ code: "Space",
103
+ keyCode: 32,
104
+ charCode: 32
105
+ });
106
+ expect(onChange).not.toHaveBeenCalled();
107
+ });
108
+ test("Uncontrolled checkbox", function () {
109
+ var onChange = jest.fn();
110
+ var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
111
+ label: "Checkbox",
112
+ onChange: onChange,
113
+ name: "test"
114
+ }));
115
+ var visibleCheckbox = component.getByText("Checkbox");
116
+ var input = component.getByRole("checkbox");
117
+ var submitInput = component.container.querySelector("input[name=\"test\"]");
118
+ expect(input.getAttribute("aria-checked")).toBe("false");
119
+ expect(submitInput.checked).toBe(false);
120
+ _react2.fireEvent.click(visibleCheckbox);
121
+ expect(onChange).toHaveBeenCalled();
122
+ expect(onChange).toHaveBeenCalledWith(true);
123
+ expect(input.getAttribute("aria-checked")).toBe("true");
124
+ expect(submitInput.checked).toBe(true);
125
+ });
126
+ test("Controlled checkbox", function () {
127
+ var onChange = jest.fn();
128
+ var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
129
+ label: "Checkbox",
130
+ checked: false,
131
+ onChange: onChange,
132
+ name: "test"
133
+ }));
134
+ var input = component.getByRole("checkbox");
135
+ var visibleCheckbox = component.getByText("Checkbox");
136
+ var submitInput = component.container.querySelector("input[name=\"test\"]");
137
+ _react2.fireEvent.click(visibleCheckbox);
138
+ expect(onChange).toHaveBeenCalled();
139
+ expect(onChange).toHaveBeenCalledWith(true);
140
+ expect(input.getAttribute("aria-checked")).toBe("false");
141
+ expect(submitInput.checked).toBe(false);
142
+ });
143
+ test("Renders with correct initial value and initial state when it is uncontrolled", function () {
144
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
145
+ label: "Default label",
146
+ defaultChecked: true,
147
+ value: "test-defaultChecked",
148
+ name: "test"
149
+ })),
150
+ getByRole = _render7.getByRole,
151
+ container = _render7.container;
152
+ var checkbox = getByRole("checkbox");
153
+ var submitInput = container.querySelector("input[name=\"test\"]");
154
+ expect(submitInput.value).toBe("test-defaultChecked");
155
+ expect(checkbox.getAttribute("aria-checked")).toBe("true");
156
+ expect(submitInput.checked).toBe(true);
157
+ });
158
+ test("Test disable keyboard and mouse interactions", function () {
159
+ var onChange = jest.fn();
160
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
161
+ label: "Checkbox",
162
+ onChange: onChange,
163
+ disabled: true,
164
+ name: "test"
165
+ })),
166
+ getByRole = _render8.getByRole,
167
+ getByText = _render8.getByText,
168
+ container = _render8.container;
169
+ var input = getByRole("checkbox");
170
+ var visibleCheckbox = getByText("Checkbox");
171
+ var submitInput = container.querySelector("input[name=\"test\"]");
172
+ _react2.fireEvent.click(visibleCheckbox);
173
+ expect(onChange).toHaveBeenCalledTimes(0);
174
+ expect(input.getAttribute("aria-checked")).toBe("false");
175
+ expect(input.getAttribute("aria-disabled")).toBe("true");
176
+ expect(submitInput.checked).toBe(false);
177
+ _userEvent["default"].tab();
178
+ expect(document.activeElement === input).toBeFalsy();
179
+ });
180
+ test("Test keyboard interactions", function () {
181
+ var onChange = jest.fn();
182
+ var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
183
+ label: "Checkbox",
184
+ name: "test",
185
+ onChange: onChange
186
+ })),
187
+ getByRole = _render9.getByRole;
188
+ var checkbox = getByRole("checkbox");
189
+ _userEvent["default"].tab();
190
+ expect(document.activeElement === checkbox).toBeTruthy();
191
+ _react2.fireEvent.keyDown(checkbox, {
192
+ key: " ",
193
+ code: "Space",
194
+ keyCode: 32,
195
+ charCode: 32
196
+ });
197
+ expect(onChange).toHaveBeenCalledWith(true);
198
+ });
199
+ });
@@ -0,0 +1,72 @@
1
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ type Margin = {
3
+ top?: Space;
4
+ bottom?: Space;
5
+ left?: Space;
6
+ right?: Space;
7
+ };
8
+ type Props = {
9
+ /**
10
+ * Initial state of the checkbox, only when it is uncontrolled.
11
+ */
12
+ defaultChecked?: boolean;
13
+ /**
14
+ * If true, the component is checked. If undefined the component will be
15
+ * uncontrolled and the value will be managed internally by the component.
16
+ */
17
+ checked?: boolean;
18
+ /**
19
+ * Will be passed to the value attribute of the html input element.
20
+ * When inside a form, this value will be only submitted if the checkbox is checked.
21
+ */
22
+ value?: string;
23
+ /**
24
+ * Text to be placed next to the checkbox.
25
+ */
26
+ label?: string;
27
+ /**
28
+ * Whether the label should appear after or before the checkbox.
29
+ */
30
+ labelPosition?: "before" | "after";
31
+ /**
32
+ * Name attribute of the input element.
33
+ */
34
+ name?: string;
35
+ /**
36
+ * If true, the component will be disabled.
37
+ */
38
+ disabled?: boolean;
39
+ /**
40
+ * If true, the component will display '(Optional)' next to the label.
41
+ */
42
+ optional?: boolean;
43
+ /**
44
+ * If true, the component will not be mutable, meaning the user can not edit the control.
45
+ */
46
+ readOnly?: boolean;
47
+ /**
48
+ * This function will be called when the user clicks the checkbox.
49
+ * The new value will be passed as a parameter.
50
+ */
51
+ onChange?: (value: boolean) => void;
52
+ /**
53
+ * Size of the margin to be applied to the component
54
+ * ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
55
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties
56
+ * in order to specify different margin sizes.
57
+ */
58
+ margin?: Space | Margin;
59
+ /**
60
+ * Size of the component.
61
+ */
62
+ size?: "small" | "medium" | "large" | "fillParent" | "fitContent";
63
+ /**
64
+ * Value of the tabindex.
65
+ */
66
+ tabIndex?: number;
67
+ };
68
+ /**
69
+ * Reference to the component.
70
+ */
71
+ export type RefType = HTMLDivElement;
72
+ export default Props;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -0,0 +1,67 @@
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 _jestAxe = require("jest-axe");
9
+ var _Chip = _interopRequireDefault(require("./Chip.tsx"));
10
+ var iconSVG = /*#__PURE__*/_react["default"].createElement("svg", {
11
+ version: "1.1",
12
+ x: "0px",
13
+ y: "0px",
14
+ width: "438.536px",
15
+ height: "438.536px",
16
+ viewBox: "0 0 438.536 438.536",
17
+ fill: "currentColor"
18
+ }, /*#__PURE__*/_react["default"].createElement("g", null, /*#__PURE__*/_react["default"].createElement("path", {
19
+ d: "M414.41,24.123C398.333,8.042,378.963,0,356.315,0H82.228C59.58,0,40.21,8.042,24.126,24.123\nC8.045,40.207,0.003,59.576,0.003,82.225v274.084c0,22.647,8.042,42.018,24.123,58.102c16.084,16.084,35.454,24.126,58.102,24.126\nh274.084c22.648,0,42.018-8.042,58.095-24.126c16.084-16.084,24.126-35.454,24.126-58.102V82.225\nC438.532,59.576,430.49,40.204,414.41,24.123z M373.155,225.548h-49.963V406.84h-74.802V225.548H210.99V163.02h37.401v-37.402\nc0-26.838,6.283-47.107,18.843-60.813c12.559-13.706,33.304-20.555,62.242-20.555h49.963v62.526h-31.401\nc-10.663,0-17.467,1.853-20.417,5.568c-2.949,3.711-4.428,10.23-4.428,19.558v31.119h56.534L373.155,225.548z"
20
+ })));
21
+ describe("Chip component accessibility tests", function () {
22
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
23
+ var _render, container, results;
24
+ return _regenerator["default"].wrap(function _callee$(_context) {
25
+ while (1) switch (_context.prev = _context.next) {
26
+ case 0:
27
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
28
+ margin: "small",
29
+ prefixIcon: iconSVG,
30
+ suffixIcon: iconSVG,
31
+ label: "Chip"
32
+ })), container = _render.container;
33
+ _context.next = 3;
34
+ return (0, _jestAxe.axe)(container);
35
+ case 3:
36
+ results = _context.sent;
37
+ expect(results).toHaveNoViolations();
38
+ case 5:
39
+ case "end":
40
+ return _context.stop();
41
+ }
42
+ }, _callee);
43
+ })));
44
+ it("Should not have basic accessibility issues for disabled mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
45
+ var _render2, container, results;
46
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
47
+ while (1) switch (_context2.prev = _context2.next) {
48
+ case 0:
49
+ _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Chip["default"], {
50
+ margin: "small",
51
+ prefixIcon: iconSVG,
52
+ suffixIcon: iconSVG,
53
+ label: "Chip",
54
+ disabled: true
55
+ })), container = _render2.container;
56
+ _context2.next = 3;
57
+ return (0, _jestAxe.axe)(container);
58
+ case 3:
59
+ results = _context2.sent;
60
+ expect(results).toHaveNoViolations();
61
+ case 5:
62
+ case "end":
63
+ return _context2.stop();
64
+ }
65
+ }, _callee2);
66
+ })));
67
+ });
package/chip/Chip.d.ts ADDED
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import ChipPropsType from "./types";
3
+ declare const DxcChip: ({ label, suffixIcon, prefixIcon, onClickSuffix, onClickPrefix, disabled, margin, tabIndex, }: ChipPropsType) => JSX.Element;
4
+ export default DxcChip;