@dxc-technology/halstack-react 0.0.0-f4bae62 → 0.0.0-f53e801

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 (443) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +47 -0
  3. package/HalstackContext.d.ts +12 -0
  4. package/HalstackContext.js +295 -0
  5. package/accordion/Accordion.d.ts +4 -0
  6. package/accordion/Accordion.js +226 -0
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +72 -0
  9. package/accordion/types.d.ts +68 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +169 -0
  13. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  14. package/accordion-group/AccordionGroup.test.js +151 -0
  15. package/accordion-group/types.d.ts +72 -0
  16. package/accordion-group/types.js +5 -0
  17. package/alert/Alert.d.ts +4 -0
  18. package/{dist/alert → alert}/Alert.js +43 -153
  19. package/alert/Alert.stories.tsx +170 -0
  20. package/alert/Alert.test.js +92 -0
  21. package/alert/types.d.ts +49 -0
  22. package/alert/types.js +5 -0
  23. package/badge/Badge.d.ts +4 -0
  24. package/badge/Badge.js +61 -0
  25. package/badge/types.d.ts +5 -0
  26. package/badge/types.js +5 -0
  27. package/bleed/Bleed.d.ts +3 -0
  28. package/bleed/Bleed.js +51 -0
  29. package/bleed/Bleed.stories.tsx +341 -0
  30. package/bleed/types.d.ts +37 -0
  31. package/bleed/types.js +5 -0
  32. package/box/Box.d.ts +4 -0
  33. package/box/Box.js +116 -0
  34. package/box/Box.stories.tsx +132 -0
  35. package/box/Box.test.js +18 -0
  36. package/box/types.d.ts +43 -0
  37. package/box/types.js +5 -0
  38. package/bulleted-list/BulletedList.d.ts +7 -0
  39. package/bulleted-list/BulletedList.js +123 -0
  40. package/bulleted-list/BulletedList.stories.tsx +200 -0
  41. package/bulleted-list/types.d.ts +11 -0
  42. package/bulleted-list/types.js +5 -0
  43. package/button/Button.d.ts +4 -0
  44. package/button/Button.js +156 -0
  45. package/button/Button.stories.tsx +283 -0
  46. package/button/Button.test.js +35 -0
  47. package/button/types.d.ts +53 -0
  48. package/button/types.js +5 -0
  49. package/card/Card.d.ts +4 -0
  50. package/card/Card.js +161 -0
  51. package/card/Card.stories.tsx +201 -0
  52. package/card/Card.test.js +50 -0
  53. package/card/ice-cream.jpg +0 -0
  54. package/card/types.d.ts +67 -0
  55. package/card/types.js +5 -0
  56. package/checkbox/Checkbox.d.ts +4 -0
  57. package/{dist/checkbox → checkbox}/Checkbox.js +55 -98
  58. package/checkbox/Checkbox.stories.tsx +188 -0
  59. package/checkbox/Checkbox.test.js +78 -0
  60. package/checkbox/types.d.ts +64 -0
  61. package/checkbox/types.js +5 -0
  62. package/chip/Chip.d.ts +4 -0
  63. package/chip/Chip.js +161 -0
  64. package/chip/Chip.stories.tsx +119 -0
  65. package/chip/Chip.test.js +56 -0
  66. package/chip/types.d.ts +45 -0
  67. package/chip/types.js +5 -0
  68. package/{dist/common → common}/OpenSans.css +0 -0
  69. package/{dist/common → common}/RequiredComponent.js +3 -11
  70. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  71. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  72. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  73. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  74. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  75. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  76. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  77. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  78. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  79. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  80. package/{dist/common → common}/utils.js +0 -0
  81. package/{dist/common → common}/variables.js +370 -435
  82. package/date-input/DateInput.d.ts +4 -0
  83. package/{dist/date-input → date-input}/DateInput.js +83 -111
  84. package/date-input/DateInput.stories.tsx +138 -0
  85. package/date-input/DateInput.test.js +479 -0
  86. package/date-input/types.d.ts +107 -0
  87. package/date-input/types.js +5 -0
  88. package/dialog/Dialog.d.ts +4 -0
  89. package/dialog/Dialog.js +162 -0
  90. package/dialog/Dialog.stories.tsx +211 -0
  91. package/dialog/Dialog.test.js +70 -0
  92. package/dialog/types.d.ts +43 -0
  93. package/dialog/types.js +5 -0
  94. package/dropdown/Dropdown.d.ts +4 -0
  95. package/dropdown/Dropdown.js +387 -0
  96. package/dropdown/Dropdown.stories.tsx +312 -0
  97. package/dropdown/Dropdown.test.js +591 -0
  98. package/dropdown/DropdownMenu.d.ts +4 -0
  99. package/dropdown/DropdownMenu.js +80 -0
  100. package/dropdown/DropdownMenuItem.d.ts +4 -0
  101. package/dropdown/DropdownMenuItem.js +92 -0
  102. package/dropdown/types.d.ts +100 -0
  103. package/dropdown/types.js +5 -0
  104. package/file-input/FileInput.d.ts +4 -0
  105. package/file-input/FileInput.js +593 -0
  106. package/file-input/FileInput.stories.tsx +507 -0
  107. package/file-input/FileInput.test.js +457 -0
  108. package/file-input/FileItem.d.ts +14 -0
  109. package/file-input/FileItem.js +186 -0
  110. package/file-input/types.d.ts +112 -0
  111. package/file-input/types.js +5 -0
  112. package/flex/Flex.d.ts +4 -0
  113. package/flex/Flex.js +57 -0
  114. package/flex/Flex.stories.tsx +103 -0
  115. package/flex/types.d.ts +21 -0
  116. package/flex/types.js +5 -0
  117. package/footer/Footer.d.ts +4 -0
  118. package/footer/Footer.js +185 -0
  119. package/footer/Footer.stories.tsx +130 -0
  120. package/footer/Footer.test.js +109 -0
  121. package/footer/Icons.d.ts +2 -0
  122. package/{dist/footer → footer}/Icons.js +16 -16
  123. package/footer/types.d.ts +65 -0
  124. package/footer/types.js +5 -0
  125. package/header/Header.d.ts +7 -0
  126. package/header/Header.js +305 -0
  127. package/header/Header.stories.tsx +172 -0
  128. package/header/Header.test.js +79 -0
  129. package/header/Icons.d.ts +2 -0
  130. package/{dist/header → header}/Icons.js +9 -34
  131. package/header/types.d.ts +47 -0
  132. package/header/types.js +5 -0
  133. package/heading/Heading.d.ts +4 -0
  134. package/{dist/heading → heading}/Heading.js +31 -90
  135. package/heading/Heading.stories.tsx +54 -0
  136. package/heading/Heading.test.js +186 -0
  137. package/heading/types.d.ts +33 -0
  138. package/heading/types.js +5 -0
  139. package/inset/Inset.d.ts +3 -0
  140. package/inset/Inset.js +51 -0
  141. package/inset/Inset.stories.tsx +229 -0
  142. package/inset/types.d.ts +37 -0
  143. package/inset/types.js +5 -0
  144. package/layout/ApplicationLayout.d.ts +20 -0
  145. package/layout/ApplicationLayout.js +171 -0
  146. package/layout/ApplicationLayout.stories.tsx +161 -0
  147. package/layout/Icons.d.ts +5 -0
  148. package/{dist/layout → layout}/Icons.js +19 -8
  149. package/layout/SidenavContext.d.ts +5 -0
  150. package/layout/SidenavContext.js +19 -0
  151. package/layout/types.d.ts +42 -0
  152. package/layout/types.js +5 -0
  153. package/link/Link.d.ts +4 -0
  154. package/link/Link.js +136 -0
  155. package/link/Link.stories.tsx +193 -0
  156. package/link/Link.test.js +83 -0
  157. package/link/types.d.ts +54 -0
  158. package/link/types.js +5 -0
  159. package/main.d.ts +44 -0
  160. package/{dist/main.js → main.js} +111 -109
  161. package/number-input/NumberInput.d.ts +4 -0
  162. package/number-input/NumberInput.js +76 -0
  163. package/number-input/NumberInput.stories.tsx +115 -0
  164. package/number-input/NumberInput.test.js +506 -0
  165. package/number-input/NumberInputContext.d.ts +4 -0
  166. package/{dist/number-input → number-input}/NumberInputContext.js +5 -2
  167. package/number-input/numberInputContextTypes.d.ts +19 -0
  168. package/number-input/numberInputContextTypes.js +5 -0
  169. package/number-input/types.d.ts +124 -0
  170. package/number-input/types.js +5 -0
  171. package/package.json +40 -29
  172. package/{dist/paginator → paginator}/Icons.js +9 -9
  173. package/paginator/Paginator.d.ts +4 -0
  174. package/paginator/Paginator.js +171 -0
  175. package/paginator/Paginator.stories.tsx +63 -0
  176. package/paginator/Paginator.test.js +308 -0
  177. package/paginator/types.d.ts +38 -0
  178. package/paginator/types.js +5 -0
  179. package/paragraph/Paragraph.d.ts +6 -0
  180. package/paragraph/Paragraph.js +38 -0
  181. package/paragraph/Paragraph.stories.tsx +44 -0
  182. package/password-input/PasswordInput.d.ts +4 -0
  183. package/{dist/password-input → password-input}/PasswordInput.js +45 -77
  184. package/password-input/PasswordInput.stories.tsx +131 -0
  185. package/password-input/PasswordInput.test.js +180 -0
  186. package/password-input/types.d.ts +110 -0
  187. package/password-input/types.js +5 -0
  188. package/progress-bar/ProgressBar.d.ts +4 -0
  189. package/progress-bar/ProgressBar.js +176 -0
  190. package/progress-bar/ProgressBar.stories.jsx +60 -0
  191. package/progress-bar/ProgressBar.test.js +110 -0
  192. package/progress-bar/types.d.ts +36 -0
  193. package/progress-bar/types.js +5 -0
  194. package/quick-nav/QuickNav.d.ts +4 -0
  195. package/quick-nav/QuickNav.js +118 -0
  196. package/quick-nav/QuickNav.stories.tsx +264 -0
  197. package/quick-nav/types.d.ts +21 -0
  198. package/quick-nav/types.js +5 -0
  199. package/radio-group/Radio.d.ts +4 -0
  200. package/radio-group/Radio.js +141 -0
  201. package/radio-group/RadioGroup.d.ts +4 -0
  202. package/radio-group/RadioGroup.js +281 -0
  203. package/radio-group/RadioGroup.stories.tsx +100 -0
  204. package/radio-group/RadioGroup.test.js +695 -0
  205. package/radio-group/types.d.ts +114 -0
  206. package/radio-group/types.js +5 -0
  207. package/resultsetTable/ResultsetTable.d.ts +4 -0
  208. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +43 -147
  209. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  210. package/resultsetTable/ResultsetTable.test.js +348 -0
  211. package/resultsetTable/types.d.ts +67 -0
  212. package/resultsetTable/types.js +5 -0
  213. package/select/Icons.d.ts +10 -0
  214. package/select/Icons.js +93 -0
  215. package/select/Listbox.d.ts +4 -0
  216. package/select/Listbox.js +199 -0
  217. package/select/Option.d.ts +4 -0
  218. package/select/Option.js +110 -0
  219. package/select/Select.d.ts +4 -0
  220. package/select/Select.js +643 -0
  221. package/select/Select.stories.tsx +627 -0
  222. package/select/Select.test.js +2175 -0
  223. package/select/types.d.ts +210 -0
  224. package/select/types.js +5 -0
  225. package/sidenav/Sidenav.d.ts +10 -0
  226. package/sidenav/Sidenav.js +268 -0
  227. package/sidenav/Sidenav.stories.tsx +180 -0
  228. package/sidenav/Sidenav.test.js +44 -0
  229. package/sidenav/types.d.ts +73 -0
  230. package/sidenav/types.js +5 -0
  231. package/slider/Slider.d.ts +4 -0
  232. package/{dist/slider → slider}/Slider.js +77 -163
  233. package/slider/Slider.stories.tsx +177 -0
  234. package/slider/Slider.test.js +187 -0
  235. package/slider/types.d.ts +82 -0
  236. package/slider/types.js +5 -0
  237. package/spinner/Spinner.d.ts +4 -0
  238. package/spinner/Spinner.js +250 -0
  239. package/spinner/Spinner.stories.jsx +103 -0
  240. package/spinner/Spinner.test.js +64 -0
  241. package/spinner/types.d.ts +32 -0
  242. package/spinner/types.js +5 -0
  243. package/switch/Switch.d.ts +4 -0
  244. package/switch/Switch.js +251 -0
  245. package/switch/Switch.stories.tsx +138 -0
  246. package/switch/Switch.test.js +212 -0
  247. package/switch/types.d.ts +61 -0
  248. package/switch/types.js +5 -0
  249. package/table/Table.d.ts +4 -0
  250. package/{dist/table → table}/Table.js +12 -26
  251. package/table/Table.stories.jsx +277 -0
  252. package/table/Table.test.js +26 -0
  253. package/table/types.d.ts +21 -0
  254. package/table/types.js +5 -0
  255. package/tabs/Tabs.d.ts +4 -0
  256. package/tabs/Tabs.js +211 -0
  257. package/tabs/Tabs.stories.tsx +112 -0
  258. package/tabs/Tabs.test.js +140 -0
  259. package/tabs/types.d.ts +82 -0
  260. package/tabs/types.js +5 -0
  261. package/tabs-nav/NavTabs.d.ts +8 -0
  262. package/tabs-nav/NavTabs.js +125 -0
  263. package/tabs-nav/NavTabs.stories.tsx +170 -0
  264. package/tabs-nav/NavTabs.test.js +82 -0
  265. package/tabs-nav/Tab.d.ts +4 -0
  266. package/tabs-nav/Tab.js +130 -0
  267. package/tabs-nav/types.d.ts +53 -0
  268. package/tabs-nav/types.js +5 -0
  269. package/tag/Tag.d.ts +4 -0
  270. package/tag/Tag.js +183 -0
  271. package/tag/Tag.stories.tsx +142 -0
  272. package/tag/Tag.test.js +60 -0
  273. package/tag/types.d.ts +69 -0
  274. package/tag/types.js +5 -0
  275. package/text-input/Suggestion.d.ts +4 -0
  276. package/text-input/Suggestion.js +55 -0
  277. package/text-input/TextInput.d.ts +4 -0
  278. package/{dist/text-input → text-input}/TextInput.js +294 -504
  279. package/text-input/TextInput.stories.tsx +473 -0
  280. package/text-input/TextInput.test.js +1712 -0
  281. package/text-input/types.d.ts +178 -0
  282. package/text-input/types.js +5 -0
  283. package/textarea/Textarea.d.ts +4 -0
  284. package/{dist/textarea → textarea}/Textarea.js +50 -142
  285. package/textarea/Textarea.stories.jsx +157 -0
  286. package/textarea/Textarea.test.js +437 -0
  287. package/textarea/types.d.ts +137 -0
  288. package/textarea/types.js +5 -0
  289. package/toggle-group/ToggleGroup.d.ts +4 -0
  290. package/{dist/toggle-group → toggle-group}/ToggleGroup.js +36 -148
  291. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  292. package/toggle-group/ToggleGroup.test.js +156 -0
  293. package/toggle-group/types.d.ts +105 -0
  294. package/toggle-group/types.js +5 -0
  295. package/typography/Typography.d.ts +4 -0
  296. package/typography/Typography.js +131 -0
  297. package/typography/Typography.stories.tsx +198 -0
  298. package/typography/types.d.ts +18 -0
  299. package/typography/types.js +5 -0
  300. package/useTheme.d.ts +2 -0
  301. package/{dist/useTheme.js → useTheme.js} +2 -2
  302. package/useTranslatedLabels.d.ts +2 -0
  303. package/useTranslatedLabels.js +20 -0
  304. package/wizard/Wizard.d.ts +4 -0
  305. package/wizard/Wizard.js +285 -0
  306. package/wizard/Wizard.stories.tsx +233 -0
  307. package/wizard/Wizard.test.js +141 -0
  308. package/wizard/types.d.ts +65 -0
  309. package/wizard/types.js +5 -0
  310. package/README.md +0 -66
  311. package/babel.config.js +0 -8
  312. package/dist/BackgroundColorContext.js +0 -46
  313. package/dist/ThemeContext.js +0 -248
  314. package/dist/V3Textarea/V3Textarea.js +0 -264
  315. package/dist/accordion/Accordion.js +0 -353
  316. package/dist/accordion-group/AccordionGroup.js +0 -186
  317. package/dist/alert/index.d.ts +0 -51
  318. package/dist/badge/Badge.js +0 -63
  319. package/dist/box/Box.js +0 -156
  320. package/dist/button/Button.js +0 -238
  321. package/dist/card/Card.js +0 -254
  322. package/dist/checkbox/Checkbox.stories.js +0 -144
  323. package/dist/checkbox/readme.md +0 -116
  324. package/dist/chip/Chip.js +0 -265
  325. package/dist/date/Date.js +0 -379
  326. package/dist/date/Date.stories.js +0 -205
  327. package/dist/date/readme.md +0 -73
  328. package/dist/date-input/index.d.ts +0 -95
  329. package/dist/dialog/Dialog.js +0 -218
  330. package/dist/dropdown/Dropdown.js +0 -544
  331. package/dist/file-input/FileInput.js +0 -644
  332. package/dist/file-input/FileItem.js +0 -280
  333. package/dist/file-input/index.d.ts +0 -81
  334. package/dist/footer/Footer.js +0 -421
  335. package/dist/header/Header.js +0 -434
  336. package/dist/input-text/Icons.js +0 -22
  337. package/dist/input-text/InputText.js +0 -705
  338. package/dist/layout/ApplicationLayout.js +0 -327
  339. package/dist/link/Link.js +0 -237
  340. package/dist/link/readme.md +0 -51
  341. package/dist/main.d.ts +0 -8
  342. package/dist/new-select/NewSelect.js +0 -836
  343. package/dist/new-select/index.d.ts +0 -53
  344. package/dist/number-input/NumberInput.js +0 -136
  345. package/dist/number-input/index.d.ts +0 -113
  346. package/dist/paginator/Paginator.js +0 -283
  347. package/dist/password-input/index.d.ts +0 -94
  348. package/dist/progress-bar/ProgressBar.js +0 -242
  349. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  350. package/dist/progress-bar/readme.md +0 -63
  351. package/dist/radio/Radio.js +0 -209
  352. package/dist/radio/Radio.stories.js +0 -166
  353. package/dist/radio/readme.md +0 -70
  354. package/dist/select/Select.js +0 -549
  355. package/dist/sidenav/Sidenav.js +0 -179
  356. package/dist/slider/readme.md +0 -64
  357. package/dist/spinner/Spinner.js +0 -381
  358. package/dist/spinner/Spinner.stories.js +0 -183
  359. package/dist/spinner/readme.md +0 -65
  360. package/dist/switch/Switch.js +0 -222
  361. package/dist/switch/Switch.stories.js +0 -134
  362. package/dist/switch/readme.md +0 -133
  363. package/dist/tabs/Tabs.js +0 -343
  364. package/dist/tabs/Tabs.stories.js +0 -130
  365. package/dist/tabs/readme.md +0 -78
  366. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  367. package/dist/tabs-for-sections/readme.md +0 -78
  368. package/dist/tag/Tag.js +0 -282
  369. package/dist/text-input/index.d.ts +0 -135
  370. package/dist/textarea/index.d.ts +0 -117
  371. package/dist/toggle/Toggle.js +0 -220
  372. package/dist/toggle/Toggle.stories.js +0 -297
  373. package/dist/toggle/readme.md +0 -80
  374. package/dist/upload/Upload.js +0 -205
  375. package/dist/upload/Upload.stories.js +0 -72
  376. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -139
  377. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  378. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  379. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  380. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  381. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  382. package/dist/upload/file-upload/FileToUpload.js +0 -184
  383. package/dist/upload/file-upload/audio-icon.svg +0 -4
  384. package/dist/upload/file-upload/close.svg +0 -4
  385. package/dist/upload/file-upload/file-icon.svg +0 -4
  386. package/dist/upload/file-upload/video-icon.svg +0 -4
  387. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  388. package/dist/upload/readme.md +0 -37
  389. package/dist/upload/transaction/Transaction.js +0 -175
  390. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  391. package/dist/upload/transaction/audio-icon.svg +0 -4
  392. package/dist/upload/transaction/error-icon.svg +0 -4
  393. package/dist/upload/transaction/file-icon-err.svg +0 -4
  394. package/dist/upload/transaction/file-icon.svg +0 -4
  395. package/dist/upload/transaction/image-icon-err.svg +0 -4
  396. package/dist/upload/transaction/image-icon.svg +0 -4
  397. package/dist/upload/transaction/success-icon.svg +0 -4
  398. package/dist/upload/transaction/video-icon-err.svg +0 -4
  399. package/dist/upload/transaction/video-icon.svg +0 -4
  400. package/dist/upload/transactions/Transactions.js +0 -138
  401. package/dist/wizard/Icons.js +0 -65
  402. package/dist/wizard/Wizard.js +0 -405
  403. package/test/Accordion.test.js +0 -33
  404. package/test/AccordionGroup.test.js +0 -125
  405. package/test/Alert.test.js +0 -53
  406. package/test/Box.test.js +0 -10
  407. package/test/Button.test.js +0 -18
  408. package/test/Card.test.js +0 -30
  409. package/test/Checkbox.test.js +0 -45
  410. package/test/Chip.test.js +0 -25
  411. package/test/Date.test.js +0 -397
  412. package/test/DateInput.test.js +0 -242
  413. package/test/Dialog.test.js +0 -23
  414. package/test/Dropdown.test.js +0 -145
  415. package/test/FileInput.test.js +0 -201
  416. package/test/Footer.test.js +0 -94
  417. package/test/Header.test.js +0 -34
  418. package/test/Heading.test.js +0 -35
  419. package/test/InputText.test.js +0 -248
  420. package/test/Link.test.js +0 -43
  421. package/test/NumberInput.test.js +0 -259
  422. package/test/Paginator.test.js +0 -177
  423. package/test/PasswordInput.test.js +0 -83
  424. package/test/ProgressBar.test.js +0 -35
  425. package/test/Radio.test.js +0 -37
  426. package/test/ResultsetTable.test.js +0 -329
  427. package/test/Select.test.js +0 -212
  428. package/test/Sidenav.test.js +0 -45
  429. package/test/Slider.test.js +0 -74
  430. package/test/Spinner.test.js +0 -32
  431. package/test/Switch.test.js +0 -45
  432. package/test/Table.test.js +0 -36
  433. package/test/Tabs.test.js +0 -109
  434. package/test/TabsForSections.test.js +0 -34
  435. package/test/Tag.test.js +0 -32
  436. package/test/TextInput.test.js +0 -732
  437. package/test/Textarea.test.js +0 -193
  438. package/test/ToggleGroup.test.js +0 -85
  439. package/test/Upload.test.js +0 -60
  440. package/test/V3TextArea.test.js +0 -51
  441. package/test/Wizard.test.js +0 -130
  442. package/test/mocks/pngMock.js +0 -1
  443. package/test/mocks/svgMock.js +0 -1
