@dxc-technology/halstack-react 0.0.0-c593452 → 0.0.0-c5cf7cd

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 (331) 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 +295 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +124 -137
  7. package/accordion/Accordion.stories.tsx +306 -0
  8. package/accordion/Accordion.test.js +71 -0
  9. package/accordion/types.d.ts +12 -11
  10. package/accordion-group/AccordionGroup.d.ts +1 -1
  11. package/accordion-group/AccordionGroup.js +16 -37
  12. package/accordion-group/AccordionGroup.stories.tsx +251 -0
  13. package/accordion-group/AccordionGroup.test.js +126 -0
  14. package/accordion-group/types.d.ts +17 -10
  15. package/alert/Alert.js +7 -4
  16. package/alert/Alert.stories.tsx +170 -0
  17. package/alert/Alert.test.js +92 -0
  18. package/alert/types.d.ts +1 -1
  19. package/badge/Badge.d.ts +4 -0
  20. package/badge/Badge.js +6 -4
  21. package/badge/types.d.ts +5 -0
  22. package/{radio → badge}/types.js +0 -0
  23. package/bleed/Bleed.d.ts +3 -0
  24. package/bleed/Bleed.js +51 -0
  25. package/bleed/Bleed.stories.tsx +341 -0
  26. package/bleed/types.d.ts +37 -0
  27. package/bleed/types.js +5 -0
  28. package/box/Box.d.ts +4 -0
  29. package/box/Box.js +29 -65
  30. package/box/Box.stories.tsx +132 -0
  31. package/box/Box.test.js +18 -0
  32. package/box/types.d.ts +44 -0
  33. package/box/types.js +5 -0
  34. package/bulleted-list/BulletedList.d.ts +7 -0
  35. package/bulleted-list/BulletedList.js +123 -0
  36. package/bulleted-list/BulletedList.stories.tsx +200 -0
  37. package/bulleted-list/types.d.ts +11 -0
  38. package/bulleted-list/types.js +5 -0
  39. package/button/Button.d.ts +1 -1
  40. package/button/Button.js +61 -87
  41. package/button/Button.stories.tsx +232 -242
  42. package/button/Button.test.js +35 -0
  43. package/button/types.d.ts +14 -18
  44. package/card/Card.js +26 -30
  45. package/card/Card.stories.tsx +201 -0
  46. package/card/Card.test.js +50 -0
  47. package/card/ice-cream.jpg +0 -0
  48. package/card/types.d.ts +5 -6
  49. package/checkbox/Checkbox.d.ts +2 -2
  50. package/checkbox/Checkbox.js +108 -111
  51. package/checkbox/Checkbox.stories.tsx +208 -0
  52. package/checkbox/Checkbox.test.js +155 -0
  53. package/checkbox/types.d.ts +15 -7
  54. package/chip/Chip.d.ts +4 -0
  55. package/chip/Chip.js +16 -76
  56. package/chip/Chip.stories.tsx +119 -0
  57. package/chip/Chip.test.js +56 -0
  58. package/chip/types.d.ts +45 -0
  59. package/chip/types.js +5 -0
  60. package/common/variables.js +318 -378
  61. package/date-input/DateInput.js +66 -55
  62. package/date-input/DateInput.stories.tsx +138 -0
  63. package/date-input/DateInput.test.js +479 -0
  64. package/date-input/types.d.ts +16 -9
  65. package/dialog/Dialog.d.ts +4 -0
  66. package/dialog/Dialog.js +52 -74
  67. package/dialog/Dialog.stories.tsx +267 -0
  68. package/dialog/Dialog.test.js +70 -0
  69. package/dialog/types.d.ts +44 -0
  70. package/dialog/types.js +5 -0
  71. package/dropdown/Dropdown.d.ts +1 -1
  72. package/dropdown/Dropdown.js +244 -273
  73. package/dropdown/Dropdown.stories.tsx +312 -0
  74. package/dropdown/Dropdown.test.js +590 -0
  75. package/dropdown/DropdownMenu.d.ts +4 -0
  76. package/dropdown/DropdownMenu.js +80 -0
  77. package/dropdown/DropdownMenuItem.d.ts +4 -0
  78. package/dropdown/DropdownMenuItem.js +92 -0
  79. package/dropdown/types.d.ts +30 -19
  80. package/file-input/FileInput.d.ts +4 -0
  81. package/file-input/FileInput.js +183 -166
  82. package/file-input/FileInput.stories.tsx +535 -0
  83. package/file-input/FileInput.test.js +498 -0
  84. package/file-input/FileItem.d.ts +4 -0
  85. package/file-input/FileItem.js +49 -81
  86. package/file-input/types.d.ts +129 -0
  87. package/file-input/types.js +5 -0
  88. package/flex/Flex.d.ts +4 -0
  89. package/flex/Flex.js +69 -0
  90. package/flex/Flex.stories.tsx +103 -0
  91. package/flex/types.d.ts +32 -0
  92. package/flex/types.js +5 -0
  93. package/footer/Footer.d.ts +4 -0
  94. package/footer/Footer.js +36 -148
  95. package/footer/Footer.stories.tsx +137 -0
  96. package/footer/Footer.test.js +109 -0
  97. package/footer/Icons.d.ts +2 -0
  98. package/footer/Icons.js +4 -4
  99. package/footer/types.d.ts +66 -0
  100. package/footer/types.js +5 -0
  101. package/header/Header.d.ts +7 -0
  102. package/header/Header.js +119 -140
  103. package/header/Header.stories.tsx +172 -0
  104. package/header/Header.test.js +79 -0
  105. package/header/Icons.d.ts +2 -0
  106. package/header/Icons.js +4 -29
  107. package/header/types.d.ts +48 -0
  108. package/header/types.js +5 -0
  109. package/heading/Heading.d.ts +4 -0
  110. package/heading/Heading.js +7 -24
  111. package/heading/Heading.stories.tsx +54 -0
  112. package/heading/Heading.test.js +186 -0
  113. package/heading/types.d.ts +33 -0
  114. package/heading/types.js +5 -0
  115. package/inset/Inset.d.ts +3 -0
  116. package/inset/Inset.js +51 -0
  117. package/inset/Inset.stories.tsx +229 -0
  118. package/inset/types.d.ts +37 -0
  119. package/inset/types.js +5 -0
  120. package/layout/ApplicationLayout.d.ts +20 -0
  121. package/layout/ApplicationLayout.js +71 -135
  122. package/layout/ApplicationLayout.stories.tsx +162 -0
  123. package/layout/Icons.d.ts +5 -0
  124. package/layout/Icons.js +13 -2
  125. package/layout/SidenavContext.d.ts +5 -0
  126. package/layout/SidenavContext.js +19 -0
  127. package/layout/types.d.ts +42 -0
  128. package/layout/types.js +5 -0
  129. package/link/Link.d.ts +4 -0
  130. package/link/Link.js +60 -107
  131. package/link/Link.stories.tsx +193 -0
  132. package/link/Link.test.js +83 -0
  133. package/link/types.d.ts +54 -0
  134. package/link/types.js +5 -0
  135. package/main.d.ts +12 -12
  136. package/main.js +64 -58
  137. package/number-input/NumberInput.d.ts +4 -0
  138. package/number-input/NumberInput.js +16 -68
  139. package/number-input/NumberInput.stories.tsx +115 -0
  140. package/number-input/NumberInput.test.js +543 -0
  141. package/number-input/NumberInputContext.d.ts +4 -0
  142. package/number-input/NumberInputContext.js +5 -2
  143. package/number-input/numberInputContextTypes.d.ts +19 -0
  144. package/number-input/numberInputContextTypes.js +5 -0
  145. package/number-input/types.d.ts +124 -0
  146. package/number-input/types.js +5 -0
  147. package/package.json +16 -12
  148. package/paginator/Paginator.js +19 -46
  149. package/paginator/Paginator.stories.tsx +63 -0
  150. package/paginator/Paginator.test.js +308 -0
  151. package/paragraph/Paragraph.d.ts +6 -0
  152. package/paragraph/Paragraph.js +38 -0
  153. package/paragraph/Paragraph.stories.tsx +44 -0
  154. package/password-input/PasswordInput.d.ts +4 -0
  155. package/password-input/PasswordInput.js +22 -55
  156. package/password-input/{PasswordInput.stories.jsx → PasswordInput.stories.tsx} +4 -4
  157. package/password-input/PasswordInput.test.js +181 -0
  158. package/password-input/types.d.ts +110 -0
  159. package/password-input/types.js +5 -0
  160. package/progress-bar/ProgressBar.d.ts +2 -2
  161. package/progress-bar/ProgressBar.js +60 -54
  162. package/progress-bar/ProgressBar.stories.jsx +60 -0
  163. package/progress-bar/ProgressBar.test.js +110 -0
  164. package/progress-bar/types.d.ts +3 -4
  165. package/quick-nav/QuickNav.d.ts +4 -0
  166. package/quick-nav/QuickNav.js +117 -0
  167. package/quick-nav/QuickNav.stories.tsx +342 -0
  168. package/quick-nav/types.d.ts +21 -0
  169. package/quick-nav/types.js +5 -0
  170. package/radio-group/Radio.d.ts +4 -0
  171. package/radio-group/Radio.js +156 -0
  172. package/radio-group/RadioGroup.d.ts +4 -0
  173. package/radio-group/RadioGroup.js +283 -0
  174. package/radio-group/RadioGroup.stories.tsx +101 -0
  175. package/radio-group/RadioGroup.test.js +722 -0
  176. package/radio-group/types.d.ts +114 -0
  177. package/radio-group/types.js +5 -0
  178. package/resultsetTable/ResultsetTable.d.ts +4 -0
  179. package/resultsetTable/ResultsetTable.js +10 -32
  180. package/resultsetTable/ResultsetTable.stories.tsx +275 -0
  181. package/resultsetTable/ResultsetTable.test.js +348 -0
  182. package/resultsetTable/types.d.ts +67 -0
  183. package/resultsetTable/types.js +5 -0
  184. package/select/Icons.d.ts +10 -0
  185. package/select/Icons.js +93 -0
  186. package/select/Listbox.d.ts +4 -0
  187. package/select/Listbox.js +198 -0
  188. package/select/Option.d.ts +4 -0
  189. package/select/Option.js +110 -0
  190. package/select/Select.d.ts +4 -0
  191. package/select/Select.js +160 -380
  192. package/select/Select.stories.tsx +627 -0
  193. package/select/Select.test.js +2233 -0
  194. package/select/types.d.ts +210 -0
  195. package/select/types.js +5 -0
  196. package/sidenav/Sidenav.d.ts +10 -0
  197. package/sidenav/Sidenav.js +186 -63
  198. package/sidenav/Sidenav.stories.tsx +180 -0
  199. package/sidenav/Sidenav.test.js +44 -0
  200. package/sidenav/types.d.ts +73 -0
  201. package/sidenav/types.js +5 -0
  202. package/slider/Slider.d.ts +2 -2
  203. package/slider/Slider.js +149 -112
  204. package/slider/Slider.stories.tsx +183 -0
  205. package/slider/Slider.test.js +250 -0
  206. package/slider/types.d.ts +12 -9
  207. package/spinner/Spinner.d.ts +4 -0
  208. package/spinner/Spinner.js +9 -26
  209. package/spinner/Spinner.stories.jsx +103 -0
  210. package/spinner/Spinner.test.js +64 -0
  211. package/spinner/types.d.ts +32 -0
  212. package/spinner/types.js +5 -0
  213. package/switch/Switch.d.ts +2 -2
  214. package/switch/Switch.js +152 -69
  215. package/switch/Switch.stories.tsx +138 -0
  216. package/switch/Switch.test.js +225 -0
  217. package/switch/types.d.ts +12 -4
  218. package/table/Table.d.ts +4 -0
  219. package/table/Table.js +4 -4
  220. package/table/Table.stories.jsx +277 -0
  221. package/table/Table.test.js +26 -0
  222. package/table/types.d.ts +21 -0
  223. package/table/types.js +5 -0
  224. package/tabs/Tab.d.ts +4 -0
  225. package/tabs/Tab.js +135 -0
  226. package/tabs/Tabs.d.ts +1 -1
  227. package/tabs/Tabs.js +364 -108
  228. package/tabs/Tabs.stories.tsx +186 -0
  229. package/tabs/Tabs.test.js +351 -0
  230. package/tabs/types.d.ts +41 -20
  231. package/tabs-nav/NavTabs.d.ts +8 -0
  232. package/tabs-nav/NavTabs.js +125 -0
  233. package/tabs-nav/NavTabs.stories.tsx +170 -0
  234. package/tabs-nav/NavTabs.test.js +82 -0
  235. package/tabs-nav/Tab.d.ts +4 -0
  236. package/tabs-nav/Tab.js +130 -0
  237. package/tabs-nav/types.d.ts +53 -0
  238. package/tabs-nav/types.js +5 -0
  239. package/tag/Tag.d.ts +4 -0
  240. package/tag/Tag.js +35 -60
  241. package/tag/Tag.stories.tsx +142 -0
  242. package/tag/Tag.test.js +60 -0
  243. package/tag/types.d.ts +69 -0
  244. package/tag/types.js +5 -0
  245. package/text-input/Icons.d.ts +8 -0
  246. package/text-input/Icons.js +60 -0
  247. package/text-input/Suggestion.d.ts +4 -0
  248. package/text-input/Suggestion.js +57 -0
  249. package/text-input/Suggestions.d.ts +4 -0
  250. package/text-input/Suggestions.js +134 -0
  251. package/text-input/TextInput.d.ts +4 -0
  252. package/text-input/TextInput.js +228 -376
  253. package/text-input/TextInput.stories.tsx +481 -0
  254. package/text-input/TextInput.test.js +1771 -0
  255. package/text-input/types.d.ts +197 -0
  256. package/text-input/types.js +5 -0
  257. package/textarea/Textarea.d.ts +4 -0
  258. package/textarea/Textarea.js +39 -79
  259. package/textarea/Textarea.stories.jsx +37 -15
  260. package/textarea/Textarea.test.js +437 -0
  261. package/textarea/types.d.ts +137 -0
  262. package/textarea/types.js +5 -0
  263. package/toggle-group/ToggleGroup.d.ts +4 -0
  264. package/toggle-group/ToggleGroup.js +18 -46
  265. package/toggle-group/ToggleGroup.stories.tsx +173 -0
  266. package/toggle-group/ToggleGroup.test.js +156 -0
  267. package/toggle-group/types.d.ts +105 -0
  268. package/toggle-group/types.js +5 -0
  269. package/typography/Typography.d.ts +4 -0
  270. package/typography/Typography.js +131 -0
  271. package/typography/Typography.stories.tsx +198 -0
  272. package/typography/types.d.ts +18 -0
  273. package/typography/types.js +5 -0
  274. package/useTheme.d.ts +2 -0
  275. package/useTheme.js +2 -2
  276. package/useTranslatedLabels.d.ts +2 -0
  277. package/useTranslatedLabels.js +20 -0
  278. package/wizard/Wizard.d.ts +4 -0
  279. package/wizard/Wizard.js +118 -104
  280. package/wizard/Wizard.stories.tsx +233 -0
  281. package/wizard/Wizard.test.js +141 -0
  282. package/wizard/types.d.ts +65 -0
  283. package/wizard/types.js +5 -0
  284. package/ThemeContext.js +0 -246
  285. package/V3Select/V3Select.js +0 -455
  286. package/V3Select/index.d.ts +0 -27
  287. package/V3Textarea/V3Textarea.js +0 -260
  288. package/V3Textarea/index.d.ts +0 -27
  289. package/box/index.d.ts +0 -25
  290. package/chip/index.d.ts +0 -22
  291. package/date/Date.js +0 -373
  292. package/date/index.d.ts +0 -27
  293. package/dialog/index.d.ts +0 -18
  294. package/file-input/index.d.ts +0 -81
  295. package/footer/index.d.ts +0 -25
  296. package/header/index.d.ts +0 -25
  297. package/heading/index.d.ts +0 -17
  298. package/input-text/Icons.js +0 -22
  299. package/input-text/InputText.js +0 -611
  300. package/input-text/index.d.ts +0 -36
  301. package/link/index.d.ts +0 -23
  302. package/number-input/index.d.ts +0 -113
  303. package/password-input/index.d.ts +0 -94
  304. package/radio/Radio.d.ts +0 -4
  305. package/radio/Radio.js +0 -174
  306. package/radio/types.d.ts +0 -54
  307. package/resultsetTable/index.d.ts +0 -19
  308. package/select/index.d.ts +0 -131
  309. package/sidenav/index.d.ts +0 -13
  310. package/spinner/index.d.ts +0 -17
  311. package/table/index.d.ts +0 -13
  312. package/tag/index.d.ts +0 -24
  313. package/text-input/index.d.ts +0 -135
  314. package/textarea/index.d.ts +0 -117
  315. package/toggle/Toggle.js +0 -186
  316. package/toggle/index.d.ts +0 -21
  317. package/toggle-group/index.d.ts +0 -21
  318. package/upload/Upload.js +0 -201
  319. package/upload/buttons-upload/ButtonsUpload.js +0 -111
  320. package/upload/buttons-upload/Icons.js +0 -40
  321. package/upload/dragAndDropArea/DragAndDropArea.js +0 -225
  322. package/upload/dragAndDropArea/Icons.js +0 -39
  323. package/upload/file-upload/FileToUpload.js +0 -115
  324. package/upload/file-upload/Icons.js +0 -66
  325. package/upload/files-upload/FilesToUpload.js +0 -109
  326. package/upload/index.d.ts +0 -15
  327. package/upload/transaction/Icons.js +0 -160
  328. package/upload/transaction/Transaction.js +0 -104
  329. package/upload/transactions/Transactions.js +0 -94
  330. package/wizard/Icons.js +0 -65
  331. 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
+ );