@dxc-technology/halstack-react 3.4.1 → 5.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (443) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +47 -0
  3. package/HalstackContext.d.ts +10 -0
  4. package/HalstackContext.js +243 -0
  5. package/accordion/Accordion.d.ts +4 -0
  6. package/accordion/Accordion.js +226 -0
  7. package/accordion/Accordion.stories.tsx +307 -0
  8. package/accordion/Accordion.test.js +72 -0
  9. package/accordion/types.d.ts +68 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +168 -0
  13. package/accordion-group/AccordionGroup.stories.tsx +225 -0
  14. package/accordion-group/AccordionGroup.test.js +151 -0
  15. package/accordion-group/types.d.ts +72 -0
  16. package/accordion-group/types.js +5 -0
  17. package/alert/Alert.d.ts +4 -0
  18. package/{dist/alert → alert}/Alert.js +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 +34 -100
  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/card/Card.js +163 -0
  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 +53 -99
  53. package/checkbox/Checkbox.stories.tsx +188 -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 +350 -339
  77. package/date-input/DateInput.d.ts +4 -0
  78. package/date-input/DateInput.js +369 -0
  79. package/date-input/DateInput.stories.tsx +138 -0
  80. package/date-input/DateInput.test.js +479 -0
  81. package/date-input/types.d.ts +107 -0
  82. package/date-input/types.js +5 -0
  83. package/dialog/Dialog.d.ts +4 -0
  84. package/dialog/Dialog.js +138 -0
  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 +54 -207
  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 +183 -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 +300 -0
  113. package/header/Header.stories.tsx +172 -0
  114. package/header/Header.test.js +79 -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 +37 -0
  129. package/inset/types.js +5 -0
  130. package/layout/ApplicationLayout.d.ts +10 -0
  131. package/layout/ApplicationLayout.js +218 -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 -115
  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 +47 -0
  148. package/{dist/main.js → main.js} +137 -101
  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 +506 -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 +124 -0
  158. package/number-input/types.js +5 -0
  159. package/package.json +37 -27
  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 +181 -0
  171. package/password-input/types.d.ts +110 -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/quick-nav/QuickNav.d.ts +4 -0
  180. package/quick-nav/QuickNav.js +64 -0
  181. package/quick-nav/QuickNav.stories.tsx +237 -0
  182. package/quick-nav/types.d.ts +21 -0
  183. package/quick-nav/types.js +5 -0
  184. package/radio/Radio.d.ts +4 -0
  185. package/{dist/radio → radio}/Radio.js +23 -59
  186. package/radio/Radio.stories.tsx +192 -0
  187. package/radio/Radio.test.js +71 -0
  188. package/radio/types.d.ts +54 -0
  189. package/radio/types.js +5 -0
  190. package/radio-group/Radio.d.ts +4 -0
  191. package/radio-group/Radio.js +141 -0
  192. package/radio-group/RadioGroup.d.ts +4 -0
  193. package/radio-group/RadioGroup.js +280 -0
  194. package/radio-group/RadioGroup.stories.tsx +100 -0
  195. package/radio-group/RadioGroup.test.js +695 -0
  196. package/radio-group/types.d.ts +114 -0
  197. package/radio-group/types.js +5 -0
  198. package/resultsetTable/ResultsetTable.d.ts +4 -0
  199. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +43 -147
  200. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  201. package/resultsetTable/ResultsetTable.test.js +306 -0
  202. package/resultsetTable/types.d.ts +67 -0
  203. package/resultsetTable/types.js +5 -0
  204. package/row/Row.d.ts +3 -0
  205. package/row/Row.js +127 -0
  206. package/row/Row.stories.tsx +237 -0
  207. package/row/types.d.ts +28 -0
  208. package/row/types.js +5 -0
  209. package/select/Icons.d.ts +10 -0
  210. package/select/Icons.js +93 -0
  211. package/select/Listbox.d.ts +4 -0
  212. package/select/Listbox.js +148 -0
  213. package/select/Option.d.ts +4 -0
  214. package/select/Option.js +110 -0
  215. package/select/Select.d.ts +4 -0
  216. package/select/Select.js +655 -0
  217. package/select/Select.stories.tsx +582 -0
  218. package/select/Select.test.js +2057 -0
  219. package/select/types.d.ts +213 -0
  220. package/select/types.js +5 -0
  221. package/sidenav/Sidenav.d.ts +9 -0
  222. package/sidenav/Sidenav.js +136 -0
  223. package/sidenav/Sidenav.stories.tsx +182 -0
  224. package/sidenav/Sidenav.test.js +56 -0
  225. package/sidenav/types.d.ts +50 -0
  226. package/sidenav/types.js +5 -0
  227. package/slider/Slider.d.ts +4 -0
  228. package/slider/Slider.js +318 -0
  229. package/slider/Slider.stories.tsx +177 -0
  230. package/slider/Slider.test.js +150 -0
  231. package/slider/types.d.ts +82 -0
  232. package/slider/types.js +5 -0
  233. package/spinner/Spinner.d.ts +4 -0
  234. package/spinner/Spinner.js +250 -0
  235. package/spinner/Spinner.stories.jsx +103 -0
  236. package/spinner/Spinner.test.js +64 -0
  237. package/spinner/types.d.ts +32 -0
  238. package/spinner/types.js +5 -0
  239. package/stack/Stack.d.ts +3 -0
  240. package/stack/Stack.js +97 -0
  241. package/stack/Stack.stories.tsx +164 -0
  242. package/stack/types.d.ts +24 -0
  243. package/stack/types.js +5 -0
  244. package/switch/Switch.d.ts +4 -0
  245. package/switch/Switch.js +192 -0
  246. package/switch/Switch.stories.tsx +160 -0
  247. package/switch/Switch.test.js +98 -0
  248. package/switch/types.d.ts +62 -0
  249. package/switch/types.js +5 -0
  250. package/table/Table.d.ts +4 -0
  251. package/{dist/table → table}/Table.js +12 -26
  252. package/table/Table.stories.jsx +277 -0
  253. package/table/Table.test.js +26 -0
  254. package/table/types.d.ts +21 -0
  255. package/table/types.js +5 -0
  256. package/tabs/Tabs.d.ts +4 -0
  257. package/tabs/Tabs.js +211 -0
  258. package/tabs/Tabs.stories.tsx +118 -0
  259. package/tabs/Tabs.test.js +140 -0
  260. package/tabs/types.d.ts +82 -0
  261. package/tabs/types.js +5 -0
  262. package/tag/Tag.d.ts +4 -0
  263. package/tag/Tag.js +183 -0
  264. package/tag/Tag.stories.tsx +142 -0
  265. package/tag/Tag.test.js +60 -0
  266. package/tag/types.d.ts +69 -0
  267. package/tag/types.js +5 -0
  268. package/text/Text.d.ts +7 -0
  269. package/text/Text.js +30 -0
  270. package/text/Text.stories.tsx +19 -0
  271. package/text-input/TextInput.d.ts +4 -0
  272. package/text-input/TextInput.js +796 -0
  273. package/text-input/TextInput.stories.tsx +474 -0
  274. package/text-input/TextInput.test.js +1712 -0
  275. package/text-input/types.d.ts +166 -0
  276. package/text-input/types.js +5 -0
  277. package/textarea/Textarea.d.ts +4 -0
  278. package/{dist/new-textarea/NewTextarea.js → textarea/Textarea.js} +95 -155
  279. package/textarea/Textarea.stories.jsx +157 -0
  280. package/textarea/Textarea.test.js +437 -0
  281. package/textarea/types.d.ts +137 -0
  282. package/textarea/types.js +5 -0
  283. package/toggle-group/ToggleGroup.d.ts +4 -0
  284. package/toggle-group/ToggleGroup.js +215 -0
  285. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  286. package/toggle-group/ToggleGroup.test.js +156 -0
  287. package/toggle-group/types.d.ts +105 -0
  288. package/toggle-group/types.js +5 -0
  289. package/useTheme.d.ts +2 -0
  290. package/{dist/useTheme.js → useTheme.js} +2 -2
  291. package/wizard/Wizard.d.ts +4 -0
  292. package/wizard/Wizard.js +290 -0
  293. package/wizard/Wizard.stories.tsx +214 -0
  294. package/wizard/Wizard.test.js +141 -0
  295. package/wizard/types.d.ts +64 -0
  296. package/wizard/types.js +5 -0
  297. package/README.md +0 -66
  298. package/babel.config.js +0 -8
  299. package/dist/BackgroundColorContext.js +0 -46
  300. package/dist/ThemeContext.js +0 -240
  301. package/dist/accordion/Accordion.js +0 -353
  302. package/dist/accordion-group/AccordionGroup.js +0 -186
  303. package/dist/badge/Badge.js +0 -63
  304. package/dist/card/Card.js +0 -254
  305. package/dist/checkbox/Checkbox.stories.js +0 -144
  306. package/dist/checkbox/readme.md +0 -116
  307. package/dist/chip/Chip.js +0 -265
  308. package/dist/date/Date.js +0 -381
  309. package/dist/date/Date.stories.js +0 -205
  310. package/dist/date/readme.md +0 -73
  311. package/dist/dialog/Dialog.js +0 -218
  312. package/dist/footer/Footer.js +0 -395
  313. package/dist/footer/Footer.stories.js +0 -94
  314. package/dist/footer/dxc_logo.svg +0 -15
  315. package/dist/footer/readme.md +0 -41
  316. package/dist/header/Header.js +0 -403
  317. package/dist/header/Header.stories.js +0 -176
  318. package/dist/header/close_icon.svg +0 -1
  319. package/dist/header/dxc_logo_black.svg +0 -8
  320. package/dist/header/hamb_menu_black.svg +0 -1
  321. package/dist/header/hamb_menu_white.svg +0 -1
  322. package/dist/header/readme.md +0 -33
  323. package/dist/input-text/InputText.js +0 -707
  324. package/dist/input-text/InputText.stories.js +0 -209
  325. package/dist/input-text/error.svg +0 -1
  326. package/dist/input-text/readme.md +0 -91
  327. package/dist/layout/ApplicationLayout.js +0 -331
  328. package/dist/layout/facebook.svg +0 -45
  329. package/dist/layout/linkedin.svg +0 -50
  330. package/dist/layout/twitter.svg +0 -53
  331. package/dist/link/readme.md +0 -51
  332. package/dist/new-date/NewDate.js +0 -403
  333. package/dist/new-input-text/NewInputText.js +0 -961
  334. package/dist/number/Number.js +0 -138
  335. package/dist/paginator/Paginator.js +0 -289
  336. package/dist/paginator/images/next.svg +0 -3
  337. package/dist/paginator/images/nextPage.svg +0 -3
  338. package/dist/paginator/images/previous.svg +0 -3
  339. package/dist/paginator/images/previousPage.svg +0 -3
  340. package/dist/paginator/readme.md +0 -50
  341. package/dist/password/styles.css +0 -3
  342. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  343. package/dist/progress-bar/readme.md +0 -63
  344. package/dist/radio/Radio.stories.js +0 -166
  345. package/dist/radio/readme.md +0 -70
  346. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  347. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  348. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  349. package/dist/select/Select.js +0 -585
  350. package/dist/select/Select.stories.js +0 -235
  351. package/dist/select/readme.md +0 -72
  352. package/dist/sidenav/Sidenav.js +0 -177
  353. package/dist/slider/Slider.js +0 -319
  354. package/dist/slider/Slider.stories.js +0 -241
  355. package/dist/slider/readme.md +0 -64
  356. package/dist/spinner/Spinner.js +0 -381
  357. package/dist/spinner/Spinner.stories.js +0 -183
  358. package/dist/spinner/readme.md +0 -65
  359. package/dist/switch/Switch.js +0 -222
  360. package/dist/switch/Switch.stories.js +0 -134
  361. package/dist/switch/readme.md +0 -133
  362. package/dist/tabs/Tabs.js +0 -343
  363. package/dist/tabs/Tabs.stories.js +0 -130
  364. package/dist/tabs/readme.md +0 -78
  365. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  366. package/dist/tabs-for-sections/readme.md +0 -78
  367. package/dist/tag/Tag.js +0 -288
  368. package/dist/textarea/Textarea.js +0 -264
  369. package/dist/toggle/Toggle.js +0 -220
  370. package/dist/toggle/Toggle.stories.js +0 -297
  371. package/dist/toggle/readme.md +0 -80
  372. package/dist/toggle-group/ToggleGroup.js +0 -223
  373. package/dist/upload/Upload.js +0 -205
  374. package/dist/upload/Upload.stories.js +0 -72
  375. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -139
  376. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  377. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  378. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -329
  379. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  380. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  381. package/dist/upload/file-upload/FileToUpload.js +0 -184
  382. package/dist/upload/file-upload/audio-icon.svg +0 -4
  383. package/dist/upload/file-upload/close.svg +0 -4
  384. package/dist/upload/file-upload/file-icon.svg +0 -4
  385. package/dist/upload/file-upload/video-icon.svg +0 -4
  386. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  387. package/dist/upload/readme.md +0 -37
  388. package/dist/upload/transaction/Transaction.js +0 -175
  389. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  390. package/dist/upload/transaction/audio-icon.svg +0 -4
  391. package/dist/upload/transaction/error-icon.svg +0 -4
  392. package/dist/upload/transaction/file-icon-err.svg +0 -4
  393. package/dist/upload/transaction/file-icon.svg +0 -4
  394. package/dist/upload/transaction/image-icon-err.svg +0 -4
  395. package/dist/upload/transaction/image-icon.svg +0 -4
  396. package/dist/upload/transaction/success-icon.svg +0 -4
  397. package/dist/upload/transaction/video-icon-err.svg +0 -4
  398. package/dist/upload/transaction/video-icon.svg +0 -4
  399. package/dist/upload/transactions/Transactions.js +0 -138
  400. package/dist/wizard/Wizard.js +0 -411
  401. package/dist/wizard/invalid_icon.svg +0 -5
  402. package/dist/wizard/valid_icon.svg +0 -5
  403. package/dist/wizard/validation-wrong.svg +0 -6
  404. package/test/Accordion.test.js +0 -33
  405. package/test/AccordionGroup.test.js +0 -125
  406. package/test/Alert.test.js +0 -53
  407. package/test/Box.test.js +0 -10
  408. package/test/Button.test.js +0 -18
  409. package/test/Card.test.js +0 -30
  410. package/test/Checkbox.test.js +0 -45
  411. package/test/Chip.test.js +0 -25
  412. package/test/Date.test.js +0 -393
  413. package/test/Dialog.test.js +0 -23
  414. package/test/Dropdown.test.js +0 -145
  415. package/test/Footer.test.js +0 -99
  416. package/test/Header.test.js +0 -39
  417. package/test/Heading.test.js +0 -35
  418. package/test/InputText.test.js +0 -240
  419. package/test/Link.test.js +0 -43
  420. package/test/NewDate.test.js +0 -203
  421. package/test/NewInputText.test.js +0 -817
  422. package/test/NewTextarea.test.js +0 -201
  423. package/test/Number.test.js +0 -241
  424. package/test/Paginator.test.js +0 -177
  425. package/test/Password.test.js +0 -76
  426. package/test/ProgressBar.test.js +0 -35
  427. package/test/Radio.test.js +0 -37
  428. package/test/ResultsetTable.test.js +0 -330
  429. package/test/Select.test.js +0 -189
  430. package/test/Sidenav.test.js +0 -45
  431. package/test/Slider.test.js +0 -82
  432. package/test/Spinner.test.js +0 -32
  433. package/test/Switch.test.js +0 -45
  434. package/test/Table.test.js +0 -36
  435. package/test/Tabs.test.js +0 -109
  436. package/test/TabsForSections.test.js +0 -34
  437. package/test/Tag.test.js +0 -32
  438. package/test/TextArea.test.js +0 -52
  439. package/test/ToggleGroup.test.js +0 -81
  440. package/test/Upload.test.js +0 -60
  441. package/test/Wizard.test.js +0 -130
  442. package/test/mocks/pngMock.js +0 -1
  443. 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
+ );