@dxc-technology/halstack-react 0.0.0-f77ec3a → 0.0.0-f7c9808

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 (425) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +47 -0
  3. package/ThemeContext.d.ts +10 -0
  4. package/ThemeContext.js +243 -0
  5. package/accordion/Accordion.d.ts +4 -0
  6. package/accordion/Accordion.js +248 -0
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +72 -0
  9. package/accordion/types.d.ts +68 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +170 -0
  13. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  14. package/accordion-group/AccordionGroup.test.js +133 -0
  15. package/accordion-group/types.d.ts +68 -0
  16. package/accordion-group/types.js +5 -0
  17. package/alert/Alert.d.ts +4 -0
  18. package/{dist/alert → alert}/Alert.js +40 -153
  19. package/alert/Alert.stories.tsx +170 -0
  20. package/alert/Alert.test.js +92 -0
  21. package/alert/types.d.ts +49 -0
  22. package/alert/types.js +5 -0
  23. package/badge/Badge.d.ts +4 -0
  24. package/badge/Badge.js +59 -0
  25. package/badge/types.d.ts +4 -0
  26. package/badge/types.js +5 -0
  27. package/bleed/Bleed.d.ts +3 -0
  28. package/bleed/Bleed.js +84 -0
  29. package/bleed/Bleed.stories.tsx +342 -0
  30. package/bleed/types.d.ts +37 -0
  31. package/bleed/types.js +5 -0
  32. package/box/Box.d.ts +4 -0
  33. package/{dist/box → box}/Box.js +15 -45
  34. package/box/Box.stories.tsx +132 -0
  35. package/box/Box.test.js +18 -0
  36. package/box/types.d.ts +43 -0
  37. package/box/types.js +5 -0
  38. package/button/Button.d.ts +4 -0
  39. package/{dist/button → button}/Button.js +26 -93
  40. package/button/Button.stories.tsx +274 -0
  41. package/button/Button.test.js +35 -0
  42. package/button/types.d.ts +53 -0
  43. package/button/types.js +5 -0
  44. package/card/Card.d.ts +4 -0
  45. package/{dist/card → card}/Card.js +34 -124
  46. package/card/Card.stories.tsx +201 -0
  47. package/card/Card.test.js +50 -0
  48. package/card/ice-cream.jpg +0 -0
  49. package/card/types.d.ts +67 -0
  50. package/card/types.js +5 -0
  51. package/checkbox/Checkbox.d.ts +4 -0
  52. package/{dist/checkbox → checkbox}/Checkbox.js +21 -73
  53. package/checkbox/Checkbox.stories.tsx +192 -0
  54. package/checkbox/Checkbox.test.js +78 -0
  55. package/checkbox/types.d.ts +64 -0
  56. package/checkbox/types.js +5 -0
  57. package/chip/Chip.d.ts +4 -0
  58. package/chip/Chip.js +161 -0
  59. package/chip/Chip.stories.tsx +119 -0
  60. package/chip/Chip.test.js +56 -0
  61. package/chip/types.d.ts +45 -0
  62. package/chip/types.js +5 -0
  63. package/{dist/common → common}/OpenSans.css +0 -0
  64. package/{dist/common → common}/RequiredComponent.js +3 -11
  65. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  66. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  67. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  68. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  69. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  70. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  71. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  72. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  73. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  74. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  75. package/{dist/common → common}/utils.js +0 -0
  76. package/{dist/common → common}/variables.js +125 -326
  77. package/date-input/DateInput.d.ts +4 -0
  78. package/{dist/date-input → date-input}/DateInput.js +47 -93
  79. package/date-input/DateInput.stories.tsx +138 -0
  80. package/date-input/DateInput.test.js +492 -0
  81. package/date-input/types.d.ts +104 -0
  82. package/date-input/types.js +5 -0
  83. package/dialog/Dialog.d.ts +4 -0
  84. package/{dist/dialog → dialog}/Dialog.js +24 -76
  85. package/dialog/Dialog.stories.tsx +212 -0
  86. package/dialog/Dialog.test.js +40 -0
  87. package/dialog/types.d.ts +43 -0
  88. package/dialog/types.js +5 -0
  89. package/dropdown/Dropdown.d.ts +4 -0
  90. package/{dist/dropdown → dropdown}/Dropdown.js +48 -197
  91. package/dropdown/Dropdown.stories.tsx +249 -0
  92. package/dropdown/Dropdown.test.js +189 -0
  93. package/dropdown/types.d.ts +80 -0
  94. package/dropdown/types.js +5 -0
  95. package/file-input/FileInput.d.ts +4 -0
  96. package/file-input/FileInput.js +590 -0
  97. package/file-input/FileInput.stories.tsx +507 -0
  98. package/file-input/FileInput.test.js +457 -0
  99. package/file-input/FileItem.d.ts +14 -0
  100. package/file-input/FileItem.js +184 -0
  101. package/file-input/types.d.ts +112 -0
  102. package/file-input/types.js +5 -0
  103. package/footer/Footer.d.ts +4 -0
  104. package/footer/Footer.js +258 -0
  105. package/footer/Footer.stories.tsx +130 -0
  106. package/footer/Footer.test.js +109 -0
  107. package/footer/Icons.d.ts +2 -0
  108. package/{dist/footer → footer}/Icons.js +15 -15
  109. package/footer/types.d.ts +65 -0
  110. package/footer/types.js +5 -0
  111. package/header/Header.d.ts +7 -0
  112. package/{dist/header → header}/Header.js +58 -204
  113. package/header/Header.stories.tsx +162 -0
  114. package/header/Header.test.js +63 -0
  115. package/header/Icons.d.ts +2 -0
  116. package/{dist/header → header}/Icons.js +7 -32
  117. package/header/types.d.ts +47 -0
  118. package/header/types.js +5 -0
  119. package/heading/Heading.d.ts +4 -0
  120. package/{dist/heading → heading}/Heading.js +25 -96
  121. package/heading/Heading.stories.tsx +54 -0
  122. package/heading/Heading.test.js +186 -0
  123. package/heading/types.d.ts +33 -0
  124. package/heading/types.js +5 -0
  125. package/inset/Inset.d.ts +3 -0
  126. package/inset/Inset.js +84 -0
  127. package/inset/Inset.stories.tsx +229 -0
  128. package/inset/types.d.ts +13 -0
  129. package/inset/types.js +5 -0
  130. package/layout/ApplicationLayout.d.ts +10 -0
  131. package/{dist/layout → layout}/ApplicationLayout.js +47 -143
  132. package/layout/ApplicationLayout.stories.tsx +171 -0
  133. package/{dist/layout → layout}/Icons.js +7 -7
  134. package/layout/types.d.ts +57 -0
  135. package/layout/types.js +5 -0
  136. package/link/Link.d.ts +3 -0
  137. package/{dist/link → link}/Link.js +22 -106
  138. package/link/Link.stories.tsx +151 -0
  139. package/link/Link.test.js +91 -0
  140. package/link/types.d.ts +70 -0
  141. package/link/types.js +5 -0
  142. package/list/List.d.ts +4 -0
  143. package/list/List.js +47 -0
  144. package/list/List.stories.tsx +95 -0
  145. package/list/types.d.ts +7 -0
  146. package/list/types.js +5 -0
  147. package/main.d.ts +46 -0
  148. package/{dist/main.js → main.js} +116 -96
  149. package/number-input/NumberInput.d.ts +4 -0
  150. package/number-input/NumberInput.js +76 -0
  151. package/number-input/NumberInput.stories.tsx +115 -0
  152. package/number-input/NumberInput.test.js +508 -0
  153. package/number-input/NumberInputContext.d.ts +4 -0
  154. package/{dist/number-input → number-input}/NumberInputContext.js +5 -2
  155. package/number-input/numberInputContextTypes.d.ts +19 -0
  156. package/number-input/numberInputContextTypes.js +5 -0
  157. package/number-input/types.d.ts +121 -0
  158. package/number-input/types.js +5 -0
  159. package/package.json +22 -17
  160. package/{dist/paginator → paginator}/Icons.js +9 -9
  161. package/paginator/Paginator.d.ts +4 -0
  162. package/paginator/Paginator.js +192 -0
  163. package/paginator/Paginator.stories.tsx +63 -0
  164. package/paginator/Paginator.test.js +266 -0
  165. package/paginator/types.d.ts +38 -0
  166. package/paginator/types.js +5 -0
  167. package/password-input/PasswordInput.d.ts +4 -0
  168. package/{dist/password-input → password-input}/PasswordInput.js +37 -77
  169. package/password-input/PasswordInput.stories.tsx +131 -0
  170. package/password-input/PasswordInput.test.js +183 -0
  171. package/password-input/types.d.ts +107 -0
  172. package/password-input/types.js +5 -0
  173. package/progress-bar/ProgressBar.d.ts +4 -0
  174. package/{dist/progress-bar → progress-bar}/ProgressBar.js +22 -94
  175. package/progress-bar/ProgressBar.stories.jsx +58 -0
  176. package/progress-bar/ProgressBar.test.js +65 -0
  177. package/progress-bar/types.d.ts +37 -0
  178. package/progress-bar/types.js +5 -0
  179. package/radio/Radio.d.ts +4 -0
  180. package/{dist/radio → radio}/Radio.js +17 -52
  181. package/radio/Radio.stories.tsx +192 -0
  182. package/radio/Radio.test.js +71 -0
  183. package/radio/types.d.ts +54 -0
  184. package/radio/types.js +5 -0
  185. package/radio-group/Radio.d.ts +4 -0
  186. package/radio-group/Radio.js +141 -0
  187. package/radio-group/RadioGroup.d.ts +4 -0
  188. package/radio-group/RadioGroup.js +280 -0
  189. package/radio-group/RadioGroup.stories.tsx +100 -0
  190. package/radio-group/RadioGroup.test.js +695 -0
  191. package/radio-group/types.d.ts +114 -0
  192. package/radio-group/types.js +5 -0
  193. package/resultsetTable/ResultsetTable.d.ts +4 -0
  194. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +43 -147
  195. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  196. package/resultsetTable/ResultsetTable.test.js +306 -0
  197. package/resultsetTable/types.d.ts +67 -0
  198. package/resultsetTable/types.js +5 -0
  199. package/row/Row.d.ts +3 -0
  200. package/row/Row.js +127 -0
  201. package/row/Row.stories.tsx +237 -0
  202. package/row/types.d.ts +28 -0
  203. package/row/types.js +5 -0
  204. package/select/Icons.d.ts +10 -0
  205. package/select/Icons.js +93 -0
  206. package/select/Option.d.ts +4 -0
  207. package/select/Option.js +110 -0
  208. package/select/Select.d.ts +4 -0
  209. package/select/Select.js +740 -0
  210. package/select/Select.stories.tsx +582 -0
  211. package/select/Select.test.js +2016 -0
  212. package/select/types.d.ts +191 -0
  213. package/select/types.js +5 -0
  214. package/sidenav/Sidenav.d.ts +9 -0
  215. package/{dist/sidenav → sidenav}/Sidenav.js +21 -64
  216. package/sidenav/Sidenav.stories.tsx +182 -0
  217. package/sidenav/Sidenav.test.js +56 -0
  218. package/sidenav/types.d.ts +50 -0
  219. package/sidenav/types.js +5 -0
  220. package/slider/Slider.d.ts +4 -0
  221. package/{dist/slider → slider}/Slider.js +74 -161
  222. package/slider/Slider.stories.tsx +177 -0
  223. package/slider/Slider.test.js +129 -0
  224. package/slider/types.d.ts +78 -0
  225. package/slider/types.js +5 -0
  226. package/spinner/Spinner.d.ts +4 -0
  227. package/spinner/Spinner.js +250 -0
  228. package/spinner/Spinner.stories.jsx +103 -0
  229. package/spinner/Spinner.test.js +64 -0
  230. package/spinner/types.d.ts +32 -0
  231. package/spinner/types.js +5 -0
  232. package/stack/Stack.d.ts +3 -0
  233. package/stack/Stack.js +97 -0
  234. package/stack/Stack.stories.tsx +164 -0
  235. package/stack/types.d.ts +24 -0
  236. package/stack/types.js +5 -0
  237. package/switch/Switch.d.ts +4 -0
  238. package/{dist/switch → switch}/Switch.js +45 -75
  239. package/switch/Switch.stories.tsx +160 -0
  240. package/switch/Switch.test.js +98 -0
  241. package/switch/types.d.ts +62 -0
  242. package/switch/types.js +5 -0
  243. package/table/Table.d.ts +4 -0
  244. package/{dist/table → table}/Table.js +12 -26
  245. package/table/Table.stories.jsx +277 -0
  246. package/table/Table.test.js +26 -0
  247. package/table/types.d.ts +21 -0
  248. package/table/types.js +5 -0
  249. package/tabs/Tabs.d.ts +4 -0
  250. package/tabs/Tabs.js +213 -0
  251. package/tabs/Tabs.stories.tsx +120 -0
  252. package/tabs/Tabs.test.js +123 -0
  253. package/tabs/types.d.ts +78 -0
  254. package/tabs/types.js +5 -0
  255. package/tag/Tag.d.ts +4 -0
  256. package/tag/Tag.js +186 -0
  257. package/tag/Tag.stories.tsx +142 -0
  258. package/tag/Tag.test.js +60 -0
  259. package/tag/types.d.ts +69 -0
  260. package/tag/types.js +5 -0
  261. package/text/Text.d.ts +7 -0
  262. package/text/Text.js +30 -0
  263. package/text/Text.stories.tsx +19 -0
  264. package/text-input/TextInput.d.ts +4 -0
  265. package/{dist/text-input → text-input}/TextInput.js +285 -461
  266. package/text-input/TextInput.stories.tsx +474 -0
  267. package/text-input/TextInput.test.js +1725 -0
  268. package/text-input/types.d.ts +163 -0
  269. package/text-input/types.js +5 -0
  270. package/textarea/Textarea.d.ts +4 -0
  271. package/{dist/textarea → textarea}/Textarea.js +48 -131
  272. package/textarea/Textarea.stories.jsx +157 -0
  273. package/textarea/Textarea.test.js +437 -0
  274. package/textarea/types.d.ts +134 -0
  275. package/textarea/types.js +5 -0
  276. package/toggle-group/ToggleGroup.d.ts +4 -0
  277. package/{dist/toggle-group → toggle-group}/ToggleGroup.js +35 -148
  278. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  279. package/toggle-group/ToggleGroup.test.js +125 -0
  280. package/toggle-group/types.d.ts +97 -0
  281. package/toggle-group/types.js +5 -0
  282. package/useTheme.d.ts +2 -0
  283. package/{dist/useTheme.js → useTheme.js} +1 -1
  284. package/wizard/Wizard.d.ts +4 -0
  285. package/wizard/Wizard.js +286 -0
  286. package/wizard/Wizard.stories.tsx +214 -0
  287. package/wizard/Wizard.test.js +141 -0
  288. package/wizard/types.d.ts +64 -0
  289. package/wizard/types.js +5 -0
  290. package/README.md +0 -66
  291. package/babel.config.js +0 -7
  292. package/dist/BackgroundColorContext.js +0 -46
  293. package/dist/ThemeContext.js +0 -250
  294. package/dist/V3Select/V3Select.js +0 -549
  295. package/dist/V3Select/index.d.ts +0 -27
  296. package/dist/V3Textarea/V3Textarea.js +0 -264
  297. package/dist/V3Textarea/index.d.ts +0 -27
  298. package/dist/accordion/Accordion.js +0 -353
  299. package/dist/accordion/index.d.ts +0 -28
  300. package/dist/accordion-group/AccordionGroup.js +0 -186
  301. package/dist/accordion-group/index.d.ts +0 -16
  302. package/dist/alert/index.d.ts +0 -51
  303. package/dist/badge/Badge.js +0 -63
  304. package/dist/box/index.d.ts +0 -25
  305. package/dist/button/index.d.ts +0 -24
  306. package/dist/card/index.d.ts +0 -22
  307. package/dist/checkbox/index.d.ts +0 -24
  308. package/dist/chip/Chip.js +0 -265
  309. package/dist/chip/index.d.ts +0 -22
  310. package/dist/date/Date.js +0 -379
  311. package/dist/date/index.d.ts +0 -27
  312. package/dist/date-input/index.d.ts +0 -95
  313. package/dist/dialog/index.d.ts +0 -18
  314. package/dist/dropdown/index.d.ts +0 -26
  315. package/dist/file-input/FileInput.js +0 -644
  316. package/dist/file-input/FileItem.js +0 -287
  317. package/dist/file-input/index.d.ts +0 -81
  318. package/dist/footer/Footer.js +0 -421
  319. package/dist/footer/index.d.ts +0 -25
  320. package/dist/header/index.d.ts +0 -25
  321. package/dist/heading/index.d.ts +0 -17
  322. package/dist/input-text/Icons.js +0 -22
  323. package/dist/input-text/InputText.js +0 -705
  324. package/dist/input-text/index.d.ts +0 -36
  325. package/dist/link/index.d.ts +0 -23
  326. package/dist/main.d.ts +0 -40
  327. package/dist/number-input/NumberInput.js +0 -136
  328. package/dist/number-input/index.d.ts +0 -113
  329. package/dist/paginator/Paginator.js +0 -305
  330. package/dist/paginator/index.d.ts +0 -20
  331. package/dist/password-input/index.d.ts +0 -94
  332. package/dist/progress-bar/index.d.ts +0 -18
  333. package/dist/radio/index.d.ts +0 -23
  334. package/dist/resultsetTable/index.d.ts +0 -19
  335. package/dist/select/Select.js +0 -1096
  336. package/dist/select/index.d.ts +0 -53
  337. package/dist/sidenav/index.d.ts +0 -13
  338. package/dist/slider/index.d.ts +0 -29
  339. package/dist/spinner/Spinner.js +0 -381
  340. package/dist/spinner/index.d.ts +0 -17
  341. package/dist/stories/Button.js +0 -71
  342. package/dist/stories/Button.stories.js +0 -55
  343. package/dist/stories/Header.js +0 -67
  344. package/dist/stories/Header.stories.js +0 -31
  345. package/dist/stories/Introduction.stories.mdx +0 -211
  346. package/dist/stories/Page.js +0 -68
  347. package/dist/stories/Page.stories.js +0 -39
  348. package/dist/stories/assets/code-brackets.svg +0 -1
  349. package/dist/stories/assets/colors.svg +0 -1
  350. package/dist/stories/assets/comments.svg +0 -1
  351. package/dist/stories/assets/direction.svg +0 -1
  352. package/dist/stories/assets/flow.svg +0 -1
  353. package/dist/stories/assets/plugin.svg +0 -1
  354. package/dist/stories/assets/repo.svg +0 -1
  355. package/dist/stories/assets/stackalt.svg +0 -1
  356. package/dist/stories/button.css +0 -30
  357. package/dist/stories/header.css +0 -26
  358. package/dist/stories/page.css +0 -69
  359. package/dist/switch/index.d.ts +0 -24
  360. package/dist/table/index.d.ts +0 -13
  361. package/dist/tabs/Tabs.js +0 -343
  362. package/dist/tabs/index.d.ts +0 -19
  363. package/dist/tag/Tag.js +0 -282
  364. package/dist/tag/index.d.ts +0 -24
  365. package/dist/text-input/index.d.ts +0 -135
  366. package/dist/textarea/index.d.ts +0 -117
  367. package/dist/toggle/Toggle.js +0 -220
  368. package/dist/toggle/index.d.ts +0 -21
  369. package/dist/toggle-group/index.d.ts +0 -21
  370. package/dist/upload/Upload.js +0 -205
  371. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -135
  372. package/dist/upload/buttons-upload/Icons.js +0 -40
  373. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  374. package/dist/upload/dragAndDropArea/Icons.js +0 -39
  375. package/dist/upload/file-upload/FileToUpload.js +0 -189
  376. package/dist/upload/file-upload/Icons.js +0 -66
  377. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  378. package/dist/upload/index.d.ts +0 -15
  379. package/dist/upload/transaction/Icons.js +0 -160
  380. package/dist/upload/transaction/Transaction.js +0 -148
  381. package/dist/upload/transactions/Transactions.js +0 -138
  382. package/dist/wizard/Icons.js +0 -65
  383. package/dist/wizard/Wizard.js +0 -405
  384. package/dist/wizard/index.d.ts +0 -18
  385. package/test/Accordion.test.js +0 -33
  386. package/test/AccordionGroup.test.js +0 -125
  387. package/test/Alert.test.js +0 -53
  388. package/test/Box.test.js +0 -10
  389. package/test/Button.test.js +0 -18
  390. package/test/Card.test.js +0 -30
  391. package/test/Checkbox.test.js +0 -45
  392. package/test/Chip.test.js +0 -25
  393. package/test/Date.test.js +0 -395
  394. package/test/DateInput.test.js +0 -242
  395. package/test/Dialog.test.js +0 -23
  396. package/test/Dropdown.test.js +0 -145
  397. package/test/FileInput.test.js +0 -201
  398. package/test/Footer.test.js +0 -94
  399. package/test/Header.test.js +0 -34
  400. package/test/Heading.test.js +0 -83
  401. package/test/InputText.test.js +0 -239
  402. package/test/Link.test.js +0 -43
  403. package/test/NumberInput.test.js +0 -259
  404. package/test/Paginator.test.js +0 -181
  405. package/test/PasswordInput.test.js +0 -83
  406. package/test/ProgressBar.test.js +0 -35
  407. package/test/Radio.test.js +0 -37
  408. package/test/ResultsetTable.test.js +0 -330
  409. package/test/Select.test.js +0 -415
  410. package/test/Sidenav.test.js +0 -45
  411. package/test/Slider.test.js +0 -74
  412. package/test/Spinner.test.js +0 -32
  413. package/test/Switch.test.js +0 -45
  414. package/test/Table.test.js +0 -36
  415. package/test/Tabs.test.js +0 -109
  416. package/test/Tag.test.js +0 -32
  417. package/test/TextInput.test.js +0 -732
  418. package/test/Textarea.test.js +0 -193
  419. package/test/ToggleGroup.test.js +0 -85
  420. package/test/Upload.test.js +0 -60
  421. package/test/V3Select.test.js +0 -212
  422. package/test/V3TextArea.test.js +0 -51
  423. package/test/Wizard.test.js +0 -130
  424. package/test/mocks/pngMock.js +0 -1
  425. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,507 @@