@@ -1,16 +1,14 @@
1
1
  "use strict";
2
2
 
3
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
4
-
5
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
6
4
 
5
+ var _typeof3 = require("@babel/runtime/helpers/typeof");
6
+
7
7
  Object.defineProperty(exports, "__esModule", {
8
8
  value: true
9
9
  });
10
10
  exports["default"] = void 0;
11
11
 
12
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
13
-
14
12
  var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
15
13
 
16
14
  var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
@@ -23,50 +21,28 @@ var _styledComponents = _interopRequireWildcard(require("styled-components"));
23
21
 
24
22
  var _Checkbox = _interopRequireDefault(require("@material-ui/core/Checkbox"));
25
23
 
26
- var _propTypes = _interopRequireDefault(require("prop-types"));
27
-
28
- var _RequiredComponent = _interopRequireDefault(require("../common/RequiredComponent"));
29
-
30
24
  var _variables = require("../common/variables.js");
31
25
 
32
26
  var _utils = require("../common/utils.js");
33
27
 
34
- var _useTheme = _interopRequireDefault(require("../useTheme.js"));
35
-
36
- var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext.js"));
37
-
38
- function _templateObject3() {
39
- var data = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n width: 16px;\n height: 16px;\n position: absolute;\n left: ", ";\n right: ", ";\n z-index: 0;\n margin-left: ", ";\n margin-right: ", ";\n"]);
40
-
41
- _templateObject3 = function _templateObject3() {
42
- return data;
43
- };
44
-
45
- return data;
46
- }
28
+ var _uuid = require("uuid");
47
29
 
