@dxc-technology/halstack-react 0.0.0-da2248d → 0.0.0-da224ae

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 (361) hide show
  1. package/BackgroundColorContext.js +50 -0
  2. package/ThemeContext.js +246 -0
  3. package/V3Select/V3Select.js +455 -0
  4. package/V3Select/index.d.ts +27 -0
  5. package/V3Textarea/V3Textarea.js +260 -0
  6. package/V3Textarea/index.d.ts +27 -0
  7. package/accordion/Accordion.d.ts +4 -0
  8. package/accordion/Accordion.js +258 -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 +170 -0
  13. package/accordion-group/types.d.ts +72 -0
  14. package/accordion-group/types.js +5 -0
  15. package/alert/Alert.d.ts +4 -0
  16. package/alert/Alert.js +290 -0
  17. package/alert/Alert.stories.tsx +170 -0
  18. package/alert/types.d.ts +49 -0
  19. package/alert/types.js +5 -0
  20. package/badge/Badge.js +59 -0
  21. package/box/Box.d.ts +4 -0
  22. package/{dist/box → box}/Box.js +18 -53
  23. package/box/Box.stories.tsx +132 -0
  24. package/box/types.d.ts +47 -0
  25. package/box/types.js +5 -0
  26. package/button/Button.d.ts +4 -0
  27. package/button/Button.js +177 -0
  28. package/button/Button.stories.tsx +276 -0
  29. package/button/types.d.ts +57 -0
  30. package/button/types.js +5 -0
  31. package/card/Card.d.ts +4 -0
  32. package/{dist/card → card}/Card.js +42 -124
  33. package/card/types.d.ts +69 -0
  34. package/card/types.js +5 -0
  35. package/checkbox/Checkbox.d.ts +4 -0
  36. package/checkbox/Checkbox.js +253 -0
  37. package/checkbox/Checkbox.stories.tsx +192 -0
  38. package/checkbox/types.d.ts +60 -0
  39. package/checkbox/types.js +5 -0
  40. package/{dist/chip → chip}/Chip.js +74 -76
  41. package/chip/Chip.stories.tsx +121 -0
  42. package/chip/index.d.ts +22 -0
  43. package/{dist/common → common}/OpenSans.css +0 -0
  44. package/{dist/common → common}/RequiredComponent.js +3 -11
  45. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  46. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  47. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  48. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  49. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  50. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  51. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  52. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  53. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  54. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  55. package/{dist/common → common}/utils.js +0 -0
  56. package/common/variables.js +1577 -0
  57. package/{dist/date → date}/Date.js +71 -57
  58. package/date/index.d.ts +27 -0
  59. package/date-input/DateInput.d.ts +4 -0
  60. package/date-input/DateInput.js +361 -0
  61. package/date-input/DateInput.stories.tsx +138 -0
  62. package/date-input/types.d.ts +100 -0
  63. package/date-input/types.js +5 -0
  64. package/dialog/Dialog.d.ts +4 -0
  65. package/dialog/Dialog.js +165 -0
  66. package/dialog/Dialog.stories.tsx +212 -0
  67. package/dialog/types.d.ts +43 -0
  68. package/dialog/types.js +5 -0
  69. package/dropdown/Dropdown.d.ts +4 -0
  70. package/dropdown/Dropdown.js +417 -0
  71. package/dropdown/types.d.ts +89 -0
  72. package/dropdown/types.js +5 -0
  73. package/file-input/FileInput.js +532 -0
  74. package/file-input/FileItem.js +193 -0
  75. package/file-input/index.d.ts +81 -0
  76. package/footer/Footer.d.ts +4 -0
  77. package/footer/Footer.js +266 -0
  78. package/footer/Footer.stories.jsx +151 -0
  79. package/footer/Icons.js +77 -0
  80. package/footer/types.d.ts +61 -0
  81. package/footer/types.js +5 -0
  82. package/header/Header.d.ts +7 -0
  83. package/header/Header.js +324 -0
  84. package/header/Icons.js +34 -0
  85. package/header/types.d.ts +45 -0
  86. package/header/types.js +5 -0
  87. package/heading/Heading.d.ts +4 -0
  88. package/{dist/heading → heading}/Heading.js +30 -93
  89. package/heading/types.d.ts +33 -0
  90. package/heading/types.js +5 -0
  91. package/input-text/Icons.js +22 -0
  92. package/{dist/input-text → input-text}/InputText.js +151 -171
  93. package/input-text/index.d.ts +36 -0
  94. package/{dist/layout → layout}/ApplicationLayout.js +35 -131
  95. package/layout/Icons.js +55 -0
  96. package/link/Link.d.ts +3 -0
  97. package/link/Link.js +161 -0
  98. package/link/Link.stories.tsx +70 -0
  99. package/link/types.d.ts +74 -0
  100. package/link/types.js +5 -0
  101. package/main.d.ts +44 -0
  102. package/{dist/main.js → main.js} +121 -69
  103. package/number-input/NumberInput.d.ts +4 -0
  104. package/number-input/NumberInput.js +86 -0
  105. package/number-input/NumberInput.stories.tsx +115 -0
  106. package/number-input/NumberInputContext.js +16 -0
  107. package/number-input/types.d.ts +117 -0
  108. package/number-input/types.js +5 -0
  109. package/package.json +34 -25
  110. package/paginator/Icons.js +66 -0
  111. package/paginator/Paginator.d.ts +4 -0
  112. package/paginator/Paginator.js +198 -0
  113. package/paginator/Paginator.stories.tsx +63 -0
  114. package/paginator/types.d.ts +38 -0
  115. package/paginator/types.js +5 -0
  116. package/password-input/PasswordInput.d.ts +4 -0
  117. package/password-input/PasswordInput.js +162 -0
  118. package/password-input/PasswordInput.stories.tsx +131 -0
  119. package/password-input/types.d.ts +100 -0
  120. package/password-input/types.js +5 -0
  121. package/progress-bar/ProgressBar.d.ts +4 -0
  122. package/progress-bar/ProgressBar.js +170 -0
  123. package/progress-bar/ProgressBar.stories.jsx +58 -0
  124. package/progress-bar/types.d.ts +37 -0
  125. package/progress-bar/types.js +5 -0
  126. package/radio/Radio.d.ts +4 -0
  127. package/radio/Radio.js +174 -0
  128. package/radio/Radio.stories.tsx +192 -0
  129. package/radio/types.d.ts +54 -0
  130. package/radio/types.js +5 -0
  131. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +77 -135
  132. package/resultsetTable/index.d.ts +19 -0
  133. package/select/Select.js +865 -0
  134. package/select/Select.stories.tsx +572 -0
  135. package/select/index.d.ts +131 -0
  136. package/sidenav/Sidenav.d.ts +9 -0
  137. package/sidenav/Sidenav.js +136 -0
  138. package/sidenav/types.d.ts +50 -0
  139. package/sidenav/types.js +5 -0
  140. package/slider/Slider.d.ts +4 -0
  141. package/slider/Slider.js +317 -0
  142. package/slider/Slider.stories.tsx +177 -0
  143. package/slider/types.d.ts +78 -0
  144. package/slider/types.js +5 -0
  145. package/spinner/Spinner.d.ts +4 -0
  146. package/spinner/Spinner.js +250 -0
  147. package/spinner/Spinner.stories.jsx +102 -0
  148. package/spinner/types.d.ts +32 -0
  149. package/spinner/types.js +5 -0
  150. package/switch/Switch.d.ts +4 -0
  151. package/{dist/switch → switch}/Switch.js +28 -71
  152. package/switch/Switch.stories.tsx +160 -0
  153. package/switch/types.d.ts +58 -0
  154. package/switch/types.js +5 -0
  155. package/table/Table.d.ts +4 -0
  156. package/table/Table.js +118 -0
  157. package/table/Table.stories.jsx +276 -0
  158. package/table/types.d.ts +21 -0
  159. package/table/types.js +5 -0
  160. package/tabs/Tabs.d.ts +4 -0
  161. package/tabs/Tabs.js +211 -0
  162. package/tabs/types.d.ts +71 -0
  163. package/tabs/types.js +5 -0
  164. package/tag/Tag.d.ts +4 -0
  165. package/tag/Tag.js +193 -0
  166. package/tag/Tag.stories.tsx +145 -0
  167. package/tag/types.d.ts +60 -0
  168. package/tag/types.js +5 -0
  169. package/text-input/TextInput.js +825 -0
  170. package/text-input/index.d.ts +135 -0
  171. package/textarea/Textarea.js +317 -0
  172. package/textarea/Textarea.stories.jsx +135 -0
  173. package/textarea/index.d.ts +117 -0
  174. package/{dist/toggle → toggle}/Toggle.js +15 -49
  175. package/toggle/index.d.ts +21 -0
  176. package/toggle-group/ToggleGroup.js +243 -0
  177. package/toggle-group/ToggleGroup.stories.tsx +178 -0
  178. package/toggle-group/index.d.ts +21 -0
  179. package/{dist/upload → upload}/Upload.js +11 -19
  180. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  181. package/upload/buttons-upload/Icons.js +40 -0
  182. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  183. package/upload/dragAndDropArea/Icons.js +39 -0
  184. package/upload/file-upload/FileToUpload.js +115 -0
  185. package/upload/file-upload/Icons.js +66 -0
  186. package/{dist/upload → upload}/files-upload/FilesToUpload.js +14 -28
  187. package/upload/index.d.ts +15 -0
  188. package/upload/transaction/Icons.js +160 -0
  189. package/upload/transaction/Transaction.js +104 -0
  190. package/upload/transactions/Transactions.js +94 -0
  191. package/{dist/useTheme.js → useTheme.js} +0 -0
  192. package/wizard/Icons.js +65 -0
  193. package/wizard/Wizard.d.ts +4 -0
  194. package/wizard/Wizard.js +231 -0
  195. package/wizard/Wizard.stories.jsx +224 -0
  196. package/wizard/types.d.ts +64 -0
  197. package/wizard/types.js +5 -0
  198. package/README.md +0 -66
  199. package/babel.config.js +0 -8
  200. package/dist/BackgroundColorContext.js +0 -46
  201. package/dist/ThemeContext.js +0 -216
  202. package/dist/accordion/Accordion.js +0 -356
  203. package/dist/accordion/Accordion.stories.js +0 -207
  204. package/dist/accordion/readme.md +0 -96
  205. package/dist/accordion-group/AccordionGroup.js +0 -188
  206. package/dist/accordion-group/AccordionGroup.stories.js +0 -207
  207. package/dist/accordion-group/readme.md +0 -70
  208. package/dist/alert/Alert.js +0 -318
  209. package/dist/alert/Alert.stories.js +0 -158
  210. package/dist/alert/close.svg +0 -4
  211. package/dist/alert/error.svg +0 -4
  212. package/dist/alert/info.svg +0 -4
  213. package/dist/alert/readme.md +0 -43
  214. package/dist/alert/success.svg +0 -4
  215. package/dist/alert/warning.svg +0 -4
  216. package/dist/badge/Badge.js +0 -61
  217. package/dist/button/Button.js +0 -228
  218. package/dist/button/Button.stories.js +0 -224
  219. package/dist/button/readme.md +0 -93
  220. package/dist/checkbox/Checkbox.js +0 -233
  221. package/dist/checkbox/Checkbox.stories.js +0 -144
  222. package/dist/checkbox/readme.md +0 -116
  223. package/dist/common/variables.js +0 -882
  224. package/dist/date/Date.stories.js +0 -205
  225. package/dist/date/calendar.svg +0 -1
  226. package/dist/date/calendar_dark.svg +0 -1
  227. package/dist/date/readme.md +0 -73
  228. package/dist/dialog/Dialog.js +0 -203
  229. package/dist/dialog/Dialog.stories.js +0 -217
  230. package/dist/dialog/readme.md +0 -32
  231. package/dist/dropdown/Dropdown.js +0 -456
  232. package/dist/dropdown/Dropdown.stories.js +0 -249
  233. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  234. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  235. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  236. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  237. package/dist/dropdown/readme.md +0 -69
  238. package/dist/footer/Footer.js +0 -405
  239. package/dist/footer/Footer.stories.js +0 -94
  240. package/dist/footer/dxc_logo_wht.png +0 -0
  241. package/dist/footer/readme.md +0 -41
  242. package/dist/header/Header.js +0 -431
  243. package/dist/header/Header.stories.js +0 -176
  244. package/dist/header/close_icon.svg +0 -1
  245. package/dist/header/dxc_logo_black.png +0 -0
  246. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  247. package/dist/header/dxc_logo_white.png +0 -0
  248. package/dist/header/hamb_menu_black.svg +0 -1
  249. package/dist/header/hamb_menu_white.svg +0 -1
  250. package/dist/header/readme.md +0 -33
  251. package/dist/input-text/InputText.stories.js +0 -209
  252. package/dist/input-text/error.svg +0 -1
  253. package/dist/input-text/readme.md +0 -91
  254. package/dist/layout/facebook.svg +0 -45
  255. package/dist/layout/linkedin.svg +0 -50
  256. package/dist/layout/twitter.svg +0 -53
  257. package/dist/link/Link.js +0 -212
  258. package/dist/link/readme.md +0 -51
  259. package/dist/paginator/Paginator.js +0 -283
  260. package/dist/paginator/images/next.svg +0 -3
  261. package/dist/paginator/images/nextPage.svg +0 -3
  262. package/dist/paginator/images/previous.svg +0 -3
  263. package/dist/paginator/images/previousPage.svg +0 -3
  264. package/dist/paginator/readme.md +0 -50
  265. package/dist/progress-bar/ProgressBar.js +0 -206
  266. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  267. package/dist/progress-bar/readme.md +0 -63
  268. package/dist/radio/Radio.js +0 -190
  269. package/dist/radio/Radio.stories.js +0 -166
  270. package/dist/radio/readme.md +0 -70
  271. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  272. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  273. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  274. package/dist/select/Select.js +0 -490
  275. package/dist/select/Select.stories.js +0 -235
  276. package/dist/select/readme.md +0 -72
  277. package/dist/sidenav/Sidenav.js +0 -183
  278. package/dist/slider/Slider.js +0 -267
  279. package/dist/slider/Slider.stories.js +0 -241
  280. package/dist/slider/readme.md +0 -64
  281. package/dist/spinner/Spinner.js +0 -214
  282. package/dist/spinner/Spinner.stories.js +0 -183
  283. package/dist/spinner/readme.md +0 -65
  284. package/dist/switch/Switch.stories.js +0 -134
  285. package/dist/switch/readme.md +0 -133
  286. package/dist/table/Table.js +0 -118
  287. package/dist/tabs/Tabs.js +0 -347
  288. package/dist/tabs/Tabs.stories.js +0 -130
  289. package/dist/tabs/readme.md +0 -78
  290. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  291. package/dist/tabs-for-sections/readme.md +0 -78
  292. package/dist/tag/Tag.js +0 -268
  293. package/dist/textarea/Textarea.js +0 -238
  294. package/dist/toggle/Toggle.stories.js +0 -297
  295. package/dist/toggle/readme.md +0 -80
  296. package/dist/toggle-group/ToggleGroup.js +0 -241
  297. package/dist/toggle-group/readme.md +0 -82
  298. package/dist/upload/Upload.stories.js +0 -72
  299. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -123
  300. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  301. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  302. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -293
  303. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  304. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  305. package/dist/upload/file-upload/FileToUpload.js +0 -162
  306. package/dist/upload/file-upload/audio-icon.svg +0 -4
  307. package/dist/upload/file-upload/close.svg +0 -4
  308. package/dist/upload/file-upload/file-icon.svg +0 -4
  309. package/dist/upload/file-upload/video-icon.svg +0 -4
  310. package/dist/upload/readme.md +0 -37
  311. package/dist/upload/transaction/Transaction.js +0 -152
  312. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  313. package/dist/upload/transaction/audio-icon.svg +0 -4
  314. package/dist/upload/transaction/error-icon.svg +0 -4
  315. package/dist/upload/transaction/file-icon-err.svg +0 -4
  316. package/dist/upload/transaction/file-icon.svg +0 -4
  317. package/dist/upload/transaction/image-icon-err.svg +0 -4
  318. package/dist/upload/transaction/image-icon.svg +0 -4
  319. package/dist/upload/transaction/success-icon.svg +0 -4
  320. package/dist/upload/transaction/video-icon-err.svg +0 -4
  321. package/dist/upload/transaction/video-icon.svg +0 -4
  322. package/dist/upload/transactions/Transactions.js +0 -122
  323. package/dist/wizard/Wizard.js +0 -383
  324. package/dist/wizard/invalid_icon.svg +0 -6
  325. package/dist/wizard/valid_icon.svg +0 -6
  326. package/dist/wizard/validation-wrong.svg +0 -6
  327. package/test/Accordion.test.js +0 -33
  328. package/test/AccordionGroup.test.js +0 -125
  329. package/test/Alert.test.js +0 -53
  330. package/test/Box.test.js +0 -10
  331. package/test/Button.test.js +0 -18
  332. package/test/Card.test.js +0 -30
  333. package/test/Checkbox.test.js +0 -45
  334. package/test/Chip.test.js +0 -25
  335. package/test/Date.test.js +0 -393
  336. package/test/Dialog.test.js +0 -23
  337. package/test/Dropdown.test.js +0 -130
  338. package/test/Footer.test.js +0 -99
  339. package/test/Header.test.js +0 -39
  340. package/test/Heading.test.js +0 -35
  341. package/test/InputText.test.js +0 -240
  342. package/test/Link.test.js +0 -42
  343. package/test/Paginator.test.js +0 -177
  344. package/test/ProgressBar.test.js +0 -35
  345. package/test/Radio.test.js +0 -37
  346. package/test/ResultsetTable.test.js +0 -330
  347. package/test/Select.test.js +0 -192
  348. package/test/Sidenav.test.js +0 -45
  349. package/test/Slider.test.js +0 -82
  350. package/test/Spinner.test.js +0 -27
  351. package/test/Switch.test.js +0 -45
  352. package/test/Table.test.js +0 -36
  353. package/test/Tabs.test.js +0 -109
  354. package/test/TabsForSections.test.js +0 -34
  355. package/test/Tag.test.js +0 -32
  356. package/test/TextArea.test.js +0 -52
  357. package/test/ToggleGroup.test.js +0 -81
  358. package/test/Upload.test.js +0 -60
  359. package/test/Wizard.test.js +0 -130
  360. package/test/mocks/pngMock.js +0 -1
  361. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,178 @@