1
+ import React from "react";
2
+ import DxcFileInput from "./FileInput";
3
+ import Title from "../../.storybook/components/Title";
4
+ import ExampleContainer from "../../.storybook/components/ExampleContainer";
5
+
6
+ export default {
7
+ title: "File input",
8
+ component: DxcFileInput,
9
+ };
10
+
11
+ const picPreview =
12
+ "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADIAAAAyCAYAAAAeP4ixAAAABmJLR0QA/wD/AP+gvaeTAAAEDklEQVRogdXaXaxcUxQH8J/etloajVT1I9qgCbdIUB8PXPeKBJHgsV5ExAuVivBUgtSDxgNBVMVHxEeRUhIhkpJ40BYhoTShaQglQtA2VR+ttjMe1j45c6cztzNnzszc+09Ocs/Za+39/++zzt5rr7l0D1diA35P14b0bMJgAE+g2uR6FpP7xq4NZCL2YjlOSNdt6VkVj/eNXYu4VhD9G+c3aL8gtVWS7bjEsfhRCFk2ht2yZPNT8hl3WCUIfoZJY9gdhY+T7QM94NUWFmEfDuHCFuyXJNv9OL2LvNrGO2KGn2rD55nks6ErjAog+8B3YXYbfrPwR/Lt+4d/NLYLMrcW8F+efL/DtBJ5tY17EpEvxEbYLgawJfVxXxObRZhbiF2LWCjfE4Y66OeS1Mc/OLnm+Uw8ggP4oYP+j4hHxUy+VEJfL6e+3hTL8/X4RZ7W/FvCGE1xOdZp7wNvhvny9CULtSo+1QMhZWImPpQL+A03YbouCpkqXn8ZqA+jg1iD41P7NF0QMiAy2N0ipDrFWUa/hU9wXp1N6UIuEktsNug3HfY3gD2pr4rYTxrlZ6UJmY3n0mBZ7JYhhDi3ZP1+i6sb2HQsZBJuEEfUqljjV+Ic5QkhzifZylTF+xisae9IyBIRr1nnb+PU1DaoXCHkk5blXfvxGGYoKGQWnhbpdZb/XFNn0w0hGebgBXm4fY/rtClkOn6Wz8j96Vk9uikkw5DRm2JLQrKV4hB2pr+niJznuPI5toRN4rx/u1jZiLfUMqZiBf4Ss7Bb7Bu1WW0v3kgt5mA17i7iPB8vymN1Cy5Obb0W0jFm4Fd5jFbEfjJsggl5UBDeiLvk4bZP/4RcJj76W1p1OE2sXAfFBkgcotYrL0UpghF5BfOkVhzeTQ5rGrRdIXbiVWWxaxNvCG6vHckwq4jsFPXa8YYF8gPYVc2MaisiN/eGVyGsEBy3C86H4d5k8LliFZFeYSq+FlwP218WiJWpIpbY8Y5heeXllNqGdcqriPQKrwrO67MHZwh1ezGvT6SKIKu8VLCYWGareKgPZEZECrS5oP/Dgvtq2Jpuzi6FWmuYh7XyfK5asJ9zk++X5EWARuePsjEZd9SM+afOhBwjz9TtSDeDY3mUgBH526/gFRHnnQhZLD9NejLdvG7sn8yKoj6MtuLSmvaiQibJ8781RNl+V3rwEZaKpGxKQeIZ6sNoD+5s0G87QqYkbksT1yydWpQZDMl/kS16bawb9AN5GK3VfGnvZMwd0qEv+w+ETTgTN4rEcRAninSgVdTP6oE2fFvFf6JIuA1v4XmRkXQVk+UFhGoacKXDJ6eTj72nmGt0DWCbONdkmDBCMgzjK6MrmAtNQCGUvyH2HfXhNmGFZBgRNYD3Ou3ofwlpcfptqgzTAAAAAElFTkSuQmCC";
13
+
14
+ const file1 = new File(["file1"], "file.pdf", { type: "text/plain" });
15
+ const file2 = new File(["file2"], "file2.mp3", {
16
+ type: "audio",
17
+ });
18
+ const file3 = new File(["file3"], "file3.png", {
19
+ type: "image/png",
20
+ });
21
+ const file4 = new File(["file4"], "file4file4file4file4file4file4file4file4file4.mp4", {
22
+ type: "video",
23
+ });
24
+ const file5 = new File(["file4"], "file5file5file5file5file5file5file5file5file5.mp4", {
25
+ type: "video",
26
+ });
27
+
28
+ const fileExample = [
29
+ {
30
+ file: file1,
31
+ },
32
+ ];
33
+
34
+ const fileExampleError = [
35
+ {
36
+ error: "Error message",
37
+ file: file1,
38
+ },
39
+ ];
40
+
41
+ const filesExamples = [
42
+ {
43
+ file: file1,
44
+ },
45
+ {
46
+ file: file2,
47
+ },
48
+ {
49
+ file: file3,
50
+ preview: picPreview,
51
+ },
52
+ {
53
+ file: file4,
54
+ },
55
+ {
56
+ error: "Error message error message error message error message",
57
+ file: file5,
58
+ },
59
+ {
60
+ error: "Error message",
61
+ file: file3,
62
+ preview: picPreview,
63
+ },
64
+ ];
65
+
66
+ export const Chromatic = () => (
67
+ <>
68
+ <ExampleContainer pseudoState="pseudo-hover">
69
+ <Title title="File item hovered" theme="light" level={4} />
70
+ <DxcFileInput value={fileExample} callbackFile={() => {}} />
71
+ </ExampleContainer>
72
+ <ExampleContainer pseudoState="pseudo-focus">
73
+ <Title title="File item focused" theme="light" level={4} />
74
+ <DxcFileInput value={fileExample} callbackFile={() => {}} />
75
+ </ExampleContainer>
76
+ <ExampleContainer pseudoState="pseudo-active">
77
+ <Title title="File item actived" theme="light" level={4} />
78
+ <DxcFileInput value={fileExample} callbackFile={() => {}} />
79
+ </ExampleContainer>
80
+ <Title title="File" theme="light" level={2} />
81
+ <ExampleContainer>
82
+ <Title title="Without label" theme="light" level={4} />
83
+ <DxcFileInput value={[]} callbackFile={() => {}} />
84
+ </ExampleContainer>
85
+ <ExampleContainer>
86
+ <Title title="With label" theme="light" level={4} />
87
+ <DxcFileInput label="File input" value={[]} callbackFile={() => {}} />
88
+ </ExampleContainer>
89
+ <ExampleContainer>
90
+ <Title title="With label and helper text" theme="light" level={4} />
91
+ <DxcFileInput label="File input" helperText="Please select files" value={[]} callbackFile={() => {}} />
92
+ </ExampleContainer>
93
+ <ExampleContainer>
94
+ <Title title="Single file" theme="light" level={4} />
95
+ <DxcFileInput
96
+ label="File input"
97
+ helperText="Please select files"
98
+ value={fileExample}
99
+ multiple={false}
100
+ callbackFile={() => {}}
101
+ />
102
+ </ExampleContainer>
103
+ <ExampleContainer>
104
+ <Title title="Invalid single file" theme="light" level={4} />
105
+ <DxcFileInput
106
+ label="File input"
107
+ helperText="Please select files"
108
+ value={fileExampleError}
109
+ multiple={false}
110
+ callbackFile={() => {}}
111
+ />
112
+ </ExampleContainer>
113
+ <ExampleContainer>
114
+ <Title title="Multiple files" theme="light" level={4} />
115
+ <DxcFileInput label="File input" helperText="Please select files" value={filesExamples} callbackFile={() => {}} />
116
+ </ExampleContainer>
117
+ <ExampleContainer>
118
+ <Title title="Show preview" theme="light" level={4} />
119
+ <DxcFileInput
120
+ label="File input"
121
+ helperText="Please select files"
122
+ value={filesExamples}
123
+ callbackFile={() => {}}
124
+ showPreview
125
+ />
126
+ </ExampleContainer>
127
+ <ExampleContainer>
128
+ <Title title="Disabled" theme="light" level={4} />
129
+ <DxcFileInput label="File input" helperText="Please select files" disabled value={[]} callbackFile={() => {}} />
130
+ </ExampleContainer>
131
+ <Title title="Margins" theme="light" level={3} />
132
+ <ExampleContainer>
133
+ <Title title="Xxsmall margin" theme="light" level={4} />
134
+ <DxcFileInput
135
+ label="File input"
136
+ helperText="Please select files"
137
+ value={fileExample}
138
+ callbackFile={() => {}}
139
+ margin="xxsmall"
140
+ />
141
+ </ExampleContainer>
142
+ <ExampleContainer>
143
+ <Title title="Xsmall margin" theme="light" level={4} />
144
+ <DxcFileInput
145
+ label="File input"
146
+ helperText="Please select files"
147
+ value={fileExample}
148
+ callbackFile={() => {}}
149
+ margin="xsmall"
150
+ />
151
+ </ExampleContainer>
152
+ <ExampleContainer>
153
+ <Title title="Small margin" theme="light" level={4} />
154
+ <DxcFileInput
155
+ label="File input"
156
+ helperText="Please select files"
157
+ value={fileExample}
158
+ callbackFile={() => {}}
159
+ margin="small"
160
+ />
161
+ </ExampleContainer>
162
+ <ExampleContainer>
163
+ <Title title="Medium margin" theme="light" level={4} />
164
+ <DxcFileInput
165
+ label="File input"
166
+ helperText="Please select files"
167
+ value={fileExample}
168
+ callbackFile={() => {}}
169
+ margin="medium"
170
+ />
171
+ </ExampleContainer>
172
+ <ExampleContainer>
173
+ <Title title="Large margin" theme="light" level={4} />
174
+ <DxcFileInput
175
+ label="File input"
176
+ helperText="Please select files"
177
+ value={fileExample}
178
+ callbackFile={() => {}}
179
+ margin="large"
180
+ />
181
+ </ExampleContainer>
182
+ <ExampleContainer>
183
+ <Title title="Xlarge margin" theme="light" level={4} />
184
+ <DxcFileInput
185
+ label="File input"
186
+ helperText="Please select files"
187
+ value={fileExample}
188
+ callbackFile={() => {}}
189
+ margin="xlarge"
190
+ />
191
+ </ExampleContainer>
192
+ <ExampleContainer>
193
+ <Title title="Xxlarge margin" theme="light" level={4} />
194
+ <DxcFileInput
195
+ label="File input"
196
+ helperText="Please select files"
197
+ value={fileExample}
198
+ callbackFile={() => {}}
199
+ margin="xxlarge"
200
+ />
201
+ </ExampleContainer>
202
+ <Title title="Filedrop" theme="light" level={2} />
203
+ <ExampleContainer>
204
+ <Title title="Without label" theme="light" level={4} />
205
+ <DxcFileInput mode="filedrop" value={[]} callbackFile={() => {}} />
206
+ </ExampleContainer>
207
+ <ExampleContainer>
208
+ <Title title="With label" theme="light" level={4} />
209
+ <DxcFileInput mode="filedrop" label="File input" value={[]} callbackFile={() => {}} />
210
+ </ExampleContainer>
211
+ <ExampleContainer>
212
+ <Title title="With label, helper text and ellipsis" theme="light" level={4} />
213
+ <DxcFileInput
214
+ mode="filedrop"
215
+ label="File input"
216
+ dropAreaLabel="or drop files or drop files or drop files or drop files or drop files"
217
+ helperText="Please select files"
218
+ value={[]}
219
+ callbackFile={() => {}}
220
+ />
221
+ </ExampleContainer>
222
+ <ExampleContainer>
223
+ <Title title="Single file" theme="light" level={4} />
224
+ <DxcFileInput
225
+ mode="filedrop"
226
+ label="File input"
227
+ helperText="Please select files"
228
+ value={fileExample}
229
+ multiple={false}
230
+ callbackFile={() => {}}
231
+ />
232
+ </ExampleContainer>
233
+ <ExampleContainer>
234
+ <Title title="Invalid single file" theme="light" level={4} />
235
+ <DxcFileInput
236
+ mode="filedrop"
237
+ label="File input"
238
+ helperText="Please select files"
239
+ value={fileExampleError}
240
+ multiple={false}
241
+ callbackFile={() => {}}
242
+ />
243
+ </ExampleContainer>
244
+ <ExampleContainer>
245
+ <Title title="Multiple files" theme="light" level={4} />
246
+ <DxcFileInput
247
+ mode="filedrop"
248
+ label="File input"
249
+ helperText="Please select files"
250
+ value={filesExamples}
251
+ callbackFile={() => {}}
252
+ />
253
+ </ExampleContainer>
254
+ <ExampleContainer>
255
+ <Title title="Show preview" theme="light" level={4} />
256
+ <DxcFileInput
257
+ mode="filedrop"
258
+ label="File input"
259
+ helperText="Please select files"
260
+ value={filesExamples}
261
+ callbackFile={() => {}}
262
+ showPreview
263
+ />
264
+ </ExampleContainer>
265
+ <ExampleContainer>
266
+ <Title title="Disabled" theme="light" level={4} />
267
+ <DxcFileInput
268
+ label="File input"
269
+ helperText="Please select files"
270
+ mode="filedrop"
271
+ disabled
272
+ value={[]}
273
+ callbackFile={() => {}}
274
+ />
275
+ </ExampleContainer>
276
+ <Title title="Margins" theme="light" level={3} />
277
+ <ExampleContainer>
278
+ <Title title="Xxsmall margin" theme="light" level={4} />
279
+ <DxcFileInput
280
+ label="File input"
281
+ helperText="Please select files"
282
+ value={fileExample}
283
+ callbackFile={() => {}}
284
+ mode="filedrop"
285
+ margin="xxsmall"
286
+ />
287
+ </ExampleContainer>
288
+ <ExampleContainer>
289
+ <Title title="Xsmall margin" theme="light" level={4} />
290
+ <DxcFileInput
291
+ label="File input"
292
+ helperText="Please select files"
293
+ value={fileExample}
294
+ callbackFile={() => {}}
295
+ mode="filedrop"
296
+ margin="xsmall"
297
+ />
298
+ </ExampleContainer>
299
+ <ExampleContainer>
300
+ <Title title="Small margin" theme="light" level={4} />
301
+ <DxcFileInput
302
+ label="File input"
303
+ helperText="Please select files"
304
+ value={fileExample}
305
+ callbackFile={() => {}}
306
+ mode="filedrop"
307
+ margin="small"
308
+ />
309
+ </ExampleContainer>
310
+ <ExampleContainer>
311
+ <Title title="Medium margin" theme="light" level={4} />
312
+ <DxcFileInput
313
+ label="File input"
314
+ helperText="Please select files"
315
+ value={fileExample}
316
+ callbackFile={() => {}}
317
+ mode="filedrop"
318
+ margin="medium"
319
+ />
320
+ </ExampleContainer>
321
+ <ExampleContainer>
322
+ <Title title="Large margin" theme="light" level={4} />
323
+ <DxcFileInput
324
+ label="File input"
325
+ helperText="Please select files"
326
+ value={fileExample}
327
+ callbackFile={() => {}}
328
+ mode="filedrop"
329
+ margin="large"
330
+ />
331
+ </ExampleContainer>
332
+ <ExampleContainer>
333
+ <Title title="Xlarge margin" theme="light" level={4} />
334
+ <DxcFileInput
335
+ label="File input"
336
+ helperText="Please select files"
337
+ value={fileExample}
338
+ callbackFile={() => {}}
339
+ margin="xlarge"
340
+ />
341
+ </ExampleContainer>
342
+ <ExampleContainer>
343
+ <Title title="Xxlarge margin" theme="light" level={4} />
344
+ <DxcFileInput
345
+ label="File input"
346
+ helperText="Please select files"
347
+ value={fileExample}
348
+ callbackFile={() => {}}
349
+ mode="filedrop"
350
+ margin="xxlarge"
351
+ />
352
+ </ExampleContainer>
353
+ <Title title="Dropzone" theme="light" level={2} />
354
+ <ExampleContainer>
355
+ <Title title="Without label" theme="light" level={4} />
356
+ <DxcFileInput mode="dropzone" value={[]} callbackFile={() => {}} />
357
+ </ExampleContainer>
358
+ <ExampleContainer>
359
+ <Title title="With label" theme="light" level={4} />
360
+ <DxcFileInput label="File input" mode="dropzone" value={[]} callbackFile={() => {}} />
361
+ </ExampleContainer>
362
+ <ExampleContainer>
363
+ <Title title="With label, helper text and ellipsis" theme="light" level={4} />
364
+ <DxcFileInput
365
+ label="File input"
366
+ helperText="Please select files"
367
+ mode="dropzone"
368
+ dropAreaLabel="or drop files or drop files or drop files or drop files or drop files or drop files or drop files or drop files or drop files or drop files or drop files or drop files or drop files or drop files"
369
+ value={[]}
370
+ callbackFile={() => {}}
371
+ />
372
+ </ExampleContainer>
373
+ <ExampleContainer>
374
+ <Title title="Single file" theme="light" level={4} />
375
+ <DxcFileInput
376
+ label="File input"
377
+ helperText="Please select files"
378
+ mode="dropzone"
379
+ value={fileExample}
380
+ callbackFile={() => {}}
381
+ multiple={false}
382
+ />
383
+ </ExampleContainer>
384
+ <ExampleContainer>
385
+ <Title title="Invalid single file" theme="light" level={4} />
386
+ <DxcFileInput
387
+ label="File input"
388
+ helperText="Please select files"
389
+ mode="dropzone"
390
+ value={fileExampleError}
391
+ callbackFile={() => {}}
392
+ multiple={false}
393
+ />
394
+ </ExampleContainer>
395
+ <ExampleContainer>
396
+ <Title title="Multiple files" theme="light" level={4} />
397
+ <DxcFileInput
398
+ mode="dropzone"
399
+ label="File input"
400
+ helperText="Please select files"
401
+ value={filesExamples}
402
+ callbackFile={() => {}}
403
+ />
404
+ </ExampleContainer>
405
+ <ExampleContainer>
406
+ <Title title="Show preview" theme="light" level={4} />
407
+ <DxcFileInput
408
+ mode="dropzone"
409
+ label="File input"
410
+ helperText="Please select files"
411
+ value={filesExamples}
412
+ callbackFile={() => {}}
413
+ showPreview
414
+ />
415
+ </ExampleContainer>
416
+ <ExampleContainer>
417
+ <Title title="Disabled" theme="light" level={4} />
418
+ <DxcFileInput
419
+ label="File input"
420
+ helperText="Please select files"
421
+ mode="dropzone"
422
+ disabled
423
+ value={[]}
424
+ callbackFile={() => {}}
425
+ />
426
+ </ExampleContainer>
427
+ <Title title="Margins" theme="light" level={3} />
428
+ <ExampleContainer>
429
+ <Title title="Xxsmall margin" theme="light" level={4} />
430
+ <DxcFileInput
431
+ label="File input"
432
+ helperText="Please select files"
433
+ value={fileExample}
434
+ callbackFile={() => {}}
435
+ mode="dropzone"
436
+ margin="xxsmall"
437
+ />
438
+ </ExampleContainer>
439
+ <ExampleContainer>
440
+ <Title title="Xsmall margin" theme="light" level={4} />
441
+ <DxcFileInput
442
+ label="File input"
443
+ helperText="Please select files"
444
+ value={fileExample}
445
+ callbackFile={() => {}}
446
+ mode="dropzone"
447
+ margin="xsmall"
448
+ />
449
+ </ExampleContainer>
450
+ <ExampleContainer>
451
+ <Title title="Small margin" theme="light" level={4} />
452
+ <DxcFileInput
453
+ label="File input"
454
+ helperText="Please select files"
455
+ value={fileExample}
456
+ callbackFile={() => {}}
457
+ mode="dropzone"
458
+ margin="small"
459
+ />
460
+ </ExampleContainer>
461
+ <ExampleContainer>
462
+ <Title title="Medium margin" theme="light" level={4} />
463
+ <DxcFileInput
464
+ label="File input"
465
+ helperText="Please select files"
466
+ value={fileExample}
467
+ callbackFile={() => {}}
468
+ mode="dropzone"
469
+ margin="medium"
470
+ />
471
+ </ExampleContainer>
472
+ <ExampleContainer>
473
+ <Title title="Large margin" theme="light" level={4} />
474
+ <DxcFileInput
475
+ label="File input"
476
+ helperText="Please select files"
477
+ value={fileExample}
478
+ callbackFile={() => {}}
479
+ mode="dropzone"
480
+ margin="large"
481
+ />
482
+ </ExampleContainer>
483
+ <ExampleContainer>
484
+ <Title title="Xlarge margin" theme="light" level={4} />
485
+ <DxcFileInput
486
+ label="File input"
487
+ helperText="Please select files"
488
+ value={fileExample}
489
+ callbackFile={() => {}}
490
+ mode="dropzone"
491
+ margin="xlarge"
492
+ />
493
+ </ExampleContainer>
494
+ <ExampleContainer>
495
+ <Title title="Xxlarge margin" theme="light" level={4} />
496
+ <DxcFileInput
497
+ label="File input"
498
+ helperText="Please select files"
499
+ value={fileExample}
500
+ callbackFile={() => {}}
501
+ mode="dropzone"
502
+ margin="xxlarge"
503
+ />
504
+ <hr />
505
+ </ExampleContainer>
506
+ </>
507
+ );