48
- function _templateObject2() {
49
- var data = (0, _taggedTemplateLiteral2["default"])(["\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n width: ", ";\n display: inline-flex;\n align-items: center;\n cursor: ", ";\n position: relative;\n flex-direction: ", ";\n .MuiCheckbox-colorSecondary {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n }\n }\n &.Mui-disabled {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n opacity: 0.34;\n }\n }\n }\n &.Mui-checked {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n }\n }\n\n &:hover {\n background-color: transparent;\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n background-color: transparent;\n color: ", ";\n }\n }\n }\n }\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n width: 24px;\n height: 24px;\n }\n }\n }\n\n .MuiIconButton-colorSecondary {\n &:hover {\n background-color: transparent;\n }\n }\n .MuiButtonBase-root {\n &:hover {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n }\n }\n }\n\n &.Mui-focusVisible {\n .MuiIconButton-label {\n box-shadow: 0 0 0 2px\n ", ";\n }\n }\n z-index: 1;\n margin: ", ";\n margin-left: ", ";\n margin-right: ", ";\n padding: 0px;\n left: ", ";\n right: ", ";\n }\n"]);
30
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
50
31
 
51
- _templateObject2 = function _templateObject2() {
52
- return data;
53
- };
32
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
54
33
 
55
- return data;
56
- }
34
+ var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
57
35
 