1
+ import React from "react";
2
+ import { userEvent, within } from "@storybook/testing-library";
3
+ import DxcToggleGroup from "./ToggleGroup";
4
+ import Title from "../../.storybook/components/Title";
5
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
6
+
7
+ export default {
8
+ title: "ToggleGroup",
9
+ component: DxcToggleGroup,
10
+ };
11
+
12
+ const ethernetSVG = () => {
13
+ return (
14
+ <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
15
+ <path d="M0 0h24v24H0V0z" fill="none" />
16
+ <path d="M7.77 6.76L6.23 5.48.82 12l5.41 6.52 1.54-1.28L3.42 12l4.35-5.24zM7 13h2v-2H7v2zm10-2h-2v2h2v-2zm-6 2h2v-2h-2v2zm6.77-7.52l-1.54 1.28L20.58 12l-4.35 5.24 1.54 1.28L23.18 12l-5.41-6.52z" />
17
+ </svg>
18
+ );
19
+ };
20
+ const gMobileSVG = () => {
21
+ return (
22
+ <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
23
+ <g>
24
+ <path d="M0,0h24v24H0V0z" fill="none" />
25
+ </g>
26
+ <g>
27
+ <g>
28
+ <path d="M3,7v2h5v2H4v2h4v2H3v2h5c1.1,0,2-0.9,2-2v-1.5c0-0.83-0.67-1.5-1.5-1.5c0.83,0,1.5-0.67,1.5-1.5V9c0-1.1-0.9-2-2-2H3z M21,11v4c0,1.1-0.9,2-2,2h-5c-1.1,0-2-0.9-2-2V9c0-1.1,0.9-2,2-2h5c1.1,0,2,0.9,2,2h-7v6h5v-2h-2.5v-2H21z" />
29
+ </g>
30
+ </g>
31
+ </svg>
32
+ );
33
+ };
34
+ const wifiSVG = () => {
35
+ return (
36
+ <svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 0 24 24" width="24px" fill="currentColor">
37
+ <path d="M0 0h24v24H0V0zm0 0h24v24H0V0z" fill="none" />
38
+ <path d="M1 9l2 2c4.97-4.97 13.03-4.97 18 0l2-2C16.93 2.93 7.08 2.93 1 9zm8 8l3 3 3-3c-1.65-1.66-4.34-1.66-6 0zm-4-4l2 2c2.76-2.76 7.24-2.76 10 0l2-2C15.14 9.14 8.87 9.14 5 13z" />
39
+ </svg>
40
+ );
41
+ };
42
+ const options = [
43
+ {
44
+ value: 1,
45
+ label: "Facebook",
46
+ },
47
+ {
48
+ value: 2,
49
+ label: "Twitter",
50
+ },
51
+ {
52
+ value: 3,
53
+ label: "Linkedin",
54
+ },
55
+ ];
56
+ const optionsWithIcon = [
57
+ {
58
+ value: 1,
59
+ icon: wifiSVG,
60
+ },
61
+ {
62
+ value: 2,
63
+ icon: ethernetSVG,
64
+ },
65
+ {
66
+ value: 3,
67
+ icon: gMobileSVG,
68
+ },
69
+ ];
70
+ const optionsWithIconAndLabel = [
71
+ {
72
+ value: 1,
73
+ label: "Wi-fi",
74
+ icon: wifiSVG,
75
+ },
76
+ {
77
+ value: 2,
78
+ label: "Ethernet",
79
+ icon: ethernetSVG,
80
+ },
81
+ {
82
+ value: 3,
83
+ label: "3G Mobile",
84
+ icon: gMobileSVG,
85
+ },
86
+ ];
87
+ const twoOptions = [
88
+ {
89
+ value: 1,
90
+ label: "Facebook",
91
+ },
92
+ {
93
+ value: 2,
94
+ label: "Twitter",
95
+ },
96
+ ];
97
+ export const Chromatic = () => (
98
+ <>
99
+ <ExampleContainer>
100
+ <Title title="Basic toggle group" theme="light" level={4} />
101
+ <DxcToggleGroup label="Toggle group" helperText="HelperText" options={options} />
102
+ </ExampleContainer>
103
+ <ExampleContainer>
104
+ <Title title="Selected" theme="light" level={4} />
105
+ <DxcToggleGroup label="Selected" helperText="HelperText" value={2} options={options} />
106
+ </ExampleContainer>
107
+ <ExampleContainer>
108
+ <Title title="Icons toggle group" theme="light" level={4} />
109
+ <DxcToggleGroup label="Icons group" options={optionsWithIcon} />
110
+ </ExampleContainer>
111
+ <ExampleContainer>
112
+ <Title title="Icons & label toggle group" theme="light" level={4} />
113
+ <DxcToggleGroup label="Icons & label" options={optionsWithIconAndLabel} />
114
+ </ExampleContainer>
115
+ <ExampleContainer>
116
+ <Title title="Disabled" theme="light" level={4} />
117
+ <DxcToggleGroup label="Disabled" value={2} options={options} disabled />
118
+ </ExampleContainer>
119
+ <ExampleContainer pseudoState="pseudo-hover">
120
+ <Title title="Hovered" theme="light" level={4} />
121
+ <DxcToggleGroup label="Hovered" options={twoOptions} value={2} />
122
+ </ExampleContainer>
123
+ <ExampleContainer>
124
+ <Title title="Multiple toggleGroup" theme="light" level={4} />
125
+ <DxcToggleGroup
126
+ label="Toggle group"
127
+ helperText="Please select one or more"
128
+ options={options}
129
+ value={[1, 3]}
130
+ multiple
131
+ ></DxcToggleGroup>
132
+ </ExampleContainer>
133
+ <Title title="Margins" theme="light" level={2} />
134
+ <ExampleContainer>
135
+ <Title title="xxSmall" theme="light" level={4} />
136
+ <DxcToggleGroup label="xxSmall margin" options={options} margin="xxsmall" />
137
+ </ExampleContainer>
138
+ <ExampleContainer>
139
+ <Title title="xSmall" theme="light" level={4} />
140
+ <DxcToggleGroup label="xSmall margin" options={options} margin="xsmall" />
141
+ </ExampleContainer>
142
+ <ExampleContainer>
143
+ <Title title="Small" theme="light" level={4} />
144
+ <DxcToggleGroup label="Small margin" options={options} margin="small" />
145
+ </ExampleContainer>
146
+ <ExampleContainer>
147
+ <Title title="Medium" theme="light" level={4} />
148
+ <DxcToggleGroup label="Medium margin" options={options} margin="medium" />
149
+ </ExampleContainer>
150
+ <ExampleContainer>
151
+ <Title title="Large" theme="light" level={4} />
152
+ <DxcToggleGroup label="Large margin" options={options} margin="large" />
153
+ </ExampleContainer>
154
+ <ExampleContainer>
155
+ <Title title="xLarge" theme="light" level={4} />
156
+ <DxcToggleGroup label="xLarge margin" options={options} margin="xlarge" />
157
+ </ExampleContainer>
158
+ <ExampleContainer>
159
+ <Title title="xxLarge" theme="light" level={4} />
160
+ <DxcToggleGroup label="xxLarge margin" options={options} margin="xxlarge" />
161
+ </ExampleContainer>
162
+ </>
163
+ );
164
+ const OptionSelected = () => <DxcToggleGroup label="Toggle group" helperText="HelperText" options={options} />;
165
+
166
+ export const ToggleGroupSelectedActived = OptionSelected.bind({});
167
+ ToggleGroupSelectedActived.play = async ({ canvasElement }) => {
168
+ const canvas = within(canvasElement);
169
+ const option = canvas.getByText("Linkedin");
170
+ await userEvent.click(option);
171
+ };
172
+ export const ToggleGroupUnselectedActived = OptionSelected.bind({});
173
+ ToggleGroupUnselectedActived.play = async ({ canvasElement }) => {
174
+ const canvas = within(canvasElement);
175
+ const option = canvas.getByText("Twitter");
176
+ await userEvent.click(option);
177
+ userEvent.tab();
178
+ };
@@ -0,0 +1,21 @@
1
+ type Space = "xxsmall" | "xsmall" | "small" | "medium" | "large" | "xlarge" | "xxlarge";
2
+ type Margin = {
3
+ top?: Space;
4
+ bottom?: Space;
5
+ left?: Space;
6
+ right?: Space;
7
+ };
8
+
9
+ type Props = {
10
+ label?: string;
11
+ helperText?: string;
12
+ value?: any;
13
+ onChange?: void;
14
+ disabled?: boolean;
15
+ options?: any;
16
+ multiple?: boolean;
17
+ margin?: Space | Margin;
18
+ tabIndex?: number;
19
+ };
20
+
21
+ export default function DxcToggleGroup(props: Props): JSX.Element;
@@ -1,9 +1,9 @@
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
  });
