@dxc-technology/halstack-react 0.0.0-de3a219 → 0.0.0-dec566a

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 (562) 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.d.ts +4 -0
  7. package/accordion/Accordion.js +169 -0
  8. package/accordion/Accordion.stories.tsx +252 -0
  9. package/accordion/Accordion.test.js +56 -0
  10. package/accordion/types.d.ts +57 -0
  11. package/accordion/types.js +5 -0
  12. package/accordion-group/AccordionGroup.d.ts +7 -0
  13. package/accordion-group/AccordionGroup.js +101 -0
  14. package/accordion-group/AccordionGroup.stories.tsx +252 -0
  15. package/accordion-group/AccordionGroup.test.js +98 -0
  16. package/accordion-group/AccordionGroupAccordion.d.ts +4 -0
  17. package/accordion-group/AccordionGroupAccordion.js +31 -0
  18. package/accordion-group/AccordionGroupContext.d.ts +3 -0
  19. package/accordion-group/AccordionGroupContext.js +8 -0
  20. package/accordion-group/types.d.ts +67 -0
  21. package/accordion-group/types.js +5 -0
  22. package/action-icon/ActionIcon.d.ts +4 -0
  23. package/action-icon/ActionIcon.js +48 -0
  24. package/action-icon/ActionIcon.stories.tsx +41 -0
  25. package/action-icon/ActionIcon.test.js +64 -0
  26. package/action-icon/types.d.ts +26 -0
  27. package/action-icon/types.js +5 -0
  28. package/alert/Alert.d.ts +4 -0
  29. package/alert/Alert.js +200 -0
  30. package/alert/Alert.stories.tsx +198 -0
  31. package/alert/Alert.test.js +75 -0
  32. package/alert/types.d.ts +49 -0
  33. package/alert/types.js +5 -0
  34. package/badge/Badge.d.ts +4 -0
  35. package/badge/Badge.js +159 -0
  36. package/badge/Badge.stories.tsx +210 -0
  37. package/badge/Badge.test.js +30 -0
  38. package/badge/types.d.ts +54 -0
  39. package/badge/types.js +5 -0
  40. package/bleed/Bleed.d.ts +3 -0
  41. package/bleed/Bleed.js +43 -0
  42. package/bleed/Bleed.stories.tsx +342 -0
  43. package/bleed/types.d.ts +37 -0
  44. package/bleed/types.js +5 -0
  45. package/box/Box.d.ts +4 -0
  46. package/box/Box.js +75 -0
  47. package/box/Box.stories.tsx +119 -0
  48. package/box/Box.test.js +13 -0
  49. package/box/types.d.ts +32 -0
  50. package/box/types.js +5 -0
  51. package/bulleted-list/BulletedList.d.ts +7 -0
  52. package/bulleted-list/BulletedList.js +92 -0
  53. package/bulleted-list/BulletedList.stories.tsx +115 -0
  54. package/bulleted-list/types.d.ts +38 -0
  55. package/bulleted-list/types.js +5 -0
  56. package/button/Button.d.ts +4 -0
  57. package/button/Button.js +121 -0
  58. package/button/Button.stories.tsx +326 -0
  59. package/button/Button.test.js +38 -0
  60. package/button/types.d.ts +57 -0
  61. package/button/types.js +5 -0
  62. package/card/Card.d.ts +4 -0
  63. package/card/Card.js +120 -0
  64. package/card/Card.stories.tsx +171 -0
  65. package/card/Card.test.js +39 -0
  66. package/card/types.d.ts +62 -0
  67. package/card/types.js +5 -0
  68. package/checkbox/Checkbox.d.ts +4 -0
  69. package/checkbox/Checkbox.js +215 -0
  70. package/checkbox/Checkbox.stories.tsx +222 -0
  71. package/checkbox/Checkbox.test.js +199 -0
  72. package/checkbox/types.d.ts +72 -0
  73. package/checkbox/types.js +5 -0
  74. package/chip/Chip.d.ts +4 -0
  75. package/chip/Chip.js +121 -0
  76. package/chip/Chip.stories.tsx +214 -0
  77. package/chip/Chip.test.js +41 -0
  78. package/chip/types.d.ts +45 -0
  79. package/chip/types.js +5 -0
  80. package/common/coreTokens.d.ts +237 -0
  81. package/common/coreTokens.js +184 -0
  82. package/common/utils.d.ts +1 -0
  83. package/{dist/common → common}/utils.js +6 -12
  84. package/common/variables.d.ts +1395 -0
  85. package/common/variables.js +1267 -0
  86. package/container/Container.d.ts +4 -0
  87. package/container/Container.js +194 -0
  88. package/container/Container.stories.tsx +214 -0
  89. package/container/types.d.ts +74 -0
  90. package/container/types.js +5 -0
  91. package/contextual-menu/ContextualMenu.d.ts +7 -0
  92. package/contextual-menu/ContextualMenu.js +71 -0
  93. package/contextual-menu/ContextualMenu.stories.tsx +182 -0
  94. package/contextual-menu/ContextualMenu.test.js +71 -0
  95. package/contextual-menu/MenuItemAction.d.ts +4 -0
  96. package/contextual-menu/MenuItemAction.js +46 -0
  97. package/contextual-menu/types.d.ts +22 -0
  98. package/contextual-menu/types.js +5 -0
  99. package/date-input/Calendar.d.ts +4 -0
  100. package/date-input/Calendar.js +214 -0
  101. package/date-input/DateInput.d.ts +4 -0
  102. package/date-input/DateInput.js +223 -0
  103. package/date-input/DateInput.stories.tsx +285 -0
  104. package/date-input/DateInput.test.js +808 -0
  105. package/date-input/DatePicker.d.ts +4 -0
  106. package/date-input/DatePicker.js +115 -0
  107. package/date-input/Icons.d.ts +6 -0
  108. package/date-input/Icons.js +58 -0
  109. package/date-input/YearPicker.d.ts +4 -0
  110. package/date-input/YearPicker.js +100 -0
  111. package/date-input/types.d.ts +164 -0
  112. package/date-input/types.js +5 -0
  113. package/dialog/Dialog.d.ts +4 -0
  114. package/dialog/Dialog.js +104 -0
  115. package/dialog/Dialog.stories.tsx +365 -0
  116. package/dialog/Dialog.test.js +307 -0
  117. package/dialog/types.d.ts +36 -0
  118. package/dialog/types.js +5 -0
  119. package/divider/Divider.d.ts +4 -0
  120. package/divider/Divider.js +36 -0
  121. package/divider/Divider.stories.tsx +223 -0
  122. package/divider/Divider.test.js +38 -0
  123. package/divider/types.d.ts +21 -0
  124. package/divider/types.js +5 -0
  125. package/dropdown/Dropdown.d.ts +4 -0
  126. package/dropdown/Dropdown.js +319 -0
  127. package/dropdown/Dropdown.stories.tsx +427 -0
  128. package/dropdown/Dropdown.test.js +599 -0
  129. package/dropdown/DropdownMenu.d.ts +4 -0
  130. package/dropdown/DropdownMenu.js +63 -0
  131. package/dropdown/DropdownMenuItem.d.ts +4 -0
  132. package/dropdown/DropdownMenuItem.js +70 -0
  133. package/dropdown/types.d.ts +96 -0
  134. package/dropdown/types.js +5 -0
  135. package/file-input/FileInput.d.ts +4 -0
  136. package/file-input/FileInput.js +479 -0
  137. package/file-input/FileInput.stories.tsx +618 -0
  138. package/file-input/FileInput.test.js +459 -0
  139. package/file-input/FileItem.d.ts +4 -0
  140. package/file-input/FileItem.js +135 -0
  141. package/file-input/types.d.ts +129 -0
  142. package/file-input/types.js +5 -0
  143. package/flex/Flex.d.ts +4 -0
  144. package/flex/Flex.js +57 -0
  145. package/flex/Flex.stories.tsx +112 -0
  146. package/flex/types.d.ts +97 -0
  147. package/flex/types.js +5 -0
  148. package/footer/Footer.d.ts +4 -0
  149. package/footer/Footer.js +138 -0
  150. package/footer/Footer.stories.tsx +171 -0
  151. package/footer/Footer.test.js +85 -0
  152. package/footer/Icons.d.ts +3 -0
  153. package/footer/Icons.js +136 -0
  154. package/footer/types.d.ts +64 -0
  155. package/footer/types.js +5 -0
  156. package/grid/Grid.d.ts +7 -0
  157. package/grid/Grid.js +76 -0
  158. package/grid/Grid.stories.tsx +219 -0
  159. package/grid/types.d.ts +115 -0
  160. package/grid/types.js +5 -0
  161. package/header/Header.d.ts +8 -0
  162. package/header/Header.js +220 -0
  163. package/header/Header.stories.tsx +251 -0
  164. package/header/Header.test.js +66 -0
  165. package/header/Icons.d.ts +2 -0
  166. package/header/Icons.js +29 -0
  167. package/header/types.d.ts +33 -0
  168. package/header/types.js +5 -0
  169. package/heading/Heading.d.ts +4 -0
  170. package/{dist/heading → heading}/Heading.js +34 -119
  171. package/heading/Heading.stories.tsx +54 -0
  172. package/heading/Heading.test.js +169 -0
  173. package/heading/types.d.ts +33 -0
  174. package/heading/types.js +5 -0
  175. package/icon/Icon.d.ts +4 -0
  176. package/icon/Icon.js +33 -0
  177. package/icon/Icon.stories.tsx +28 -0
  178. package/icon/types.d.ts +4 -0
  179. package/icon/types.js +5 -0
  180. package/image/Image.d.ts +4 -0
  181. package/image/Image.js +70 -0
  182. package/image/Image.stories.tsx +129 -0
  183. package/image/types.d.ts +72 -0
  184. package/image/types.js +5 -0
  185. package/inset/Inset.d.ts +3 -0
  186. package/inset/Inset.js +43 -0
  187. package/inset/Inset.stories.tsx +230 -0
  188. package/inset/types.d.ts +37 -0
  189. package/inset/types.js +5 -0
  190. package/layout/ApplicationLayout.d.ts +20 -0
  191. package/layout/ApplicationLayout.js +134 -0
  192. package/layout/ApplicationLayout.stories.tsx +162 -0
  193. package/layout/Icons.d.ts +8 -0
  194. package/layout/Icons.js +58 -0
  195. package/layout/types.d.ts +41 -0
  196. package/layout/types.js +5 -0
  197. package/link/Link.d.ts +4 -0
  198. package/link/Link.js +115 -0
  199. package/link/Link.stories.tsx +253 -0
  200. package/link/Link.test.js +63 -0
  201. package/link/types.d.ts +54 -0
  202. package/link/types.js +5 -0
  203. package/main.d.ts +49 -0
  204. package/{dist/main.js → main.js} +161 -115
  205. package/nav-tabs/NavTabs.d.ts +7 -0
  206. package/nav-tabs/NavTabs.js +93 -0
  207. package/nav-tabs/NavTabs.stories.tsx +276 -0
  208. package/nav-tabs/NavTabs.test.js +76 -0
  209. package/nav-tabs/NavTabsContext.d.ts +3 -0
  210. package/nav-tabs/NavTabsContext.js +8 -0
  211. package/nav-tabs/Tab.d.ts +4 -0
  212. package/nav-tabs/Tab.js +118 -0
  213. package/nav-tabs/types.d.ts +52 -0
  214. package/nav-tabs/types.js +5 -0
  215. package/number-input/NumberInput.d.ts +4 -0
  216. package/number-input/NumberInput.js +86 -0
  217. package/number-input/NumberInput.stories.tsx +131 -0
  218. package/number-input/NumberInput.test.js +989 -0
  219. package/number-input/NumberInputContext.d.ts +3 -0
  220. package/number-input/NumberInputContext.js +8 -0
  221. package/number-input/types.d.ts +136 -0
  222. package/number-input/types.js +5 -0
  223. package/package.json +59 -49
  224. package/paginator/Icons.d.ts +5 -0
  225. package/paginator/Icons.js +40 -0
  226. package/paginator/Paginator.d.ts +4 -0
  227. package/paginator/Paginator.js +135 -0
  228. package/paginator/Paginator.stories.tsx +87 -0
  229. package/paginator/Paginator.test.js +335 -0
  230. package/paginator/types.d.ts +38 -0
  231. package/paginator/types.js +5 -0
  232. package/paragraph/Paragraph.d.ts +5 -0
  233. package/paragraph/Paragraph.js +22 -0
  234. package/paragraph/Paragraph.stories.tsx +27 -0
  235. package/password-input/Icons.d.ts +6 -0
  236. package/password-input/Icons.js +35 -0
  237. package/password-input/PasswordInput.d.ts +4 -0
  238. package/password-input/PasswordInput.js +97 -0
  239. package/password-input/PasswordInput.stories.tsx +99 -0
  240. package/password-input/PasswordInput.test.js +198 -0
  241. package/password-input/types.d.ts +111 -0
  242. package/password-input/types.js +5 -0
  243. package/progress-bar/ProgressBar.d.ts +4 -0
  244. package/progress-bar/ProgressBar.js +144 -0
  245. package/progress-bar/ProgressBar.stories.tsx +93 -0
  246. package/progress-bar/ProgressBar.test.js +93 -0
  247. package/progress-bar/types.d.ts +37 -0
  248. package/progress-bar/types.js +5 -0
  249. package/quick-nav/QuickNav.d.ts +4 -0
  250. package/quick-nav/QuickNav.js +94 -0
  251. package/quick-nav/QuickNav.stories.tsx +356 -0
  252. package/quick-nav/types.d.ts +21 -0
  253. package/quick-nav/types.js +5 -0
  254. package/radio-group/Radio.d.ts +4 -0
  255. package/radio-group/Radio.js +124 -0
  256. package/radio-group/RadioGroup.d.ts +4 -0
  257. package/radio-group/RadioGroup.js +235 -0
  258. package/radio-group/RadioGroup.stories.tsx +214 -0
  259. package/radio-group/RadioGroup.test.js +756 -0
  260. package/radio-group/types.d.ts +114 -0
  261. package/radio-group/types.js +5 -0
  262. package/resultset-table/Icons.d.ts +7 -0
  263. package/resultset-table/Icons.js +47 -0
  264. package/resultset-table/ResultsetTable.d.ts +7 -0
  265. package/resultset-table/ResultsetTable.js +170 -0
  266. package/resultset-table/ResultsetTable.stories.tsx +401 -0
  267. package/resultset-table/ResultsetTable.test.js +381 -0
  268. package/resultset-table/types.d.ts +100 -0
  269. package/resultset-table/types.js +5 -0
  270. package/select/Icons.d.ts +10 -0
  271. package/select/Icons.js +89 -0
  272. package/select/Listbox.d.ts +4 -0
  273. package/select/Listbox.js +143 -0
  274. package/select/Option.d.ts +4 -0
  275. package/select/Option.js +87 -0
  276. package/select/Select.d.ts +4 -0
  277. package/select/Select.js +590 -0
  278. package/select/Select.stories.tsx +971 -0
  279. package/select/Select.test.js +2370 -0
  280. package/select/types.d.ts +209 -0
  281. package/select/types.js +5 -0
  282. package/sidenav/Icons.d.ts +7 -0
  283. package/sidenav/Icons.js +47 -0
  284. package/sidenav/Sidenav.d.ts +10 -0
  285. package/sidenav/Sidenav.js +197 -0
  286. package/sidenav/Sidenav.stories.tsx +282 -0
  287. package/sidenav/Sidenav.test.js +37 -0
  288. package/sidenav/SidenavContext.d.ts +5 -0
  289. package/sidenav/SidenavContext.js +13 -0
  290. package/sidenav/types.d.ts +76 -0
  291. package/sidenav/types.js +5 -0
  292. package/slider/Slider.d.ts +4 -0
  293. package/slider/Slider.js +285 -0
  294. package/slider/Slider.test.js +254 -0
  295. package/slider/types.d.ts +86 -0
  296. package/slider/types.js +5 -0
  297. package/spinner/Spinner.d.ts +4 -0
  298. package/spinner/Spinner.js +206 -0
  299. package/spinner/Spinner.stories.tsx +129 -0
  300. package/spinner/Spinner.test.js +55 -0
  301. package/spinner/types.d.ts +32 -0
  302. package/spinner/types.js +5 -0
  303. package/status-light/StatusLight.d.ts +4 -0
  304. package/status-light/StatusLight.js +51 -0
  305. package/status-light/StatusLight.stories.tsx +74 -0
  306. package/status-light/StatusLight.test.js +25 -0
  307. package/status-light/types.d.ts +17 -0
  308. package/status-light/types.js +5 -0
  309. package/switch/Switch.d.ts +4 -0
  310. package/switch/Switch.js +214 -0
  311. package/switch/Switch.stories.tsx +137 -0
  312. package/switch/Switch.test.js +180 -0
  313. package/switch/types.d.ts +66 -0
  314. package/switch/types.js +5 -0
  315. package/table/DropdownTheme.js +62 -0
  316. package/table/Table.d.ts +8 -0
  317. package/table/Table.js +161 -0
  318. package/table/Table.stories.tsx +651 -0
  319. package/table/Table.test.js +113 -0
  320. package/table/types.d.ts +49 -0
  321. package/table/types.js +5 -0
  322. package/tabs/Tab.d.ts +4 -0
  323. package/tabs/Tab.js +116 -0
  324. package/tabs/Tabs.d.ts +4 -0
  325. package/tabs/Tabs.js +384 -0
  326. package/tabs/Tabs.stories.tsx +226 -0
  327. package/tabs/Tabs.test.js +294 -0
  328. package/tabs/types.d.ts +92 -0
  329. package/tabs/types.js +5 -0
  330. package/tag/Tag.d.ts +4 -0
  331. package/tag/Tag.js +151 -0
  332. package/tag/Tag.stories.tsx +155 -0
  333. package/tag/Tag.test.js +49 -0
  334. package/tag/types.d.ts +69 -0
  335. package/tag/types.js +5 -0
  336. package/text-input/Suggestion.d.ts +4 -0
  337. package/text-input/Suggestion.js +67 -0
  338. package/text-input/Suggestions.d.ts +4 -0
  339. package/text-input/Suggestions.js +86 -0
  340. package/text-input/TextInput.d.ts +4 -0
  341. package/text-input/TextInput.js +567 -0
  342. package/text-input/TextInput.stories.tsx +465 -0
  343. package/text-input/TextInput.test.js +1756 -0
  344. package/text-input/types.d.ts +205 -0
  345. package/text-input/types.js +5 -0
  346. package/textarea/Textarea.d.ts +4 -0
  347. package/textarea/Textarea.js +234 -0
  348. package/textarea/Textarea.stories.tsx +174 -0
  349. package/textarea/Textarea.test.js +406 -0
  350. package/textarea/types.d.ts +141 -0
  351. package/textarea/types.js +5 -0
  352. package/toggle-group/ToggleGroup.d.ts +4 -0
  353. package/toggle-group/ToggleGroup.js +201 -0
  354. package/toggle-group/ToggleGroup.stories.tsx +218 -0
  355. package/toggle-group/ToggleGroup.test.js +137 -0
  356. package/toggle-group/types.d.ts +114 -0
  357. package/toggle-group/types.js +5 -0
  358. package/typography/Typography.d.ts +4 -0
  359. package/typography/Typography.js +23 -0
  360. package/typography/Typography.stories.tsx +198 -0
  361. package/typography/types.d.ts +18 -0
  362. package/typography/types.js +5 -0
  363. package/useTheme.d.ts +1148 -0
  364. package/{dist/useTheme.js → useTheme.js} +4 -11
  365. package/useTranslatedLabels.d.ts +85 -0
  366. package/useTranslatedLabels.js +14 -0
  367. package/utils/BaseTypography.d.ts +21 -0
  368. package/utils/BaseTypography.js +94 -0
  369. package/utils/FocusLock.d.ts +13 -0
  370. package/utils/FocusLock.js +124 -0
  371. package/wizard/Wizard.d.ts +4 -0
  372. package/wizard/Wizard.js +250 -0
  373. package/wizard/Wizard.stories.tsx +253 -0
  374. package/wizard/Wizard.test.js +114 -0
  375. package/wizard/types.d.ts +64 -0
  376. package/wizard/types.js +5 -0
  377. package/babel.config.js +0 -8
  378. package/dist/BackgroundColorContext.js +0 -46
  379. package/dist/ThemeContext.js +0 -216
  380. package/dist/accordion/Accordion.js +0 -356
  381. package/dist/accordion/Accordion.stories.js +0 -207
  382. package/dist/accordion/readme.md +0 -96
  383. package/dist/accordion-group/AccordionGroup.js +0 -188
  384. package/dist/accordion-group/AccordionGroup.stories.js +0 -207
  385. package/dist/accordion-group/readme.md +0 -70
  386. package/dist/alert/Alert.js +0 -388
  387. package/dist/alert/Alert.stories.js +0 -158
  388. package/dist/alert/close.svg +0 -4
  389. package/dist/alert/error.svg +0 -4
  390. package/dist/alert/info.svg +0 -4
  391. package/dist/alert/readme.md +0 -43
  392. package/dist/alert/success.svg +0 -4
  393. package/dist/alert/warning.svg +0 -4
  394. package/dist/badge/Badge.js +0 -61
  395. package/dist/box/Box.js +0 -164
  396. package/dist/button/Button.js +0 -228
  397. package/dist/button/Button.stories.js +0 -224
  398. package/dist/button/readme.md +0 -93
  399. package/dist/card/Card.js +0 -247
  400. package/dist/checkbox/Checkbox.js +0 -291
  401. package/dist/checkbox/Checkbox.stories.js +0 -144
  402. package/dist/checkbox/readme.md +0 -116
  403. package/dist/chip/Chip.js +0 -277
  404. package/dist/common/OpenSans.css +0 -81
  405. package/dist/common/RequiredComponent.js +0 -40
  406. package/dist/common/fonts/OpenSans-Bold.ttf +0 -0
  407. package/dist/common/fonts/OpenSans-BoldItalic.ttf +0 -0
  408. package/dist/common/fonts/OpenSans-ExtraBold.ttf +0 -0
  409. package/dist/common/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  410. package/dist/common/fonts/OpenSans-Italic.ttf +0 -0
  411. package/dist/common/fonts/OpenSans-Light.ttf +0 -0
  412. package/dist/common/fonts/OpenSans-LightItalic.ttf +0 -0
  413. package/dist/common/fonts/OpenSans-Regular.ttf +0 -0
  414. package/dist/common/fonts/OpenSans-SemiBold.ttf +0 -0
  415. package/dist/common/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  416. package/dist/common/variables.js +0 -1164
  417. package/dist/date/Date.js +0 -391
  418. package/dist/date/Date.stories.js +0 -205
  419. package/dist/date/calendar.svg +0 -1
  420. package/dist/date/calendar_dark.svg +0 -1
  421. package/dist/date/readme.md +0 -73
  422. package/dist/dialog/Dialog.js +0 -236
  423. package/dist/dialog/Dialog.stories.js +0 -217
  424. package/dist/dialog/readme.md +0 -32
  425. package/dist/dropdown/Dropdown.js +0 -498
  426. package/dist/dropdown/Dropdown.stories.js +0 -249
  427. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  428. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  429. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  430. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  431. package/dist/dropdown/readme.md +0 -69
  432. package/dist/footer/Footer.js +0 -405
  433. package/dist/footer/Footer.stories.js +0 -94
  434. package/dist/footer/dxc_logo_wht.png +0 -0
  435. package/dist/footer/readme.md +0 -41
  436. package/dist/header/Header.js +0 -431
  437. package/dist/header/Header.stories.js +0 -176
  438. package/dist/header/close_icon.svg +0 -1
  439. package/dist/header/dxc_logo_black.png +0 -0
  440. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  441. package/dist/header/dxc_logo_white.png +0 -0
  442. package/dist/header/hamb_menu_black.svg +0 -1
  443. package/dist/header/hamb_menu_white.svg +0 -1
  444. package/dist/header/readme.md +0 -33
  445. package/dist/input-text/InputText.js +0 -669
  446. package/dist/input-text/InputText.stories.js +0 -209
  447. package/dist/input-text/error.svg +0 -1
  448. package/dist/input-text/readme.md +0 -91
  449. package/dist/layout/ApplicationLayout.js +0 -331
  450. package/dist/layout/facebook.svg +0 -45
  451. package/dist/layout/linkedin.svg +0 -50
  452. package/dist/layout/twitter.svg +0 -53
  453. package/dist/link/Link.js +0 -212
  454. package/dist/link/readme.md +0 -51
  455. package/dist/paginator/Paginator.js +0 -283
  456. package/dist/paginator/images/next.svg +0 -3
  457. package/dist/paginator/images/nextPage.svg +0 -3
  458. package/dist/paginator/images/previous.svg +0 -3
  459. package/dist/paginator/images/previousPage.svg +0 -3
  460. package/dist/paginator/readme.md +0 -50
  461. package/dist/progress-bar/ProgressBar.js +0 -206
  462. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  463. package/dist/progress-bar/readme.md +0 -63
  464. package/dist/radio/Radio.js +0 -209
  465. package/dist/radio/Radio.stories.js +0 -166
  466. package/dist/radio/readme.md +0 -70
  467. package/dist/resultsetTable/ResultsetTable.js +0 -375
  468. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  469. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  470. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  471. package/dist/select/Select.js +0 -525
  472. package/dist/select/Select.stories.js +0 -235
  473. package/dist/select/readme.md +0 -72
  474. package/dist/sidenav/Sidenav.js +0 -183
  475. package/dist/slider/Slider.js +0 -315
  476. package/dist/slider/Slider.stories.js +0 -241
  477. package/dist/slider/readme.md +0 -64
  478. package/dist/spinner/Spinner.js +0 -214
  479. package/dist/spinner/Spinner.stories.js +0 -183
  480. package/dist/spinner/readme.md +0 -65
  481. package/dist/switch/Switch.js +0 -222
  482. package/dist/switch/Switch.stories.js +0 -134
  483. package/dist/switch/readme.md +0 -133
  484. package/dist/table/Table.js +0 -122
  485. package/dist/tabs/Tabs.js +0 -347
  486. package/dist/tabs/Tabs.stories.js +0 -130
  487. package/dist/tabs/readme.md +0 -78
  488. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  489. package/dist/tabs-for-sections/readme.md +0 -78
  490. package/dist/tag/Tag.js +0 -280
  491. package/dist/textarea/Textarea.js +0 -260
  492. package/dist/toggle/Toggle.js +0 -220
  493. package/dist/toggle/Toggle.stories.js +0 -297
  494. package/dist/toggle/readme.md +0 -80
  495. package/dist/toggle-group/ToggleGroup.js +0 -241
  496. package/dist/toggle-group/readme.md +0 -82
  497. package/dist/upload/Upload.js +0 -205
  498. package/dist/upload/Upload.stories.js +0 -72
  499. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -135
  500. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  501. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  502. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -325
  503. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  504. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  505. package/dist/upload/file-upload/FileToUpload.js +0 -184
  506. package/dist/upload/file-upload/audio-icon.svg +0 -4
  507. package/dist/upload/file-upload/close.svg +0 -4
  508. package/dist/upload/file-upload/file-icon.svg +0 -4
  509. package/dist/upload/file-upload/video-icon.svg +0 -4
  510. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  511. package/dist/upload/readme.md +0 -37
  512. package/dist/upload/transaction/Transaction.js +0 -171
  513. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  514. package/dist/upload/transaction/audio-icon.svg +0 -4
  515. package/dist/upload/transaction/error-icon.svg +0 -4
  516. package/dist/upload/transaction/file-icon-err.svg +0 -4
  517. package/dist/upload/transaction/file-icon.svg +0 -4
  518. package/dist/upload/transaction/image-icon-err.svg +0 -4
  519. package/dist/upload/transaction/image-icon.svg +0 -4
  520. package/dist/upload/transaction/success-icon.svg +0 -4
  521. package/dist/upload/transaction/video-icon-err.svg +0 -4
  522. package/dist/upload/transaction/video-icon.svg +0 -4
  523. package/dist/upload/transactions/Transactions.js +0 -138
  524. package/dist/wizard/Wizard.js +0 -383
  525. package/dist/wizard/invalid_icon.svg +0 -6
  526. package/dist/wizard/valid_icon.svg +0 -6
  527. package/dist/wizard/validation-wrong.svg +0 -6
  528. package/test/Accordion.test.js +0 -33
  529. package/test/AccordionGroup.test.js +0 -125
  530. package/test/Alert.test.js +0 -53
  531. package/test/Box.test.js +0 -10
  532. package/test/Button.test.js +0 -18
  533. package/test/Card.test.js +0 -30
  534. package/test/Checkbox.test.js +0 -45
  535. package/test/Chip.test.js +0 -25
  536. package/test/Date.test.js +0 -393
  537. package/test/Dialog.test.js +0 -23
  538. package/test/Dropdown.test.js +0 -130
  539. package/test/Footer.test.js +0 -99
  540. package/test/Header.test.js +0 -39
  541. package/test/Heading.test.js +0 -35
  542. package/test/InputText.test.js +0 -240
  543. package/test/Link.test.js +0 -42
  544. package/test/Paginator.test.js +0 -177
  545. package/test/ProgressBar.test.js +0 -35
  546. package/test/Radio.test.js +0 -37
  547. package/test/ResultsetTable.test.js +0 -330
  548. package/test/Select.test.js +0 -192
  549. package/test/Sidenav.test.js +0 -45
  550. package/test/Slider.test.js +0 -82
  551. package/test/Spinner.test.js +0 -27
  552. package/test/Switch.test.js +0 -45
  553. package/test/Table.test.js +0 -36
  554. package/test/Tabs.test.js +0 -109
  555. package/test/TabsForSections.test.js +0 -34
  556. package/test/Tag.test.js +0 -32
  557. package/test/TextArea.test.js +0 -52
  558. package/test/ToggleGroup.test.js +0 -81
  559. package/test/Upload.test.js +0 -60
  560. package/test/Wizard.test.js +0 -130
  561. package/test/mocks/pngMock.js +0 -1
  562. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,214 @@
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 _uuid = require("uuid");
15
+ var _variables = require("../common/variables");
16
+ var _utils = require("../common/utils");
17
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
18
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
19
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
20
+ 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); }
21
+ 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 && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
22
+ var DxcSwitch = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
23
+ var defaultChecked = _ref.defaultChecked,
24
+ checked = _ref.checked,
25
+ value = _ref.value,
26
+ _ref$label = _ref.label,
27
+ label = _ref$label === void 0 ? "" : _ref$label,
28
+ _ref$labelPosition = _ref.labelPosition,
29
+ labelPosition = _ref$labelPosition === void 0 ? "before" : _ref$labelPosition,
30
+ _ref$name = _ref.name,
31
+ name = _ref$name === void 0 ? "" : _ref$name,
32
+ _ref$disabled = _ref.disabled,
33
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
34
+ _ref$optional = _ref.optional,
35
+ optional = _ref$optional === void 0 ? false : _ref$optional,
36
+ onChange = _ref.onChange,
37
+ margin = _ref.margin,
38
+ _ref$size = _ref.size,
39
+ size = _ref$size === void 0 ? "fitContent" : _ref$size,
40
+ _ref$tabIndex = _ref.tabIndex,
41
+ tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
42
+ var _useState = (0, _react.useState)("switch-".concat((0, _uuid.v4)())),
43
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
44
+ switchId = _useState2[0];
45
+ var labelId = "label-".concat(switchId);
46
+ var _useState3 = (0, _react.useState)(defaultChecked !== null && defaultChecked !== void 0 ? defaultChecked : false),
47
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
48
+ innerChecked = _useState4[0],
49
+ setInnerChecked = _useState4[1];
50
+ var colorsTheme = (0, _useTheme["default"])();
51
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
52
+ var refTrack = (0, _react.useRef)(null);
53
+ var handleOnKeyDown = function handleOnKeyDown(event) {
54
+ switch (event.key) {
55
+ case "Enter":
56
+ case " ":
57
+ // Space
58
+ event.preventDefault();
59
+ refTrack.current.focus();
60
+ var isChecked = !(checked !== null && checked !== void 0 ? checked : innerChecked);
61
+ setInnerChecked(isChecked);
62
+ onChange === null || onChange === void 0 ? void 0 : onChange(isChecked);
63
+ break;
64
+ }
65
+ };
66
+ var handlerSwitchChange = function handlerSwitchChange(event) {
67
+ checked !== null && checked !== void 0 ? checked : setInnerChecked(function (innerChecked) {
68
+ return !innerChecked;
69
+ });
70
+ onChange === null || onChange === void 0 ? void 0 : onChange(checked ? !checked : !innerChecked);
71
+ };
72
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
73
+ theme: colorsTheme["switch"]
74
+ }, /*#__PURE__*/_react["default"].createElement(SwitchContainer, {
75
+ margin: margin,
76
+ size: size,
77
+ onKeyDown: handleOnKeyDown,
78
+ disabled: disabled,
79
+ onClick: !disabled ? handlerSwitchChange : undefined,
80
+ ref: ref
81
+ }, labelPosition === "before" && label && /*#__PURE__*/_react["default"].createElement(LabelContainer, {
82
+ id: labelId,
83
+ labelPosition: labelPosition,
84
+ disabled: disabled,
85
+ label: label
86
+ }, label, " ", optional && /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, translatedLabels.formFields.optionalLabel)), /*#__PURE__*/_react["default"].createElement(ValueInput, {
87
+ type: "checkbox",
88
+ name: name,
89
+ "aria-hidden": true,
90
+ value: value,
91
+ disabled: disabled,
92
+ checked: checked !== null && checked !== void 0 ? checked : innerChecked,
93
+ readOnly: true
94
+ }), /*#__PURE__*/_react["default"].createElement(SwitchBase, null, /*#__PURE__*/_react["default"].createElement(SwitchTrack, {
95
+ role: "switch",
96
+ "aria-checked": checked !== null && checked !== void 0 ? checked : innerChecked,
97
+ "aria-disabled": disabled,
98
+ disabled: disabled,
99
+ "aria-labelledby": labelId,
100
+ tabIndex: !disabled ? tabIndex : -1,
101
+ ref: refTrack
102
+ })), labelPosition === "after" && label && /*#__PURE__*/_react["default"].createElement(LabelContainer, {
103
+ id: labelId,
104
+ labelPosition: labelPosition,
105
+ disabled: disabled,
106
+ label: label
107
+ }, optional && /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, translatedLabels.formFields.optionalLabel), " ", label)));
108
+ });
109
+ var sizes = {
110
+ small: "60px",
111
+ medium: "240px",
112
+ large: "480px",
113
+ fillParent: "100%",
114
+ fitContent: "fit-content"
115
+ };
116
+ var calculateWidth = function calculateWidth(margin, size) {
117
+ return size === "fillParent" ? "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")") : sizes[size];
118
+ };
119
+ var getDisabledColor = function getDisabledColor(theme, element, subElement) {
120
+ switch (element) {
121
+ case "track":
122
+ switch (subElement) {
123
+ case "check":
124
+ return theme.disabledCheckedTrackBackgroundColor;
125
+ case "uncheck":
126
+ return theme.disabledUncheckedTrackBackgroundColor;
127
+ }
128
+ case "thumb":
129
+ switch (subElement) {
130
+ case "check":
131
+ return theme.disabledCheckedThumbBackgroundColor;
132
+ case "uncheck":
133
+ return theme.disabledUncheckedThumbBackgroundColor;
134
+ }
135
+ case "label":
136
+ return theme.disabledLabelFontColor;
137
+ }
138
+ };
139
+ var getNotDisabledColor = function getNotDisabledColor(theme, element, subElement) {
140
+ switch (element) {
141
+ case "track":
142
+ switch (subElement) {
143
+ case "check":
144
+ return theme.checkedTrackBackgroundColor;
145
+ case "uncheck":
146
+ return theme.uncheckedTrackBackgroundColor;
147
+ }
148
+ case "thumb":
149
+ switch (subElement) {
150
+ case "check":
151
+ return theme.checkedThumbBackgroundColor;
152
+ case "uncheck":
153
+ return theme.uncheckedThumbBackgroundColor;
154
+ }
155
+ case "label":
156
+ return theme.labelFontColor;
157
+ }
158
+ };
159
+ 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) {
160
+ return calculateWidth(props.margin, props.size);
161
+ }, function (props) {
162
+ return props.disabled === true ? "not-allowed" : "pointer";
163
+ }, function (props) {
164
+ return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
165
+ }, function (props) {
166
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
167
+ }, function (props) {
168
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
169
+ }, function (props) {
170
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
171
+ }, function (props) {
172
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
173
+ });
174
+ 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) {
175
+ return props.disabled ? getDisabledColor(props.theme, "label") : getNotDisabledColor(props.theme, "label");
176
+ }, function (props) {
177
+ return props.theme.labelFontFamily;
178
+ }, function (props) {
179
+ return props.theme.labelFontSize;
180
+ }, function (props) {
181
+ return props.disabled ? props.theme.disabledLabelFontStyle : props.theme.labelFontStyle;
182
+ }, function (props) {
183
+ return props.theme.labelFontWeight;
184
+ }, function (props) {
185
+ return !props.label ? "margin: 0px;" : props.labelPosition === "after" ? "margin-left: ".concat(props.theme.spaceBetweenLabelSwitch, ";") : "margin-right: ".concat(props.theme.spaceBetweenLabelSwitch, ";");
186
+ }, function (props) {
187
+ return props.labelPosition === "before" && "order: -1";
188
+ });
189
+ 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"])));
190
+ var ValueInput = _styledComponents["default"].input(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: none;\n"])));
191
+ 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) {
192
+ return props.theme.trackWidth;
193
+ }, function (props) {
194
+ return props.theme.trackHeight;
195
+ }, function (props) {
196
+ return props.disabled ? "not-allowed" : "pointer";
197
+ }, function (props) {
198
+ return "".concat(props.theme.thumbFocusColor, " solid 2px");
199
+ }, function (props) {
200
+ return props.theme.thumbWidth;
201
+ }, function (props) {
202
+ return props.theme.thumbHeight;
203
+ }, function (props) {
204
+ return props.disabled ? getDisabledColor(props.theme, "thumb", "uncheck") : getNotDisabledColor(props.theme, "thumb", "uncheck");
205
+ }, function (props) {
206
+ return props.disabled ? getDisabledColor(props.theme, "track", "uncheck") : getNotDisabledColor(props.theme, "track", "uncheck");
207
+ }, function (props) {
208
+ return props.disabled ? getDisabledColor(props.theme, "track", "check") : getNotDisabledColor(props.theme, "track", "check");
209
+ }, function (props) {
210
+ return props.theme.thumbShift;
211
+ }, function (props) {
212
+ return props.disabled ? getDisabledColor(props.theme, "thumb", "check") : getNotDisabledColor(props.theme, "thumb", "check");
213
+ });
214
+ var _default = exports["default"] = DxcSwitch;
@@ -0,0 +1,137 @@
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
+
7
+ export default {
8
+ title: "Switch",
9
+ component: DxcSwitch,
10
+ };
11
+
12
+ const opinionatedTheme = {
13
+ switch: {
14
+ checkedBaseColor: "#5f249f",
15
+ fontColor: "#000000",
16
+ },
17
+ };
18
+
19
+ export const Chromatic = () => (
20
+ <>
21
+ <ExampleContainer>
22
+ <Title title="With label after" theme="light" level={4} />
23
+ <DxcSwitch label="Switch" labelPosition="after" />
24
+ </ExampleContainer>
25
+ <ExampleContainer>
26
+ <Title title="Without label" theme="light" level={4} />
27
+ <DxcSwitch />
28
+ </ExampleContainer>
29
+ <ExampleContainer pseudoState="pseudo-focus-visible">
30
+ <Title title="Focused" theme="light" level={4} />
31
+ <DxcSwitch label="Switch" labelPosition="after" />
32
+ </ExampleContainer>
33
+ <ExampleContainer>
34
+ <Title title="Checked" theme="light" level={4} />
35
+ <DxcSwitch label="Switch" defaultChecked />
36
+ </ExampleContainer>
37
+ <ExampleContainer>
38
+ <Title title="Optional" theme="light" level={4} />
39
+ <DxcSwitch label="Switch" optional />
40
+ </ExampleContainer>
41
+ <ExampleContainer>
42
+ <Title title="Disabled" theme="light" level={4} />
43
+ <DxcSwitch label="Switch" disabled />
44
+ </ExampleContainer>
45
+ <ExampleContainer>
46
+ <Title title="Disabled optional" theme="light" level={4} />
47
+ <DxcSwitch label="Switch" disabled optional labelPosition="after" />
48
+ </ExampleContainer>
49
+ <ExampleContainer>
50
+ <Title title="Disabled checked" theme="light" level={4} />
51
+ <DxcSwitch label="Switch" disabled defaultChecked labelPosition="after" />
52
+ </ExampleContainer>
53
+ <Title title="Margins" theme="light" level={2} />
54
+ <ExampleContainer>
55
+ <Title title="Xxsmall margin" theme="light" level={4} />
56
+ <DxcSwitch label="Xxsmall" margin="xxsmall" />
57
+ </ExampleContainer>
58
+ <ExampleContainer>
59
+ <Title title="Xsmall margin" theme="light" level={4} />
60
+ <DxcSwitch label="Xsmall" margin="xsmall" />
61
+ </ExampleContainer>
62
+ <ExampleContainer>
63
+ <Title title="Small margin" theme="light" level={4} />
64
+ <DxcSwitch label="Small" margin="small" />
65
+ </ExampleContainer>
66
+ <ExampleContainer>
67
+ <Title title="Medium margin" theme="light" level={4} />
68
+ <DxcSwitch label="Medium" margin="medium" />
69
+ </ExampleContainer>
70
+ <ExampleContainer>
71
+ <Title title="Large margin" theme="light" level={4} />
72
+ <DxcSwitch label="Large" margin="large" />
73
+ </ExampleContainer>
74
+ <ExampleContainer>
75
+ <Title title="Xlarge margin" theme="light" level={4} />
76
+ <DxcSwitch label="Xlarge" margin="xlarge" />
77
+ </ExampleContainer>
78
+ <ExampleContainer>
79
+ <Title title="Xxlarge margin" theme="light" level={4} />
80
+ <DxcSwitch label="Xxlarge" margin="xxlarge" />
81
+ </ExampleContainer>
82
+ <Title title="Sizes" theme="light" level={2} />
83
+ <ExampleContainer>
84
+ <Title title="Small size" theme="light" level={4} />
85
+ <DxcSwitch label="Small" size="small" />
86
+ </ExampleContainer>
87
+ <ExampleContainer>
88
+ <Title title="Medium size (with large label)" theme="light" level={4} />
89
+ <DxcSwitch label="Very very very large label or even huge" size="medium" />
90
+ </ExampleContainer>
91
+ <ExampleContainer>
92
+ <Title title="Medium size (with long label)" theme="light" level={4} />
93
+ <DxcSwitch
94
+ label="Large texttttttttttttttttttttttttttttttttttttttttttttttttttttttttttttt"
95
+ labelPosition="after"
96
+ size="medium"
97
+ />
98
+ </ExampleContainer>
99
+ <ExampleContainer>
100
+ <Title title="Large size" theme="light" level={4} />
101
+ <DxcSwitch label="Large" size="large" />
102
+ </ExampleContainer>
103
+ <ExampleContainer>
104
+ <Title title="FillParent size" theme="light" level={4} />
105
+ <DxcSwitch label="FillParent" size="fillParent" />
106
+ </ExampleContainer>
107
+ <ExampleContainer>
108
+ <Title title="FitContent size" theme="light" level={4} />
109
+ <DxcSwitch label="FitContent" size="fitContent" />
110
+ </ExampleContainer>
111
+ <Title title="Opinionated theme" theme="light" level={2} />
112
+ <ExampleContainer>
113
+ <Title title="Checked" theme="light" level={4} />
114
+ <HalstackProvider theme={opinionatedTheme}>
115
+ <DxcSwitch label="Switch" defaultChecked />
116
+ </HalstackProvider>
117
+ </ExampleContainer>
118
+ <ExampleContainer>
119
+ <Title title="Default" theme="light" level={4} />
120
+ <HalstackProvider theme={opinionatedTheme}>
121
+ <DxcSwitch label="Switch" />
122
+ </HalstackProvider>
123
+ </ExampleContainer>
124
+ <ExampleContainer>
125
+ <Title title="Disabled" theme="light" level={4} />
126
+ <HalstackProvider theme={opinionatedTheme}>
127
+ <DxcSwitch label="Switch" disabled />
128
+ </HalstackProvider>
129
+ </ExampleContainer>
130
+ <ExampleContainer>
131
+ <Title title="Disabled checked" theme="light" level={4} />
132
+ <HalstackProvider theme={opinionatedTheme}>
133
+ <DxcSwitch label="Switch" disabled defaultChecked />
134
+ </HalstackProvider>
135
+ </ExampleContainer>
136
+ </>
137
+ );
@@ -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.tsx"));
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
+ });
@@ -0,0 +1,66 @@
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 switch, only when it is uncontrolled.
11
+ */
12
+ defaultChecked?: boolean;
13
+ /**
14
+ * If true, the component is checked. If undefined, the component will be uncontrolled
15
+ * and the checked attribute 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. When inside a form,
20
+ * this value will be only submitted if the switch is checked.
21
+ */
22
+ value?: string;
23
+ /**
24
+ * Text to be placed next to the switch.
25
+ */
26
+ label?: string;
27
+ /**
28
+ * Whether the label should appear after or before the switch.
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
+ * This function will be called when the user changes the state of the switch.
41
+ * The new value of the checked attribute will be passed as a parameter.
42
+ */
43
+ onChange?: (checked: boolean) => void;
44
+ /**
45
+ * If true, the component will display '(Optional)' next to the label.
46
+ */
47
+ optional?: boolean;
48
+ /**
49
+ * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
50
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
51
+ */
52
+ margin?: Space | Margin;
53
+ /**
54
+ * Size of the component.
55
+ */
56
+ size?: "small" | "medium" | "large" | "fillParent" | "fitContent";
57
+ /**
58
+ * Value of the tabindex.
59
+ */
60
+ tabIndex?: number;
61
+ };
62
+ /**
63
+ * Reference to the component.
64
+ */
65
+ export type RefType = HTMLDivElement;
66
+ export default Props;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -0,0 +1,62 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports["default"] = void 0;
7
+ var _variables = require("../common/variables");
8
+ var _default = exports["default"] = {
9
+ dropdown: {
10
+ // ActionIcon size tokens
11
+ buttonIconSize: "16px",
12
+ buttonPaddingTop: "4px",
13
+ buttonPaddingBottom: "4px",
14
+ buttonPaddingLeft: "4px",
15
+ buttonPaddingRight: "4px",
16
+ buttonHeight: "24px",
17
+ buttonBorderRadius: "2px",
18
+ buttonBorderStyle: "none",
19
+ buttonBorderThickness: "0px",
20
+ buttonBorderColor: "transparent",
21
+ optionFontSize: "14px",
22
+ optionPaddingTop: "0px",
23
+ optionPaddingBottom: "0px",
24
+ optionPaddingLeft: "16px",
25
+ optionPaddingRight: "16px",
26
+ // Dropdown tokens
27
+ buttonBackgroundColor: _variables.componentTokens.table.actionBackgroundColor,
28
+ hoverButtonBackgroundColor: _variables.componentTokens.table.hoverActionBackgroundColor,
29
+ activeButtonBackgroundColor: _variables.componentTokens.table.activeActionBackgroundColor,
30
+ buttonFontFamily: _variables.componentTokens.dropdown.buttonFontFamily,
31
+ buttonFontSize: _variables.componentTokens.dropdown.buttonFontSize,
32
+ buttonFontStyle: _variables.componentTokens.dropdown.buttonFontStyle,
33
+ buttonFontWeight: _variables.componentTokens.dropdown.buttonFontWeight,
34
+ buttonFontColor: _variables.componentTokens.dropdown.buttonFontColor,
35
+ buttonIconSpacing: _variables.componentTokens.dropdown.buttonIconSpacing,
36
+ buttonIconColor: _variables.componentTokens.table.actionIconColor,
37
+ disabledColor: _variables.componentTokens.table.disabledActionIconColor,
38
+ disabledButtonBorderColor: _variables.componentTokens.dropdown.disabledButtonBorderColor,
39
+ disabledButtonBackgroundColor: _variables.componentTokens.table.disabledActionBackgroundColor,
40
+ disabledBorderColor: _variables.componentTokens.dropdown.disabledBorderColor,
41
+ optionBackgroundColor: _variables.componentTokens.dropdown.optionBackgroundColor,
42
+ hoverOptionBackgroundColor: _variables.componentTokens.dropdown.hoverOptionBackgroundColor,
43
+ activeOptionBackgroundColor: _variables.componentTokens.dropdown.activeOptionBackgroundColor,
44
+ optionFontFamily: _variables.componentTokens.dropdown.optionFontFamily,
45
+ optionFontStyle: _variables.componentTokens.dropdown.optionFontStyle,
46
+ optionFontWeight: _variables.componentTokens.dropdown.optionFontWeight,
47
+ optionFontColor: _variables.componentTokens.dropdown.optionFontColor,
48
+ optionIconSize: _variables.componentTokens.dropdown.optionIconSize,
49
+ optionIconSpacing: _variables.componentTokens.dropdown.optionIconSpacing,
50
+ optionIconColor: _variables.componentTokens.dropdown.optionIconColor,
51
+ caretIconSize: _variables.componentTokens.dropdown.caretIconSize,
52
+ caretIconColor: _variables.componentTokens.dropdown.caretIconColor,
53
+ caretIconSpacing: _variables.componentTokens.dropdown.caretIconSpacing,
54
+ borderRadius: _variables.componentTokens.dropdown.borderRadius,
55
+ borderStyle: _variables.componentTokens.dropdown.borderStyle,
56
+ borderThickness: _variables.componentTokens.dropdown.borderThickness,
57
+ borderColor: _variables.componentTokens.dropdown.borderColor,
58
+ scrollBarThumbColor: _variables.componentTokens.dropdown.scrollBarThumbColor,
59
+ scrollBarTrackColor: _variables.componentTokens.dropdown.scrollBarTrackColor,
60
+ focusColor: _variables.componentTokens.table.focusActionBorderColor
61
+ }
62
+ };