58
- function _templateObject() {
59
- var data = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n cursor: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n"]);
36
+ var _templateObject, _templateObject2, _templateObject3;
60
37
 
61
- _templateObject = function _templateObject() {
62
- return data;
63
- };
38
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
64
39
 
65
- return data;
66
- }
40
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
67
41
 
68
42
  var DxcCheckbox = function DxcCheckbox(_ref) {
69
43
  var checked = _ref.checked,
44
+ _ref$defaultChecked = _ref.defaultChecked,
45
+ defaultChecked = _ref$defaultChecked === void 0 ? false : _ref$defaultChecked,
70
46
  value = _ref.value,
71
47
  _ref$label = _ref.label,
72
48
  label = _ref$label === void 0 ? "" : _ref$label,
@@ -76,27 +52,34 @@ var DxcCheckbox = function DxcCheckbox(_ref) {
76
52
  name = _ref$name === void 0 ? "" : _ref$name,
77
53
  _ref$disabled = _ref.disabled,
78
54
  disabled = _ref$disabled === void 0 ? false : _ref$disabled,
55
+ _ref$optional = _ref.optional,
56
+ optional = _ref$optional === void 0 ? false : _ref$optional,
79
57
  onChange = _ref.onChange,
80
- _ref$required = _ref.required,
81
- required = _ref$required === void 0 ? false : _ref$required,
82
58
  margin = _ref.margin,
83
59
  _ref$size = _ref.size,
84
60
  size = _ref$size === void 0 ? "fitContent" : _ref$size,
85
61
  _ref$tabIndex = _ref.tabIndex,
86
62
  tabIndex = _ref$tabIndex === void 0 ? 0 : _ref$tabIndex;
87
63
 
88
- var _useState = (0, _react.useState)(false),
89
- _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
90
- innerChecked = _useState2[0],
91
- setInnerChecked = _useState2[1];
64
+ var _useState = (0, _react.useState)("checkbox-".concat((0, _uuid.v4)())),
65
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
66
+ switchId = _useState2[0];
92
67
 
93
- var _useState3 = (0, _react.useState)(false),
68
+ var labelId = "label-".concat(switchId);
69
+
70
+ var _useState3 = (0, _react.useState)(defaultChecked),
94
71
  _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
95
- isLabelHovered = _useState4[0],
96
- setIsLabelHovered = _useState4[1];
72
+ innerChecked = _useState4[0],
73
+ setInnerChecked = _useState4[1];
74
+
75
+ var _useState5 = (0, _react.useState)(false),
76
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 2),
77
+ isLabelHovered = _useState6[0],
78
+ setIsLabelHovered = _useState6[1];
97
79
 
98
80
  var colorsTheme = (0, _useTheme["default"])();
99
81
  var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
82
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
100
83
 
101
84
  var handlerCheckboxChange = function handlerCheckboxChange(checkboxValue) {
102
85
  if (checked === undefined) {
@@ -117,24 +100,36 @@ var DxcCheckbox = function DxcCheckbox(_ref) {
117
100
  setIsLabelHovered(!isLabelHovered);
118
101
  };
119
102
 
120
- return _react["default"].createElement(_styledComponents.ThemeProvider, {
103
+ var labelComponent = /*#__PURE__*/_react["default"].createElement(LabelContainer, {
104
+ id: labelId,
105
+ labelPosition: labelPosition,
106
+ onClick: disabled === true ? function () {} : handlerCheckboxChange,
107
+ disabled: disabled,
108
+ className: "labelContainer",
109
+ backgroundType: backgroundType,
110
+ onMouseOver: handleLabelHover,
111
+ onMouseOut: handleLabelHover
112
+ }, labelPosition === "before" ? /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, label, " ", optional && /*#__PURE__*/_react["default"].createElement("span", null, translatedLabels.formFields.optionalLabel)) : /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, optional && /*#__PURE__*/_react["default"].createElement("span", null, "(Optional)"), " ", label));
113
+
114
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
121
115
  theme: colorsTheme.checkbox
122
- }, _react["default"].createElement(CheckboxContainer, {
116
+ }, /*#__PURE__*/_react["default"].createElement(CheckboxContainer, {
123
117
  id: name,
124
118
  brightness: _variables.componentTokens,
119
+ label: label,
125
120
  labelPosition: labelPosition,
126
121
  disabled: disabled,
127
122
  margin: margin,
128
123
  size: size,
129
124
  backgroundType: backgroundType,
130
125
  isLabelHovered: isLabelHovered
131
- }, _react["default"].createElement(_Checkbox["default"], {
132
- checked: checked != undefined ? checked : innerChecked,
126
+ }, label && labelPosition === "before" && labelComponent, /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
127
+ checked: checked !== null && checked !== void 0 ? checked : innerChecked,
133
128
  inputProps: {
134
129
  name: name,
135
- "aria-label": label,
130
+ "aria-labelledby": labelId,
136
131
  role: "checkbox",
137
- "aria-checked": checked != undefined ? checked : innerChecked
132
+ "aria-checked": checked !== null && checked !== void 0 ? checked : innerChecked
138
133
  },
139
134
  onChange: handlerCheckboxChange,
140
135
  value: value,
@@ -142,20 +137,12 @@ var DxcCheckbox = function DxcCheckbox(_ref) {
142
137
  disableRipple: true,
143
138
  className: "test",
144
139
  tabIndex: tabIndex
145
- }), _react["default"].createElement(CheckboxBlackBack, {
140
+ }), /*#__PURE__*/_react["default"].createElement(CheckboxBlackBack, {
146
141
  labelPosition: labelPosition,
147
142
  disabled: disabled,
148
- checked: checked != undefined ? checked : innerChecked,
143
+ checked: checked !== null && checked !== void 0 ? checked : innerChecked,
149
144
  backgroundType: backgroundType
150
- }), required && _react["default"].createElement(_RequiredComponent["default"], null), label && _react["default"].createElement(LabelContainer, {
151
- labelPosition: labelPosition,
152
- onClick: disabled === true ? function (e) {} : handlerCheckboxChange,
153
- disabled: disabled,
154
- className: "labelContainer",
155
- backgroundType: backgroundType,
156
- onMouseOver: handleLabelHover,
157
- onMouseOut: handleLabelHover
158
- }, label)));
145
+ }), label && labelPosition === "after" && labelComponent));
159
146
  };