@@ -31,15 +31,11 @@ var _Transactions = _interopRequireDefault(require("./transactions/Transactions"
31
31
 
32
32
  var _variables = require("../common/variables.js");
33
33
 
34
- function _templateObject() {
35
- var data = (0, _taggedTemplateLiteral2["default"])(["\n font-size: ", ";\n font-family: ", ";\n max-width: 100%;\n height: 400px;\n box-shadow: 0px 3px 6px #00000029;\n border-radius: 4px;\n display: flex;\n flex-direction: row;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"]);
34
+ var _templateObject;
36
35
 
37
- _templateObject = function _templateObject() {
38
- return data;
39
- };
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); }
40
37
 
41
- return data;
42
- }
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; }
43
39
 
44
40
  var DxcUpload = function DxcUpload(_ref) {
45
41
  var callbackUpload = _ref.callbackUpload,
@@ -157,20 +153,20 @@ var DxcUpload = function DxcUpload(_ref) {
157
153
 
158
154
  var filesToUpload = getFilesToUpload();
159
155
  var transactionFiles = getTransactionsFiles();
160
- return _react["default"].createElement(DXCUpload, {
156
+ return /*#__PURE__*/_react["default"].createElement(DXCUpload, {
161
157
  margin: margin
162
- }, transactionFiles && transactionFiles.length !== 0 && _react["default"].createElement(_Transactions["default"], {
158
+ }, transactionFiles && transactionFiles.length !== 0 && /*#__PURE__*/_react["default"].createElement(_Transactions["default"], {
163
159
  tabIndexValue: tabIndex,
164
160
  transactions: transactionFiles
165
- }), filesToUpload && filesToUpload.length === 0 && transactionFiles && transactionFiles.length === 0 && _react["default"].createElement(_DragAndDropArea["default"], {
161
+ }), filesToUpload && filesToUpload.length === 0 && transactionFiles && transactionFiles.length === 0 && /*#__PURE__*/_react["default"].createElement(_DragAndDropArea["default"], {
166
162
  dashed: false,
167
163
  addFile: onDragHandler,
168
164
  tabIndexValue: tabIndex
169
- }) || filesToUpload && filesToUpload.length === 0 && transactionFiles && transactionFiles.length !== 0 && _react["default"].createElement(_DragAndDropArea["default"], {
165
+ }) || filesToUpload && filesToUpload.length === 0 && transactionFiles && transactionFiles.length !== 0 && /*#__PURE__*/_react["default"].createElement(_DragAndDropArea["default"], {
170
166
  dashed: true,
171
167
  addFile: onDragHandler,
172
168
  tabIndexValue: tabIndex
173
- }), filesToUpload && filesToUpload.length !== 0 && _react["default"].createElement(_FilesToUpload["default"], {
169
+ }), filesToUpload && filesToUpload.length !== 0 && /*#__PURE__*/_react["default"].createElement(_FilesToUpload["default"], {
174
170
  filesToUpload: filesToUpload,
175
171
  addFile: onDragHandler,
176
172
  onUpload: onUploadHandler,
@@ -189,11 +185,7 @@ DxcUpload.propTypes = {
189
185
  tabIndex: _propTypes["default"].number
190
186
  };
191
187
 
192
- var DXCUpload = _styledComponents["default"].div(_templateObject(), function (props) {
193
- return props.theme.fontSizeBase;
194
- }, function (props) {
195
- return props.theme.fontFamily;
196
- }, function (props) {
188
+ var DXCUpload = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n max-width: 100%;\n height: 400px;\n box-shadow: 0px 3px 6px #00000029;\n border-radius: 4px;\n display: flex;\n flex-direction: row;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n"])), function (props) {
197
189
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
198
190
  }, function (props) {
199
191
  return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
@@ -0,0 +1,111 @@
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 _react = _interopRequireDefault(require("react"));
15
+
16
+ var _propTypes = _interopRequireDefault(require("prop-types"));
17
+
18
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
+
20
+ var _Button = _interopRequireDefault(require("../../button/Button"));
21
+
22
+ var _Icons = require("./Icons");
23
+
24
+ var _useTheme = _interopRequireDefault(require("../../useTheme.js"));
25
+
26
+ var _BackgroundColorContext = require("../../BackgroundColorContext.js");
27
+
28
+ var _templateObject, _templateObject2, _templateObject3;
29
+
30
+ 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); }
31
+
32
+ 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; }
33
+
34
+ var DxcButtonsUpload = function DxcButtonsUpload(_ref) {
35
+ var addFile = _ref.addFile,
36
+ onUpload = _ref.onUpload;
37
+ var colorsTheme = (0, _useTheme["default"])();
38
+
39
+ var selectFile = function selectFile(e) {
40
+ var filesObject = e.target.files;
41
+
42
+ if (filesObject && filesObject.length > 0) {
43
+ var filesArray = Object.keys(filesObject).map(function (key) {
44
+ return filesObject[key];
45
+ });
46
+ addFile(filesArray);
47
+ }
48
+ };
49
+
50
+ var handleClick = function handleClick() {
51
+ document.getElementById("chooseFiles").click();
52
+ };
53
+
54
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
55
+ theme: colorsTheme.upload
56
+ }, /*#__PURE__*/_react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
57
+ color: colorsTheme.upload.backgroundColor
58
+ }, /*#__PURE__*/_react["default"].createElement(DXCButtonsUpload, null, /*#__PURE__*/_react["default"].createElement(DragAndDropLabel, null, /*#__PURE__*/_react["default"].createElement(DragAndDropIconContainer, null, _Icons.dragAndDropIcon), "Drag and Drop area"), /*#__PURE__*/_react["default"].createElement(_Button["default"], {
59
+ margin: {
60
+ right: "small"
61
+ },
62
+ mode: "text",
63
+ label: "CHOOSE FILES",
64
+ onClick: handleClick
65
+ }), /*#__PURE__*/_react["default"].createElement("input", {
66
+ id: "chooseFiles",
67
+ type: "file",
68
+ multiple: true,
69
+ onChange: selectFile,
70
+ style: {
71
+ display: "none"
72
+ }
73
+ }), /*#__PURE__*/_react["default"].createElement(_Button["default"], {
74
+ label: "UPLOAD",
75
+ iconPosition: "after",
76
+ icon: _Icons.uploadIcon,
77
+ onClick: onUpload
78
+ }))));
79
+ };
80
+
81
+ DxcButtonsUpload.propTypes = {
82
+ addFile: _propTypes["default"].func,
83
+ onUpload: _propTypes["default"].func
84
+ };
85
+
86
+ var DXCButtonsUpload = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n margin-right: 80px;\n display: flex;\n flex-direction: row;\n justify-content: flex-end;\n"])));
87
+
88
+ var DragAndDropLabel = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: row;\n align-items: center;\n font-family: ", ";\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n text-transform: ", ";\n color: ", ";\n margin-right: 50px;\n"])), function (props) {
89
+ return props.theme.fontFamily;
90
+ }, function (props) {
91
+ return props.theme.dragAndDropAreaTextFontSize;
92
+ }, function (props) {
93
+ return props.theme.dragAndDropAreaTextFontStyle;
94
+ }, function (props) {
95
+ return props.theme.dragAndDropAreaTextFontWeight;
96
+ }, function (props) {
97
+ return props.theme.dragAndDropAreaTextFontTextTransform;
98
+ }, function (props) {
99
+ return props.theme.dragAndDropAreaTextFontColor;
100
+ });
101
+
102
+ var DragAndDropIconContainer = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n height: ", ";\n width: ", ";\n margin-right: 5px;\n & svg {\n fill: ", ";\n }\n"])), function (props) {
103
+ return props.theme.dragAndDropAreaIconSize;
104
+ }, function (props) {
105
+ return props.theme.dragAndDropAreaIconSize;
106
+ }, function (props) {
107
+ return props.theme.dragAndDropAreaIconColor;
108
+ });
109
+
110
+ var _default = DxcButtonsUpload;
111
+ exports["default"] = _default;
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.uploadIcon = exports.dragAndDropIcon = void 0;
9
+
10
+ var _react = _interopRequireDefault(require("react"));
11
+
12
+ var uploadIcon = /*#__PURE__*/_react["default"].createElement("svg", {
13
+ xmlns: "http://www.w3.org/2000/svg",
14
+ width: "24",
15
+ height: "24",
16
+ viewBox: "0 0 24 24",
17
+ fill: "#FFFFFF"
18
+ }, /*#__PURE__*/_react["default"].createElement("path", {
19
+ d: "M0 0h24v24H0z",
20
+ fill: "none"
21
+ }), /*#__PURE__*/_react["default"].createElement("path", {
22
+ d: "M19.35 10.04C18.67 6.59 15.64 4 12 4 9.11 4 6.6 5.64 5.35 8.04 2.34 8.36 0 10.91 0 14c0 3.31 2.69 6 6 6h13c2.76 0 5-2.24 5-5 0-2.64-2.05-4.78-4.65-4.96zM14 13v4h-4v-4H7l5-5 5 5h-3z"
23
+ }));
24
+
25
+ exports.uploadIcon = uploadIcon;
26
+
27
+ var dragAndDropIcon = /*#__PURE__*/_react["default"].createElement("svg", {
28
+ xmlns: "http://www.w3.org/2000/svg",
29
+ width: "24",
30
+ height: "24",
31
+ viewBox: "0 0 24 24",
32
+ fill: "#666666"
33
+ }, /*#__PURE__*/_react["default"].createElement("path", {
34
+ fill: "none",
35
+ d: "M0 0h24v24H0V0z"
36
+ }), /*#__PURE__*/_react["default"].createElement("path", {
37
+ d: "M3 13h2v-2H3v2zm0 4h2v-2H3v2zm2 4v-2H3c0 1.1.89 2 2 2zM3 9h2V7H3v2zm12 12h2v-2h-2v2zm4-18H9c-1.11 0-2 .9-2 2v10c0 1.1.89 2 2 2h10c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 12H9V5h10v10zm-8 6h2v-2h-2v2zm-4 0h2v-2H7v2z"
38
+ }));
39
+
40
+ exports.dragAndDropIcon = dragAndDropIcon;
@@ -0,0 +1,225 @@
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 = _interopRequireDefault(require("react"));
17
+
18
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
19
+
20
+ var _propTypes = _interopRequireDefault(require("prop-types"));
21
+
22
+ var _Icons = require("./Icons");
23
+
24
+ var _Button = _interopRequireDefault(require("../../button/Button"));
25
+
26
+ var _useTheme = _interopRequireDefault(require("../../useTheme.js"));
27
+
28
+ var _BackgroundColorContext = require("../../BackgroundColorContext.js");
29
+
30
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11;
31
+
32
+ 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); }
33
+
34
+ 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; }
35
+
36
+ var DxcDragAndDropArea = function DxcDragAndDropArea(_ref) {
37
+ var _ref$dashed = _ref.dashed,
38
+ dashed = _ref$dashed === void 0 ? false : _ref$dashed,
39
+ addFile = _ref.addFile,
40
+ tabIndexValue = _ref.tabIndexValue;
41
+
42
+ var _React$useState = _react["default"].useState(false),
43
+ _React$useState2 = (0, _slicedToArray2["default"])(_React$useState, 2),
44
+ dragging = _React$useState2[0],
45
+ setDragging = _React$useState2[1];
46
+
47
+ var colorsTheme = (0, _useTheme["default"])();
48
+ var text = "There are no files to upload";
49
+ var description = "Drag and drop your files here or choose one from your computer";
50
+ var textHover = "Drag your file here";
51
+
52
+ var handleDrag = function handleDrag(e) {
53
+ e.preventDefault();
54
+ e.stopPropagation();
55
+ };
56
+
57
+ var handleDragIn = function handleDragIn(e) {
58
+ e.preventDefault();
59
+ e.stopPropagation();
60
+
61
+ if (e.dataTransfer.items && e.dataTransfer.items.length > 0) {
62
+ setDragging(true);
63
+ }
64
+ };
65
+
66
+ var handleDragOut = function handleDragOut(e) {
67
+ e.preventDefault();
68
+ e.stopPropagation();
69
+ setDragging(false);
70
+ };
71
+
72
+ var handleDrop = function handleDrop(e) {
73
+ e.preventDefault();
74
+ e.stopPropagation();
75
+ var filesObject = e.dataTransfer.files;
76
+
77
+ if (filesObject && filesObject.length > 0) {
78
+ var filesArray = Object.keys(filesObject).map(function (key) {
79
+ return filesObject[key];
80
+ });
81
+ addFile(filesArray);
82
+ e.dataTransfer.clearData();
83
+ }
84
+ };
85
+
86
+ var selectFile = function selectFile(e) {
87
+ var filesObject = e.target.files;
88
+
89
+ if (filesObject && filesObject.length > 0) {
90
+ var filesArray = Object.keys(filesObject).map(function (key) {
91
+ return filesObject[key];
92
+ });
93
+ addFile(filesArray);
94
+ }
95
+ };
96
+
97
+ var handleClick = function handleClick() {
98
+ document.getElementById("chooseFiles").click();
99
+ };
100
+
101
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
102
+ theme: colorsTheme.upload
103
+ }, /*#__PURE__*/_react["default"].createElement(_BackgroundColorContext.BackgroundColorProvider, {
104
+ color: colorsTheme.upload.backgroundColor
105
+ }, /*#__PURE__*/_react["default"].createElement(DXCDragAndDrop, {
106
+ onDrop: handleDrop,
107
+ onDragEnter: handleDragIn,
108
+ onDragOver: handleDrag,
109
+ onDragLeave: handleDragOut,
110
+ dashed: dashed
111
+ }, !dragging && !dashed && /*#__PURE__*/_react["default"].createElement(DXCDragAndDropArea, null, /*#__PURE__*/_react["default"].createElement(DragAndDropContent, null, /*#__PURE__*/_react["default"].createElement(DragAndDropIcon, null, _Icons.uploadFileIcon), /*#__PURE__*/_react["default"].createElement(DragAndDropText, null, /*#__PURE__*/_react["default"].createElement(DragAndDropTitle, null, text), /*#__PURE__*/_react["default"].createElement(DragAndDropDescription, null, description)), /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
112
+ label: "CHOOSE FILES",
113
+ onClick: handleClick,
114
+ tabIndex: tabIndexValue
115
+ }), /*#__PURE__*/_react["default"].createElement("input", {
116
+ id: "chooseFiles",
117
+ type: "file",
118
+ multiple: true,
119
+ onChange: selectFile,
120
+ style: {
121
+ display: "none"
122
+ }
123
+ })))), !dragging && dashed && /*#__PURE__*/_react["default"].createElement(DragAndDropContentHover, null, /*#__PURE__*/_react["default"].createElement(DragAndDropContent, null, /*#__PURE__*/_react["default"].createElement(DragAndDropIcon, null, _Icons.uploadFileIcon), /*#__PURE__*/_react["default"].createElement(DragAndDropText, null, /*#__PURE__*/_react["default"].createElement(DragAndDropTitle, null, text), /*#__PURE__*/_react["default"].createElement(DragAndDropDescription, null, description)), /*#__PURE__*/_react["default"].createElement(ButtonChooseFiles, null, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
124
+ theme: "light",
125
+ label: "CHOOSE FILES",
126
+ onClick: handleClick,
127
+ tabIndex: tabIndexValue
128
+ }), /*#__PURE__*/_react["default"].createElement("input", {
129
+ id: "chooseFiles",
130
+ type: "file",
131
+ multiple: true,
132
+ onChange: selectFile,
133
+ style: {
134
+ display: "none"
135
+ }
136
+ })))), dragging && /*#__PURE__*/_react["default"].createElement(DragAndDropContentHover, null, /*#__PURE__*/_react["default"].createElement(DragAndDropTextHover, null, textHover), /*#__PURE__*/_react["default"].createElement(DragAndDropIconHover, null, _Icons.dropFileIcon)))));
137
+ };
138
+
139
+ DxcDragAndDropArea.propTypes = {
140
+ dashed: _propTypes["default"].bool,
141
+ addFile: _propTypes["default"].func
142
+ };
143
+
144
+ var DXCDragAndDrop = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n font-family: ", ";\n background-color: ", ";\n width: 100%;\n height: 100%;\n"])), function (props) {
145
+ return props.theme.fontFamily;
146
+ }, function (props) {
147
+ return props.theme.backgroundColor;
148
+ });
149
+
150
+ var DXCDragAndDropArea = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n width: 100%;\n height: 100%;\n display: flex;\n justify-content: center;\n border-radius: 4px;\n box-shadow: 0px 3px 6px ", ";\n"])), function (props) {
151
+ return props.theme.shadowColor;
152
+ });
153
+
154
+ var DragAndDropContent = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n"])));
155
+
156
+ var DragAndDropIcon = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n height: ", ";\n width: ", ";\n margin-bottom: 20px;\n & svg {\n fill: ", ";\n height: ", ";\n width: ", ";\n }\n"])), function (props) {
157
+ return props.theme.dragAndDropIconSize;
158
+ }, function (props) {
159
+ return props.theme.dragAndDropIconSize;
160
+ }, function (props) {
161
+ return props.theme.dragAndDropIconColor;
162
+ }, function (props) {
163
+ return props.theme.dragAndDropIconSize;
164
+ }, function (props) {
165
+ return props.theme.dragAndDropIconSize;
166
+ });
167
+
168
+ var DragAndDropText = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n align-items: center;\n"])));
169
+
170
+ var DragAndDropTitle = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n text-transform: ", ";\n color: ", ";\n margin-bottom: 10px;\n"])), function (props) {
171
+ return props.theme.dragAndDropTitleFontSize;
172
+ }, function (props) {
173
+ return props.theme.dragAndDropTitleFontStyle;
174
+ }, function (props) {
175
+ return props.theme.dragAndDropTitleFontWeight;
176
+ }, function (props) {
177
+ return props.theme.dragAndDropTitleFontTextTransform;
178
+ }, function (props) {
179
+ return props.theme.dragAndDropTitleFontColor;
180
+ });
181
+
182
+ var DragAndDropDescription = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n text-transform: ", ";\n color: ", ";\n margin-bottom: 40px;\n"])), function (props) {
183
+ return props.theme.dragAndDropDescriptionFontSize;
184
+ }, function (props) {
185
+ return props.theme.dragAndDropDescriptionFontStyle;
186
+ }, function (props) {
187
+ return props.theme.dragAndDropDescriptionFontWeight;
188
+ }, function (props) {
189
+ return props.theme.dragAndDropDescriptionFontTextTransform;
190
+ }, function (props) {
191
+ return props.theme.dragAndDropDescriptionFontColor;
192
+ });
193
+
194
+ var ButtonChooseFiles = _styledComponents["default"].div(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])([""])));
195
+
196
+ var DragAndDropContentHover = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n --border-color: #666666;\n --border-weight: 1px;\n --dash-size: 8px;\n --gap-size: 8px;\n background: linear-gradient(90deg, var(--border-color) 100%, transparent 100%) top left no-repeat,\n linear-gradient(\n 90deg,\n transparent calc(var(--gap-size) / 2),\n var(--border-color) calc(var(--gap-size) / 2),\n var(--border-color) calc(var(--gap-size) / 2 + var(--dash-size)),\n transparent calc(var(--gap-size) / 2 + var(--dash-size))\n )\n top center repeat-x,\n linear-gradient(90deg, var(--border-color) 100%, transparent 100%) top right no-repeat,\n linear-gradient(0deg, var(--border-color) 100%, transparent 100%) top left no-repeat,\n linear-gradient(\n 0deg,\n transparent calc(var(--gap-size) / 2),\n var(--border-color) calc(var(--gap-size) / 2),\n var(--border-color) calc(var(--gap-size) / 2 + var(--dash-size)),\n transparent calc(var(--gap-size) / 2 + var(--dash-size))\n )\n center left repeat-y,\n linear-gradient(0deg, var(--border-color) 100%, transparent 100%) bottom left no-repeat,\n linear-gradient(90deg, var(--border-color) 100%, transparent 100%) bottom left no-repeat,\n linear-gradient(\n 90deg,\n transparent calc(var(--gap-size) / 2),\n var(--border-color) calc(var(--gap-size) / 2),\n var(--border-color) calc(var(--gap-size) / 2 + var(--dash-size)),\n transparent calc(var(--gap-size) / 2 + var(--dash-size))\n )\n bottom center repeat-x,\n linear-gradient(90deg, var(--border-color) 100%, transparent 100%) bottom right no-repeat,\n linear-gradient(0deg, var(--border-color) 100%, transparent 100%) top right no-repeat,\n linear-gradient(\n 0deg,\n transparent calc(var(--gap-size) / 2),\n var(--border-color) calc(var(--gap-size) / 2),\n var(--border-color) calc(var(--gap-size) / 2 + var(--dash-size)),\n transparent calc(var(--gap-size) / 2 + var(--dash-size))\n )\n center right repeat-y,\n linear-gradient(0deg, var(--border-color) 100%, transparent 100%) bottom right no-repeat;\n background-size: var(--dash-size) var(--border-weight), calc(var(--dash-size) + var(--gap-size)) var(--border-weight),\n var(--dash-size) var(--border-weight), var(--border-weight) var(--dash-size),\n var(--border-weight) calc(var(--dash-size) + var(--gap-size)), var(--border-weight) var(--dash-size);\n background-color: ", ";\n display: flex;\n flex-direction: column;\n justify-content: center;\n align-items: center;\n width: 100%;\n height: 100%;\n cursor: pointer;\n"])), function (props) {
197
+ return props.theme.draggingStateBackgroundColor;
198
+ });
199
+
200
+ var DragAndDropIconHover = _styledComponents["default"].div(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2["default"])(["\n height: ", ";\n width: ", ";\n & svg {\n fill: ", ";\n height: ", ";\n width: ", ";\n }\n"])), function (props) {
201
+ return props.theme.dragAndDropDraggingStateIconSize;
202
+ }, function (props) {
203
+ return props.theme.dragAndDropDraggingStateIconSize;
204
+ }, function (props) {
205
+ return props.theme.dragAndDropDraggingStateIconColor;
206
+ }, function (props) {
207
+ return props.theme.dragAndDropDraggingStateIconSize;
208
+ }, function (props) {
209
+ return props.theme.dragAndDropDraggingStateIconSize;
210
+ });
211
+
212
+ var DragAndDropTextHover = _styledComponents["default"].div(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2["default"])(["\n font-size: ", ";\n font-style: ", ";\n font-weight: ", ";\n text-transform: ", ";\n color: ", ";\n margin-bottom: 10px;\n"])), function (props) {
213
+ return props.theme.dragAndDropDraggingStateFontSize;
214
+ }, function (props) {
215
+ return props.theme.dragAndDropDraggingStateFontStyle;
216
+ }, function (props) {
217
+ return props.theme.dragAndDropDraggingStateFontWeight;
218
+ }, function (props) {
219
+ return props.theme.dragAndDropDraggingStateFontTextTransform;
220
+ }, function (props) {
221
+ return props.theme.dragAndDropDraggingStateFontColor;
222
+ });
223
+
224
+ var _default = DxcDragAndDropArea;
225
+ exports["default"] = _default;