@dxc-technology/halstack-react 0.0.0-e081e21 → 0.0.0-e1386cf

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 (348) hide show
  1. package/BackgroundColorContext.d.ts +10 -0
  2. package/BackgroundColorContext.js +1 -4
  3. package/HalstackContext.d.ts +12 -0
  4. package/HalstackContext.js +294 -0
  5. package/accordion/Accordion.d.ts +4 -0
  6. package/accordion/Accordion.js +126 -170
  7. package/accordion/Accordion.stories.tsx +306 -0
  8. package/accordion/Accordion.test.js +71 -0
  9. package/accordion/types.d.ts +69 -0
  10. package/accordion/types.js +5 -0
  11. package/accordion-group/AccordionGroup.d.ts +7 -0
  12. package/accordion-group/AccordionGroup.js +61 -96
  13. package/accordion-group/AccordionGroup.stories.tsx +251 -0
  14. package/accordion-group/AccordionGroup.test.js +126 -0
  15. package/accordion-group/types.d.ts +79 -0
  16. package/accordion-group/types.js +5 -0
  17. package/alert/Alert.js +7 -4
  18. package/alert/Alert.stories.tsx +170 -0
  19. package/alert/Alert.test.js +92 -0
  20. package/alert/types.d.ts +1 -1
  21. package/badge/Badge.d.ts +4 -0
  22. package/badge/Badge.js +6 -4
  23. package/badge/types.d.ts +5 -0
  24. package/badge/types.js +5 -0
  25. package/bleed/Bleed.d.ts +3 -0
  26. package/bleed/Bleed.js +51 -0
  27. package/bleed/Bleed.stories.tsx +341 -0
  28. package/bleed/types.d.ts +37 -0
  29. package/bleed/types.js +5 -0
  30. package/box/Box.d.ts +4 -0
  31. package/box/Box.js +29 -65
  32. package/box/Box.stories.tsx +132 -0
  33. package/box/Box.test.js +18 -0
  34. package/box/types.d.ts +44 -0
  35. package/box/types.js +5 -0
  36. package/bulleted-list/BulletedList.d.ts +7 -0
  37. package/bulleted-list/BulletedList.js +123 -0
  38. package/bulleted-list/BulletedList.stories.tsx +200 -0
  39. package/bulleted-list/types.d.ts +11 -0
  40. package/bulleted-list/types.js +5 -0
  41. package/button/Button.d.ts +1 -1
  42. package/button/Button.js +61 -87
  43. package/button/Button.stories.tsx +259 -282
  44. package/button/Button.test.js +35 -0
  45. package/button/types.d.ts +14 -18
  46. package/card/Card.d.ts +4 -0
  47. package/card/Card.js +38 -77
  48. package/card/Card.stories.tsx +201 -0
  49. package/card/Card.test.js +50 -0
  50. package/card/ice-cream.jpg +0 -0
  51. package/card/types.d.ts +68 -0
  52. package/card/types.js +5 -0
  53. package/checkbox/Checkbox.d.ts +2 -2
  54. package/checkbox/Checkbox.js +108 -111
  55. package/checkbox/Checkbox.stories.tsx +208 -0
  56. package/checkbox/Checkbox.test.js +155 -0
  57. package/checkbox/types.d.ts +15 -8
  58. package/chip/Chip.d.ts +4 -0
  59. package/chip/Chip.js +16 -76
  60. package/chip/Chip.stories.tsx +119 -0
  61. package/chip/Chip.test.js +56 -0
  62. package/chip/types.d.ts +45 -0
  63. package/chip/types.js +5 -0
  64. package/common/variables.js +319 -380
  65. package/date-input/DateInput.d.ts +4 -0
  66. package/date-input/DateInput.js +65 -89
  67. package/date-input/DateInput.stories.tsx +138 -0
  68. package/date-input/DateInput.test.js +543 -0
  69. package/date-input/types.d.ts +107 -0
  70. package/date-input/types.js +5 -0
  71. package/dialog/Dialog.d.ts +4 -0
  72. package/dialog/Dialog.js +52 -74
  73. package/dialog/Dialog.stories.tsx +267 -0
  74. package/dialog/Dialog.test.js +70 -0
  75. package/dialog/types.d.ts +44 -0
  76. package/dialog/types.js +5 -0
  77. package/dropdown/Dropdown.d.ts +4 -0
  78. package/dropdown/Dropdown.js +243 -302
  79. package/dropdown/Dropdown.stories.tsx +312 -0
  80. package/dropdown/Dropdown.test.js +585 -0
  81. package/dropdown/DropdownMenu.d.ts +4 -0
  82. package/dropdown/DropdownMenu.js +80 -0
  83. package/dropdown/DropdownMenuItem.d.ts +4 -0
  84. package/dropdown/DropdownMenuItem.js +92 -0
  85. package/dropdown/types.d.ts +100 -0
  86. package/dropdown/types.js +5 -0
  87. package/file-input/FileInput.d.ts +4 -0
  88. package/file-input/FileInput.js +185 -166
  89. package/file-input/FileInput.stories.tsx +535 -0
  90. package/file-input/FileInput.test.js +498 -0
  91. package/file-input/FileItem.d.ts +4 -0
  92. package/file-input/FileItem.js +49 -81
  93. package/file-input/types.d.ts +129 -0
  94. package/file-input/types.js +5 -0
  95. package/flex/Flex.d.ts +4 -0
  96. package/flex/Flex.js +69 -0
  97. package/flex/Flex.stories.tsx +103 -0
  98. package/flex/types.d.ts +32 -0
  99. package/flex/types.js +5 -0
  100. package/footer/Footer.d.ts +4 -0
  101. package/footer/Footer.js +36 -148
  102. package/footer/Footer.stories.tsx +137 -0
  103. package/footer/Footer.test.js +109 -0
  104. package/footer/Icons.d.ts +2 -0
  105. package/footer/Icons.js +4 -4
  106. package/footer/types.d.ts +66 -0
  107. package/footer/types.js +5 -0
  108. package/header/Header.d.ts +7 -0
  109. package/header/Header.js +119 -140
  110. package/header/Header.stories.tsx +172 -0
  111. package/header/Header.test.js +79 -0
  112. package/header/Icons.d.ts +2 -0
  113. package/header/Icons.js +4 -29
  114. package/header/types.d.ts +48 -0
  115. package/header/types.js +5 -0
  116. package/heading/Heading.d.ts +4 -0
  117. package/heading/Heading.js +7 -24
  118. package/heading/Heading.stories.tsx +54 -0
  119. package/heading/Heading.test.js +186 -0
  120. package/heading/types.d.ts +33 -0
  121. package/heading/types.js +5 -0
  122. package/inset/Inset.d.ts +3 -0
  123. package/inset/Inset.js +51 -0
  124. package/inset/Inset.stories.tsx +229 -0
  125. package/inset/types.d.ts +37 -0
  126. package/inset/types.js +5 -0
  127. package/layout/ApplicationLayout.d.ts +20 -0
  128. package/layout/ApplicationLayout.js +71 -135
  129. package/layout/ApplicationLayout.stories.tsx +162 -0
  130. package/layout/Icons.d.ts +5 -0
  131. package/layout/Icons.js +13 -2
  132. package/layout/SidenavContext.d.ts +5 -0
  133. package/layout/SidenavContext.js +19 -0
  134. package/layout/types.d.ts +42 -0
  135. package/layout/types.js +5 -0
  136. package/link/Link.d.ts +4 -0
  137. package/link/Link.js +61 -108
  138. package/link/Link.stories.tsx +193 -0
  139. package/link/Link.test.js +83 -0
  140. package/link/types.d.ts +54 -0
  141. package/link/types.js +5 -0
  142. package/main.d.ts +12 -12
  143. package/main.js +64 -58
  144. package/number-input/NumberInput.d.ts +4 -0
  145. package/number-input/NumberInput.js +16 -68
  146. package/number-input/NumberInput.stories.tsx +115 -0
  147. package/number-input/NumberInput.test.js +542 -0
  148. package/number-input/NumberInputContext.d.ts +4 -0
  149. package/number-input/NumberInputContext.js +5 -2
  150. package/number-input/numberInputContextTypes.d.ts +19 -0
  151. package/number-input/numberInputContextTypes.js +5 -0
  152. package/number-input/types.d.ts +124 -0
  153. package/number-input/types.js +5 -0
  154. package/package.json +22 -16
  155. package/paginator/Paginator.js +19 -46
  156. package/paginator/Paginator.stories.tsx +63 -0
  157. package/paginator/Paginator.test.js +308 -0
  158. package/paragraph/Paragraph.d.ts +6 -0
  159. package/paragraph/Paragraph.js +38 -0
  160. package/paragraph/Paragraph.stories.tsx +44 -0
  161. package/password-input/PasswordInput.d.ts +4 -0
  162. package/password-input/PasswordInput.js +24 -57
  163. package/password-input/PasswordInput.stories.tsx +131 -0
  164. package/password-input/PasswordInput.test.js +181 -0
  165. package/password-input/types.d.ts +110 -0
  166. package/password-input/types.js +5 -0
  167. package/progress-bar/ProgressBar.d.ts +4 -0
  168. package/progress-bar/ProgressBar.js +60 -72
  169. package/progress-bar/ProgressBar.stories.jsx +60 -0
  170. package/progress-bar/ProgressBar.test.js +110 -0
  171. package/progress-bar/types.d.ts +36 -0
  172. package/progress-bar/types.js +5 -0
  173. package/quick-nav/QuickNav.d.ts +4 -0
  174. package/quick-nav/QuickNav.js +117 -0
  175. package/quick-nav/QuickNav.stories.tsx +342 -0
  176. package/quick-nav/types.d.ts +21 -0
  177. package/quick-nav/types.js +5 -0
  178. package/radio-group/Radio.d.ts +4 -0
  179. package/radio-group/Radio.js +156 -0
  180. package/radio-group/RadioGroup.d.ts +4 -0
  181. package/radio-group/RadioGroup.js +283 -0
  182. package/radio-group/RadioGroup.stories.tsx +101 -0
  183. package/radio-group/RadioGroup.test.js +722 -0
  184. package/radio-group/types.d.ts +114 -0
  185. package/radio-group/types.js +5 -0
  186. package/resultsetTable/ResultsetTable.d.ts +4 -0
  187. package/resultsetTable/ResultsetTable.js +10 -32
  188. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  189. package/resultsetTable/ResultsetTable.test.js +348 -0
  190. package/resultsetTable/types.d.ts +67 -0
  191. package/resultsetTable/types.js +5 -0
  192. package/select/Icons.d.ts +10 -0
  193. package/select/Icons.js +93 -0
  194. package/select/Listbox.d.ts +4 -0
  195. package/select/Listbox.js +198 -0
  196. package/select/Option.d.ts +4 -0
  197. package/select/Option.js +110 -0
  198. package/select/Select.d.ts +4 -0
  199. package/select/Select.js +160 -380
  200. package/select/Select.stories.tsx +627 -0
  201. package/select/Select.test.js +2233 -0
  202. package/select/types.d.ts +210 -0
  203. package/select/types.js +5 -0
  204. package/sidenav/Sidenav.d.ts +10 -0
  205. package/sidenav/Sidenav.js +186 -63
  206. package/sidenav/Sidenav.stories.tsx +180 -0
  207. package/sidenav/Sidenav.test.js +44 -0
  208. package/sidenav/types.d.ts +73 -0
  209. package/sidenav/types.js +5 -0
  210. package/slider/Slider.d.ts +4 -0
  211. package/slider/Slider.js +159 -156
  212. package/slider/Slider.stories.tsx +183 -0
  213. package/slider/Slider.test.js +250 -0
  214. package/slider/types.d.ts +86 -0
  215. package/slider/types.js +5 -0
  216. package/spinner/Spinner.d.ts +4 -0
  217. package/spinner/Spinner.js +9 -26
  218. package/spinner/Spinner.stories.jsx +103 -0
  219. package/spinner/Spinner.test.js +64 -0
  220. package/spinner/types.d.ts +32 -0
  221. package/spinner/types.js +5 -0
  222. package/switch/Switch.d.ts +2 -2
  223. package/switch/Switch.js +152 -69
  224. package/switch/Switch.stories.tsx +138 -0
  225. package/switch/Switch.test.js +225 -0
  226. package/switch/types.d.ts +12 -4
  227. package/table/Table.d.ts +4 -0
  228. package/table/Table.js +4 -4
  229. package/table/Table.stories.jsx +277 -0
  230. package/table/Table.test.js +26 -0
  231. package/table/types.d.ts +21 -0
  232. package/table/types.js +5 -0
  233. package/tabs/Tab.d.ts +4 -0
  234. package/tabs/Tab.js +135 -0
  235. package/tabs/Tabs.d.ts +4 -0
  236. package/tabs/Tabs.js +364 -156
  237. package/tabs/Tabs.stories.tsx +186 -0
  238. package/tabs/Tabs.test.js +351 -0
  239. package/tabs/types.d.ts +92 -0
  240. package/tabs/types.js +5 -0
  241. package/tabs-nav/NavTabs.d.ts +8 -0
  242. package/tabs-nav/NavTabs.js +125 -0
  243. package/tabs-nav/NavTabs.stories.tsx +170 -0
  244. package/tabs-nav/NavTabs.test.js +82 -0
  245. package/tabs-nav/Tab.d.ts +4 -0
  246. package/tabs-nav/Tab.js +130 -0
  247. package/tabs-nav/types.d.ts +53 -0
  248. package/tabs-nav/types.js +5 -0
  249. package/tag/Tag.d.ts +4 -0
  250. package/tag/Tag.js +35 -60
  251. package/tag/Tag.stories.tsx +142 -0
  252. package/tag/Tag.test.js +60 -0
  253. package/tag/types.d.ts +69 -0
  254. package/tag/types.js +5 -0
  255. package/text-input/Icons.d.ts +8 -0
  256. package/text-input/Icons.js +60 -0
  257. package/text-input/Suggestion.d.ts +4 -0
  258. package/text-input/Suggestion.js +57 -0
  259. package/text-input/Suggestions.d.ts +4 -0
  260. package/text-input/Suggestions.js +134 -0
  261. package/text-input/TextInput.d.ts +4 -0
  262. package/text-input/TextInput.js +228 -376
  263. package/text-input/TextInput.stories.tsx +481 -0
  264. package/text-input/TextInput.test.js +1624 -0
  265. package/text-input/types.d.ts +197 -0
  266. package/text-input/types.js +5 -0
  267. package/textarea/Textarea.d.ts +4 -0
  268. package/textarea/Textarea.js +39 -79
  269. package/textarea/Textarea.stories.jsx +157 -0
  270. package/textarea/Textarea.test.js +437 -0
  271. package/textarea/types.d.ts +137 -0
  272. package/textarea/types.js +5 -0
  273. package/toggle-group/ToggleGroup.d.ts +4 -0
  274. package/toggle-group/ToggleGroup.js +18 -46
  275. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  276. package/toggle-group/ToggleGroup.test.js +156 -0
  277. package/toggle-group/types.d.ts +105 -0
  278. package/toggle-group/types.js +5 -0
  279. package/typography/Typography.d.ts +4 -0
  280. package/typography/Typography.js +131 -0
  281. package/typography/Typography.stories.tsx +198 -0
  282. package/typography/types.d.ts +18 -0
  283. package/typography/types.js +5 -0
  284. package/useTheme.d.ts +2 -0
  285. package/useTheme.js +2 -2
  286. package/useTranslatedLabels.d.ts +2 -0
  287. package/useTranslatedLabels.js +20 -0
  288. package/wizard/Wizard.d.ts +4 -0
  289. package/wizard/Wizard.js +118 -104
  290. package/wizard/Wizard.stories.tsx +233 -0
  291. package/wizard/Wizard.test.js +141 -0
  292. package/wizard/types.d.ts +65 -0
  293. package/wizard/types.js +5 -0
  294. package/ThemeContext.js +0 -246
  295. package/V3Select/V3Select.js +0 -455
  296. package/V3Select/index.d.ts +0 -27
  297. package/V3Textarea/V3Textarea.js +0 -260
  298. package/V3Textarea/index.d.ts +0 -27
  299. package/accordion/index.d.ts +0 -28
  300. package/accordion-group/index.d.ts +0 -16
  301. package/box/index.d.ts +0 -25
  302. package/card/index.d.ts +0 -22
  303. package/chip/index.d.ts +0 -22
  304. package/date/Date.js +0 -373
  305. package/date/index.d.ts +0 -27
  306. package/date-input/index.d.ts +0 -95
  307. package/dialog/index.d.ts +0 -18
  308. package/dropdown/index.d.ts +0 -26
  309. package/file-input/index.d.ts +0 -81
  310. package/footer/index.d.ts +0 -25
  311. package/header/index.d.ts +0 -25
  312. package/heading/index.d.ts +0 -17
  313. package/input-text/Icons.js +0 -22
  314. package/input-text/InputText.js +0 -611
  315. package/input-text/index.d.ts +0 -36
  316. package/link/index.d.ts +0 -23
  317. package/number-input/index.d.ts +0 -113
  318. package/password-input/index.d.ts +0 -94
  319. package/progress-bar/index.d.ts +0 -18
  320. package/radio/Radio.js +0 -195
  321. package/radio/index.d.ts +0 -23
  322. package/resultsetTable/index.d.ts +0 -19
  323. package/select/index.d.ts +0 -131
  324. package/sidenav/index.d.ts +0 -13
  325. package/slider/index.d.ts +0 -29
  326. package/spinner/index.d.ts +0 -17
  327. package/table/index.d.ts +0 -13
  328. package/tabs/index.d.ts +0 -19
  329. package/tag/index.d.ts +0 -24
  330. package/text-input/index.d.ts +0 -135
  331. package/textarea/index.d.ts +0 -117
  332. package/toggle/Toggle.js +0 -186
  333. package/toggle/index.d.ts +0 -21
  334. package/toggle-group/index.d.ts +0 -21
  335. package/upload/Upload.js +0 -201
  336. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  337. package/upload/buttons-upload/Icons.js +0 -40
  338. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  339. package/upload/dragAndDropArea/Icons.js +0 -39
  340. package/upload/file-upload/FileToUpload.js +0 -115
  341. package/upload/file-upload/Icons.js +0 -66
  342. package/upload/files-upload/FilesToUpload.js +0 -109
  343. package/upload/index.d.ts +0 -15
  344. package/upload/transaction/Icons.js +0 -160
  345. package/upload/transaction/Transaction.js +0 -104
  346. package/upload/transactions/Transactions.js +0 -94
  347. package/wizard/Icons.js +0 -65
  348. package/wizard/index.d.ts +0 -18