160
147
 
161
148
  var sizes = {
@@ -178,19 +165,15 @@ var getDisabledColor = function getDisabledColor(props, element) {
178
165
  switch (element) {
179
166
  case "check":
180
167
  return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledCheckColorOnDark : props.theme.disabledCheckColor;
181
- break;
182
168
 
183
169
  case "background":
184
170
  return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledBackgroundColorCheckedOnDark : props.theme.disabledBackgroundColorChecked;
185
- break;
186
171
 
187
172
  case "border":
188
173
  return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledBorderColorOnDark : props.theme.disabledBorderColor;
189
- break;
190
174
 
191
175
  case "label":
192
176
  return props.backgroundType && props.backgroundType === "dark" ? props.theme.disabledFontColorOnDark : props.theme.disabledFontColor;
193
- break;
194
177
  }
195
178
  };
196
179
 
@@ -198,35 +181,31 @@ var getNotDisabledColor = function getNotDisabledColor(props, element) {
198
181
  switch (element) {
199
182
  case "check":
200
183
  return props.backgroundType && props.backgroundType === "dark" ? props.theme.checkColorOnDark : props.theme.checkColor;
201
- break;
202
184
 
203
185
  case "background":
204
186
  return props.backgroundType && props.backgroundType === "dark" ? props.theme.backgroundColorCheckedOnDark : props.theme.backgroundColorChecked;
205
- break;
206
187
 
207
188
  case "border":
208
189
  return props.backgroundType && props.backgroundType === "dark" ? props.theme.borderColorOnDark : props.theme.borderColor;
209
- break;
210
190
 
211
191
  case "label":
212
192
  return props.backgroundType && props.backgroundType === "dark" ? props.theme.fontColorOnDark : props.theme.fontColor;
213
- break;
214
193
  }
215
194
  };
216
195
 
217
- var LabelContainer = _styledComponents["default"].span(_templateObject(), function (props) {
196
+ var LabelContainer = _styledComponents["default"].span(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n cursor: ", ";\n"])), function (props) {
218
197
  return props.disabled ? getDisabledColor(props, "label") : getNotDisabledColor(props, "label");
219
- }, function (props) {
220
- return props.disabled ? "not-allowed" : "pointer";
221
198
  }, function (props) {
222
199
  return props.theme.fontFamily;
223
200
  }, function (props) {
224
201
  return props.theme.fontSize;
225
202
  }, function (props) {
226
203
  return props.theme.fontWeight;
204
+ }, function (props) {
205
+ return props.disabled ? "not-allowed" : "pointer";
227
206
  });
228
207
 
229
- var CheckboxContainer = _styledComponents["default"].span(_templateObject2(), function (props) {
208
+ var CheckboxContainer = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n width: ", ";\n display: inline-flex;\n align-items: center;\n cursor: ", ";\n position: relative;\n .MuiCheckbox-colorSecondary {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n }\n }\n &.Mui-disabled {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n opacity: 0.34;\n }\n }\n }\n &.Mui-checked {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n }\n }\n\n &:hover {\n background-color: transparent;\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n background-color: transparent;\n color: ", ";\n }\n }\n }\n }\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n width: 24px;\n height: 24px;\n }\n }\n }\n\n .MuiIconButton-colorSecondary {\n &:hover {\n background-color: transparent;\n }\n }\n .MuiButtonBase-root {\n &:hover {\n .MuiIconButton-label {\n & > .MuiSvgIcon-root {\n color: ", ";\n }\n }\n }\n\n &.Mui-focusVisible {\n .MuiIconButton-label {\n border-radius: 2px;\n outline: 2px solid\n ", ";\n outline-offset: -1px;\n }\n }\n z-index: 1;\n margin-left: ", ";\n margin-right: ", ";\n padding: 0px;\n left: ", ";\n right: ", ";\n }\n"])), function (props) {
230
209
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
231
210
  }, function (props) {
232
211
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
@@ -240,8 +219,6 @@ var CheckboxContainer = _styledComponents["default"].span(_templateObject2(), fu
240
219
  return calculateWidth(props.margin, props.size);
241
220
  }, function (props) {
242
221
  return props.disabled ? "not-allowed" : "pointer";
243
- }, function (props) {
244
- return props.labelPosition === "before" ? "row-reverse" : "row";
245
222
  }, function (props) {
246
223
  return props.isLabelHovered ? props.backgroundType === "dark" ? props.theme.hoverBorderColorOnDark : props.theme.hoverBorderColor : getNotDisabledColor(props, "border");
247
224
  }, function (props) {
@@ -255,18 +232,16 @@ var CheckboxContainer = _styledComponents["default"].span(_templateObject2(), fu
255
232
  }, function (props) {
256
233
  return props.backgroundType === "dark" ? props.theme.focusColorOnDark : props.theme.focusColor;
257
234
  }, function (props) {
258
- return props.theme.checkLabelSpacing;
235
+ return props.labelPosition === "before" && props.label ? props.theme.checkLabelSpacing : "0";
259
236
  }, function (props) {
260
- return props.labelPosition === "after" ? "0px" : "";
261
- }, function (props) {
262
- return props.labelPosition === "before" ? "0px" : "";
237
+ return props.labelPosition === "after" && props.label ? props.theme.checkLabelSpacing : "0";
263
238
  }, function (props) {
264
239
  return props.labelPosition === "before" ? "unset" : "1px";
265
240
  }, function (props) {
266
241
  return props.labelPosition === "before" ? "1px" : "unset";
267
242
  });
268
243
 
269
- var CheckboxBlackBack = _styledComponents["default"].span(_templateObject3(), function (props) {
244
+ var CheckboxBlackBack = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n width: 16px;\n height: 16px;\n position: absolute;\n left: ", ";\n right: ", ";\n z-index: 0;\n margin-left: ", ";\n margin-right: ", ";\n"])), function (props) {
270
245
  return !props.checked ? "transparent" : props.disabled ? getDisabledColor(props, "check") : getNotDisabledColor(props, "check");
271
246
  }, function (props) {
272
247
  return props.labelPosition === "before" ? "unset" : "5px";
@@ -278,23 +253,5 @@ var CheckboxBlackBack = _styledComponents["default"].span(_templateObject3(), fu
278
253
  return props.labelPosition === "before" ? "0px" : "";
279
254
  });
280
255
 
281
- DxcCheckbox.propTypes = {
282
- checked: _propTypes["default"].bool,
283
- value: _propTypes["default"].any,
284
- label: _propTypes["default"].string,
285
- labelPosition: _propTypes["default"].oneOf(["after", "before", ""]),
286
- name: _propTypes["default"].string,
287
- disabled: _propTypes["default"].bool,
288
- onChange: _propTypes["default"].func,
289
- required: _propTypes["default"].bool,
290
- size: _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(sizes))),
291
- margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
292
- top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
293
- bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
294
- left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
295
- right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
296
- }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))]),
297
- tabIndex: _propTypes["default"].number
298
- };
299
256
  var _default = DxcCheckbox;
