@dxc-technology/halstack-react 0.0.0-b1729d7 → 0.0.0-b18ba60

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 (680) hide show
  1. package/BackgroundColorContext.d.ts +1 -0
  2. package/BackgroundColorContext.js +30 -0
  3. package/HalstackContext.d.ts +1247 -0
  4. package/HalstackContext.js +310 -0
  5. package/README.md +28 -47
  6. package/accordion/Accordion.accessibility.test.d.ts +1 -0
  7. package/accordion/Accordion.accessibility.test.js +71 -0
  8. package/accordion/Accordion.d.ts +4 -0
  9. package/accordion/Accordion.js +168 -0
  10. package/accordion/Accordion.stories.tsx +241 -0
  11. package/accordion/Accordion.test.d.ts +1 -0
  12. package/accordion/Accordion.test.js +56 -0
  13. package/accordion/types.d.ts +57 -0
  14. package/accordion/types.js +5 -0
  15. package/accordion-group/AccordionGroup.accessibility.test.d.ts +1 -0
  16. package/accordion-group/AccordionGroup.accessibility.test.js +82 -0
  17. package/accordion-group/AccordionGroup.d.ts +7 -0
  18. package/accordion-group/AccordionGroup.js +101 -0
  19. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  20. package/accordion-group/AccordionGroup.test.d.ts +1 -0
  21. package/accordion-group/AccordionGroup.test.js +94 -0
  22. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  23. package/accordion-group/AccordionGroupAccordion.js +31 -0
  24. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  25. package/accordion-group/AccordionGroupContext.js +8 -0
  26. package/accordion-group/types.d.ts +67 -0
  27. package/accordion-group/types.js +5 -0
  28. package/action-icon/ActionIcon.accessibility.test.d.ts +1 -0
  29. package/action-icon/ActionIcon.accessibility.test.js +63 -0
  30. package/action-icon/ActionIcon.d.ts +4 -0
  31. package/action-icon/ActionIcon.js +48 -0
  32. package/action-icon/ActionIcon.stories.tsx +41 -0
  33. package/action-icon/ActionIcon.test.d.ts +1 -0
  34. package/action-icon/ActionIcon.test.js +64 -0
  35. package/action-icon/types.d.ts +26 -0
  36. package/action-icon/types.js +5 -0
  37. package/alert/Alert.accessibility.test.d.ts +1 -0
  38. package/alert/Alert.accessibility.test.js +95 -0
  39. package/alert/Alert.d.ts +4 -0
  40. package/alert/Alert.js +203 -0
  41. package/alert/Alert.stories.tsx +198 -0
  42. package/alert/Alert.test.d.ts +1 -0
  43. package/alert/Alert.test.js +75 -0
  44. package/alert/types.d.ts +49 -0
  45. package/alert/types.js +5 -0
  46. package/badge/Badge.accessibility.test.d.ts +1 -0
  47. package/badge/Badge.accessibility.test.js +129 -0
  48. package/badge/Badge.d.ts +4 -0
  49. package/badge/Badge.js +161 -0
  50. package/badge/Badge.stories.tsx +210 -0
  51. package/badge/Badge.test.d.ts +1 -0
  52. package/badge/Badge.test.js +30 -0
  53. package/badge/types.d.ts +54 -0
  54. package/badge/types.js +5 -0
  55. package/bleed/Bleed.d.ts +3 -0
  56. package/bleed/Bleed.js +43 -0
  57. package/bleed/Bleed.stories.tsx +342 -0
  58. package/bleed/types.d.ts +37 -0
  59. package/bleed/types.js +5 -0
  60. package/box/Box.accessibility.test.d.ts +1 -0
  61. package/box/Box.accessibility.test.js +33 -0
  62. package/box/Box.d.ts +4 -0
  63. package/box/Box.js +75 -0
  64. package/box/Box.stories.tsx +119 -0
  65. package/box/Box.test.d.ts +1 -0
  66. package/box/Box.test.js +13 -0
  67. package/box/types.d.ts +32 -0
  68. package/box/types.js +5 -0
  69. package/breadcrumbs/Breadcrumbs.accessibility.test.d.ts +1 -0
  70. package/breadcrumbs/Breadcrumbs.accessibility.test.js +96 -0
  71. package/breadcrumbs/Breadcrumbs.d.ts +4 -0
  72. package/breadcrumbs/Breadcrumbs.js +79 -0
  73. package/breadcrumbs/Breadcrumbs.stories.tsx +194 -0
  74. package/breadcrumbs/Breadcrumbs.test.d.ts +1 -0
  75. package/breadcrumbs/Breadcrumbs.test.js +169 -0
  76. package/breadcrumbs/Item.d.ts +4 -0
  77. package/breadcrumbs/Item.js +52 -0
  78. package/breadcrumbs/dropdownTheme.d.ts +53 -0
  79. package/breadcrumbs/dropdownTheme.js +62 -0
  80. package/breadcrumbs/types.d.ts +16 -0
  81. package/breadcrumbs/types.js +5 -0
  82. package/bulleted-list/BulletedList.accessibility.test.d.ts +1 -0
  83. package/bulleted-list/BulletedList.accessibility.test.js +119 -0
  84. package/bulleted-list/BulletedList.d.ts +7 -0
  85. package/bulleted-list/BulletedList.js +92 -0
  86. package/bulleted-list/BulletedList.stories.tsx +115 -0
  87. package/bulleted-list/types.d.ts +38 -0
  88. package/bulleted-list/types.js +5 -0
  89. package/button/Button.accessibility.test.d.ts +1 -0
  90. package/button/Button.accessibility.test.js +127 -0
  91. package/button/Button.d.ts +4 -0
  92. package/button/Button.js +121 -0
  93. package/button/Button.stories.tsx +325 -0
  94. package/button/Button.test.d.ts +1 -0
  95. package/button/Button.test.js +38 -0
  96. package/button/types.d.ts +57 -0
  97. package/button/types.js +5 -0
  98. package/card/Card.accessibility.test.d.ts +1 -0
  99. package/card/Card.accessibility.test.js +36 -0
  100. package/card/Card.d.ts +4 -0
  101. package/card/Card.js +121 -0
  102. package/card/Card.stories.tsx +171 -0
  103. package/card/Card.test.d.ts +1 -0
  104. package/card/Card.test.js +39 -0
  105. package/card/types.d.ts +62 -0
  106. package/card/types.js +5 -0
  107. package/checkbox/Checkbox.accessibility.test.d.ts +1 -0
  108. package/checkbox/Checkbox.accessibility.test.js +87 -0
  109. package/checkbox/Checkbox.d.ts +4 -0
  110. package/checkbox/Checkbox.js +212 -0
  111. package/checkbox/Checkbox.stories.tsx +222 -0
  112. package/checkbox/Checkbox.test.d.ts +1 -0
  113. package/checkbox/Checkbox.test.js +199 -0
  114. package/checkbox/types.d.ts +72 -0
  115. package/checkbox/types.js +5 -0
  116. package/chip/Chip.accessibility.test.d.ts +1 -0
  117. package/chip/Chip.accessibility.test.js +69 -0
  118. package/chip/Chip.d.ts +4 -0
  119. package/chip/Chip.js +115 -0
  120. package/chip/Chip.stories.tsx +231 -0
  121. package/chip/Chip.test.d.ts +1 -0
  122. package/chip/Chip.test.js +41 -0
  123. package/chip/types.d.ts +68 -0
  124. package/chip/types.js +5 -0
  125. package/common/coreTokens.d.ts +237 -0
  126. package/common/coreTokens.js +184 -0
  127. package/common/utils.d.ts +1 -0
  128. package/{dist/common → common}/utils.js +6 -12
  129. package/common/variables.d.ts +1390 -0
  130. package/common/variables.js +1262 -0
  131. package/container/Container.d.ts +4 -0
  132. package/container/Container.js +194 -0
  133. package/container/Container.stories.tsx +214 -0
  134. package/container/types.d.ts +74 -0
  135. package/container/types.js +5 -0
  136. package/contextual-menu/ContextualMenu.accessibility.test.d.ts +1 -0
  137. package/contextual-menu/ContextualMenu.accessibility.test.js +98 -0
  138. package/contextual-menu/ContextualMenu.d.ts +5 -0
  139. package/contextual-menu/ContextualMenu.js +88 -0
  140. package/contextual-menu/ContextualMenu.stories.tsx +232 -0
  141. package/contextual-menu/ContextualMenu.test.d.ts +1 -0
  142. package/contextual-menu/ContextualMenu.test.js +205 -0
  143. package/contextual-menu/GroupItem.d.ts +4 -0
  144. package/contextual-menu/GroupItem.js +67 -0
  145. package/contextual-menu/ItemAction.d.ts +4 -0
  146. package/contextual-menu/ItemAction.js +51 -0
  147. package/contextual-menu/MenuItem.d.ts +4 -0
  148. package/contextual-menu/MenuItem.js +29 -0
  149. package/contextual-menu/SingleItem.d.ts +4 -0
  150. package/contextual-menu/SingleItem.js +38 -0
  151. package/contextual-menu/types.d.ts +58 -0
  152. package/contextual-menu/types.js +5 -0
  153. package/date-input/Calendar.d.ts +4 -0
  154. package/date-input/Calendar.js +214 -0
  155. package/date-input/DateInput.accessibility.test.d.ts +1 -0
  156. package/date-input/DateInput.accessibility.test.js +230 -0
  157. package/date-input/DateInput.d.ts +4 -0
  158. package/date-input/DateInput.js +222 -0
  159. package/date-input/DateInput.stories.tsx +292 -0
  160. package/date-input/DateInput.test.d.ts +1 -0
  161. package/date-input/DateInput.test.js +809 -0
  162. package/date-input/DatePicker.d.ts +4 -0
  163. package/date-input/DatePicker.js +121 -0
  164. package/date-input/YearPicker.d.ts +4 -0
  165. package/date-input/YearPicker.js +100 -0
  166. package/date-input/types.d.ts +164 -0
  167. package/date-input/types.js +5 -0
  168. package/dialog/Dialog.accessibility.test.d.ts +1 -0
  169. package/dialog/Dialog.accessibility.test.js +69 -0
  170. package/dialog/Dialog.d.ts +4 -0
  171. package/dialog/Dialog.js +93 -0
  172. package/dialog/Dialog.stories.tsx +370 -0
  173. package/dialog/Dialog.test.d.ts +1 -0
  174. package/dialog/Dialog.test.js +371 -0
  175. package/dialog/types.d.ts +36 -0
  176. package/dialog/types.js +5 -0
  177. package/divider/Divider.accessibility.test.d.ts +1 -0
  178. package/divider/Divider.accessibility.test.js +33 -0
  179. package/divider/Divider.d.ts +4 -0
  180. package/divider/Divider.js +36 -0
  181. package/divider/Divider.stories.tsx +223 -0
  182. package/divider/Divider.test.d.ts +1 -0
  183. package/divider/Divider.test.js +38 -0
  184. package/divider/types.d.ts +21 -0
  185. package/divider/types.js +5 -0
  186. package/dropdown/Dropdown.accessibility.test.d.ts +1 -0
  187. package/dropdown/Dropdown.accessibility.test.js +184 -0
  188. package/dropdown/Dropdown.d.ts +4 -0
  189. package/dropdown/Dropdown.js +320 -0
  190. package/dropdown/Dropdown.stories.tsx +427 -0
  191. package/dropdown/Dropdown.test.d.ts +1 -0
  192. package/dropdown/Dropdown.test.js +629 -0
  193. package/dropdown/DropdownMenu.d.ts +4 -0
  194. package/dropdown/DropdownMenu.js +63 -0
  195. package/dropdown/DropdownMenuItem.d.ts +4 -0
  196. package/dropdown/DropdownMenuItem.js +71 -0
  197. package/dropdown/types.d.ts +96 -0
  198. package/dropdown/types.js +5 -0
  199. package/file-input/FileInput.accessibility.test.d.ts +1 -0
  200. package/file-input/FileInput.accessibility.test.js +167 -0
  201. package/file-input/FileInput.d.ts +4 -0
  202. package/file-input/FileInput.js +440 -0
  203. package/file-input/FileInput.stories.tsx +618 -0
  204. package/file-input/FileInput.test.d.ts +1 -0
  205. package/file-input/FileInput.test.js +404 -0
  206. package/file-input/FileItem.d.ts +4 -0
  207. package/file-input/FileItem.js +125 -0
  208. package/file-input/types.d.ts +129 -0
  209. package/file-input/types.js +5 -0
  210. package/flex/Flex.d.ts +4 -0
  211. package/flex/Flex.js +57 -0
  212. package/flex/Flex.stories.tsx +112 -0
  213. package/flex/types.d.ts +97 -0
  214. package/flex/types.js +5 -0
  215. package/footer/Footer.accessibility.test.d.ts +1 -0
  216. package/footer/Footer.accessibility.test.js +125 -0
  217. package/footer/Footer.d.ts +4 -0
  218. package/footer/Footer.js +140 -0
  219. package/footer/Footer.stories.tsx +208 -0
  220. package/footer/Footer.test.d.ts +1 -0
  221. package/footer/Footer.test.js +85 -0
  222. package/footer/Icons.d.ts +3 -0
  223. package/footer/Icons.js +108 -0
  224. package/footer/types.d.ts +64 -0
  225. package/footer/types.js +5 -0
  226. package/grid/Grid.d.ts +7 -0
  227. package/grid/Grid.js +76 -0
  228. package/grid/Grid.stories.tsx +219 -0
  229. package/grid/types.d.ts +115 -0
  230. package/grid/types.js +5 -0
  231. package/header/Header.accessibility.test.d.ts +1 -0
  232. package/header/Header.accessibility.test.js +94 -0
  233. package/header/Header.d.ts +8 -0
  234. package/header/Header.js +210 -0
  235. package/header/Header.stories.tsx +267 -0
  236. package/header/Header.test.d.ts +1 -0
  237. package/header/Header.test.js +66 -0
  238. package/header/Icons.d.ts +2 -0
  239. package/{dist/header → header}/Icons.js +8 -43
  240. package/header/types.d.ts +33 -0
  241. package/header/types.js +5 -0
  242. package/heading/Heading.accessibility.test.d.ts +1 -0
  243. package/heading/Heading.accessibility.test.js +33 -0
  244. package/heading/Heading.d.ts +4 -0
  245. package/{dist/heading → heading}/Heading.js +34 -115
  246. package/heading/Heading.stories.tsx +54 -0
  247. package/heading/Heading.test.d.ts +1 -0
  248. package/heading/Heading.test.js +156 -0
  249. package/heading/types.d.ts +33 -0
  250. package/heading/types.js +5 -0
  251. package/icon/Icon.accessibility.test.d.ts +1 -0
  252. package/icon/Icon.accessibility.test.js +30 -0
  253. package/icon/Icon.d.ts +4 -0
  254. package/icon/Icon.js +33 -0
  255. package/icon/Icon.stories.tsx +28 -0
  256. package/icon/types.d.ts +4 -0
  257. package/icon/types.js +5 -0
  258. package/image/Image.accessibility.test.d.ts +1 -0
  259. package/image/Image.accessibility.test.js +56 -0
  260. package/image/Image.d.ts +4 -0
  261. package/image/Image.js +70 -0
  262. package/image/Image.stories.tsx +129 -0
  263. package/image/types.d.ts +72 -0
  264. package/image/types.js +5 -0
  265. package/inset/Inset.d.ts +3 -0
  266. package/inset/Inset.js +43 -0
  267. package/inset/Inset.stories.tsx +230 -0
  268. package/inset/types.d.ts +37 -0
  269. package/inset/types.js +5 -0
  270. package/layout/ApplicationLayout.d.ts +20 -0
  271. package/layout/ApplicationLayout.js +137 -0
  272. package/layout/ApplicationLayout.stories.tsx +162 -0
  273. package/layout/Icons.d.ts +7 -0
  274. package/layout/Icons.js +48 -0
  275. package/layout/types.d.ts +41 -0
  276. package/layout/types.js +5 -0
  277. package/link/Link.accessibility.test.d.ts +1 -0
  278. package/link/Link.accessibility.test.js +108 -0
  279. package/link/Link.d.ts +4 -0
  280. package/link/Link.js +117 -0
  281. package/link/Link.stories.tsx +253 -0
  282. package/link/Link.test.d.ts +1 -0
  283. package/link/Link.test.js +63 -0
  284. package/link/types.d.ts +54 -0
  285. package/link/types.js +5 -0
  286. package/main.d.ts +50 -0
  287. package/{dist/main.js → main.js} +141 -144
  288. package/nav-tabs/NavTabs.accessibility.test.d.ts +1 -0
  289. package/nav-tabs/NavTabs.accessibility.test.js +44 -0
  290. package/nav-tabs/NavTabs.d.ts +7 -0
  291. package/nav-tabs/NavTabs.js +108 -0
  292. package/nav-tabs/NavTabs.stories.tsx +294 -0
  293. package/nav-tabs/NavTabs.test.d.ts +1 -0
  294. package/nav-tabs/NavTabs.test.js +77 -0
  295. package/nav-tabs/NavTabsContext.d.ts +3 -0
  296. package/nav-tabs/NavTabsContext.js +8 -0
  297. package/nav-tabs/Tab.d.ts +4 -0
  298. package/nav-tabs/Tab.js +117 -0
  299. package/nav-tabs/types.d.ts +52 -0
  300. package/nav-tabs/types.js +5 -0
  301. package/number-input/NumberInput.accessibility.test.d.ts +1 -0
  302. package/number-input/NumberInput.accessibility.test.js +228 -0
  303. package/number-input/NumberInput.d.ts +4 -0
  304. package/number-input/NumberInput.js +86 -0
  305. package/number-input/NumberInput.stories.tsx +131 -0
  306. package/number-input/NumberInput.test.d.ts +1 -0
  307. package/number-input/NumberInput.test.js +989 -0
  308. package/number-input/NumberInputContext.d.ts +3 -0
  309. package/number-input/NumberInputContext.js +8 -0
  310. package/number-input/types.d.ts +136 -0
  311. package/number-input/types.js +5 -0
  312. package/package.json +64 -56
  313. package/paginator/Paginator.accessibility.test.d.ts +1 -0
  314. package/paginator/Paginator.accessibility.test.js +79 -0
  315. package/paginator/Paginator.d.ts +4 -0
  316. package/paginator/Paginator.js +138 -0
  317. package/paginator/Paginator.stories.tsx +87 -0
  318. package/paginator/Paginator.test.d.ts +1 -0
  319. package/paginator/Paginator.test.js +335 -0
  320. package/paginator/types.d.ts +38 -0
  321. package/paginator/types.js +5 -0
  322. package/paragraph/Paragraph.accessibility.test.d.ts +1 -0
  323. package/paragraph/Paragraph.accessibility.test.js +28 -0
  324. package/paragraph/Paragraph.d.ts +5 -0
  325. package/paragraph/Paragraph.js +22 -0
  326. package/paragraph/Paragraph.stories.tsx +27 -0
  327. package/password-input/PasswordInput.accessibility.test.d.ts +1 -0
  328. package/password-input/PasswordInput.accessibility.test.js +153 -0
  329. package/password-input/PasswordInput.d.ts +4 -0
  330. package/password-input/PasswordInput.js +97 -0
  331. package/password-input/PasswordInput.stories.tsx +99 -0
  332. package/password-input/PasswordInput.test.d.ts +1 -0
  333. package/password-input/PasswordInput.test.js +198 -0
  334. package/password-input/types.d.ts +111 -0
  335. package/password-input/types.js +5 -0
  336. package/progress-bar/ProgressBar.accessibility.test.d.ts +1 -0
  337. package/progress-bar/ProgressBar.accessibility.test.js +35 -0
  338. package/progress-bar/ProgressBar.d.ts +4 -0
  339. package/progress-bar/ProgressBar.js +146 -0
  340. package/progress-bar/ProgressBar.stories.tsx +93 -0
  341. package/progress-bar/ProgressBar.test.d.ts +1 -0
  342. package/progress-bar/ProgressBar.test.js +93 -0
  343. package/progress-bar/types.d.ts +37 -0
  344. package/progress-bar/types.js +5 -0
  345. package/quick-nav/QuickNav.accessibility.test.d.ts +1 -0
  346. package/quick-nav/QuickNav.accessibility.test.js +57 -0
  347. package/quick-nav/QuickNav.d.ts +4 -0
  348. package/quick-nav/QuickNav.js +94 -0
  349. package/quick-nav/QuickNav.stories.tsx +356 -0
  350. package/quick-nav/types.d.ts +21 -0
  351. package/quick-nav/types.js +5 -0
  352. package/radio-group/Radio.d.ts +4 -0
  353. package/radio-group/Radio.js +121 -0
  354. package/radio-group/RadioGroup.accessibility.test.d.ts +1 -0
  355. package/radio-group/RadioGroup.accessibility.test.js +97 -0
  356. package/radio-group/RadioGroup.d.ts +4 -0
  357. package/radio-group/RadioGroup.js +233 -0
  358. package/radio-group/RadioGroup.stories.tsx +214 -0
  359. package/radio-group/RadioGroup.test.d.ts +1 -0
  360. package/radio-group/RadioGroup.test.js +754 -0
  361. package/radio-group/types.d.ts +114 -0
  362. package/radio-group/types.js +5 -0
  363. package/resultset-table/Icons.d.ts +7 -0
  364. package/resultset-table/Icons.js +47 -0
  365. package/resultset-table/ResultsetTable.accessibility.test.d.ts +1 -0
  366. package/resultset-table/ResultsetTable.accessibility.test.js +285 -0
  367. package/resultset-table/ResultsetTable.d.ts +7 -0
  368. package/resultset-table/ResultsetTable.js +171 -0
  369. package/resultset-table/ResultsetTable.stories.tsx +413 -0
  370. package/resultset-table/ResultsetTable.test.d.ts +1 -0
  371. package/resultset-table/ResultsetTable.test.js +380 -0
  372. package/resultset-table/types.d.ts +100 -0
  373. package/resultset-table/types.js +5 -0
  374. package/select/Listbox.d.ts +4 -0
  375. package/select/Listbox.js +151 -0
  376. package/select/Option.d.ts +4 -0
  377. package/select/Option.js +89 -0
  378. package/select/Select.accessibility.test.d.ts +1 -0
  379. package/select/Select.accessibility.test.js +228 -0
  380. package/select/Select.d.ts +4 -0
  381. package/select/Select.js +600 -0
  382. package/select/Select.stories.tsx +919 -0
  383. package/select/Select.test.d.ts +1 -0
  384. package/select/Select.test.js +2268 -0
  385. package/select/types.d.ts +209 -0
  386. package/select/types.js +5 -0
  387. package/sidenav/Sidenav.accessibility.test.d.ts +1 -0
  388. package/sidenav/Sidenav.accessibility.test.js +59 -0
  389. package/sidenav/Sidenav.d.ts +10 -0
  390. package/sidenav/Sidenav.js +201 -0
  391. package/sidenav/Sidenav.stories.tsx +277 -0
  392. package/sidenav/Sidenav.test.d.ts +1 -0
  393. package/sidenav/Sidenav.test.js +37 -0
  394. package/sidenav/SidenavContext.d.ts +5 -0
  395. package/sidenav/SidenavContext.js +13 -0
  396. package/sidenav/types.d.ts +76 -0
  397. package/sidenav/types.js +5 -0
  398. package/slider/Slider.accessibility.test.d.ts +1 -0
  399. package/slider/Slider.accessibility.test.js +104 -0
  400. package/slider/Slider.d.ts +4 -0
  401. package/slider/Slider.js +283 -0
  402. package/slider/Slider.stories.tsx +180 -0
  403. package/slider/Slider.test.d.ts +1 -0
  404. package/slider/Slider.test.js +257 -0
  405. package/slider/types.d.ts +86 -0
  406. package/slider/types.js +5 -0
  407. package/spinner/Spinner.accessibility.test.d.ts +1 -0
  408. package/spinner/Spinner.accessibility.test.js +96 -0
  409. package/spinner/Spinner.d.ts +4 -0
  410. package/spinner/Spinner.js +210 -0
  411. package/spinner/Spinner.stories.tsx +129 -0
  412. package/spinner/Spinner.test.d.ts +1 -0
  413. package/spinner/Spinner.test.js +55 -0
  414. package/spinner/types.d.ts +32 -0
  415. package/spinner/types.js +5 -0
  416. package/status-light/StatusLight.accessibility.test.d.ts +1 -0
  417. package/status-light/StatusLight.accessibility.test.js +157 -0
  418. package/status-light/StatusLight.d.ts +4 -0
  419. package/status-light/StatusLight.js +51 -0
  420. package/status-light/StatusLight.stories.tsx +74 -0
  421. package/status-light/StatusLight.test.d.ts +1 -0
  422. package/status-light/StatusLight.test.js +25 -0
  423. package/status-light/types.d.ts +17 -0
  424. package/status-light/types.js +5 -0
  425. package/switch/Switch.accessibility.test.d.ts +1 -0
  426. package/switch/Switch.accessibility.test.js +98 -0
  427. package/switch/Switch.d.ts +4 -0
  428. package/switch/Switch.js +211 -0
  429. package/switch/Switch.stories.tsx +149 -0
  430. package/switch/Switch.test.d.ts +1 -0
  431. package/switch/Switch.test.js +180 -0
  432. package/switch/types.d.ts +66 -0
  433. package/switch/types.js +5 -0
  434. package/table/DropdownTheme.js +62 -0
  435. package/table/Table.accessibility.test.d.ts +1 -0
  436. package/table/Table.accessibility.test.js +93 -0
  437. package/table/Table.d.ts +8 -0
  438. package/table/Table.js +161 -0
  439. package/table/Table.stories.tsx +663 -0
  440. package/table/Table.test.d.ts +1 -0
  441. package/table/Table.test.js +112 -0
  442. package/table/types.d.ts +49 -0
  443. package/table/types.js +5 -0
  444. package/tabs/Tab.d.ts +4 -0
  445. package/tabs/Tab.js +117 -0
  446. package/tabs/Tabs.accessibility.test.d.ts +1 -0
  447. package/tabs/Tabs.accessibility.test.js +56 -0
  448. package/tabs/Tabs.d.ts +4 -0
  449. package/tabs/Tabs.js +373 -0
  450. package/tabs/Tabs.stories.tsx +230 -0
  451. package/tabs/Tabs.test.d.ts +1 -0
  452. package/tabs/Tabs.test.js +276 -0
  453. package/tabs/types.d.ts +92 -0
  454. package/tabs/types.js +5 -0
  455. package/tag/Tag.accessibility.test.d.ts +1 -0
  456. package/tag/Tag.accessibility.test.js +69 -0
  457. package/tag/Tag.d.ts +4 -0
  458. package/tag/Tag.js +151 -0
  459. package/tag/Tag.stories.tsx +152 -0
  460. package/tag/Tag.test.d.ts +1 -0
  461. package/tag/Tag.test.js +41 -0
  462. package/tag/types.d.ts +69 -0
  463. package/tag/types.js +5 -0
  464. package/text-input/Suggestion.d.ts +4 -0
  465. package/text-input/Suggestion.js +67 -0
  466. package/text-input/Suggestions.d.ts +4 -0
  467. package/text-input/Suggestions.js +94 -0
  468. package/text-input/TextInput.accessibility.test.d.ts +1 -0
  469. package/text-input/TextInput.accessibility.test.js +321 -0
  470. package/text-input/TextInput.d.ts +4 -0
  471. package/text-input/TextInput.js +569 -0
  472. package/text-input/TextInput.stories.tsx +474 -0
  473. package/text-input/TextInput.test.d.ts +1 -0
  474. package/text-input/TextInput.test.js +1756 -0
  475. package/text-input/types.d.ts +205 -0
  476. package/text-input/types.js +5 -0
  477. package/textarea/Textarea.accessibility.test.d.ts +1 -0
  478. package/textarea/Textarea.accessibility.test.js +155 -0
  479. package/textarea/Textarea.d.ts +4 -0
  480. package/textarea/Textarea.js +232 -0
  481. package/textarea/Textarea.stories.tsx +174 -0
  482. package/textarea/Textarea.test.d.ts +1 -0
  483. package/textarea/Textarea.test.js +406 -0
  484. package/textarea/types.d.ts +141 -0
  485. package/textarea/types.js +5 -0
  486. package/toggle-group/ToggleGroup.accessibility.test.d.ts +1 -0
  487. package/toggle-group/ToggleGroup.accessibility.test.js +107 -0
  488. package/toggle-group/ToggleGroup.d.ts +4 -0
  489. package/toggle-group/ToggleGroup.js +199 -0
  490. package/toggle-group/ToggleGroup.stories.tsx +218 -0
  491. package/toggle-group/ToggleGroup.test.d.ts +1 -0
  492. package/toggle-group/ToggleGroup.test.js +137 -0
  493. package/toggle-group/types.d.ts +114 -0
  494. package/toggle-group/types.js +5 -0
  495. package/typography/Typography.accessibility.test.d.ts +1 -0
  496. package/typography/Typography.accessibility.test.js +339 -0
  497. package/typography/Typography.d.ts +4 -0
  498. package/typography/Typography.js +23 -0
  499. package/typography/Typography.stories.tsx +198 -0
  500. package/typography/types.d.ts +18 -0
  501. package/typography/types.js +5 -0
  502. package/useTheme.d.ts +1143 -0
  503. package/{dist/useTheme.js → useTheme.js} +4 -11
  504. package/useTranslatedLabels.d.ts +85 -0
  505. package/useTranslatedLabels.js +14 -0
  506. package/utils/BaseTypography.d.ts +21 -0
  507. package/utils/BaseTypography.js +94 -0
  508. package/utils/FocusLock.d.ts +13 -0
  509. package/utils/FocusLock.js +124 -0
  510. package/wizard/Wizard.accessibility.test.d.ts +1 -0
  511. package/wizard/Wizard.accessibility.test.js +55 -0
  512. package/wizard/Wizard.d.ts +4 -0
  513. package/wizard/Wizard.js +239 -0
  514. package/wizard/Wizard.stories.tsx +272 -0
  515. package/wizard/Wizard.test.d.ts +1 -0
  516. package/wizard/Wizard.test.js +114 -0
  517. package/wizard/types.d.ts +64 -0
  518. package/wizard/types.js +5 -0
  519. package/babel.config.js +0 -8
  520. package/dist/BackgroundColorContext.js +0 -46
  521. package/dist/ThemeContext.js +0 -248
  522. package/dist/V3Textarea/V3Textarea.js +0 -264
  523. package/dist/accordion/Accordion.js +0 -353
  524. package/dist/accordion-group/AccordionGroup.js +0 -186
  525. package/dist/alert/Alert.js +0 -403
  526. package/dist/alert/index.d.ts +0 -51
  527. package/dist/badge/Badge.js +0 -63
  528. package/dist/box/Box.js +0 -156
  529. package/dist/button/Button.js +0 -238
  530. package/dist/card/Card.js +0 -254
  531. package/dist/checkbox/Checkbox.js +0 -300
  532. package/dist/checkbox/Checkbox.stories.js +0 -144
  533. package/dist/checkbox/readme.md +0 -116
  534. package/dist/chip/Chip.js +0 -265
  535. package/dist/common/OpenSans.css +0 -81
  536. package/dist/common/RequiredComponent.js +0 -40
  537. package/dist/common/fonts/OpenSans-Bold.ttf +0 -0
  538. package/dist/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  539. package/dist/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  540. package/dist/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  541. package/dist/common/fonts/OpenSans-Italic.ttf +0 -0
  542. package/dist/common/fonts/OpenSans-Light.ttf +0 -0
  543. package/dist/common/fonts/OpenSans-LightItalic.ttf +0 -0
  544. package/dist/common/fonts/OpenSans-Regular.ttf +0 -0
  545. package/dist/common/fonts/OpenSans-SemiBold.ttf +0 -0
  546. package/dist/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  547. package/dist/common/variables.js +0 -1569
  548. package/dist/date/Date.js +0 -379
  549. package/dist/date/Date.stories.js +0 -205
  550. package/dist/date/readme.md +0 -73
  551. package/dist/date-input/DateInput.js +0 -400
  552. package/dist/date-input/index.d.ts +0 -95
  553. package/dist/dialog/Dialog.js +0 -218
  554. package/dist/dropdown/Dropdown.js +0 -544
  555. package/dist/file-input/FileInput.js +0 -644
  556. package/dist/file-input/FileItem.js +0 -280
  557. package/dist/file-input/index.d.ts +0 -81
  558. package/dist/footer/Footer.js +0 -421
  559. package/dist/footer/Icons.js +0 -77
  560. package/dist/header/Header.js +0 -434
  561. package/dist/input-text/Icons.js +0 -22
  562. package/dist/input-text/InputText.js +0 -705
  563. package/dist/layout/ApplicationLayout.js +0 -327
  564. package/dist/layout/Icons.js +0 -55
  565. package/dist/link/Link.js +0 -237
  566. package/dist/link/readme.md +0 -51
  567. package/dist/main.d.ts +0 -8
  568. package/dist/new-select/NewSelect.js +0 -836
  569. package/dist/new-select/index.d.ts +0 -53
  570. package/dist/number-input/NumberInput.js +0 -136
  571. package/dist/number-input/NumberInputContext.js +0 -16
  572. package/dist/number-input/index.d.ts +0 -113
  573. package/dist/paginator/Icons.js +0 -66
  574. package/dist/paginator/Paginator.js +0 -283
  575. package/dist/password-input/PasswordInput.js +0 -198
  576. package/dist/password-input/index.d.ts +0 -94
  577. package/dist/progress-bar/ProgressBar.js +0 -242
  578. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  579. package/dist/progress-bar/readme.md +0 -63
  580. package/dist/radio/Radio.js +0 -209
  581. package/dist/radio/Radio.stories.js +0 -166
  582. package/dist/radio/readme.md +0 -70
  583. package/dist/resultsetTable/ResultsetTable.js +0 -358
  584. package/dist/select/Select.js +0 -549
  585. package/dist/sidenav/Sidenav.js +0 -179
  586. package/dist/slider/Slider.js +0 -404
  587. package/dist/slider/readme.md +0 -64
  588. package/dist/spinner/Spinner.js +0 -381
  589. package/dist/spinner/Spinner.stories.js +0 -183
  590. package/dist/spinner/readme.md +0 -65
  591. package/dist/switch/Switch.js +0 -222
  592. package/dist/switch/Switch.stories.js +0 -134
  593. package/dist/switch/readme.md +0 -133
  594. package/dist/table/Table.js +0 -132
  595. package/dist/tabs/Tabs.js +0 -343
  596. package/dist/tabs/Tabs.stories.js +0 -130
  597. package/dist/tabs/readme.md +0 -78
  598. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  599. package/dist/tabs-for-sections/readme.md +0 -78
  600. package/dist/tag/Tag.js +0 -282
  601. package/dist/text-input/TextInput.js +0 -971
  602. package/dist/text-input/index.d.ts +0 -135
  603. package/dist/textarea/Textarea.js +0 -369
  604. package/dist/textarea/index.d.ts +0 -117
  605. package/dist/toggle/Toggle.js +0 -220
  606. package/dist/toggle/Toggle.stories.js +0 -297
  607. package/dist/toggle/readme.md +0 -80
  608. package/dist/toggle-group/ToggleGroup.js +0 -327
  609. package/dist/upload/Upload.js +0 -205
  610. package/dist/upload/Upload.stories.js +0 -72
  611. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -139
  612. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  613. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  614. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  615. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  616. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  617. package/dist/upload/file-upload/FileToUpload.js +0 -184
  618. package/dist/upload/file-upload/audio-icon.svg +0 -4
  619. package/dist/upload/file-upload/close.svg +0 -4
  620. package/dist/upload/file-upload/file-icon.svg +0 -4
  621. package/dist/upload/file-upload/video-icon.svg +0 -4
  622. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  623. package/dist/upload/readme.md +0 -37
  624. package/dist/upload/transaction/Transaction.js +0 -175
  625. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  626. package/dist/upload/transaction/audio-icon.svg +0 -4
  627. package/dist/upload/transaction/error-icon.svg +0 -4
  628. package/dist/upload/transaction/file-icon-err.svg +0 -4
  629. package/dist/upload/transaction/file-icon.svg +0 -4
  630. package/dist/upload/transaction/image-icon-err.svg +0 -4
  631. package/dist/upload/transaction/image-icon.svg +0 -4
  632. package/dist/upload/transaction/success-icon.svg +0 -4
  633. package/dist/upload/transaction/video-icon-err.svg +0 -4
  634. package/dist/upload/transaction/video-icon.svg +0 -4
  635. package/dist/upload/transactions/Transactions.js +0 -138
  636. package/dist/wizard/Wizard.js +0 -411
  637. package/dist/wizard/invalid_icon.svg +0 -5
  638. package/dist/wizard/valid_icon.svg +0 -5
  639. package/dist/wizard/validation-wrong.svg +0 -6
  640. package/test/Accordion.test.js +0 -33
  641. package/test/AccordionGroup.test.js +0 -125
  642. package/test/Alert.test.js +0 -53
  643. package/test/Box.test.js +0 -10
  644. package/test/Button.test.js +0 -18
  645. package/test/Card.test.js +0 -30
  646. package/test/Checkbox.test.js +0 -45
  647. package/test/Chip.test.js +0 -25
  648. package/test/Date.test.js +0 -397
  649. package/test/DateInput.test.js +0 -242
  650. package/test/Dialog.test.js +0 -23
  651. package/test/Dropdown.test.js +0 -145
  652. package/test/FileInput.test.js +0 -201
  653. package/test/Footer.test.js +0 -94
  654. package/test/Header.test.js +0 -34
  655. package/test/Heading.test.js +0 -35
  656. package/test/InputText.test.js +0 -248
  657. package/test/Link.test.js +0 -43
  658. package/test/NumberInput.test.js +0 -259
  659. package/test/Paginator.test.js +0 -177
  660. package/test/PasswordInput.test.js +0 -83
  661. package/test/ProgressBar.test.js +0 -35
  662. package/test/Radio.test.js +0 -37
  663. package/test/ResultsetTable.test.js +0 -329
  664. package/test/Select.test.js +0 -212
  665. package/test/Sidenav.test.js +0 -45
  666. package/test/Slider.test.js +0 -74
  667. package/test/Spinner.test.js +0 -32
  668. package/test/Switch.test.js +0 -45
  669. package/test/Table.test.js +0 -36
  670. package/test/Tabs.test.js +0 -109
  671. package/test/TabsForSections.test.js +0 -34
  672. package/test/Tag.test.js +0 -32
  673. package/test/TextInput.test.js +0 -732
  674. package/test/Textarea.test.js +0 -193
  675. package/test/ToggleGroup.test.js +0 -85
  676. package/test/Upload.test.js +0 -60
  677. package/test/V3TextArea.test.js +0 -51
  678. package/test/Wizard.test.js +0 -130
  679. package/test/mocks/pngMock.js +0 -1
  680. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,98 @@
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 _axeHelper = require("../../test/accessibility/axe-helper.js");
9
+ var _Switch = _interopRequireDefault(require("./Switch"));
10
+ var _disabledRules = require("../../test/accessibility/rules/specific/switch/disabledRules.js");
11
+ var disabledRules = {
12
+ rules: _disabledRules.disabledRules.reduce(function (rulesObj, rule) {
13
+ rulesObj[rule] = {
14
+ enabled: false
15
+ };
16
+ return rulesObj;
17
+ }, {})
18
+ };
19
+ describe("Switch component accessibility tests", function () {
20
+ it("Should not have basic accessibility issues", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee() {
21
+ var _render, container, results;
22
+ return _regenerator["default"].wrap(function _callee$(_context) {
23
+ while (1) switch (_context.prev = _context.next) {
24
+ case 0:
25
+ _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
26
+ label: "Default label",
27
+ defaultChecked: true,
28
+ value: "test-defaultChecked",
29
+ name: "test",
30
+ labelPosition: "after",
31
+ margin: "medium",
32
+ size: "medium",
33
+ checked: true
34
+ })), container = _render.container;
35
+ _context.next = 3;
36
+ return (0, _axeHelper.axe)(container, disabledRules);
37
+ case 3:
38
+ results = _context.sent;
39
+ expect(results).toHaveNoViolations();
40
+ case 5:
41
+ case "end":
42
+ return _context.stop();
43
+ }
44
+ }, _callee);
45
+ })));
46
+ it("Should not have basic accessibility issues for optional mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
47
+ var _render2, container, results;
48
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
49
+ while (1) switch (_context2.prev = _context2.next) {
50
+ case 0:
51
+ _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
52
+ label: "Default label",
53
+ defaultChecked: true,
54
+ value: "test-defaultChecked",
55
+ name: "test",
56
+ labelPosition: "after",
57
+ margin: "medium",
58
+ size: "medium",
59
+ optional: true
60
+ })), container = _render2.container;
61
+ _context2.next = 3;
62
+ return (0, _axeHelper.axe)(container, disabledRules);
63
+ case 3:
64
+ results = _context2.sent;
65
+ expect(results).toHaveNoViolations();
66
+ case 5:
67
+ case "end":
68
+ return _context2.stop();
69
+ }
70
+ }, _callee2);
71
+ })));
72
+ it("Should not have basic accessibility issues for disabled mode", /*#__PURE__*/(0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3() {
73
+ var _render3, container, results;
74
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
75
+ while (1) switch (_context3.prev = _context3.next) {
76
+ case 0:
77
+ _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
78
+ label: "Default label",
79
+ defaultChecked: true,
80
+ value: "test-defaultChecked",
81
+ name: "test",
82
+ labelPosition: "after",
83
+ margin: "medium",
84
+ size: "medium",
85
+ disabled: true
86
+ })), container = _render3.container;
87
+ _context3.next = 3;
88
+ return (0, _axeHelper.axe)(container, disabledRules);
89
+ case 3:
90
+ results = _context3.sent;
91
+ expect(results).toHaveNoViolations();
92
+ case 5:
93
+ case "end":
94
+ return _context3.stop();
95
+ }
96
+ }, _callee3);
97
+ })));
98
+ });
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import SwitchPropsType from "./types";
3
+ declare const DxcSwitch: React.ForwardRefExoticComponent<SwitchPropsType & React.RefAttributes<HTMLDivElement>>;
4
+ export default DxcSwitch;
@@ -0,0 +1,211 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof3 = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports["default"] = void 0;
9
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
10
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
11
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
12
+ var _react = _interopRequireWildcard(require("react"));
13
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
14
+ var _variables = require("../common/variables");
15
+ var _utils = require("../common/utils");
16
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
17
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
18
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
19
+ 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); }
20
+ function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof3(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; }
21
+ var DxcSwitch = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
22
+ var defaultChecked = _ref.defaultChecked,
23
+ checked = _ref.checked,
24
+ value = _ref.value,
25
+ _ref$label = _ref.label,
26
+ label = _ref$label === void 0 ? "" : _ref$label,
27
+ _ref$labelPosition = _ref.labelPosition,
28
+ labelPosition = _ref$labelPosition === void 0 ? "before" : _ref$labelPosition,
29
+ _ref$name = _ref.name,
30
+ name = _ref$name === void 0 ? "" : _ref$name,
31
+ _ref$disabled = _ref.disabled,
32
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
33
+ _ref$optional = _ref.optional,
34
+ optional = _ref$optional === void 0 ? false : _ref$optional,
35
+ onChange = _ref.onChange,
36
+ margin = _ref.margin,
37
+ _ref$size = _ref.size,
38
+ size = _ref$size === void 0 ? "fitContent" : _ref$size,
39
+ _ref$tabIndex = _ref.tabIndex,
40
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
41
+ var switchId = "switch-".concat((0, _react.useId)());
42
+ var labelId = "label-".concat(switchId);
43
+ var _useState = (0, _react.useState)(defaultChecked !== null && defaultChecked !== void 0 ? defaultChecked : false),
44
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
45
+ innerChecked = _useState2[0],
46
+ setInnerChecked = _useState2[1];
47
+ var colorsTheme = (0, _useTheme["default"])();
48
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
49
+ var refTrack = (0, _react.useRef)(null);
50
+ var handleOnKeyDown = function handleOnKeyDown(event) {
51
+ switch (event.key) {
52
+ case "Enter":
53
+ case " ":
54
+ // Space
55
+ event.preventDefault();
56
+ refTrack.current.focus();
57
+ var isChecked = !(checked !== null && checked !== void 0 ? checked : innerChecked);
58
+ setInnerChecked(isChecked);
59
+ onChange === null || onChange === void 0 ? void 0 : onChange(isChecked);
60
+ break;
61
+ }
62
+ };
63
+ var handlerSwitchChange = function handlerSwitchChange(event) {
64
+ checked !== null && checked !== void 0 ? checked : setInnerChecked(function (innerChecked) {
65
+ return !innerChecked;
66
+ });
67
+ onChange === null || onChange === void 0 ? void 0 : onChange(checked ? !checked : !innerChecked);
68
+ };
69
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
70
+ theme: colorsTheme["switch"]
71
+ }, /*#__PURE__*/_react["default"].createElement(SwitchContainer, {
72
+ margin: margin,
73
+ size: size,
74
+ onKeyDown: handleOnKeyDown,
75
+ disabled: disabled,
76
+ onClick: !disabled ? handlerSwitchChange : undefined,
77
+ ref: ref
78
+ }, labelPosition === "before" && label && /*#__PURE__*/_react["default"].createElement(LabelContainer, {
79
+ id: labelId,
80
+ labelPosition: labelPosition,
81
+ disabled: disabled,
82
+ label: label
83
+ }, label, " ", optional && /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, translatedLabels.formFields.optionalLabel)), /*#__PURE__*/_react["default"].createElement(ValueInput, {
84
+ type: "checkbox",
85
+ name: name,
86
+ "aria-hidden": true,
87
+ value: value,
88
+ disabled: disabled,
89
+ checked: checked !== null && checked !== void 0 ? checked : innerChecked,
90
+ readOnly: true
91
+ }), /*#__PURE__*/_react["default"].createElement(SwitchBase, null, /*#__PURE__*/_react["default"].createElement(SwitchTrack, {
92
+ role: "switch",
93
+ "aria-checked": checked !== null && checked !== void 0 ? checked : innerChecked,
94
+ "aria-disabled": disabled,
95
+ disabled: disabled,
96
+ "aria-labelledby": labelId,
97
+ tabIndex: !disabled ? tabIndex : -1,
98
+ ref: refTrack
99
+ })), labelPosition === "after" && label && /*#__PURE__*/_react["default"].createElement(LabelContainer, {
100
+ id: labelId,
101
+ labelPosition: labelPosition,
102
+ disabled: disabled,
103
+ label: label
104
+ }, optional && /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, translatedLabels.formFields.optionalLabel), " ", label)));
105
+ });
106
+ var sizes = {
107
+ small: "60px",
108
+ medium: "240px",
109
+ large: "480px",
110
+ fillParent: "100%",
111
+ fitContent: "fit-content"
112
+ };
113
+ var calculateWidth = function calculateWidth(margin, size) {
114
+ return size === "fillParent" ? "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")") : sizes[size];
115
+ };
116
+ var getDisabledColor = function getDisabledColor(theme, element, subElement) {
117
+ switch (element) {
118
+ case "track":
119
+ switch (subElement) {
120
+ case "check":
121
+ return theme.disabledCheckedTrackBackgroundColor;
122
+ case "uncheck":
123
+ return theme.disabledUncheckedTrackBackgroundColor;
124
+ }
125
+ case "thumb":
126
+ switch (subElement) {
127
+ case "check":
128
+ return theme.disabledCheckedThumbBackgroundColor;
129
+ case "uncheck":
130
+ return theme.disabledUncheckedThumbBackgroundColor;
131
+ }
132
+ case "label":
133
+ return theme.disabledLabelFontColor;
134
+ }
135
+ };
136
+ var getNotDisabledColor = function getNotDisabledColor(theme, element, subElement) {
137
+ switch (element) {
138
+ case "track":
139
+ switch (subElement) {
140
+ case "check":
141
+ return theme.checkedTrackBackgroundColor;
142
+ case "uncheck":
143
+ return theme.uncheckedTrackBackgroundColor;
144
+ }
145
+ case "thumb":
146
+ switch (subElement) {
147
+ case "check":
148
+ return theme.checkedThumbBackgroundColor;
149
+ case "uncheck":
150
+ return theme.uncheckedThumbBackgroundColor;
151
+ }
152
+ case "label":
153
+ return theme.labelFontColor;
154
+ }
155
+ };
156
+ var SwitchContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: inline-flex;\n align-items: center;\n width: ", ";\n height: 40px;\n cursor: ", ";\n\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"])), function (props) {
157
+ return calculateWidth(props.margin, props.size);
158
+ }, function (props) {
159
+ return props.disabled === true ? "not-allowed" : "pointer";
160
+ }, function (props) {
161
+ return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
162
+ }, function (props) {
163
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
164
+ }, function (props) {
165
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
166
+ }, function (props) {
167
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
168
+ }, function (props) {
169
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
170
+ });
171
+ var LabelContainer = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n color: ", ";\n opacity: 1;\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n\n ", ";\n\n ", "\n"])), function (props) {
172
+ return props.disabled ? getDisabledColor(props.theme, "label") : getNotDisabledColor(props.theme, "label");
173
+ }, function (props) {
174
+ return props.theme.labelFontFamily;
175
+ }, function (props) {
176
+ return props.theme.labelFontSize;
177
+ }, function (props) {
178
+ return props.disabled ? props.theme.disabledLabelFontStyle : props.theme.labelFontStyle;
179
+ }, function (props) {
180
+ return props.theme.labelFontWeight;
181
+ }, function (props) {
182
+ return !props.label ? "margin: 0px;" : props.labelPosition === "after" ? "margin-left: ".concat(props.theme.spaceBetweenLabelSwitch, ";") : "margin-right: ".concat(props.theme.spaceBetweenLabelSwitch, ";");
183
+ }, function (props) {
184
+ return props.labelPosition === "before" && "order: -1";
185
+ });
186
+ var SwitchBase = _styledComponents["default"].label(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: space-between;\n cursor: pointer;\n margin: 0px 12px;\n"])));
187
+ var ValueInput = _styledComponents["default"].input(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: none;\n"])));
188
+ var SwitchTrack = _styledComponents["default"].span(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n border-radius: 15px;\n width: ", ";\n height: ", ";\n position: relative;\n cursor: ", ";\n\n &:focus-visible {\n outline: none;\n ::before {\n outline: ", ";\n outline-offset: 6px;\n }\n }\n\n /* Thumb element */\n ::before {\n content: \"\";\n transform: initial;\n position: absolute;\n width: ", ";\n height: ", ";\n border-radius: 50%;\n box-shadow: 0px 2px 1px -1px rgb(0 0 0 / 20%), 0px 1px 1px 0px rgb(0 0 0 / 14%), 0px 1px 3px 0px rgb(0 0 0 / 12%);\n bottom: -6px;\n left: -4px;\n transform: translateX(0px);\n background-color: ", ";\n }\n\n /* Unchecked */\n background-color: ", ";\n\n /* Checked */\n &[aria-checked=\"true\"] {\n background-color: ", ";\n ::before {\n transform: translateX(", ");\n background-color: ", ";\n }\n }\n"])), function (props) {
189
+ return props.theme.trackWidth;
190
+ }, function (props) {
191
+ return props.theme.trackHeight;
192
+ }, function (props) {
193
+ return props.disabled ? "not-allowed" : "pointer";
194
+ }, function (props) {
195
+ return "".concat(props.theme.thumbFocusColor, " solid 2px");
196
+ }, function (props) {
197
+ return props.theme.thumbWidth;
198
+ }, function (props) {
199
+ return props.theme.thumbHeight;
200
+ }, function (props) {
201
+ return props.disabled ? getDisabledColor(props.theme, "thumb", "uncheck") : getNotDisabledColor(props.theme, "thumb", "uncheck");
202
+ }, function (props) {
203
+ return props.disabled ? getDisabledColor(props.theme, "track", "uncheck") : getNotDisabledColor(props.theme, "track", "uncheck");
204
+ }, function (props) {
205
+ return props.disabled ? getDisabledColor(props.theme, "track", "check") : getNotDisabledColor(props.theme, "track", "check");
206
+ }, function (props) {
207
+ return props.theme.thumbShift;
208
+ }, function (props) {
209
+ return props.disabled ? getDisabledColor(props.theme, "thumb", "check") : getNotDisabledColor(props.theme, "thumb", "check");
210
+ });
211
+ var _default = exports["default"] = DxcSwitch;
@@ -0,0 +1,149 @@
1
+ import React from "react";
2
+ import DxcSwitch from "./Switch";
3
+ import Title from "../../.storybook/components/Title";
4
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
+ import { HalstackProvider } from "../HalstackContext";
6
+ import { disabledRules } from "../../test/accessibility/rules/specific/switch/disabledRules";
7
+ import preview from "../../.storybook/preview";
8
+
9
+ export default {
10
+ title: "Switch",
11
+ component: DxcSwitch,
12
+ parameters: {
13
+ a11y: {
14
+ config: {
15
+ rules: [
16
+ ...disabledRules.map((ruleId) => ({ id: ruleId, enabled: false })),
17
+ ...preview?.parameters?.a11y?.config?.rules,
18
+ ],
19
+ },
20
+ },
21
+ },
22
+ };
23
+
24
+ const opinionatedTheme = {
25
+ switch: {
26
+ checkedBaseColor: "#5f249f",
27
+ fontColor: "#000000",
28
+ },
29
+ };
30
+
31
+ export const Chromatic = () => (
32
+ <>
33
+ <ExampleContainer>
34
+ <Title title="With label after" theme="light" level={4} />
35
+ <DxcSwitch label="Switch" labelPosition="after" />
36
+ </ExampleContainer>
37
+ <ExampleContainer>
38
+ <Title title="Without label" theme="light" level={4} />
39
+ <DxcSwitch />
40
+ </ExampleContainer>
41
+ <ExampleContainer pseudoState="pseudo-focus-visible">
42
+ <Title title="Focused" theme="light" level={4} />
43
+ <DxcSwitch label="Switch" labelPosition="after" />
44
+ </ExampleContainer>
45
+ <ExampleContainer>
46
+ <Title title="Checked" theme="light" level={4} />
47
+ <DxcSwitch label="Switch" defaultChecked />
48
+ </ExampleContainer>
49
+ <ExampleContainer>
50
+ <Title title="Optional" theme="light" level={4} />
51
+ <DxcSwitch label="Switch" optional />
52
+ </ExampleContainer>
53
+ <ExampleContainer>
54
+ <Title title="Disabled" theme="light" level={4} />
55
+ <DxcSwitch label="Switch" disabled />
56
+ </ExampleContainer>
57
+ <ExampleContainer>
58
+ <Title title="Disabled optional" theme="light" level={4} />
59
+ <DxcSwitch label="Switch" disabled optional labelPosition="after" />
60
+ </ExampleContainer>
61
+ <ExampleContainer>
62
+ <Title title="Disabled checked" theme="light" level={4} />
63
+ <DxcSwitch label="Switch" disabled defaultChecked labelPosition="after" />
64
+ </ExampleContainer>
65
+ <Title title="Margins" theme="light" level={2} />
66
+ <ExampleContainer>
67
+ <Title title="Xxsmall margin" theme="light" level={4} />
68
+ <DxcSwitch label="Xxsmall" margin="xxsmall" />
69
+ </ExampleContainer>
70
+ <ExampleContainer>
71
+ <Title title="Xsmall margin" theme="light" level={4} />
72
+ <DxcSwitch label="Xsmall" margin="xsmall" />
73
+ </ExampleContainer>
74
+ <ExampleContainer>
75
+ <Title title="Small margin" theme="light" level={4} />
76
+ <DxcSwitch label="Small" margin="small" />
77
+ </ExampleContainer>
78
+ <ExampleContainer>
79
+ <Title title="Medium margin" theme="light" level={4} />
80
+ <DxcSwitch label="Medium" margin="medium" />
81
+ </ExampleContainer>
82
+ <ExampleContainer>
83
+ <Title title="Large margin" theme="light" level={4} />
84
+ <DxcSwitch label="Large" margin="large" />
85
+ </ExampleContainer>
86
+ <ExampleContainer>
87
+ <Title title="Xlarge margin" theme="light" level={4} />
88
+ <DxcSwitch label="Xlarge" margin="xlarge" />
89
+ </ExampleContainer>
90
+ <ExampleContainer>
91
+ <Title title="Xxlarge margin" theme="light" level={4} />
92
+ <DxcSwitch label="Xxlarge" margin="xxlarge" />
93
+ </ExampleContainer>
94
+ <Title title="Sizes" theme="light" level={2} />
95
+ <ExampleContainer>
96
+ <Title title="Small size" theme="light" level={4} />
97
+ <DxcSwitch label="Small" size="small" />
98
+ </ExampleContainer>
99
+ <ExampleContainer>
100
+ <Title title="Medium size (with large label)" theme="light" level={4} />
101
+ <DxcSwitch label="Very very very large label or even huge" size="medium" />
102
+ </ExampleContainer>
103
+ <ExampleContainer>
104
+ <Title title="Medium size (with long label)" theme="light" level={4} />
105
+ <DxcSwitch
106
+ label="Large texttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttt"
107
+ labelPosition="after"
108
+ size="medium"
109
+ />
110
+ </ExampleContainer>
111
+ <ExampleContainer>
112
+ <Title title="Large size" theme="light" level={4} />
113
+ <DxcSwitch label="Large" size="large" />
114
+ </ExampleContainer>
115
+ <ExampleContainer>
116
+ <Title title="FillParent size" theme="light" level={4} />
117
+ <DxcSwitch label="FillParent" size="fillParent" />
118
+ </ExampleContainer>
119
+ <ExampleContainer>
120
+ <Title title="FitContent size" theme="light" level={4} />
121
+ <DxcSwitch label="FitContent" size="fitContent" />
122
+ </ExampleContainer>
123
+ <Title title="Opinionated theme" theme="light" level={2} />
124
+ <ExampleContainer>
125
+ <Title title="Checked" theme="light" level={4} />
126
+ <HalstackProvider theme={opinionatedTheme}>
127
+ <DxcSwitch label="Switch" defaultChecked />
128
+ </HalstackProvider>
129
+ </ExampleContainer>
130
+ <ExampleContainer>
131
+ <Title title="Default" theme="light" level={4} />
132
+ <HalstackProvider theme={opinionatedTheme}>
133
+ <DxcSwitch label="Switch" />
134
+ </HalstackProvider>
135
+ </ExampleContainer>
136
+ <ExampleContainer>
137
+ <Title title="Disabled" theme="light" level={4} />
138
+ <HalstackProvider theme={opinionatedTheme}>
139
+ <DxcSwitch label="Switch" disabled />
140
+ </HalstackProvider>
141
+ </ExampleContainer>
142
+ <ExampleContainer>
143
+ <Title title="Disabled checked" theme="light" level={4} />
144
+ <HalstackProvider theme={opinionatedTheme}>
145
+ <DxcSwitch label="Switch" disabled defaultChecked />
146
+ </HalstackProvider>
147
+ </ExampleContainer>
148
+ </>
149
+ );
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,180 @@
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 _Switch = _interopRequireDefault(require("./Switch"));
7
+ describe("Switch component tests", function () {
8
+ test("Switch renders with correct text", function () {
9
+ var onChange = jest.fn(function (returnedValue) {
10
+ expect(returnedValue).toBe(true);
11
+ });
12
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
13
+ label: "SwitchComponent",
14
+ checked: false,
15
+ onChange: onChange
16
+ })),
17
+ getByText = _render.getByText;
18
+ expect(getByText("SwitchComponent")).toBeTruthy();
19
+ });
20
+ test("Calls correct function on click", function () {
21
+ var onChange = jest.fn();
22
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
23
+ label: "SwitchComponent",
24
+ checked: false,
25
+ onChange: onChange
26
+ })),
27
+ getByText = _render2.getByText;
28
+ _react2.fireEvent.click(getByText("SwitchComponent"));
29
+ expect(onChange).toHaveBeenCalled();
30
+ });
31
+ test("Calls correct function on key down", function () {
32
+ var onChange = jest.fn();
33
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
34
+ label: "SwitchComponent",
35
+ checked: false,
36
+ onChange: onChange
37
+ })),
38
+ getByText = _render3.getByText;
39
+ _react2.fireEvent.focus(getByText("SwitchComponent"));
40
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
41
+ key: "Enter"
42
+ });
43
+ expect(onChange).toHaveBeenCalled();
44
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
45
+ key: " "
46
+ });
47
+ expect(onChange).toHaveBeenCalled();
48
+ });
49
+ test("Everytime the user clicks the component the onchange function is called with the correct value CONTROLLED COMPONENT", function () {
50
+ var onChange = jest.fn();
51
+ var _render4 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
52
+ label: "SwitchComponent",
53
+ checked: false,
54
+ onChange: onChange
55
+ })),
56
+ getByText = _render4.getByText;
57
+ _react2.fireEvent.click(getByText("SwitchComponent"));
58
+ _react2.fireEvent.click(getByText("SwitchComponent"));
59
+ expect(onChange.mock.calls[0][0]).toBe(true);
60
+ expect(onChange.mock.calls[1][0]).toBe(true);
61
+ });
62
+ test("Everytime the user use enter in the component, the onchange function is called with the correct value CONTROLLED COMPONENT", function () {
63
+ var onChange = jest.fn();
64
+ var _render5 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
65
+ label: "SwitchComponent",
66
+ checked: false,
67
+ onChange: onChange
68
+ })),
69
+ getByText = _render5.getByText;
70
+ _react2.fireEvent.focus(getByText("SwitchComponent"));
71
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
72
+ key: "Enter"
73
+ });
74
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
75
+ key: "Enter"
76
+ });
77
+ expect(onChange.mock.calls[0][0]).toBe(true);
78
+ expect(onChange.mock.calls[1][0]).toBe(true);
79
+ });
80
+ test("Everytime the user use space in the component, the onchange function is called with the correct value CONTROLLED COMPONENT", function () {
81
+ var onChange = jest.fn();
82
+ var _render6 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
83
+ label: "SwitchComponent",
84
+ checked: false,
85
+ onChange: onChange
86
+ })),
87
+ getByText = _render6.getByText;
88
+ _react2.fireEvent.focus(getByText("SwitchComponent"));
89
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
90
+ key: " "
91
+ });
92
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
93
+ key: " "
94
+ });
95
+ expect(onChange.mock.calls[0][0]).toBe(true);
96
+ expect(onChange.mock.calls[1][0]).toBe(true);
97
+ });
98
+ test("Everytime the user clicks the component the onchange function is called with the correct value UNCONTROLLED COMPONENT", function () {
99
+ var onChange = jest.fn();
100
+ var _render7 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
101
+ label: "SwitchComponent",
102
+ onChange: onChange
103
+ })),
104
+ getByText = _render7.getByText;
105
+ _react2.fireEvent.click(getByText("SwitchComponent"));
106
+ _react2.fireEvent.click(getByText("SwitchComponent"));
107
+ expect(onChange.mock.calls[0][0]).toBe(true);
108
+ expect(onChange.mock.calls[1][0]).toBe(false);
109
+ });
110
+ test("Everytime the user use enter in the component, the onchange function is called with the correct value UNCONTROLLED COMPONENT", function () {
111
+ var onChange = jest.fn();
112
+ var _render8 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
113
+ label: "SwitchComponent",
114
+ onChange: onChange
115
+ })),
116
+ getByText = _render8.getByText;
117
+ _react2.fireEvent.focus(getByText("SwitchComponent"));
118
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
119
+ key: "Enter"
120
+ });
121
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
122
+ key: "Enter"
123
+ });
124
+ expect(onChange.mock.calls[0][0]).toBe(true);
125
+ expect(onChange.mock.calls[1][0]).toBe(false);
126
+ });
127
+ test("Everytime the user use space in the component, the onchange function is called with the correct value UNCONTROLLED COMPONENT", function () {
128
+ var onChange = jest.fn();
129
+ var _render9 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
130
+ label: "SwitchComponent",
131
+ onChange: onChange
132
+ })),
133
+ getByText = _render9.getByText;
134
+ _react2.fireEvent.focus(getByText("SwitchComponent"));
135
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
136
+ key: " "
137
+ });
138
+ _react2.fireEvent.keyDown(getByText("SwitchComponent"), {
139
+ key: " "
140
+ });
141
+ expect(onChange.mock.calls[0][0]).toBe(true);
142
+ expect(onChange.mock.calls[1][0]).toBe(false);
143
+ });
144
+ test("Renders with correct initial value and initial state when it is uncontrolled", function () {
145
+ var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
146
+ label: "Default label",
147
+ defaultChecked: true,
148
+ value: "test-defaultChecked",
149
+ name: "test"
150
+ }));
151
+ var switchEl = component.getByRole("switch");
152
+ var inputEl = component.container.querySelector("input[name=\"test\"]");
153
+ expect(inputEl.value).toBe("test-defaultChecked");
154
+ expect(switchEl.getAttribute("aria-checked")).toBe("true");
155
+ });
156
+ test("Renders with correct aria attributes", function () {
157
+ var _render10 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
158
+ label: "Default label"
159
+ })),
160
+ getByText = _render10.getByText,
161
+ getByRole = _render10.getByRole;
162
+ var switchEl = getByRole("switch");
163
+ var label = getByText("Default label");
164
+ expect(switchEl.getAttribute("aria-labelledby")).toBe(label.id);
165
+ expect(switchEl.getAttribute("aria-checked")).toBe("false");
166
+ });
167
+ test("Renders disabled switch correctly", function () {
168
+ var _render11 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Switch["default"], {
169
+ label: "Default label",
170
+ disabled: true
171
+ })),
172
+ getByText = _render11.getByText,
173
+ getByRole = _render11.getByRole;
174
+ var switchEl = getByRole("switch");
175
+ var label = getByText("Default label");
176
+ expect(switchEl.getAttribute("aria-labelledby")).toBe(label.id);
177
+ expect(switchEl.getAttribute("aria-checked")).toBe("false");
178
+ expect(switchEl.getAttribute("aria-disabled")).toBe("true");
179
+ });
180
+ });