@dxc-technology/halstack-react 0.0.0-c0aaf04 → 0.0.0-c25d3b6

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 (433) 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 +247 -0
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +57 -0
  9. package/accordion/types.d.ts +64 -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 +44 -157
  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 +27 -94
  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 +18 -65
  53. package/checkbox/Checkbox.stories.tsx +192 -0
  54. package/checkbox/Checkbox.test.js +65 -0
  55. package/checkbox/types.d.ts +60 -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 +345 -333
  77. package/date-input/DateInput.d.ts +4 -0
  78. package/date-input/DateInput.js +354 -0
  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/footer/Icons.js +77 -0
  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/header/Header.js +324 -0
  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/header/Icons.js +34 -0
  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 +31 -90
  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/layout/ApplicationLayout.js +231 -0
  132. package/layout/ApplicationLayout.stories.tsx +171 -0
  133. package/layout/Icons.js +55 -0
  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 +23 -111
  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} +131 -103
  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/NumberContext.js → number-input/NumberInputContext.js} +6 -3
  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 +34 -24
  160. package/paginator/Icons.js +66 -0
  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/Password.js → password-input/PasswordInput.js} +46 -83
  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 +10 -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/sidenav/Sidenav.js +136 -0
  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/slider/Slider.js +317 -0
  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 +28 -71
  239. package/switch/Switch.stories.tsx +160 -0
  240. package/switch/Switch.test.js +73 -0
  241. package/switch/types.d.ts +58 -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/text-input/TextInput.js +798 -0
  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/new-textarea/NewTextarea.js → textarea/Textarea.js} +97 -155
  272. package/textarea/Textarea.stories.jsx +157 -0
  273. package/textarea/Textarea.test.js +447 -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/toggle-group/ToggleGroup.js +214 -0
  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 +281 -0
  286. package/wizard/Wizard.stories.tsx +224 -0
  287. package/wizard/Wizard.test.js +128 -0
  288. package/wizard/types.d.ts +60 -0
  289. package/wizard/types.js +5 -0
  290. package/README.md +0 -66
  291. package/babel.config.js +0 -8
  292. package/dist/BackgroundColorContext.js +0 -46
  293. package/dist/ThemeContext.js +0 -240
  294. package/dist/accordion/Accordion.js +0 -353
  295. package/dist/accordion-group/AccordionGroup.js +0 -186
  296. package/dist/badge/Badge.js +0 -63
  297. package/dist/checkbox/Checkbox.stories.js +0 -144
  298. package/dist/checkbox/readme.md +0 -116
  299. package/dist/chip/Chip.js +0 -265
  300. package/dist/date/Date.js +0 -381
  301. package/dist/date/Date.stories.js +0 -205
  302. package/dist/date/readme.md +0 -73
  303. package/dist/footer/Footer.js +0 -395
  304. package/dist/footer/Footer.stories.js +0 -94
  305. package/dist/footer/dxc_logo.svg +0 -15
  306. package/dist/footer/readme.md +0 -41
  307. package/dist/header/Header.js +0 -403
  308. package/dist/header/Header.stories.js +0 -176
  309. package/dist/header/close_icon.svg +0 -1
  310. package/dist/header/dxc_logo_black.svg +0 -8
  311. package/dist/header/hamb_menu_black.svg +0 -1
  312. package/dist/header/hamb_menu_white.svg +0 -1
  313. package/dist/header/readme.md +0 -33
  314. package/dist/input-text/InputText.js +0 -707
  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 -331
  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/readme.md +0 -51
  323. package/dist/new-date/NewDate.js +0 -403
  324. package/dist/new-input-text/NewInputText.js +0 -961
  325. package/dist/number/Number.js +0 -138
  326. package/dist/paginator/Paginator.js +0 -289
  327. package/dist/paginator/images/next.svg +0 -3
  328. package/dist/paginator/images/nextPage.svg +0 -3
  329. package/dist/paginator/images/previous.svg +0 -3
  330. package/dist/paginator/images/previousPage.svg +0 -3
  331. package/dist/paginator/readme.md +0 -50
  332. package/dist/password/styles.css +0 -3
  333. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  334. package/dist/progress-bar/readme.md +0 -63
  335. package/dist/radio/Radio.stories.js +0 -166
  336. package/dist/radio/readme.md +0 -70
  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 -585
  341. package/dist/select/Select.stories.js +0 -235
  342. package/dist/select/readme.md +0 -72
  343. package/dist/sidenav/Sidenav.js +0 -177
  344. package/dist/slider/Slider.js +0 -319
  345. package/dist/slider/Slider.stories.js +0 -241
  346. package/dist/slider/readme.md +0 -64
  347. package/dist/spinner/Spinner.js +0 -381
  348. package/dist/spinner/Spinner.stories.js +0 -183
  349. package/dist/spinner/readme.md +0 -65
  350. package/dist/switch/Switch.stories.js +0 -134
  351. package/dist/switch/readme.md +0 -133
  352. package/dist/tabs/Tabs.js +0 -343
  353. package/dist/tabs/Tabs.stories.js +0 -130
  354. package/dist/tabs/readme.md +0 -78
  355. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  356. package/dist/tabs-for-sections/readme.md +0 -78
  357. package/dist/tag/Tag.js +0 -288
  358. package/dist/textarea/Textarea.js +0 -264
  359. package/dist/toggle/Toggle.js +0 -220
  360. package/dist/toggle/Toggle.stories.js +0 -297
  361. package/dist/toggle/readme.md +0 -80
  362. package/dist/toggle-group/ToggleGroup.js +0 -223
  363. package/dist/upload/Upload.js +0 -205
  364. package/dist/upload/Upload.stories.js +0 -72
  365. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -139
  366. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  367. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  368. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  369. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  370. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  371. package/dist/upload/file-upload/FileToUpload.js +0 -184
  372. package/dist/upload/file-upload/audio-icon.svg +0 -4
  373. package/dist/upload/file-upload/close.svg +0 -4
  374. package/dist/upload/file-upload/file-icon.svg +0 -4
  375. package/dist/upload/file-upload/video-icon.svg +0 -4
  376. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  377. package/dist/upload/readme.md +0 -37
  378. package/dist/upload/transaction/Transaction.js +0 -175
  379. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  380. package/dist/upload/transaction/audio-icon.svg +0 -4
  381. package/dist/upload/transaction/error-icon.svg +0 -4
  382. package/dist/upload/transaction/file-icon-err.svg +0 -4
  383. package/dist/upload/transaction/file-icon.svg +0 -4
  384. package/dist/upload/transaction/image-icon-err.svg +0 -4
  385. package/dist/upload/transaction/image-icon.svg +0 -4
  386. package/dist/upload/transaction/success-icon.svg +0 -4
  387. package/dist/upload/transaction/video-icon-err.svg +0 -4
  388. package/dist/upload/transaction/video-icon.svg +0 -4
  389. package/dist/upload/transactions/Transactions.js +0 -138
  390. package/dist/wizard/Wizard.js +0 -411
  391. package/dist/wizard/invalid_icon.svg +0 -5
  392. package/dist/wizard/valid_icon.svg +0 -5
  393. package/dist/wizard/validation-wrong.svg +0 -6
  394. package/test/Accordion.test.js +0 -33
  395. package/test/AccordionGroup.test.js +0 -125
  396. package/test/Alert.test.js +0 -53
  397. package/test/Box.test.js +0 -10
  398. package/test/Button.test.js +0 -18
  399. package/test/Card.test.js +0 -30
  400. package/test/Checkbox.test.js +0 -45
  401. package/test/Chip.test.js +0 -25
  402. package/test/Date.test.js +0 -393
  403. package/test/Dialog.test.js +0 -23
  404. package/test/Dropdown.test.js +0 -145
  405. package/test/Footer.test.js +0 -99
  406. package/test/Header.test.js +0 -39
  407. package/test/Heading.test.js +0 -35
  408. package/test/InputText.test.js +0 -240
  409. package/test/Link.test.js +0 -43
  410. package/test/NewDate.test.js +0 -203
  411. package/test/NewInputText.test.js +0 -817
  412. package/test/NewTextarea.test.js +0 -201
  413. package/test/Number.test.js +0 -241
  414. package/test/Paginator.test.js +0 -177
  415. package/test/Password.test.js +0 -76
  416. package/test/ProgressBar.test.js +0 -35
  417. package/test/Radio.test.js +0 -37
  418. package/test/ResultsetTable.test.js +0 -330
  419. package/test/Select.test.js +0 -189
  420. package/test/Sidenav.test.js +0 -45
  421. package/test/Slider.test.js +0 -82
  422. package/test/Spinner.test.js +0 -32
  423. package/test/Switch.test.js +0 -45
  424. package/test/Table.test.js +0 -36
  425. package/test/Tabs.test.js +0 -109
  426. package/test/TabsForSections.test.js +0 -34
  427. package/test/Tag.test.js +0 -32
  428. package/test/TextArea.test.js +0 -52
  429. package/test/ToggleGroup.test.js +0 -81
  430. package/test/Upload.test.js +0 -60
  431. package/test/Wizard.test.js +0 -130
  432. package/test/mocks/pngMock.js +0 -1
  433. 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
+ );