300
257
  exports["default"] = _default;
@@ -0,0 +1,188 @@
1
+ import React from "react";
2
+ import DxcCheckbox from "./Checkbox";
3
+ import { BackgroundColorProvider } from "../BackgroundColorContext";
4
+ import Title from "../../.storybook/components/Title";
5
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+ import DarkContainer from "../../.storybook/components/DarkSection";
7
+ import { userEvent } from "@storybook/testing-library";
8
+
9
+ export default {
10
+ title: "Checkbox",
11
+ component: DxcCheckbox,
12
+ };
13
+
14
+ const Checkbox = () => (
15
+ <>
16
+ <ExampleContainer>
17
+ <Title title="Default" theme="light" level={4} />
18
+ <DxcCheckbox label="Checkbox" />
19
+ </ExampleContainer>
20
+ <ExampleContainer>
21
+ <Title title="Focused" theme="light" level={4} />
22
+ <DxcCheckbox label="Focused" />
23
+ </ExampleContainer>
24
+ <ExampleContainer>
25
+ <Title title="Checked" theme="light" level={4} />
26
+ <DxcCheckbox label="Checkbox" defaultChecked />
27
+ </ExampleContainer>
28
+ <ExampleContainer>
29
+ <Title title="Optional" theme="light" level={4} />
30
+ <DxcCheckbox label="Checkbox" optional />
31
+ </ExampleContainer>
32
+ <ExampleContainer>
33
+ <Title title="Disabled and checked" theme="light" level={4} />
34
+ <DxcCheckbox label="Checkbox" disabled defaultChecked />
35
+ </ExampleContainer>
36
+ <ExampleContainer>
37
+ <Title title="Disabled and optional" theme="light" level={4} />
38
+ <DxcCheckbox label="Checkbox" disabled optional />
39
+ </ExampleContainer>
40
+ <ExampleContainer>
41
+ <Title title="Disabled, optional and checked" theme="light" level={4} />
42
+ <DxcCheckbox label="Checkbox" disabled optional defaultChecked />
43
+ </ExampleContainer>
44
+ <ExampleContainer>
45
+ <Title title="Label after" theme="light" level={4} />
46
+ <DxcCheckbox label="Checkbox" labelPosition="after" />
47
+ </ExampleContainer>
48
+ <ExampleContainer>
49
+ <Title title="Checked with label after" theme="light" level={4} />
50
+ <DxcCheckbox label="Checkbox" defaultChecked labelPosition="after" />
51
+ </ExampleContainer>
52
+ <ExampleContainer>
53
+ <Title title="Optional with label after" theme="light" level={4} />
54
+ <DxcCheckbox label="Checkbox" optional labelPosition="after" />
55
+ </ExampleContainer>
56
+ <ExampleContainer>
57
+ <Title title="Disabled and checked with label after" theme="light" level={4} />
58
+ <DxcCheckbox label="Checkbox" disabled defaultChecked labelPosition="after" />
59
+ </ExampleContainer>
60
+ <ExampleContainer>
61
+ <Title title="Disabled and optional with label after" theme="light" level={4} />
62
+ <DxcCheckbox label="Checkbox" disabled optional labelPosition="after" />
63
+ </ExampleContainer>
64
+ <ExampleContainer>
65
+ <Title title="Disabled, optional and checked with label after" theme="light" level={4} />
66
+ <DxcCheckbox label="Checkbox" disabled optional defaultChecked labelPosition="after" />
67
+ </ExampleContainer>
68
+ <ExampleContainer pseudoState="pseudo-hover">
69
+ <Title title="Hovered" theme="light" level={4} />
70
+ <DxcCheckbox label="Hovered" />
71
+ </ExampleContainer>
72
+ <ExampleContainer pseudoState="pseudo-hover">
73
+ <Title title="Hovered and checked" theme="light" level={4} />
74
+ <DxcCheckbox label="Hovered" defaultChecked />
75
+ </ExampleContainer>
76
+ <BackgroundColorProvider color="#333333">
77
+ <DarkContainer>
78
+ <ExampleContainer>
79
+ <Title title="Default" theme="dark" level={4} />
80
+ <DxcCheckbox label="Checkbox" />
81
+ </ExampleContainer>
82
+ <ExampleContainer>
83
+ <Title title="Checked" theme="dark" level={4} />
84
+ <DxcCheckbox label="Checkbox" defaultChecked />
85
+ </ExampleContainer>
86
+ <ExampleContainer>
87
+ <Title title="Optional" theme="dark" level={4} />
88
+ <DxcCheckbox label="Checkbox" optional />
89
+ </ExampleContainer>
90
+ <ExampleContainer>
91
+ <Title title="Disabled and checked" theme="dark" level={4} />
92
+ <DxcCheckbox label="Checkbox" disabled defaultChecked />
93
+ </ExampleContainer>
94
+ <ExampleContainer>
95
+ <Title title="Disabled and optional" theme="dark" level={4} />
96
+ <DxcCheckbox label="Checkbox" disabled optional />
97
+ </ExampleContainer>
98
+ <ExampleContainer>
99
+ <Title title="Disabled, optional and checked" theme="dark" level={4} />
100
+ <DxcCheckbox label="Checkbox" disabled optional defaultChecked />
101
+ </ExampleContainer>
102
+ <ExampleContainer>
103
+ <Title title="Label after" theme="dark" level={4} />
104
+ <DxcCheckbox label="Checkbox" labelPosition="after" />
105
+ </ExampleContainer>
106
+ <ExampleContainer>
107
+ <Title title="Checked with label after" theme="dark" level={4} />
108
+ <DxcCheckbox label="Checkbox" defaultChecked labelPosition="after" />
109
+ </ExampleContainer>
110
+ <ExampleContainer>
111
+ <Title title="Optional with label after" theme="dark" level={4} />
112
+ <DxcCheckbox label="Checkbox" optional labelPosition="after" />
113
+ </ExampleContainer>
114
+ <ExampleContainer>
115
+ <Title title="Disabled and checked with label after" theme="dark" level={4} />
116
+ <DxcCheckbox label="Checkbox" disabled defaultChecked labelPosition="after" />
117
+ </ExampleContainer>
118
+ <ExampleContainer>
119
+ <Title title="Disabled and optional with label after" theme="dark" level={4} />
120
+ <DxcCheckbox label="Checkbox" disabled optional labelPosition="after" />
121
+ </ExampleContainer>
122
+ <ExampleContainer>
123
+ <Title title="Disabled, optional and checked with label after" theme="dark" level={4} />
124
+ <DxcCheckbox label="Checkbox" disabled optional defaultChecked labelPosition="after" />
125
+ </ExampleContainer>
126
+ <ExampleContainer pseudoState="pseudo-hover">
127
+ <Title title="Hovered" theme="dark" level={4} />
128
+ <DxcCheckbox label="Hovered" />
129
+ </ExampleContainer>
130
+ <ExampleContainer pseudoState="pseudo-hover">
131
+ <Title title="Hovered and checked" theme="dark" level={4} />
132
+ <DxcCheckbox label="Hovered" defaultChecked />
133
+ </ExampleContainer>
134
+ </DarkContainer>
135
+ </BackgroundColorProvider>
136
+ <Title title="Sizes" theme="light" level={2} />
137
+ <ExampleContainer>
138
+ <DxcCheckbox label="Small" size="small" />
139
+ </ExampleContainer>
140
+ <ExampleContainer>
141
+ <DxcCheckbox label="Medium" size="medium" />
142
+ </ExampleContainer>
143
+ <ExampleContainer>
144
+ <DxcCheckbox label="Large" size="large" />
145
+ </ExampleContainer>
146
+ <ExampleContainer>
147
+ <DxcCheckbox label="FitContent" size="fitContent" />
148
+ </ExampleContainer>
149
+ <ExampleContainer>
150
+ <DxcCheckbox label="FillParent" size="fillParent" />
151
+ </ExampleContainer>
152
+ <Title title="Margins" theme="light" level={2} />
153
+ <ExampleContainer>
154
+ <Title title="Xxsmall" theme="light" level={4} />
155
+ <DxcCheckbox label="Xxsmall" margin="xxsmall" />
156
+ </ExampleContainer>
157
+ <ExampleContainer>
158
+ <Title title="Xsmall" theme="light" level={4} />
159
+ <DxcCheckbox label="Xsmall" margin="xsmall" />
160
+ </ExampleContainer>
161
+ <ExampleContainer>
162
+ <Title title="Small" theme="light" level={4} />
163
+ <DxcCheckbox label="Small" margin="small" />
164
+ </ExampleContainer>
165
+ <ExampleContainer>
166
+ <Title title="Medium" theme="light" level={4} />
167
+ <DxcCheckbox label="Medium" margin="medium" />
168
+ </ExampleContainer>
169
+ <ExampleContainer>
170
+ <Title title="Large" theme="light" level={4} />
171
+ <DxcCheckbox label="Large" margin="large" />
172
+ </ExampleContainer>
173
+ <ExampleContainer>
174
+ <Title title="Xlarge" theme="light" level={4} />
175
+ <DxcCheckbox label="Xlarge" margin="xlarge" />
176
+ </ExampleContainer>
177
+ <ExampleContainer>
178
+ <Title title="Xxlarge" theme="light" level={4} />
179
+ <DxcCheckbox label="Xxlarge" margin="xxlarge" />
180
+ </ExampleContainer>
181
+ </>
182
+ );
183
+
184
+ export const Chromatic = Checkbox.bind({});
185
+ Chromatic.play = async () => {
186
+ await userEvent.tab();
187
+ await userEvent.tab();
188
+ };
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _react = _interopRequireDefault(require("react"));
6
+
7
+ var _react2 = require("@testing-library/react");
8
+
9
+ var _Checkbox = _interopRequireDefault(require("./Checkbox"));
10
+
11
+ describe("Checkbox component tests", function () {
12
+ test("Checkbox renders with correct text", function () {
13
+ var _render = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
14
+ label: "Checkbox"
15
+ })),
16
+ getByText = _render.getByText;
17
+
18
+ expect(getByText("Checkbox")).toBeTruthy();
19
+ });
20
+ test("Calls correct function on click", function () {
21
+ var onChange = jest.fn();
22
+
23
+ var _render2 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
24
+ label: "Checkbox",
25
+ onChange: onChange
26
+ })),
27
+ getByText = _render2.getByText;
28
+
29
+ _react2.fireEvent.click(getByText("Checkbox"));
30
+
31
+ expect(onChange).toHaveBeenCalled();
32
+ });
33
+ test("Uncontrolled checkbox", function () {
34
+ var onChange = jest.fn();
35
+ var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
36
+ label: "Checkbox",
37
+ onChange: onChange
38
+ }));
39
+ var visibleCheckbox = component.getByText("Checkbox");
40
+ var input = component.getByRole("checkbox");
41
+ expect(input.checked).toBe(false);
42
+
43
+ _react2.fireEvent.click(visibleCheckbox);
44
+
45
+ expect(onChange).toHaveBeenCalled();
46
+ expect(onChange).toHaveBeenCalledWith(true);
47
+ expect(input.checked).toBe(true);
48
+ });
49
+ test("Controlled checkbox", function () {
50
+ var onChange = jest.fn();
51
+ var component = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
52
+ label: "Checkbox",
53
+ checked: false,
54
+ onChange: onChange
55
+ }));
56
+ var input = component.getByRole("checkbox");
57
+ var visibleCheckbox = component.getByText("Checkbox");
58
+
59
+ _react2.fireEvent.click(visibleCheckbox);
60
+
61
+ expect(onChange).toHaveBeenCalled();
62
+ expect(onChange).toHaveBeenCalledWith(true);
63
+ expect(input.checked).toBe(false);
64
+ });
65
+ test("Renders with correct initial value and initial state when it is uncontrolled", function () {
66
+ var _render3 = (0, _react2.render)( /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], {
67
+ label: "Default label",
68
+ defaultChecked: true,
69
+ value: "test-defaultChecked"
70
+ })),
71
+ getByRole = _render3.getByRole;
72
+
73
+ var input = getByRole("checkbox");
74
+ expect(input.checked).toBe(true);
75
+ expect(input.value).toBe("test-defaultChecked");
76
+ expect(input.getAttribute("aria-checked")).toBe("true");
77
+ });
78
+ });
@@ -0,0 +1,64 @@
1
+ declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ declare type Margin = {
3
+ top?: Space;
4
+ bottom?: Space;
5
+ left?: Space;
6
+ right?: Space;
7
+ };
8
+ declare type Props = {
9
+ /**
10
+ * Initial state of the checkbox, only when it is uncontrolled.
11
+ */
12
+ defaultChecked?: boolean;
13
+ /**
14
+ * If true, the component is checked. If undefined the component will be
15
+ * uncontrolled and the value will be managed internally by the component.
16
+ */
17
+ checked?: boolean;
18
+ /**
19
+ * Will be passed to the value attribute of the html input element.
20
+ * When inside a form, this value will be only submitted if the checkbox is checked.
21
+ */
22
+ value?: string;
23
+ /**
24
+ * Text to be placed next to the checkbox.
25
+ */
26
+ label?: string;
27
+ /**
28
+ * Whether the label should appear after or before the checkbox.
29
+ */
30
+ labelPosition?: "before" | "after";
31
+ /**
32
+ * Name attribute of the input element.
33
+ */
34
+ name?: string;
35
+ /**
36
+ * If true, the component will be disabled.
37
+ */
38
+ disabled?: boolean;
39
+ /**
40
+ * If true, the component will display '(Optional)' next to the label.
41
+ */
42
+ optional?: boolean;
43
+ /**
44
+ * This function will be called when the user clicks the checkbox.
45
+ * The new value will be passed as a parameter.
46
+ */
47
+ onChange?: (value: boolean) => void;
48
+ /**
49
+ * Size of the margin to be applied to the component
50
+ * ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
51
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties
52
+ * in order to specify different margin sizes.
53
+ */
54
+ margin?: Space | Margin;
55
+ /**
56
+ * Size of the component.
57
+ */
58
+ size?: "small" | "medium" | "large" | "fillParent" | "fitContent";
59
+ /**
60
+ * Value of the tabindex.
61
+ */
62
+ tabIndex?: number;
63
+ };
64
+ export default Props;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
package/chip/Chip.d.ts ADDED
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import ChipPropsType from "./types";
3
+ declare const DxcChip: ({ label, suffixIcon, prefixIcon, onClickSuffix, onClickPrefix, disabled, margin, tabIndex, }: ChipPropsType) => JSX.Element;
4
+ export default DxcChip;