@dxc-technology/halstack-react 0.0.0-f46d22a → 0.0.0-f4755a1

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 (429) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +47 -0
  3. package/ThemeContext.d.ts +15 -0
  4. package/ThemeContext.js +243 -0
  5. package/V3Select/V3Select.js +455 -0
  6. package/V3Select/index.d.ts +27 -0
  7. package/V3Textarea/V3Textarea.js +260 -0
  8. package/V3Textarea/index.d.ts +27 -0
  9. package/accordion/Accordion.d.ts +4 -0
  10. package/accordion/Accordion.js +258 -0
  11. package/accordion/Accordion.stories.tsx +300 -0
  12. package/accordion/types.d.ts +68 -0
  13. package/accordion/types.js +5 -0
  14. package/accordion-group/AccordionGroup.d.ts +7 -0
  15. package/accordion-group/AccordionGroup.js +170 -0
  16. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  17. package/accordion-group/types.d.ts +72 -0
  18. package/accordion-group/types.js +5 -0
  19. package/alert/Alert.d.ts +4 -0
  20. package/alert/Alert.js +290 -0
  21. package/alert/Alert.stories.tsx +170 -0
  22. package/alert/types.d.ts +49 -0
  23. package/alert/types.js +5 -0
  24. package/badge/Badge.js +59 -0
  25. package/box/Box.d.ts +4 -0
  26. package/box/Box.js +126 -0
  27. package/box/Box.stories.tsx +132 -0
  28. package/box/types.d.ts +43 -0
  29. package/box/types.js +5 -0
  30. package/button/Button.d.ts +4 -0
  31. package/button/Button.js +179 -0
  32. package/button/Button.stories.tsx +276 -0
  33. package/button/types.d.ts +57 -0
  34. package/button/types.js +5 -0
  35. package/card/Card.d.ts +4 -0
  36. package/card/Card.js +164 -0
  37. package/card/Card.stories.tsx +201 -0
  38. package/card/ice-cream.jpg +0 -0
  39. package/card/types.d.ts +67 -0
  40. package/card/types.js +5 -0
  41. package/checkbox/Checkbox.d.ts +4 -0
  42. package/checkbox/Checkbox.js +253 -0
  43. package/checkbox/Checkbox.stories.tsx +192 -0
  44. package/checkbox/types.d.ts +60 -0
  45. package/checkbox/types.js +5 -0
  46. package/chip/Chip.d.ts +4 -0
  47. package/chip/Chip.js +199 -0
  48. package/chip/Chip.stories.tsx +121 -0
  49. package/chip/types.d.ts +53 -0
  50. package/chip/types.js +5 -0
  51. package/{dist/common → common}/OpenSans.css +0 -0
  52. package/{dist/common → common}/RequiredComponent.js +3 -11
  53. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  54. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  55. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  56. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  57. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  58. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  59. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  60. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  61. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  62. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  63. package/common/utils.js +22 -0
  64. package/common/variables.js +1605 -0
  65. package/{dist/date → date}/Date.js +79 -63
  66. package/date/index.d.ts +27 -0
  67. package/date-input/DateInput.d.ts +4 -0
  68. package/date-input/DateInput.js +358 -0
  69. package/date-input/DateInput.stories.tsx +138 -0
  70. package/date-input/types.d.ts +100 -0
  71. package/date-input/types.js +5 -0
  72. package/dialog/Dialog.d.ts +4 -0
  73. package/dialog/Dialog.js +166 -0
  74. package/dialog/Dialog.stories.tsx +212 -0
  75. package/dialog/types.d.ts +43 -0
  76. package/dialog/types.js +5 -0
  77. package/dropdown/Dropdown.d.ts +4 -0
  78. package/dropdown/Dropdown.js +417 -0
  79. package/dropdown/Dropdown.stories.tsx +247 -0
  80. package/dropdown/types.d.ts +89 -0
  81. package/dropdown/types.js +5 -0
  82. package/file-input/FileInput.d.ts +4 -0
  83. package/file-input/FileInput.js +590 -0
  84. package/file-input/FileInput.stories.tsx +506 -0
  85. package/file-input/FileItem.d.ts +14 -0
  86. package/file-input/FileItem.js +184 -0
  87. package/file-input/types.d.ts +112 -0
  88. package/file-input/types.js +5 -0
  89. package/footer/Footer.d.ts +4 -0
  90. package/footer/Footer.js +260 -0
  91. package/footer/Footer.stories.tsx +130 -0
  92. package/footer/Icons.d.ts +2 -0
  93. package/footer/Icons.js +77 -0
  94. package/footer/types.d.ts +65 -0
  95. package/footer/types.js +5 -0
  96. package/header/Header.d.ts +7 -0
  97. package/header/Header.js +324 -0
  98. package/header/Header.stories.tsx +162 -0
  99. package/header/Icons.d.ts +2 -0
  100. package/header/Icons.js +34 -0
  101. package/header/types.d.ts +47 -0
  102. package/header/types.js +5 -0
  103. package/heading/Heading.d.ts +4 -0
  104. package/heading/Heading.js +159 -0
  105. package/heading/Heading.stories.tsx +53 -0
  106. package/heading/types.d.ts +33 -0
  107. package/heading/types.js +5 -0
  108. package/input-text/Icons.js +22 -0
  109. package/input-text/InputText.js +611 -0
  110. package/input-text/index.d.ts +36 -0
  111. package/layout/ApplicationLayout.d.ts +10 -0
  112. package/layout/ApplicationLayout.js +225 -0
  113. package/layout/ApplicationLayout.stories.tsx +171 -0
  114. package/layout/Icons.js +55 -0
  115. package/layout/types.d.ts +57 -0
  116. package/layout/types.js +5 -0
  117. package/link/Link.d.ts +3 -0
  118. package/link/Link.js +161 -0
  119. package/link/Link.stories.tsx +146 -0
  120. package/link/types.d.ts +74 -0
  121. package/link/types.js +5 -0
  122. package/list/List.d.ts +8 -0
  123. package/list/List.js +47 -0
  124. package/list/List.stories.tsx +95 -0
  125. package/main.d.ts +48 -0
  126. package/{dist/main.js → main.js} +147 -55
  127. package/number-input/NumberInput.d.ts +4 -0
  128. package/number-input/NumberInput.js +83 -0
  129. package/number-input/NumberInput.stories.tsx +115 -0
  130. package/number-input/NumberInputContext.d.ts +4 -0
  131. package/number-input/NumberInputContext.js +19 -0
  132. package/number-input/numberInputContextTypes.d.ts +19 -0
  133. package/number-input/numberInputContextTypes.js +5 -0
  134. package/number-input/types.d.ts +117 -0
  135. package/number-input/types.js +5 -0
  136. package/package.json +34 -23
  137. package/paginator/Icons.js +66 -0
  138. package/paginator/Paginator.d.ts +4 -0
  139. package/paginator/Paginator.js +192 -0
  140. package/paginator/Paginator.stories.tsx +63 -0
  141. package/paginator/types.d.ts +38 -0
  142. package/paginator/types.js +5 -0
  143. package/password-input/PasswordInput.d.ts +4 -0
  144. package/password-input/PasswordInput.js +163 -0
  145. package/password-input/PasswordInput.stories.tsx +131 -0
  146. package/password-input/types.d.ts +107 -0
  147. package/password-input/types.js +5 -0
  148. package/progress-bar/ProgressBar.d.ts +4 -0
  149. package/progress-bar/ProgressBar.js +170 -0
  150. package/progress-bar/ProgressBar.stories.jsx +58 -0
  151. package/progress-bar/types.d.ts +37 -0
  152. package/progress-bar/types.js +5 -0
  153. package/radio/Radio.d.ts +4 -0
  154. package/radio/Radio.js +174 -0
  155. package/radio/Radio.stories.tsx +192 -0
  156. package/radio/types.d.ts +54 -0
  157. package/radio/types.js +5 -0
  158. package/radio-group/Radio.d.ts +4 -0
  159. package/radio-group/Radio.js +109 -0
  160. package/radio-group/RadioGroup.d.ts +4 -0
  161. package/radio-group/RadioGroup.js +166 -0
  162. package/radio-group/RadioGroup.stories.tsx +56 -0
  163. package/radio-group/types.d.ts +37 -0
  164. package/radio-group/types.js +5 -0
  165. package/resultsetTable/ResultsetTable.d.ts +4 -0
  166. package/resultsetTable/ResultsetTable.js +251 -0
  167. package/resultsetTable/ResultsetTable.stories.tsx +276 -0
  168. package/resultsetTable/types.d.ts +67 -0
  169. package/resultsetTable/types.js +5 -0
  170. package/row/Row.d.ts +11 -0
  171. package/row/Row.js +127 -0
  172. package/row/Row.stories.tsx +239 -0
  173. package/select/Select.d.ts +4 -0
  174. package/select/Select.js +863 -0
  175. package/select/Select.stories.tsx +572 -0
  176. package/select/types.d.ts +170 -0
  177. package/select/types.js +5 -0
  178. package/sidenav/Sidenav.d.ts +9 -0
  179. package/sidenav/Sidenav.js +136 -0
  180. package/sidenav/Sidenav.stories.tsx +165 -0
  181. package/sidenav/types.d.ts +50 -0
  182. package/sidenav/types.js +5 -0
  183. package/slider/Slider.d.ts +4 -0
  184. package/slider/Slider.js +317 -0
  185. package/slider/Slider.stories.tsx +177 -0
  186. package/slider/types.d.ts +78 -0
  187. package/slider/types.js +5 -0
  188. package/spinner/Spinner.d.ts +4 -0
  189. package/spinner/Spinner.js +250 -0
  190. package/spinner/Spinner.stories.jsx +102 -0
  191. package/spinner/types.d.ts +32 -0
  192. package/spinner/types.js +5 -0
  193. package/stack/Stack.d.ts +10 -0
  194. package/stack/Stack.js +97 -0
  195. package/stack/Stack.stories.tsx +166 -0
  196. package/switch/Switch.d.ts +4 -0
  197. package/switch/Switch.js +179 -0
  198. package/switch/Switch.stories.tsx +160 -0
  199. package/switch/types.d.ts +58 -0
  200. package/switch/types.js +5 -0
  201. package/table/Table.d.ts +4 -0
  202. package/table/Table.js +118 -0
  203. package/table/Table.stories.jsx +276 -0
  204. package/table/types.d.ts +21 -0
  205. package/table/types.js +5 -0
  206. package/tabs/Tabs.d.ts +4 -0
  207. package/tabs/Tabs.js +213 -0
  208. package/tabs/Tabs.stories.tsx +121 -0
  209. package/tabs/types.d.ts +70 -0
  210. package/tabs/types.js +5 -0
  211. package/tag/Tag.d.ts +4 -0
  212. package/tag/Tag.js +193 -0
  213. package/tag/Tag.stories.tsx +145 -0
  214. package/tag/types.d.ts +60 -0
  215. package/tag/types.js +5 -0
  216. package/text/Text.d.ts +7 -0
  217. package/text/Text.js +30 -0
  218. package/text/Text.stories.tsx +19 -0
  219. package/text-input/TextInput.d.ts +4 -0
  220. package/text-input/TextInput.js +786 -0
  221. package/text-input/TextInput.stories.tsx +456 -0
  222. package/text-input/types.d.ts +159 -0
  223. package/text-input/types.js +5 -0
  224. package/textarea/Textarea.d.ts +4 -0
  225. package/textarea/Textarea.js +284 -0
  226. package/textarea/Textarea.stories.jsx +135 -0
  227. package/textarea/types.d.ts +130 -0
  228. package/textarea/types.js +5 -0
  229. package/{dist/toggle → toggle}/Toggle.js +30 -67
  230. package/toggle/index.d.ts +21 -0
  231. package/toggle-group/ToggleGroup.d.ts +4 -0
  232. package/toggle-group/ToggleGroup.js +214 -0
  233. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  234. package/toggle-group/types.d.ts +97 -0
  235. package/toggle-group/types.js +5 -0
  236. package/{dist/upload → upload}/Upload.js +23 -22
  237. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  238. package/upload/buttons-upload/Icons.js +40 -0
  239. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  240. package/upload/dragAndDropArea/Icons.js +39 -0
  241. package/upload/file-upload/FileToUpload.js +115 -0
  242. package/upload/file-upload/Icons.js +66 -0
  243. package/upload/files-upload/FilesToUpload.js +109 -0
  244. package/upload/index.d.ts +15 -0
  245. package/upload/transaction/Icons.js +160 -0
  246. package/upload/transaction/Transaction.js +104 -0
  247. package/upload/transactions/Transactions.js +94 -0
  248. package/useTheme.d.ts +2 -0
  249. package/{dist/useTheme.js → useTheme.js} +1 -1
  250. package/wizard/Wizard.d.ts +4 -0
  251. package/wizard/Wizard.js +281 -0
  252. package/wizard/Wizard.stories.tsx +224 -0
  253. package/wizard/types.d.ts +60 -0
  254. package/wizard/types.js +5 -0
  255. package/README.md +0 -66
  256. package/babel.config.js +0 -8
  257. package/dist/ThemeContext.js +0 -187
  258. package/dist/accordion/Accordion.js +0 -268
  259. package/dist/accordion/Accordion.stories.js +0 -207
  260. package/dist/accordion/readme.md +0 -96
  261. package/dist/accordion-group/AccordionGroup.js +0 -159
  262. package/dist/accordion-group/AccordionGroup.stories.js +0 -207
  263. package/dist/accordion-group/readme.md +0 -70
  264. package/dist/alert/Alert.js +0 -303
  265. package/dist/alert/Alert.stories.js +0 -158
  266. package/dist/alert/close.svg +0 -4
  267. package/dist/alert/error.svg +0 -4
  268. package/dist/alert/info.svg +0 -4
  269. package/dist/alert/readme.md +0 -43
  270. package/dist/alert/success.svg +0 -4
  271. package/dist/alert/warning.svg +0 -4
  272. package/dist/badge/Badge.js +0 -42
  273. package/dist/box/Box.js +0 -145
  274. package/dist/button/Button.js +0 -199
  275. package/dist/button/Button.stories.js +0 -224
  276. package/dist/button/readme.md +0 -93
  277. package/dist/card/Card.js +0 -217
  278. package/dist/checkbox/Checkbox.js +0 -229
  279. package/dist/checkbox/Checkbox.stories.js +0 -144
  280. package/dist/checkbox/readme.md +0 -116
  281. package/dist/chip/Chip.js +0 -205
  282. package/dist/common/services/example-service.js +0 -10
  283. package/dist/common/services/example-service.test.js +0 -12
  284. package/dist/common/utils.js +0 -42
  285. package/dist/common/variables.js +0 -360
  286. package/dist/date/Date.stories.js +0 -205
  287. package/dist/date/calendar.svg +0 -1
  288. package/dist/date/calendar_dark.svg +0 -1
  289. package/dist/date/readme.md +0 -73
  290. package/dist/dialog/Dialog.js +0 -195
  291. package/dist/dialog/Dialog.stories.js +0 -217
  292. package/dist/dialog/readme.md +0 -32
  293. package/dist/dropdown/Dropdown.js +0 -446
  294. package/dist/dropdown/Dropdown.stories.js +0 -249
  295. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  296. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  297. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  298. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  299. package/dist/dropdown/readme.md +0 -69
  300. package/dist/footer/Footer.js +0 -366
  301. package/dist/footer/Footer.stories.js +0 -94
  302. package/dist/footer/dxc_logo_wht.png +0 -0
  303. package/dist/footer/readme.md +0 -41
  304. package/dist/header/Header.js +0 -368
  305. package/dist/header/Header.stories.js +0 -176
  306. package/dist/header/close_icon.svg +0 -1
  307. package/dist/header/dxc_logo_black.png +0 -0
  308. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  309. package/dist/header/dxc_logo_white.png +0 -0
  310. package/dist/header/hamb_menu_black.svg +0 -1
  311. package/dist/header/hamb_menu_white.svg +0 -1
  312. package/dist/header/readme.md +0 -33
  313. package/dist/heading/Heading.js +0 -153
  314. package/dist/input-text/InputText.js +0 -559
  315. package/dist/input-text/InputText.stories.js +0 -209
  316. package/dist/input-text/error.svg +0 -1
  317. package/dist/input-text/readme.md +0 -91
  318. package/dist/layout/ApplicationLayout.js +0 -332
  319. package/dist/layout/facebook.svg +0 -45
  320. package/dist/layout/linkedin.svg +0 -50
  321. package/dist/layout/twitter.svg +0 -53
  322. package/dist/link/Link.js +0 -187
  323. package/dist/link/readme.md +0 -51
  324. package/dist/paginator/Paginator.js +0 -251
  325. package/dist/paginator/images/next.svg +0 -3
  326. package/dist/paginator/images/nextPage.svg +0 -3
  327. package/dist/paginator/images/previous.svg +0 -3
  328. package/dist/paginator/images/previousPage.svg +0 -3
  329. package/dist/paginator/readme.md +0 -50
  330. package/dist/progress-bar/ProgressBar.js +0 -186
  331. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  332. package/dist/progress-bar/readme.md +0 -63
  333. package/dist/radio/Radio.js +0 -190
  334. package/dist/radio/Radio.stories.js +0 -166
  335. package/dist/radio/readme.md +0 -70
  336. package/dist/resultsetTable/ResultsetTable.js +0 -327
  337. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  338. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  339. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  340. package/dist/select/Select.js +0 -472
  341. package/dist/select/Select.stories.js +0 -235
  342. package/dist/select/readme.md +0 -72
  343. package/dist/sidenav/Sidenav.js +0 -125
  344. package/dist/slider/Slider.js +0 -257
  345. package/dist/slider/Slider.stories.js +0 -241
  346. package/dist/slider/readme.md +0 -64
  347. package/dist/spinner/Spinner.js +0 -192
  348. package/dist/spinner/Spinner.stories.js +0 -183
  349. package/dist/spinner/readme.md +0 -65
  350. package/dist/switch/Switch.js +0 -190
  351. package/dist/switch/Switch.stories.js +0 -134
  352. package/dist/switch/readme.md +0 -133
  353. package/dist/table/Table.js +0 -104
  354. package/dist/tabs/Tabs.js +0 -302
  355. package/dist/tabs/Tabs.stories.js +0 -130
  356. package/dist/tabs/readme.md +0 -78
  357. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  358. package/dist/tabs-for-sections/readme.md +0 -78
  359. package/dist/tag/Tag.js +0 -249
  360. package/dist/textarea/Textarea.js +0 -224
  361. package/dist/toggle/Toggle.stories.js +0 -297
  362. package/dist/toggle/readme.md +0 -80
  363. package/dist/toggle-group/ToggleGroup.js +0 -223
  364. package/dist/toggle-group/readme.md +0 -82
  365. package/dist/upload/Upload.stories.js +0 -72
  366. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -122
  367. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  368. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  369. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -279
  370. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  371. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  372. package/dist/upload/file-upload/FileToUpload.js +0 -158
  373. package/dist/upload/file-upload/audio-icon.svg +0 -4
  374. package/dist/upload/file-upload/close.svg +0 -4
  375. package/dist/upload/file-upload/file-icon.svg +0 -4
  376. package/dist/upload/file-upload/video-icon.svg +0 -4
  377. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  378. package/dist/upload/readme.md +0 -37
  379. package/dist/upload/transaction/Transaction.js +0 -155
  380. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  381. package/dist/upload/transaction/audio-icon.svg +0 -4
  382. package/dist/upload/transaction/error-icon.svg +0 -4
  383. package/dist/upload/transaction/file-icon-err.svg +0 -4
  384. package/dist/upload/transaction/file-icon.svg +0 -4
  385. package/dist/upload/transaction/image-icon-err.svg +0 -4
  386. package/dist/upload/transaction/image-icon.svg +0 -4
  387. package/dist/upload/transaction/success-icon.svg +0 -4
  388. package/dist/upload/transaction/video-icon-err.svg +0 -4
  389. package/dist/upload/transaction/video-icon.svg +0 -4
  390. package/dist/upload/transactions/Transactions.js +0 -120
  391. package/dist/wizard/Wizard.js +0 -328
  392. package/dist/wizard/invalid_icon.svg +0 -6
  393. package/dist/wizard/valid_icon.svg +0 -6
  394. package/dist/wizard/validation-wrong.svg +0 -6
  395. package/test/Accordion.test.js +0 -33
  396. package/test/AccordionGroup.test.js +0 -109
  397. package/test/Alert.test.js +0 -53
  398. package/test/Box.test.js +0 -10
  399. package/test/Button.test.js +0 -18
  400. package/test/Card.test.js +0 -30
  401. package/test/Checkbox.test.js +0 -45
  402. package/test/Chip.test.js +0 -25
  403. package/test/Date.test.js +0 -393
  404. package/test/Dialog.test.js +0 -23
  405. package/test/Dropdown.test.js +0 -130
  406. package/test/Footer.test.js +0 -99
  407. package/test/Header.test.js +0 -39
  408. package/test/Heading.test.js +0 -35
  409. package/test/InputText.test.js +0 -240
  410. package/test/Link.test.js +0 -42
  411. package/test/Paginator.test.js +0 -177
  412. package/test/ProgressBar.test.js +0 -35
  413. package/test/Radio.test.js +0 -37
  414. package/test/ResultsetTable.test.js +0 -330
  415. package/test/Select.test.js +0 -192
  416. package/test/Sidenav.test.js +0 -45
  417. package/test/Slider.test.js +0 -82
  418. package/test/Spinner.test.js +0 -27
  419. package/test/Switch.test.js +0 -45
  420. package/test/Table.test.js +0 -36
  421. package/test/Tabs.test.js +0 -109
  422. package/test/TabsForSections.test.js +0 -34
  423. package/test/Tag.test.js +0 -32
  424. package/test/TextArea.test.js +0 -52
  425. package/test/ToggleGroup.test.js +0 -81
  426. package/test/Upload.test.js +0 -60
  427. package/test/Wizard.test.js +0 -130
  428. package/test/mocks/pngMock.js +0 -1
  429. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,37 @@
