@dxc-technology/halstack-react 0.0.0-efa7c74 → 0.0.0-f00a97a

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