@@ -0,0 +1,535 @@
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
+ import FileItem from "./FileItem";
6
+
7
+ export default {
8
+ title: "File input",
9
+ component: DxcFileInput,
10
+ };
11
+
12
+ const picPreview = "https://cdn.mos.cms.futurecdn.net/CAZ6JXi6huSuN4QGE627NR.jpg"
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(["file5"], "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: "This error message is a multiline paragraph for testing.",
57
+ file: file5,
58
+ },
59
+ {
60
+ error: "Error message",
61
+ file: file3,
62
+ preview: picPreview,
63
+ },
64
+ ];
65
+
66
+ export const Chromatic = () => (
67
+ <>
68
+ <Title title="File item states" theme="light" level={2} />
69
+ <ExampleContainer pseudoState="pseudo-hover">
70
+ <Title title="Hovered" theme="light" level={4} />
71
+ <FileItem
72
+ fileName="file"
73
+ error=""
74
+ singleFileMode={false}
75
+ showPreview={false}
76
+ preview={picPreview}
77
+ type="image/png"
78
+ onDelete={() => {}}
79
+ tabIndex={0}
80
+ />
81
+ </ExampleContainer>
82
+ <ExampleContainer pseudoState="pseudo-focus">
83
+ <Title title="Focused" theme="light" level={4} />
84
+ <FileItem
85
+ fileName="file"
86
+ error=""
87
+ singleFileMode={false}
88
+ showPreview={false}
89
+ preview={picPreview}
90
+ type="image/png"
91
+ onDelete={() => {}}
92
+ tabIndex={0}
93
+ />
94
+ </ExampleContainer>
95
+ <ExampleContainer pseudoState="pseudo-active">
96
+ <Title title="Actived" theme="light" level={4} />
97
+ <FileItem
98
+ fileName="file"
99
+ error=""
100
+ singleFileMode={false}
101
+ showPreview={false}
102
+ preview={picPreview}
103
+ type="image/png"
104
+ onDelete={() => {}}
105
+ tabIndex={0}
106
+ />
107
+ </ExampleContainer>
108
+ <Title title="File" theme="light" level={2} />
109
+ <ExampleContainer>
110
+ <Title title="Without label" theme="light" level={4} />
111
+ <DxcFileInput value={[]} callbackFile={() => {}} />
112
+ </ExampleContainer>
113
+ <ExampleContainer>
114
+ <Title title="With label" theme="light" level={4} />
115
+ <DxcFileInput label="File input" value={[]} callbackFile={() => {}} />
116
+ </ExampleContainer>
117
+ <ExampleContainer>
118
+ <Title title="With label and helper text" theme="light" level={4} />
119
+ <DxcFileInput label="File input" helperText="Please select files" value={[]} callbackFile={() => {}} />
120
+ </ExampleContainer>
121
+ <ExampleContainer>
122
+ <Title title="Single file" theme="light" level={4} />
123
+ <DxcFileInput
124
+ label="File input"
125
+ helperText="Please select files"
126
+ value={fileExample}
127
+ multiple={false}
128
+ callbackFile={() => {}}
129
+ />
130
+ </ExampleContainer>
131
+ <ExampleContainer>
132
+ <Title title="Invalid single file" theme="light" level={4} />
133
+ <DxcFileInput
134
+ label="File input"
135
+ helperText="Please select files"
136
+ value={fileExampleError}
137
+ multiple={false}
138
+ callbackFile={() => {}}
139
+ />
140
+ </ExampleContainer>
141
+ <ExampleContainer>
142
+ <Title title="Multiple files" theme="light" level={4} />
143
+ <DxcFileInput label="File input" helperText="Please select files" value={filesExamples} callbackFile={() => {}} />
144
+ </ExampleContainer>
145
+ <ExampleContainer>
146
+ <Title title="Show preview" theme="light" level={4} />
147
+ <DxcFileInput
148
+ label="File input"
149
+ helperText="Please select files"
150
+ value={filesExamples}
151
+ callbackFile={() => {}}
152
+ showPreview
153
+ />
154
+ </ExampleContainer>
155
+ <ExampleContainer>
156
+ <Title title="Disabled" theme="light" level={4} />
157
+ <DxcFileInput label="File input" helperText="Please select files" disabled value={[]} callbackFile={() => {}} />
158
+ </ExampleContainer>
159
+ <Title title="Margins" theme="light" level={3} />
160
+ <ExampleContainer>
161
+ <Title title="Xxsmall margin" theme="light" level={4} />
162
+ <DxcFileInput
163
+ label="File input"
164
+ helperText="Please select files"
165
+ value={fileExample}
166
+ callbackFile={() => {}}
167
+ margin="xxsmall"
168
+ />
169
+ </ExampleContainer>
170
+ <ExampleContainer>
171
+ <Title title="Xsmall margin" theme="light" level={4} />
172
+ <DxcFileInput
173
+ label="File input"
174
+ helperText="Please select files"
175
+ value={fileExample}
176
+ callbackFile={() => {}}
177
+ margin="xsmall"
178
+ />
179
+ </ExampleContainer>
180
+ <ExampleContainer>
181
+ <Title title="Small margin" theme="light" level={4} />
182
+ <DxcFileInput
183
+ label="File input"
184
+ helperText="Please select files"
185
+ value={fileExample}
186
+ callbackFile={() => {}}
187
+ margin="small"
188
+ />
189
+ </ExampleContainer>
190
+ <ExampleContainer>
191
+ <Title title="Medium margin" theme="light" level={4} />
192
+ <DxcFileInput
193
+ label="File input"
194
+ helperText="Please select files"
195
+ value={fileExample}
196
+ callbackFile={() => {}}
197
+ margin="medium"
198
+ />
199
+ </ExampleContainer>
200
+ <ExampleContainer>
201
+ <Title title="Large margin" theme="light" level={4} />
202
+ <DxcFileInput
203
+ label="File input"
204
+ helperText="Please select files"
205
+ value={fileExample}
206
+ callbackFile={() => {}}
207
+ margin="large"
208
+ />
209
+ </ExampleContainer>
210
+ <ExampleContainer>
211
+ <Title title="Xlarge margin" theme="light" level={4} />
212
+ <DxcFileInput
213
+ label="File input"
214
+ helperText="Please select files"
215
+ value={fileExample}
216
+ callbackFile={() => {}}
217
+ margin="xlarge"
218
+ />
219
+ </ExampleContainer>
220
+ <ExampleContainer>
221
+ <Title title="Xxlarge margin" theme="light" level={4} />
222
+ <DxcFileInput
223
+ label="File input"
224
+ helperText="Please select files"
225
+ value={fileExample}
226
+ callbackFile={() => {}}
227
+ margin="xxlarge"
228
+ />
229
+ </ExampleContainer>
230
+ <Title title="Filedrop" theme="light" level={2} />
231
+ <ExampleContainer>
232
+ <Title title="Without label" theme="light" level={4} />
233
+ <DxcFileInput mode="filedrop" value={[]} callbackFile={() => {}} />
234
+ </ExampleContainer>
235
+ <ExampleContainer>
236
+ <Title title="With label" theme="light" level={4} />
237
+ <DxcFileInput mode="filedrop" label="File input" value={[]} callbackFile={() => {}} />
238
+ </ExampleContainer>
239
+ <ExampleContainer>
240
+ <Title title="With label, helper text and ellipsis" theme="light" level={4} />
241
+ <DxcFileInput
242
+ mode="filedrop"
243
+ label="File input"
244
+ dropAreaLabel="or drop files or drop files or drop files or drop files or drop files"
245
+ helperText="Please select files"
246
+ value={[]}
247
+ callbackFile={() => {}}
248
+ />
249
+ </ExampleContainer>
250
+ <ExampleContainer>
251
+ <Title title="Single file" theme="light" level={4} />
252
+ <DxcFileInput
253
+ mode="filedrop"
254
+ label="File input"
255
+ helperText="Please select files"
256
+ value={fileExample}
257
+ multiple={false}
258
+ callbackFile={() => {}}
259
+ />
260
+ </ExampleContainer>
261
+ <ExampleContainer>
262
+ <Title title="Invalid single file" theme="light" level={4} />
263
+ <DxcFileInput
264
+ mode="filedrop"
265
+ label="File input"
266
+ helperText="Please select files"
267
+ value={fileExampleError}
268
+ multiple={false}
269
+ callbackFile={() => {}}
270
+ />
271
+ </ExampleContainer>
272
+ <ExampleContainer>
273
+ <Title title="Multiple files" theme="light" level={4} />
274
+ <DxcFileInput
275
+ mode="filedrop"
276
+ label="File input"
277
+ helperText="Please select files"
278
+ value={filesExamples}
279
+ callbackFile={() => {}}
280
+ />
281
+ </ExampleContainer>
282
+ <ExampleContainer>
283
+ <Title title="Show preview" theme="light" level={4} />
284
+ <DxcFileInput
285
+ mode="filedrop"
286
+ label="File input"
287
+ helperText="Please select files"
288
+ value={filesExamples}
289
+ callbackFile={() => {}}
290
+ showPreview
291
+ />
292
+ </ExampleContainer>
293
+ <ExampleContainer>
294
+ <Title title="Disabled" theme="light" level={4} />
295
+ <DxcFileInput
296
+ label="File input"
297
+ helperText="Please select files"
298
+ mode="filedrop"
299
+ disabled
300
+ value={[]}
301
+ callbackFile={() => {}}
302
+ />
303
+ </ExampleContainer>
304
+ <Title title="Margins" theme="light" level={3} />
305
+ <ExampleContainer>
306
+ <Title title="Xxsmall margin" theme="light" level={4} />
307
+ <DxcFileInput
308
+ label="File input"
309
+ helperText="Please select files"
310
+ value={fileExample}
311
+ callbackFile={() => {}}
312
+ mode="filedrop"
313
+ margin="xxsmall"
314
+ />
315
+ </ExampleContainer>
316
+ <ExampleContainer>
317
+ <Title title="Xsmall margin" theme="light" level={4} />
318
+ <DxcFileInput
319
+ label="File input"
320
+ helperText="Please select files"
321
+ value={fileExample}
322
+ callbackFile={() => {}}
323
+ mode="filedrop"
324
+ margin="xsmall"
325
+ />
326
+ </ExampleContainer>
327
+ <ExampleContainer>
328
+ <Title title="Small margin" theme="light" level={4} />
329
+ <DxcFileInput
330
+ label="File input"
331
+ helperText="Please select files"
332
+ value={fileExample}
333
+ callbackFile={() => {}}
334
+ mode="filedrop"
335
+ margin="small"
336
+ />
337
+ </ExampleContainer>
338
+ <ExampleContainer>
339
+ <Title title="Medium margin" theme="light" level={4} />
340
+ <DxcFileInput
341
+ label="File input"
342
+ helperText="Please select files"
343
+ value={fileExample}
344
+ callbackFile={() => {}}
345
+ mode="filedrop"
346
+ margin="medium"
347
+ />
348
+ </ExampleContainer>
349
+ <ExampleContainer>
350
+ <Title title="Large margin" theme="light" level={4} />
351
+ <DxcFileInput
352
+ label="File input"
353
+ helperText="Please select files"
354
+ value={fileExample}
355
+ callbackFile={() => {}}
356
+ mode="filedrop"
357
+ margin="large"
358
+ />
359
+ </ExampleContainer>
360
+ <ExampleContainer>
361
+ <Title title="Xlarge margin" theme="light" level={4} />
362
+ <DxcFileInput
363
+ label="File input"
364
+ helperText="Please select files"
365
+ value={fileExample}
366
+ callbackFile={() => {}}
367
+ margin="xlarge"
368
+ />
369
+ </ExampleContainer>
370
+ <ExampleContainer>
371
+ <Title title="Xxlarge margin" theme="light" level={4} />
372
+ <DxcFileInput
373
+ label="File input"
374
+ helperText="Please select files"
375
+ value={fileExample}
376
+ callbackFile={() => {}}
377
+ mode="filedrop"
378
+ margin="xxlarge"
379
+ />
380
+ </ExampleContainer>
381
+ <Title title="Dropzone" theme="light" level={2} />
382
+ <ExampleContainer>
383
+ <Title title="Without label" theme="light" level={4} />
384
+ <DxcFileInput mode="dropzone" value={[]} callbackFile={() => {}} />
385
+ </ExampleContainer>
386
+ <ExampleContainer>
387
+ <Title title="With label" theme="light" level={4} />
388
+ <DxcFileInput label="File input" mode="dropzone" value={[]} callbackFile={() => {}} />
389
+ </ExampleContainer>
390
+ <ExampleContainer>
391
+ <Title title="With label, helper text and ellipsis" theme="light" level={4} />
392
+ <DxcFileInput
393
+ label="File input"
394
+ helperText="Please select files"
395
+ mode="dropzone"
396
+ 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"
397
+ value={[]}
398
+ callbackFile={() => {}}
399
+ />
400
+ </ExampleContainer>
401
+ <ExampleContainer>
402
+ <Title title="Single file" theme="light" level={4} />
403
+ <DxcFileInput
404
+ label="File input"
405
+ helperText="Please select files"
406
+ mode="dropzone"
407
+ value={fileExample}
408
+ callbackFile={() => {}}
409
+ multiple={false}
410
+ />
411
+ </ExampleContainer>
412
+ <ExampleContainer>
413
+ <Title title="Invalid single file" theme="light" level={4} />
414
+ <DxcFileInput
415
+ label="File input"
416
+ helperText="Please select files"
417
+ mode="dropzone"
418
+ value={fileExampleError}
419
+ callbackFile={() => {}}
420
+ multiple={false}
421
+ />
422
+ </ExampleContainer>
423
+ <ExampleContainer>
424
+ <Title title="Multiple files" theme="light" level={4} />
425
+ <DxcFileInput
426
+ mode="dropzone"
427
+ label="File input"
428
+ helperText="Please select files"
429
+ value={filesExamples}
430
+ callbackFile={() => {}}
431
+ />
432
+ </ExampleContainer>
433
+ <ExampleContainer>
434
+ <Title title="Show preview" theme="light" level={4} />
435
+ <DxcFileInput
436
+ mode="dropzone"
437
+ label="File input"
438
+ helperText="Please select files"
439
+ value={filesExamples}
440
+ callbackFile={() => {}}
441
+ showPreview
442
+ />
443
+ </ExampleContainer>
444
+ <ExampleContainer>
445
+ <Title title="Disabled" theme="light" level={4} />
446
+ <DxcFileInput
447
+ label="File input"
448
+ helperText="Please select files"
449
+ mode="dropzone"
450
+ disabled
451
+ value={[]}
452
+ callbackFile={() => {}}
453
+ />
454
+ </ExampleContainer>
455
+ <Title title="Margins" theme="light" level={3} />
456
+ <ExampleContainer>
457
+ <Title title="Xxsmall margin" theme="light" level={4} />
458
+ <DxcFileInput
459
+ label="File input"
460
+ helperText="Please select files"
461
+ value={fileExample}
462
+ callbackFile={() => {}}
463
+ mode="dropzone"
464
+ margin="xxsmall"
465
+ />
466
+ </ExampleContainer>
467
+ <ExampleContainer>
468
+ <Title title="Xsmall margin" theme="light" level={4} />
469
+ <DxcFileInput
470
+ label="File input"
471
+ helperText="Please select files"
472
+ value={fileExample}
473
+ callbackFile={() => {}}
474
+ mode="dropzone"
475
+ margin="xsmall"
476
+ />
477
+ </ExampleContainer>
478
+ <ExampleContainer>
479
+ <Title title="Small margin" theme="light" level={4} />
480
+ <DxcFileInput
481
+ label="File input"
482
+ helperText="Please select files"
483
+ value={fileExample}
484
+ callbackFile={() => {}}
485
+ mode="dropzone"
486
+ margin="small"
487
+ />
488
+ </ExampleContainer>
489
+ <ExampleContainer>
490
+ <Title title="Medium margin" theme="light" level={4} />
491
+ <DxcFileInput
492
+ label="File input"
493
+ helperText="Please select files"
494
+ value={fileExample}
495
+ callbackFile={() => {}}
496
+ mode="dropzone"
497
+ margin="medium"
498
+ />
499
+ </ExampleContainer>
500
+ <ExampleContainer>
501
+ <Title title="Large margin" theme="light" level={4} />
502
+ <DxcFileInput
503
+ label="File input"
504
+ helperText="Please select files"
505
+ value={fileExample}
506
+ callbackFile={() => {}}
507
+ mode="dropzone"
508
+ margin="large"
509
+ />
510
+ </ExampleContainer>
511
+ <ExampleContainer>
512
+ <Title title="Xlarge margin" theme="light" level={4} />
513
+ <DxcFileInput
514
+ label="File input"
515
+ helperText="Please select files"
516
+ value={fileExample}
517
+ callbackFile={() => {}}
518
+ mode="dropzone"
519
+ margin="xlarge"
520
+ />
521
+ </ExampleContainer>
522
+ <ExampleContainer>
523
+ <Title title="Xxlarge margin" theme="light" level={4} />
524
+ <DxcFileInput
525
+ label="File input"
526
+ helperText="Please select files"
527
+ value={fileExample}
528
+ callbackFile={() => {}}
529
+ mode="dropzone"
530
+ margin="xxlarge"
531
+ />
532
+ <hr />
533
+ </ExampleContainer>
534
+ </>
535
+ );