1
+ declare type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ declare type Size = {
3
+ top?: Space;
4
+ bottom?: Space;
5
+ left?: Space;
6
+ right?: Space;
7
+ };
8
+ declare type Props = {
9
+ /**
10
+ * Text to be placed above the progress bar.
11
+ */
12
+ label?: string;
13
+ /**
14
+ * Helper text to be placed under the progress bar.
15
+ */
16
+ helperText?: string;
17
+ /**
18
+ * If true, the progress bar will be displayed as a modal.
19
+ */
20
+ overlay?: boolean;
21
+ /**
22
+ * The value of the progress indicator. If it's received the component is
23
+ * determinate otherwise is indeterminate.
24
+ */
25
+ value?: number;
26
+ /**
27
+ * If true, the value is displayed above the progress bar.
28
+ */
29
+ showValue?: boolean;
30
+ /**
31
+ * Size of the margin to be applied to the component. You can pass
32
+ * an object with 'top', 'bottom', 'left' and 'right' properties
33
+ * in order to specify different margin sizes.
34
+ */
35
+ margin?: Space | Size;
36
+ };
37
+ export default Props;
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import RadioPropsType from "./types";
3
+ declare const DxcRadio: ({ checked, value, label, labelPosition, name, disabled, onClick, required, margin, size, }: RadioPropsType) => JSX.Element;
4
+ export default DxcRadio;
package/radio/Radio.js ADDED
@@ -0,0 +1,174 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof3 = require("@babel/runtime/helpers/typeof");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports["default"] = void 0;
11
+
12
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
+
14
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
+
16
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
17
+
18
+ var _react = _interopRequireWildcard(require("react"));
19
+
20
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
21
+
22
+ var _Radio = _interopRequireDefault(require("@material-ui/core/Radio"));
23
+
24
+ var _RequiredComponent = _interopRequireDefault(require("../common/RequiredComponent"));
25
+
26
+ var _variables = require("../common/variables.js");
27
+
28
+ var _utils = require("../common/utils.js");
29
+
30
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
31
+
32
+ var _BackgroundColorContext = _interopRequireDefault(require("../BackgroundColorContext"));
33
+
34
+ var _templateObject, _templateObject2;
35
+
36
+ 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); }
37
+
38
+ 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; }
39
+
40
+ var DxcRadio = function DxcRadio(_ref) {
41
+ var _ref$checked = _ref.checked,
42
+ checked = _ref$checked === void 0 ? false : _ref$checked,
43
+ value = _ref.value,
44
+ _ref$label = _ref.label,
45
+ label = _ref$label === void 0 ? "" : _ref$label,
46
+ _ref$labelPosition = _ref.labelPosition,
47
+ labelPosition = _ref$labelPosition === void 0 ? "before" : _ref$labelPosition,
48
+ name = _ref.name,
49
+ _ref$disabled = _ref.disabled,
50
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
51
+ onClick = _ref.onClick,
52
+ _ref$required = _ref.required,
53
+ required = _ref$required === void 0 ? false : _ref$required,
54
+ margin = _ref.margin,
55
+ _ref$size = _ref.size,
56
+ size = _ref$size === void 0 ? "fitContent" : _ref$size;
57
+
58
+ var _useState = (0, _react.useState)(false),
59
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
60
+ innerChecked = _useState2[0],
61
+ setInnerChecked = _useState2[1];
62
+
63
+ var colorsTheme = (0, _useTheme["default"])();
64
+ var backgroundType = (0, _react.useContext)(_BackgroundColorContext["default"]);
65
+
66
+ var handlerRadioChange = function handlerRadioChange() {
67
+ if (checked == null) {
68
+ setInnerChecked(true);
69
+ }
70
+
71
+ if (typeof onClick === "function") {
72
+ onClick(true);
73
+ }
74
+ };
75
+
76
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
77
+ theme: colorsTheme.radio
78
+ }, /*#__PURE__*/_react["default"].createElement(RadioContainer, {
79
+ id: name,
80
+ labelPosition: labelPosition,
81
+ disabled: disabled,
82
+ margin: margin,
83
+ size: size,
84
+ backgroundType: backgroundType
85
+ }, /*#__PURE__*/_react["default"].createElement(_Radio["default"], {
86
+ checked: checked != null && checked || innerChecked,
87
+ name: name,
88
+ onClick: handlerRadioChange,
89
+ value: value,
90
+ disabled: disabled,
91
+ disableRipple: true
92
+ }), /*#__PURE__*/_react["default"].createElement(LabelContainer, {
93
+ checked: checked || innerChecked,
94
+ labelPosition: labelPosition,
95
+ disabled: disabled,
96
+ onClick: !disabled && handlerRadioChange || null,
97
+ backgroundType: backgroundType
98
+ }, required && /*#__PURE__*/_react["default"].createElement(_RequiredComponent["default"], null), label)));
99
+ };
100
+
101
+ var sizes = {
102
+ small: "120px",
103
+ medium: "240px",
104
+ large: "480px",
105
+ fillParent: "100%",
106
+ fitContent: "unset"
107
+ };
108
+
109
+ var calculateWidth = function calculateWidth(margin, size) {
110
+ if (size === "fillParent") {
111
+ return "calc(".concat(sizes[size], " - ").concat((0, _utils.getMargin)(margin, "left"), " - ").concat((0, _utils.getMargin)(margin, "right"), ")");
112
+ }
113
+
114
+ return sizes[size];
115
+ };
116
+
117
+ var RadioContainer = _styledComponents["default"].span(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n width: ", ";\n\n display: inline-flex;\n align-items: center;\n max-height: 42px;\n position: relative;\n flex-direction: ", ";\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n cursor: ", ";\n .MuiButtonBase-root {\n width: auto;\n height: auto;\n padding: 10px;\n margin: 2px;\n ", ": ", ";\n padding-left: ", ";\n padding-right: ", ";\n margin-left: ", ";\n margin-right: ", ";\n .MuiIconButton-label {\n .MuiSvgIcon-root {\n height: ", ";\n width: ", ";\n }\n color: ", ";\n\n > div > :nth-child(2) path {\n color: ", ";\n }\n }\n\n &.Mui-focusVisible {\n background-color: transparent;\n .MuiSvgIcon-root {\n outline: ", "\n auto 1px;\n }\n }\n :hover {\n background-color: transparent;\n }\n .MuiTouchRipple-ripple {\n height: 40px !important;\n width: 40px !important;\n top: 0px !important;\n left: 0px !important;\n }\n }\n .MuiRadio-colorSecondary.Mui-checked {\n color: ", ";\n :hover {\n background-color: transparent;\n }\n }\n"])), function (props) {
118
+ return calculateWidth(props.margin, props.size);
119
+ }, function (props) {
120
+ return props.labelPosition === "before" ? "row-reverse" : "row";
121
+ }, function (props) {
122
+ return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
123
+ }, function (props) {
124
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
125
+ }, function (props) {
126
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
127
+ }, function (props) {
128
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
129
+ }, function (props) {
130
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
131
+ }, function (props) {
132
+ return props.disabled === true ? "not-allowed" : "default";
133
+ }, function (props) {
134
+ return props.labelPosition === "after" ? "padding-right" : "padding-left";
135
+ }, function (props) {
136
+ return props.theme.circleLabelSpacing;
137
+ }, function (props) {
138
+ return props.labelPosition === "after" ? "0px" : "";
139
+ }, function (props) {
140
+ return props.labelPosition === "before" ? "0px" : "";
141
+ }, function (props) {
142
+ return props.labelPosition === "after" ? "0px" : "";
143
+ }, function (props) {
144
+ return props.labelPosition === "before" ? "0px" : "";
145
+ }, function (props) {
146
+ return props.theme.circleSize;
147
+ }, function (props) {
148
+ return props.theme.circleSize;
149
+ }, function (props) {
150
+ return props.backgroundType === "dark" ? props.disabled && props.theme.disabledColorOnDark || props.theme.colorOnDark : props.disabled && props.theme.disabledColor || props.theme.color;
151
+ }, function (props) {
152
+ return props.backgroundType === "dark" ? props.disabled && props.theme.disabledColorOnDark || props.theme.colorOnDark : props.disabled && props.theme.disabledColor || props.theme.color;
153
+ }, function (props) {
154
+ return props.backgroundType === "dark" ? props.theme.focusColorOnDark : props.theme.focusColor;
155
+ }, function (props) {
156
+ return props.backgroundType === "dark" ? props.disabled && props.theme.disabledColorOnDark || props.theme.colorOnDark : props.disabled && props.theme.disabledColor || props.theme.color;
157
+ });
158
+
159
+ var LabelContainer = _styledComponents["default"].span(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n font-style: ", ";\n color: ", ";\n cursor: ", ";\n"])), function (props) {
160
+ return props.theme.fontFamily;
161
+ }, function (props) {
162
+ return props.theme.fontSize;
163
+ }, function (props) {
164
+ return props.theme.fontWeight;
165
+ }, function (props) {
166
+ return props.theme.fontStyle;
167
+ }, function (props) {
168
+ return props.backgroundType === "dark" ? props.disabled && props.theme.disabledFontColorOnDark || props.theme.fontColorOnDark : props.disabled && props.theme.disabledFontColor || props.theme.fontColor;
169
+ }, function (props) {
170
+ return props.disabled === true ? "not-allowed" : "pointer";
171
+ });
172
+
173
+ var _default = DxcRadio;
174
+ exports["default"] = _default;
@@ -0,0 +1,192 @@
1
+ import React from "react";
2
+ import DxcRadio from "./Radio";
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, within } from "@storybook/testing-library";
8
+
9
+ export default {
10
+ title: "Radio",
11
+ component: DxcRadio,
12
+ };
13
+
14
+ const Radio = () => (
15
+ <>
16
+ <>
17
+ <ExampleContainer>
18
+ <Title title="Default" theme="light" level={4} />
19
+ <DxcRadio label="Radio" />
20
+ </ExampleContainer>
21
+ <ExampleContainer>
22
+ <Title title="Focused" theme="light" level={4} />
23
+ <DxcRadio label="Focused" />
24
+ </ExampleContainer>
25
+ <ExampleContainer>
26
+ <Title title="Checked" theme="light" level={4} />
27
+ <DxcRadio label="Radio" checked />
28
+ </ExampleContainer>
29
+ <ExampleContainer>
30
+ <Title title="Required" theme="light" level={4} />
31
+ <DxcRadio label="Radio" required />
32
+ </ExampleContainer>
33
+ <ExampleContainer>
34
+ <Title title="Disabled and checked" theme="light" level={4} />
35
+ <DxcRadio label="Radio" disabled checked />
36
+ </ExampleContainer>
37
+ <ExampleContainer>
38
+ <Title title="Disabled and required" theme="light" level={4} />
39
+ <DxcRadio label="Radio" disabled required />
40
+ </ExampleContainer>
41
+ <ExampleContainer>
42
+ <Title title="Disabled, required and checked" theme="light" level={4} />
43
+ <DxcRadio label="Radio" disabled required checked />
44
+ </ExampleContainer>
45
+ <ExampleContainer>
46
+ <Title title="Label after" theme="light" level={4} />
47
+ <DxcRadio label="Radio" labelPosition="after" />
48
+ </ExampleContainer>
49
+ <ExampleContainer>
50
+ <Title title="Checked with label after" theme="light" level={4} />
51
+ <DxcRadio label="Radio" checked labelPosition="after" />
52
+ </ExampleContainer>
53
+ <ExampleContainer>
54
+ <Title title="Required with label after" theme="light" level={4} />
55
+ <DxcRadio label="Radio" required labelPosition="after" />
56
+ </ExampleContainer>
57
+ <ExampleContainer>
58
+ <Title title="Disabled and checked with label after" theme="light" level={4} />
59
+ <DxcRadio label="Radio" disabled checked labelPosition="after" />
60
+ </ExampleContainer>
61
+ <ExampleContainer>
62
+ <Title title="Disabled and required with label after" theme="light" level={4} />
63
+ <DxcRadio label="Radio" disabled required labelPosition="after" />
64
+ </ExampleContainer>
65
+ <ExampleContainer>
66
+ <Title title="Disabled, required and checked with label after" theme="light" level={4} />
67
+ <DxcRadio label="Radio" disabled required checked labelPosition="after" />
68
+ </ExampleContainer>
69
+ <ExampleContainer pseudoState="pseudo-hover">
70
+ <Title title="Hovered" theme="light" level={4} />
71
+ <DxcRadio label="Hovered" />
72
+ </ExampleContainer>
73
+ <ExampleContainer pseudoState="pseudo-hover">
74
+ <Title title="Hovered and checked" theme="light" level={4} />
75
+ <DxcRadio label="Hovered" checked />
76
+ </ExampleContainer>
77
+ </>
78
+ <BackgroundColorProvider color="#333333">
79
+ <DarkContainer>
80
+ <>
81
+ <ExampleContainer>
82
+ <Title title="Default" theme="dark" level={4} />
83
+ <DxcRadio label="Radio" />
84
+ </ExampleContainer>
85
+ <ExampleContainer>
86
+ <Title title="Checked" theme="dark" level={4} />
87
+ <DxcRadio label="Radio" checked />
88
+ </ExampleContainer>
89
+ <ExampleContainer>
90
+ <Title title="Required" theme="dark" level={4} />
91
+ <DxcRadio label="Radio" required />
92
+ </ExampleContainer>
93
+ <ExampleContainer>
94
+ <Title title="Disabled and checked" theme="dark" level={4} />
95
+ <DxcRadio label="Radio" disabled checked />
96
+ </ExampleContainer>
97
+ <ExampleContainer>
98
+ <Title title="Disabled and required" theme="dark" level={4} />
99
+ <DxcRadio label="Radio" disabled required />
100
+ </ExampleContainer>
101
+ <ExampleContainer>
102
+ <Title title="Disabled, required and checked" theme="dark" level={4} />
103
+ <DxcRadio label="Radio" disabled required checked />
104
+ </ExampleContainer>
105
+ <ExampleContainer>
106
+ <Title title="Label after" theme="dark" level={4} />
107
+ <DxcRadio label="Radio" labelPosition="after" />
108
+ </ExampleContainer>
109
+ <ExampleContainer>
110
+ <Title title="Checked with label after" theme="dark" level={4} />
111
+ <DxcRadio label="Radio" checked labelPosition="after" />
112
+ </ExampleContainer>
113
+ <ExampleContainer>
114
+ <Title title="Required with label after" theme="dark" level={4} />
115
+ <DxcRadio label="Radio" required labelPosition="after" />
116
+ </ExampleContainer>
117
+ <ExampleContainer>
118
+ <Title title="Disabled and checked with label after" theme="dark" level={4} />
119
+ <DxcRadio label="Radio" disabled checked labelPosition="after" />
120
+ </ExampleContainer>
121
+ <ExampleContainer>
122
+ <Title title="Disabled and required with label after" theme="dark" level={4} />
123
+ <DxcRadio label="Radio" disabled required labelPosition="after" />
124
+ </ExampleContainer>
125
+ <ExampleContainer>
126
+ <Title title="Disabled, required and checked with label after" theme="dark" level={4} />
127
+ <DxcRadio label="Radio" disabled required checked labelPosition="after" />
128
+ </ExampleContainer>
129
+ <ExampleContainer pseudoState="pseudo-hover">
130
+ <Title title="Hovered" theme="dark" level={4} />
131
+ <DxcRadio label="Hovered" />
132
+ </ExampleContainer>
133
+ <ExampleContainer pseudoState="pseudo-hover">
134
+ <Title title="Hovered and checked" theme="dark" level={4} />
135
+ <DxcRadio label="Hovered" checked />
136
+ </ExampleContainer>
137
+ </>
138
+ </DarkContainer>
139
+ </BackgroundColorProvider>
140
+ <Title title="Sizes" theme="light" level={2} />
141
+ <ExampleContainer>
142
+ <DxcRadio label="Small" size="small" />
143
+ </ExampleContainer>
144
+ <ExampleContainer>
145
+ <DxcRadio label="Medium" size="medium" />
146
+ </ExampleContainer>
147
+ <ExampleContainer>
148
+ <DxcRadio label="Large" size="large" />
149
+ </ExampleContainer>
150
+ <ExampleContainer>
151
+ <DxcRadio label="FitContent" size="fitContent" />
152
+ </ExampleContainer>
153
+ <ExampleContainer>
154
+ <DxcRadio label="FillParent" size="fillParent" />
155
+ </ExampleContainer>
156
+ <Title title="Margins" theme="light" level={2} />
157
+ <ExampleContainer>
158
+ <Title title="Xxsmall" theme="light" level={4} />
159
+ <DxcRadio label="Xxsmall" margin={"xxsmall"} />
160
+ </ExampleContainer>
161
+ <ExampleContainer>
162
+ <Title title="Xsmall" theme="light" level={4} />
163
+ <DxcRadio label="Xsmall" margin={"xsmall"} />
164
+ </ExampleContainer>
165
+ <ExampleContainer>
166
+ <Title title="Small" theme="light" level={4} />
167
+ <DxcRadio label="Small" margin={"small"} />
168
+ </ExampleContainer>
169
+ <ExampleContainer>
170
+ <Title title="Medium" theme="light" level={4} />
171
+ <DxcRadio label="Medium" margin={"medium"} />
172
+ </ExampleContainer>
173
+ <ExampleContainer>
174
+ <Title title="Large" theme="light" level={4} />
175
+ <DxcRadio label="Large" margin={"large"} />
176
+ </ExampleContainer>
177
+ <ExampleContainer>
178
+ <Title title="Xlarge" theme="light" level={4} />
179
+ <DxcRadio label="Xlarge" margin={"xlarge"} />
180
+ </ExampleContainer>
181
+ <ExampleContainer>
182
+ <Title title="Xxlarge" theme="light" level={4} />
183
+ <DxcRadio label="Xxlarge" margin={"xxlarge"} />
184
+ </ExampleContainer>
185
+ </>
186
+ );
187
+
188
+ export const Chromatic = Radio.bind({});
189
+ Chromatic.play = async () => {
190
+ await userEvent.tab();
191
+ await userEvent.tab();
192
+ };
@@ -0,0 +1,54 @@
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
+ * If true, the radio is selected. If undefined the component will be uncontrolled
11
+ * and the value will be managed internally by the component.
12
+ */
13
+ checked?: boolean;
14
+ /**
15
+ * Will be passed to the value attribute of the html input element. When inside a
16
+ * form, this value will be only submitted if the radio is checked.
17
+ */
18
+ value?: string;
19
+ /**
20
+ * Text to be placed next to the radio.
21
+ */
22
+ label: string;
23
+ /**
24
+ * Whether the label should appear after or before the radio.
25
+ */
26
+ labelPosition?: "before" | "after";
27
+ /**
28
+ * Name attribute of the input element.
29
+ */
30
+ name?: string;
31
+ /**
32
+ * If true, the component will be disabled.
33
+ */
34
+ disabled?: boolean;
35
+ /**
36
+ * If true, the radio will change its appearence, showing that the value is required.
37
+ */
38
+ required?: boolean;
39
+ /**
40
+ * This function will be called when the user clicks the radio. The new value will
41
+ * be passed as a parameter.
42
+ */
43
+ onClick?: (val: boolean) => void;
44
+ /**
45
+ * Size of the margin to be applied to the component ('xxsmall' | 'xsmall' | 'small' | 'medium' | 'large' | 'xlarge' | 'xxlarge').
46
+ * You can pass an object with 'top', 'bottom', 'left' and 'right' properties in order to specify different margin sizes.
47
+ */
48
+ margin?: Space | Margin;
49
+ /**
50
+ * Size of the component.
51
+ */
52
+ size?: "small" | "medium" | "large" | "fillParent" | "fitContent";
53
+ };
54
+ export default Props;
package/radio/types.js ADDED
@@ -0,0 +1,5 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import { RadioProps } from "./types";
3
+ declare const _default: React.MemoExoticComponent<({ option, currentValue, onChange, disabledRadioGroup, error, first }: RadioProps) => JSX.Element>;
4
+ export default _default;
@@ -0,0 +1,109 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof = require("@babel/runtime/helpers/typeof");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports["default"] = void 0;
11
+
12
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
13
+
14
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
15
+
16
+ var _react = _interopRequireWildcard(require("react"));
17
+
18
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
+
20
+ var _uuid = require("uuid");
21
+
22
+ var _useTheme = _interopRequireDefault(require("../useTheme"));
23
+
24
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5;
25
+
26
+ 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); }
27
+
28
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(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; }
29
+
30
+ var DxcRadio = function DxcRadio(_ref) {
31
+ var option = _ref.option,
32
+ currentValue = _ref.currentValue,
33
+ onChange = _ref.onChange,
34
+ disabledRadioGroup = _ref.disabledRadioGroup,
35
+ error = _ref.error,
36
+ _ref$first = _ref.first,
37
+ first = _ref$first === void 0 ? false : _ref$first;
38
+
39
+ var _useState = (0, _react.useState)("radio-".concat((0, _uuid.v4)())),
40
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 1),
41
+ radioLabelId = _useState2[0];
42
+
43
+ var radioRef = (0, _react.useRef)(null);
44
+ var colorsTheme = (0, _useTheme["default"])();
45
+ var checked = option.value === currentValue;
46
+ var disabled = disabledRadioGroup || option.disabled;
47
+
48
+ var handleRadioOnClick = function handleRadioOnClick() {
49
+ onChange(option.value);
50
+ };
51
+
52
+ var handleLabelOnClick = function handleLabelOnClick() {
53
+ var _radioRef$current;
54
+
55
+ onChange(option.value);
56
+ radioRef === null || radioRef === void 0 ? void 0 : (_radioRef$current = radioRef.current) === null || _radioRef$current === void 0 ? void 0 : _radioRef$current.focus();
57
+ };
58
+
59
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
60
+ theme: colorsTheme.radioGroup
61
+ }, /*#__PURE__*/_react["default"].createElement(RadioContainer, null, /*#__PURE__*/_react["default"].createElement(RadioInputContainer, null, /*#__PURE__*/_react["default"].createElement(RadioInput, {
62
+ disabled: disabled,
63
+ error: error,
64
+ onClick: handleRadioOnClick,
65
+ role: "radio",
66
+ "aria-checked": checked,
67
+ "aria-labelledby": radioLabelId,
68
+ tabIndex: (checked || first) && !disabled ? 0 : -1,
69
+ ref: radioRef
70
+ }, checked && /*#__PURE__*/_react["default"].createElement(Dot, {
71
+ error: error
72
+ }))), /*#__PURE__*/_react["default"].createElement(Label, {
73
+ id: radioLabelId,
74
+ onClick: handleLabelOnClick,
75
+ disabled: disabled
76
+ }, option.label)));
77
+ };
78
+
79
+ var RadioContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n"])));
80
+
81
+ var RadioInputContainer = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n height: 24px;\n width: 24px;\n"])));
82
+
83
+ var RadioInput = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-items: center;\n justify-content: center;\n box-sizing: border-box;\n width: 18px;\n height: 18px;\n border: 2px solid\n ", ";\n border-radius: 50%;\n box-shadow: 0 0 0 2px transparent;\n\n ", "\n"])), function (props) {
84
+ return props.disabled ? props.theme.disabledRadioInputColor : props.error ? props.theme.errorRadioInputColor : props.theme.radioInputColor;
85
+ }, function (props) {
86
+ return !props.disabled ? "\n &:focus {\n outline: 2px solid ".concat(props.theme.focusBorderColor, ";\n outline-offset: 1px;\n }\n &:focus-visible {\n outline: 2px solid ").concat(props.theme.focusBorderColor, ";\n outline-offset: 1px;\n }\n &:hover {\n cursor: pointer;\n border-color: ").concat(props.error ? props.theme.hoverErrorRadioInputColor : props.theme.hoverInputColor, ";\n & > span {\n background-color: ").concat(props.error ? props.theme.hoverErrorRadioInputColor : props.theme.hoverInputColor, ";\n }\n }\n &:active {\n cursor: pointer;\n border-color: ").concat(props.error ? props.theme.activeErrorInputColor : props.theme.activeInputColor, ";\n & > span {\n background-color: ").concat(props.error ? props.theme.activeErrorInputColor : props.theme.activeInputColor, ";\n }\n }\n ") : "\n & > span {\n background-color: ".concat(props.theme.disabledRadioInputColor, ";\n }\n cursor: not-allowed;\n pointer-events: none;\n :focus-visible {\n outline: none;\n }\n ");
87
+ });
88
+
89
+ var Dot = _styledComponents["default"].span(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n height: 10px;\n width: 10px;\n background-color: ", ";\n border-radius: 50%;\n"])), function (props) {
90
+ return props.error ? props.theme.errorRadioInputColor : props.theme.radioInputColor;
91
+ });
92
+
93
+ var Label = _styledComponents["default"].label(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n margin-left: 0.5rem;\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n line-height: ", ";\n ", "\n"])), function (props) {
94
+ return props.theme.fontFamily;
95
+ }, function (props) {
96
+ return props.theme.radioInputLabelFontSize;
97
+ }, function (props) {
98
+ return props.theme.radioInputLabelFontStyle;
99
+ }, function (props) {
100
+ return props.theme.radioInputLabelFontWeight;
101
+ }, function (props) {
102
+ return props.theme.radioInputLabelLineHeight;
103
+ }, function (props) {
104
+ return props.disabled && "color: ".concat(props.theme.disabledRadioInputLabelFontColor, "; pointer-events: none;");
105
+ });
106
+
107
+ var _default = /*#__PURE__*/_react["default"].memo(DxcRadio);
108
+
109
+ exports["default"] = _default;
@@ -0,0 +1,4 @@
1
+ import React from "react";
2
+ import RadioGroupPropsType from "./types";
3
+ declare const DxcRadioGroup: React.ForwardRefExoticComponent<RadioGroupPropsType & React.RefAttributes<HTMLDivElement>>;
4
+ export default DxcRadioGroup;