@dxc-technology/halstack-react 0.0.0-ff6151e → 0.0.0-ff99b25

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 (330) hide show
  1. package/BackgroundColorContext.js +50 -0
  2. package/ThemeContext.js +246 -0
  3. package/V3Select/V3Select.js +455 -0
  4. package/V3Select/index.d.ts +27 -0
  5. package/V3Textarea/V3Textarea.js +260 -0
  6. package/V3Textarea/index.d.ts +27 -0
  7. package/accordion/Accordion.d.ts +4 -0
  8. package/accordion/Accordion.js +258 -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 +170 -0
  13. package/accordion-group/types.d.ts +72 -0
  14. package/accordion-group/types.js +5 -0
  15. package/alert/Alert.d.ts +4 -0
  16. package/alert/Alert.js +290 -0
  17. package/alert/types.d.ts +49 -0
  18. package/alert/types.js +5 -0
  19. package/badge/Badge.js +59 -0
  20. package/{dist/box → box}/Box.js +38 -34
  21. package/box/Box.stories.jsx +132 -0
  22. package/box/index.d.ts +25 -0
  23. package/button/Button.d.ts +4 -0
  24. package/button/Button.js +182 -0
  25. package/button/Button.stories.tsx +293 -0
  26. package/button/types.d.ts +57 -0
  27. package/button/types.js +5 -0
  28. package/card/Card.d.ts +4 -0
  29. package/card/Card.js +165 -0
  30. package/card/types.d.ts +69 -0
  31. package/card/types.js +5 -0
  32. package/checkbox/Checkbox.d.ts +4 -0
  33. package/checkbox/Checkbox.js +253 -0
  34. package/checkbox/types.d.ts +60 -0
  35. package/checkbox/types.js +5 -0
  36. package/chip/Chip.js +221 -0
  37. package/chip/index.d.ts +22 -0
  38. package/{dist/common → common}/OpenSans.css +0 -0
  39. package/{dist/common → common}/RequiredComponent.js +3 -11
  40. package/{dist/common → common}/fonts/OpenSans-Bold.ttf +0 -0
  41. package/{dist/common → common}/fonts/OpenSans-BoldItalic.ttf +0 -0
  42. package/{dist/common → common}/fonts/OpenSans-ExtraBold.ttf +0 -0
  43. package/{dist/common → common}/fonts/OpenSans-ExtraBoldItalic.ttf +0 -0
  44. package/{dist/common → common}/fonts/OpenSans-Italic.ttf +0 -0
  45. package/{dist/common → common}/fonts/OpenSans-Light.ttf +0 -0
  46. package/{dist/common → common}/fonts/OpenSans-LightItalic.ttf +0 -0
  47. package/{dist/common → common}/fonts/OpenSans-Regular.ttf +0 -0
  48. package/{dist/common → common}/fonts/OpenSans-SemiBold.ttf +0 -0
  49. package/{dist/common → common}/fonts/OpenSans-SemiBoldItalic.ttf +0 -0
  50. package/common/utils.js +22 -0
  51. package/common/variables.js +1569 -0
  52. package/{dist/date → date}/Date.js +81 -65
  53. package/date/index.d.ts +27 -0
  54. package/date-input/DateInput.d.ts +4 -0
  55. package/date-input/DateInput.js +361 -0
  56. package/date-input/types.d.ts +100 -0
  57. package/date-input/types.js +5 -0
  58. package/dialog/Dialog.d.ts +4 -0
  59. package/dialog/Dialog.js +165 -0
  60. package/dialog/types.d.ts +43 -0
  61. package/dialog/types.js +5 -0
  62. package/dropdown/Dropdown.d.ts +4 -0
  63. package/dropdown/Dropdown.js +417 -0
  64. package/dropdown/types.d.ts +89 -0
  65. package/dropdown/types.js +5 -0
  66. package/file-input/FileInput.js +532 -0
  67. package/file-input/FileItem.js +193 -0
  68. package/file-input/index.d.ts +81 -0
  69. package/footer/Footer.d.ts +4 -0
  70. package/footer/Footer.js +266 -0
  71. package/footer/Footer.stories.jsx +151 -0
  72. package/footer/Icons.js +77 -0
  73. package/footer/types.d.ts +61 -0
  74. package/footer/types.js +5 -0
  75. package/header/Header.js +326 -0
  76. package/header/Icons.js +59 -0
  77. package/header/index.d.ts +25 -0
  78. package/heading/Heading.js +176 -0
  79. package/heading/index.d.ts +17 -0
  80. package/input-text/Icons.js +22 -0
  81. package/input-text/InputText.js +611 -0
  82. package/input-text/index.d.ts +36 -0
  83. package/{dist/layout → layout}/ApplicationLayout.js +42 -142
  84. package/layout/Icons.js +55 -0
  85. package/link/Link.js +183 -0
  86. package/link/index.d.ts +23 -0
  87. package/main.d.ts +44 -0
  88. package/{dist/main.js → main.js} +125 -65
  89. package/number-input/NumberInput.js +128 -0
  90. package/number-input/NumberInput.stories.jsx +115 -0
  91. package/number-input/NumberInputContext.js +16 -0
  92. package/number-input/index.d.ts +113 -0
  93. package/package.json +34 -22
  94. package/paginator/Icons.js +66 -0
  95. package/paginator/Paginator.d.ts +4 -0
  96. package/paginator/Paginator.js +198 -0
  97. package/paginator/types.d.ts +38 -0
  98. package/paginator/types.js +5 -0
  99. package/password-input/PasswordInput.js +199 -0
  100. package/password-input/PasswordInput.stories.jsx +131 -0
  101. package/password-input/index.d.ts +94 -0
  102. package/progress-bar/ProgressBar.d.ts +4 -0
  103. package/progress-bar/ProgressBar.js +170 -0
  104. package/progress-bar/types.d.ts +37 -0
  105. package/progress-bar/types.js +5 -0
  106. package/radio/Radio.d.ts +4 -0
  107. package/radio/Radio.js +174 -0
  108. package/radio/types.d.ts +54 -0
  109. package/radio/types.js +5 -0
  110. package/{dist/resultsetTable → resultsetTable}/ResultsetTable.js +95 -162
  111. package/resultsetTable/index.d.ts +19 -0
  112. package/select/Select.js +865 -0
  113. package/select/index.d.ts +131 -0
  114. package/sidenav/Sidenav.js +145 -0
  115. package/sidenav/index.d.ts +13 -0
  116. package/slider/Slider.d.ts +4 -0
  117. package/slider/Slider.js +306 -0
  118. package/slider/types.d.ts +83 -0
  119. package/slider/types.js +5 -0
  120. package/spinner/Spinner.js +267 -0
  121. package/spinner/index.d.ts +17 -0
  122. package/switch/Switch.d.ts +4 -0
  123. package/switch/Switch.js +179 -0
  124. package/switch/types.d.ts +58 -0
  125. package/switch/types.js +5 -0
  126. package/table/Table.js +118 -0
  127. package/table/index.d.ts +13 -0
  128. package/tabs/Tabs.d.ts +4 -0
  129. package/tabs/Tabs.js +211 -0
  130. package/tabs/types.d.ts +71 -0
  131. package/tabs/types.js +5 -0
  132. package/tag/Tag.js +208 -0
  133. package/tag/index.d.ts +24 -0
  134. package/text-input/TextInput.js +825 -0
  135. package/text-input/index.d.ts +135 -0
  136. package/textarea/Textarea.js +317 -0
  137. package/textarea/Textarea.stories.jsx +135 -0
  138. package/textarea/index.d.ts +117 -0
  139. package/{dist/toggle → toggle}/Toggle.js +30 -67
  140. package/toggle/index.d.ts +21 -0
  141. package/toggle-group/ToggleGroup.js +243 -0
  142. package/toggle-group/index.d.ts +21 -0
  143. package/{dist/upload → upload}/Upload.js +23 -22
  144. package/upload/buttons-upload/ButtonsUpload.js +111 -0
  145. package/upload/buttons-upload/Icons.js +40 -0
  146. package/upload/dragAndDropArea/DragAndDropArea.js +225 -0
  147. package/upload/dragAndDropArea/Icons.js +39 -0
  148. package/upload/file-upload/FileToUpload.js +115 -0
  149. package/upload/file-upload/Icons.js +66 -0
  150. package/upload/files-upload/FilesToUpload.js +109 -0
  151. package/upload/index.d.ts +15 -0
  152. package/upload/transaction/Icons.js +160 -0
  153. package/upload/transaction/Transaction.js +104 -0
  154. package/upload/transactions/Transactions.js +94 -0
  155. package/{dist/useTheme.js → useTheme.js} +0 -0
  156. package/wizard/Icons.js +65 -0
  157. package/wizard/Wizard.js +271 -0
  158. package/wizard/index.d.ts +18 -0
  159. package/README.md +0 -66
  160. package/babel.config.js +0 -4
  161. package/dist/ThemeContext.js +0 -54
  162. package/dist/accordion/Accordion.js +0 -273
  163. package/dist/accordion/Accordion.stories.js +0 -207
  164. package/dist/accordion/readme.md +0 -96
  165. package/dist/accordion-group/AccordionGroup.js +0 -159
  166. package/dist/accordion-group/AccordionGroup.stories.js +0 -207
  167. package/dist/accordion-group/readme.md +0 -70
  168. package/dist/alert/Alert.js +0 -304
  169. package/dist/alert/Alert.stories.js +0 -158
  170. package/dist/alert/close.svg +0 -4
  171. package/dist/alert/error.svg +0 -4
  172. package/dist/alert/info.svg +0 -4
  173. package/dist/alert/readme.md +0 -43
  174. package/dist/alert/success.svg +0 -4
  175. package/dist/alert/warning.svg +0 -4
  176. package/dist/badge/Badge.js +0 -58
  177. package/dist/button/Button.js +0 -202
  178. package/dist/button/Button.stories.js +0 -224
  179. package/dist/button/readme.md +0 -93
  180. package/dist/card/Card.js +0 -217
  181. package/dist/checkbox/Checkbox.js +0 -240
  182. package/dist/checkbox/Checkbox.stories.js +0 -144
  183. package/dist/checkbox/readme.md +0 -116
  184. package/dist/chip/Chip.js +0 -208
  185. package/dist/common/services/example-service.js +0 -10
  186. package/dist/common/services/example-service.test.js +0 -12
  187. package/dist/common/utils.js +0 -42
  188. package/dist/common/variables.js +0 -436
  189. package/dist/date/Date.stories.js +0 -205
  190. package/dist/date/calendar.svg +0 -1
  191. package/dist/date/calendar_dark.svg +0 -1
  192. package/dist/date/readme.md +0 -73
  193. package/dist/dialog/Dialog.js +0 -197
  194. package/dist/dialog/Dialog.stories.js +0 -217
  195. package/dist/dialog/readme.md +0 -32
  196. package/dist/dropdown/Dropdown.js +0 -449
  197. package/dist/dropdown/Dropdown.stories.js +0 -249
  198. package/dist/dropdown/baseline-arrow_drop_down.svg +0 -1
  199. package/dist/dropdown/baseline-arrow_drop_down_wh.svg +0 -4
  200. package/dist/dropdown/baseline-arrow_drop_up.svg +0 -1
  201. package/dist/dropdown/baseline-arrow_drop_up_wh.svg +0 -4
  202. package/dist/dropdown/readme.md +0 -69
  203. package/dist/footer/Footer.js +0 -371
  204. package/dist/footer/Footer.stories.js +0 -94
  205. package/dist/footer/dxc_logo_wht.png +0 -0
  206. package/dist/footer/readme.md +0 -41
  207. package/dist/header/Header.js +0 -373
  208. package/dist/header/Header.stories.js +0 -176
  209. package/dist/header/close_icon.svg +0 -1
  210. package/dist/header/dxc_logo_black.png +0 -0
  211. package/dist/header/dxc_logo_blk_rgb.svg +0 -6
  212. package/dist/header/dxc_logo_white.png +0 -0
  213. package/dist/header/hamb_menu_black.svg +0 -1
  214. package/dist/header/hamb_menu_white.svg +0 -1
  215. package/dist/header/readme.md +0 -33
  216. package/dist/heading/Heading.js +0 -153
  217. package/dist/input-text/InputText.js +0 -570
  218. package/dist/input-text/InputText.stories.js +0 -209
  219. package/dist/input-text/error.svg +0 -1
  220. package/dist/input-text/readme.md +0 -91
  221. package/dist/layout/facebook.svg +0 -45
  222. package/dist/layout/linkedin.svg +0 -50
  223. package/dist/layout/twitter.svg +0 -53
  224. package/dist/link/Link.js +0 -192
  225. package/dist/link/readme.md +0 -51
  226. package/dist/paginator/Paginator.js +0 -232
  227. package/dist/paginator/images/next.svg +0 -3
  228. package/dist/paginator/images/nextPage.svg +0 -3
  229. package/dist/paginator/images/previous.svg +0 -3
  230. package/dist/paginator/images/previousPage.svg +0 -3
  231. package/dist/paginator/readme.md +0 -50
  232. package/dist/progress-bar/ProgressBar.js +0 -185
  233. package/dist/progress-bar/ProgressBar.stories.js +0 -280
  234. package/dist/progress-bar/readme.md +0 -63
  235. package/dist/radio/Radio.js +0 -195
  236. package/dist/radio/Radio.stories.js +0 -166
  237. package/dist/radio/readme.md +0 -70
  238. package/dist/resultsetTable/arrow_downward-24px_wht.svg +0 -1
  239. package/dist/resultsetTable/arrow_upward-24px_wht.svg +0 -1
  240. package/dist/resultsetTable/unfold_more-24px_wht.svg +0 -1
  241. package/dist/select/Select.js +0 -473
  242. package/dist/select/Select.stories.js +0 -235
  243. package/dist/select/readme.md +0 -72
  244. package/dist/sidenav/Sidenav.js +0 -128
  245. package/dist/slider/Slider.js +0 -266
  246. package/dist/slider/Slider.stories.js +0 -241
  247. package/dist/slider/readme.md +0 -64
  248. package/dist/spinner/Spinner.js +0 -193
  249. package/dist/spinner/Spinner.stories.js +0 -183
  250. package/dist/spinner/readme.md +0 -65
  251. package/dist/switch/Switch.js +0 -199
  252. package/dist/switch/Switch.stories.js +0 -134
  253. package/dist/switch/readme.md +0 -133
  254. package/dist/table/Table.js +0 -105
  255. package/dist/tabs/Tabs.js +0 -292
  256. package/dist/tabs/Tabs.stories.js +0 -130
  257. package/dist/tabs/readme.md +0 -78
  258. package/dist/tabs-for-sections/TabsForSections.js +0 -92
  259. package/dist/tabs-for-sections/readme.md +0 -78
  260. package/dist/tag/Tag.js +0 -249
  261. package/dist/textarea/Textarea.js +0 -227
  262. package/dist/toggle/Toggle.stories.js +0 -297
  263. package/dist/toggle/readme.md +0 -80
  264. package/dist/toggle-group/ToggleGroup.js +0 -226
  265. package/dist/toggle-group/readme.md +0 -82
  266. package/dist/upload/Upload.stories.js +0 -72
  267. package/dist/upload/buttons-upload/ButtonsUpload.js +0 -122
  268. package/dist/upload/buttons-upload/drag-drop-icon.svg +0 -4
  269. package/dist/upload/buttons-upload/upload-button.svg +0 -1
  270. package/dist/upload/dragAndDropArea/DragAndDropArea.js +0 -279
  271. package/dist/upload/dragAndDropArea/upload_drop.svg +0 -4
  272. package/dist/upload/dragAndDropArea/upload_file.svg +0 -4
  273. package/dist/upload/file-upload/FileToUpload.js +0 -158
  274. package/dist/upload/file-upload/audio-icon.svg +0 -4
  275. package/dist/upload/file-upload/close.svg +0 -4
  276. package/dist/upload/file-upload/file-icon.svg +0 -4
  277. package/dist/upload/file-upload/video-icon.svg +0 -4
  278. package/dist/upload/files-upload/FilesToUpload.js +0 -123
  279. package/dist/upload/readme.md +0 -37
  280. package/dist/upload/transaction/Transaction.js +0 -155
  281. package/dist/upload/transaction/audio-icon-err.svg +0 -4
  282. package/dist/upload/transaction/audio-icon.svg +0 -4
  283. package/dist/upload/transaction/error-icon.svg +0 -4
  284. package/dist/upload/transaction/file-icon-err.svg +0 -4
  285. package/dist/upload/transaction/file-icon.svg +0 -4
  286. package/dist/upload/transaction/image-icon-err.svg +0 -4
  287. package/dist/upload/transaction/image-icon.svg +0 -4
  288. package/dist/upload/transaction/success-icon.svg +0 -4
  289. package/dist/upload/transaction/video-icon-err.svg +0 -4
  290. package/dist/upload/transaction/video-icon.svg +0 -4
  291. package/dist/upload/transactions/Transactions.js +0 -120
  292. package/dist/wizard/Wizard.js +0 -331
  293. package/dist/wizard/invalid_icon.svg +0 -6
  294. package/dist/wizard/valid_icon.svg +0 -6
  295. package/dist/wizard/validation-wrong.svg +0 -6
  296. package/test/Accordion.test.js +0 -33
  297. package/test/AccordionGroup.test.js +0 -109
  298. package/test/Alert.test.js +0 -53
  299. package/test/Box.test.js +0 -10
  300. package/test/Button.test.js +0 -18
  301. package/test/Card.test.js +0 -30
  302. package/test/Checkbox.test.js +0 -45
  303. package/test/Chip.test.js +0 -25
  304. package/test/Date.test.js +0 -393
  305. package/test/Dialog.test.js +0 -23
  306. package/test/Dropdown.test.js +0 -130
  307. package/test/Footer.test.js +0 -99
  308. package/test/Header.test.js +0 -39
  309. package/test/Heading.test.js +0 -35
  310. package/test/InputText.test.js +0 -240
  311. package/test/Link.test.js +0 -42
  312. package/test/Paginator.test.js +0 -194
  313. package/test/ProgressBar.test.js +0 -35
  314. package/test/Radio.test.js +0 -37
  315. package/test/ResultsetTable.test.js +0 -304
  316. package/test/Select.test.js +0 -192
  317. package/test/Sidenav.test.js +0 -45
  318. package/test/Slider.test.js +0 -82
  319. package/test/Spinner.test.js +0 -27
  320. package/test/Switch.test.js +0 -45
  321. package/test/Table.test.js +0 -36
  322. package/test/Tabs.test.js +0 -109
  323. package/test/TabsForSections.test.js +0 -34
  324. package/test/Tag.test.js +0 -32
  325. package/test/TextArea.test.js +0 -52
  326. package/test/ToggleGroup.test.js +0 -81
  327. package/test/Upload.test.js +0 -60
  328. package/test/Wizard.test.js +0 -130
  329. package/test/mocks/pngMock.js +0 -1
  330. package/test/mocks/svgMock.js +0 -1
@@ -0,0 +1,532 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ var _typeof3 = require("@babel/runtime/helpers/typeof");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports["default"] = void 0;
11
+
12
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
13
+
14
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
15
+
16
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
17
+
18
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
19
+
20
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
21
+
22
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
23
+
24
+ var _react = _interopRequireWildcard(require("react"));
25
+
26
+ var _propTypes = _interopRequireDefault(require("prop-types"));
27
+
28
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
29
+
30
+ var _uuid = require("uuid");
31
+
32
+ var _variables = require("../common/variables.js");
33
+
34
+ var _useTheme = _interopRequireDefault(require("../useTheme.js"));
35
+
36
+ var _Button = _interopRequireDefault(require("../button/Button"));
37
+
38
+ var _FileItem = _interopRequireDefault(require("./FileItem"));
39
+
40
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11;
41
+
42
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
43
+
44
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
45
+
46
+ var audioIcon = /*#__PURE__*/_react["default"].createElement("svg", {
47
+ xmlns: "http://www.w3.org/2000/svg",
48
+ width: "24",
49
+ height: "24",
50
+ viewBox: "0 0 24 24",
51
+ fill: "currentColor"
52
+ }, /*#__PURE__*/_react["default"].createElement("path", {
53
+ fill: "none",
54
+ d: "M0 0h24v24H0V0z"
55
+ }), /*#__PURE__*/_react["default"].createElement("path", {
56
+ d: "M21 3H3c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h18c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm0 16H3V5h18v14zM8 15c0-1.66 1.34-3 3-3 .35 0 .69.07 1 .18V6h5v2h-3v7.03c-.02 1.64-1.35 2.97-3 2.97-1.66 0-3-1.34-3-3z"
57
+ }));
58
+
59
+ var videoIcon = /*#__PURE__*/_react["default"].createElement("svg", {
60
+ xmlns: "http://www.w3.org/2000/svg",
61
+ width: "24",
62
+ height: "24",
63
+ viewBox: "0 0 24 24",
64
+ fill: "currentColor"
65
+ }, /*#__PURE__*/_react["default"].createElement("path", {
66
+ d: "M18 4l2 4h-3l-2-4h-2l2 4h-3l-2-4H8l2 4H7L5 4H4c-1.1 0-1.99.9-1.99 2L2 18c0 1.1.9 2 2 2h16c1.1 0 2-.9 2-2V4h-4z"
67
+ }), /*#__PURE__*/_react["default"].createElement("path", {
68
+ d: "M0 0h24v24H0z",
69
+ fill: "none"
70
+ }));
71
+
72
+ var fileIcon = /*#__PURE__*/_react["default"].createElement("svg", {
73
+ xmlns: "http://www.w3.org/2000/svg",
74
+ width: "24",
75
+ height: "24",
76
+ viewBox: "0 0 24 24",
77
+ fill: "currentColor"
78
+ }, /*#__PURE__*/_react["default"].createElement("path", {
79
+ fill: "none",
80
+ d: "M0 0h24v24H0V0z"
81
+ }), /*#__PURE__*/_react["default"].createElement("path", {
82
+ d: "M14 2H6c-1.1 0-1.99.9-1.99 2L4 20c0 1.1.89 2 1.99 2H18c1.1 0 2-.9 2-2V8l-6-6zM6 20V4h7v5h5v11H6z"
83
+ }));
84
+
85
+ var DxcFileInput = function DxcFileInput(_ref) {
86
+ var _ref$name = _ref.name,
87
+ name = _ref$name === void 0 ? "" : _ref$name,
88
+ _ref$mode = _ref.mode,
89
+ mode = _ref$mode === void 0 ? "file" : _ref$mode,
90
+ _ref$label = _ref.label,
91
+ label = _ref$label === void 0 ? "" : _ref$label,
92
+ _ref$helperText = _ref.helperText,
93
+ helperText = _ref$helperText === void 0 ? "" : _ref$helperText,
94
+ accept = _ref.accept,
95
+ minSize = _ref.minSize,
96
+ maxSize = _ref.maxSize,
97
+ _ref$showPreview = _ref.showPreview,
98
+ showPreview = _ref$showPreview === void 0 ? false : _ref$showPreview,
99
+ _ref$multiple = _ref.multiple,
100
+ multiple = _ref$multiple === void 0 ? true : _ref$multiple,
101
+ _ref$disabled = _ref.disabled,
102
+ disabled = _ref$disabled === void 0 ? false : _ref$disabled,
103
+ callbackFile = _ref.callbackFile,
104
+ value = _ref.value,
105
+ margin = _ref.margin,
106
+ tabIndex = _ref.tabIndex;
107
+
108
+ var _useState = (0, _react.useState)(false),
109
+ _useState2 = (0, _slicedToArray2["default"])(_useState, 2),
110
+ isDragging = _useState2[0],
111
+ setIsDragging = _useState2[1];
112
+
113
+ var _useState3 = (0, _react.useState)([]),
114
+ _useState4 = (0, _slicedToArray2["default"])(_useState3, 2),
115
+ files = _useState4[0],
116
+ setFiles = _useState4[1];
117
+
118
+ var _useState5 = (0, _react.useState)("file-input-".concat((0, _uuid.v4)())),
119
+ _useState6 = (0, _slicedToArray2["default"])(_useState5, 1),
120
+ fileInputId = _useState6[0];
121
+
122
+ var colorsTheme = (0, _useTheme["default"])();
123
+ (0, _react.useEffect)(function () {
124
+ if (value) {
125
+ setFiles(value);
126
+ } else {
127
+ setFiles([]);
128
+ }
129
+ }, [value]);
130
+
131
+ var handleClick = function handleClick() {
132
+ document.getElementById(fileInputId).click();
133
+ };
134
+
135
+ var checkFileSize = function checkFileSize(file) {
136
+ if (file.size < minSize) {
137
+ return "File size must be greater than min size.";
138
+ }
139
+
140
+ if (file.size > maxSize) {
141
+ return "File size must be less than max size.";
142
+ }
143
+ };
144
+
145
+ var getFilePreview = function getFilePreview(file) {
146
+ if (file.type.includes("video")) {
147
+ return videoIcon;
148
+ }
149
+
150
+ if (file.type.includes("audio")) {
151
+ return audioIcon;
152
+ }
153
+
154
+ if (file.type.includes("image")) {
155
+ return new Promise(function (resolve) {
156
+ var reader = new FileReader();
157
+ reader.readAsDataURL(file);
158
+
159
+ reader.onload = function (e) {
160
+ resolve(e.target.result);
161
+ };
162
+ });
163
+ }
164
+
165
+ return fileIcon;
166
+ };
167
+
168
+ var getFilesToAdd = /*#__PURE__*/function () {
169
+ var _ref2 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(selectedFiles) {
170
+ var filesToAdd;
171
+ return _regenerator["default"].wrap(function _callee$(_context) {
172
+ while (1) {
173
+ switch (_context.prev = _context.next) {
174
+ case 0:
175
+ _context.next = 2;
176
+ return Promise.all(selectedFiles.map(function (selectedFile) {
177
+ return getFilePreview(selectedFile);
178
+ })).then(function (previews) {
179
+ return selectedFiles.map(function (selectedFile, index) {
180
+ var fileInfo = {
181
+ file: selectedFile,
182
+ error: checkFileSize(selectedFile),
183
+ preview: previews[index]
184
+ };
185
+ return fileInfo;
186
+ });
187
+ });
188
+
189
+ case 2:
190
+ filesToAdd = _context.sent;
191
+ return _context.abrupt("return", filesToAdd);
192
+
193
+ case 4:
194
+ case "end":
195
+ return _context.stop();
196
+ }
197
+ }
198
+ }, _callee);
199
+ }));
200
+
201
+ return function getFilesToAdd(_x) {
202
+ return _ref2.apply(this, arguments);
203
+ };
204
+ }();
205
+
206
+ var addFile = /*#__PURE__*/function () {
207
+ var _ref3 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2(selectedFiles) {
208
+ var filesToAdd, finalFiles, fileToAdd;
209
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
210
+ while (1) {
211
+ switch (_context2.prev = _context2.next) {
212
+ case 0:
213
+ if (!multiple) {
214
+ _context2.next = 8;
215
+ break;
216
+ }
217
+
218
+ _context2.next = 3;
219
+ return getFilesToAdd(selectedFiles);
220
+
221
+ case 3:
222
+ filesToAdd = _context2.sent;
223
+ finalFiles = [].concat((0, _toConsumableArray2["default"])(files), (0, _toConsumableArray2["default"])(filesToAdd));
224
+
225
+ if (typeof callbackFile === "function") {
226
+ callbackFile(finalFiles);
227
+ }
228
+
229
+ _context2.next = 19;
230
+ break;
231
+
232
+ case 8:
233
+ if (!(selectedFiles.length === 1)) {
234
+ _context2.next = 14;
235
+ break;
236
+ }
237
+
238
+ _context2.next = 11;
239
+ return getFilesToAdd(selectedFiles);
240
+
241
+ case 11:
242
+ _context2.t0 = _context2.sent;
243
+ _context2.next = 17;
244
+ break;
245
+
246
+ case 14:
247
+ _context2.next = 16;
248
+ return getFilesToAdd([selectedFiles[0]]);
249
+
250
+ case 16:
251
+ _context2.t0 = _context2.sent;
252
+
253
+ case 17:
254
+ fileToAdd = _context2.t0;
255
+
256
+ if (typeof callbackFile === "function") {
257
+ callbackFile(fileToAdd);
258
+ }
259
+
260
+ case 19:
261
+ case "end":
262
+ return _context2.stop();
263
+ }
264
+ }
265
+ }, _callee2);
266
+ }));
267
+
268
+ return function addFile(_x2) {
269
+ return _ref3.apply(this, arguments);
270
+ };
271
+ }();
272
+
273
+ var selectFiles = function selectFiles(e) {
274
+ var selectedFiles = e.target.files;
275
+ var filesArray = Object.keys(selectedFiles).map(function (key) {
276
+ return selectedFiles[key];
277
+ });
278
+ addFile(filesArray);
279
+ };
280
+
281
+ var onDelete = function onDelete(fileName) {
282
+ var filesCopy = (0, _toConsumableArray2["default"])(files);
283
+ var fileToRemove = filesCopy.find(function (file) {
284
+ return file.file.name === fileName;
285
+ });
286
+ var fileIndex = filesCopy.indexOf(fileToRemove);
287
+ filesCopy.splice(fileIndex, 1);
288
+
289
+ if (typeof callbackFile === "function") {
290
+ callbackFile(filesCopy);
291
+ }
292
+ };
293
+
294
+ var handleDrag = function handleDrag(e) {
295
+ e.preventDefault();
296
+ e.stopPropagation();
297
+ };
298
+
299
+ var handleDragIn = function handleDragIn(e) {
300
+ e.preventDefault();
301
+ e.stopPropagation();
302
+
303
+ if (e.dataTransfer.items && e.dataTransfer.items.length > 0) {
304
+ setIsDragging(true);
305
+ }
306
+ };
307
+
308
+ var handleDragOut = function handleDragOut(e) {
309
+ e.preventDefault();
310
+ e.stopPropagation();
311
+ setIsDragging(false);
312
+ };
313
+
314
+ var handleDrop = function handleDrop(e) {
315
+ e.preventDefault();
316
+ e.stopPropagation();
317
+ setIsDragging(false);
318
+ var filesObject = e.dataTransfer.files;
319
+
320
+ if (filesObject && filesObject.length > 0) {
321
+ var filesArray = Object.keys(filesObject).map(function (key) {
322
+ return filesObject[key];
323
+ });
324
+ addFile(filesArray);
325
+ }
326
+ };
327
+
328
+ return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
329
+ theme: colorsTheme.fileInput
330
+ }, /*#__PURE__*/_react["default"].createElement(FileInputContainer, {
331
+ margin: margin,
332
+ name: name,
333
+ tabIndex: tabIndex
334
+ }, /*#__PURE__*/_react["default"].createElement(Label, {
335
+ htmlFor: fileInputId,
336
+ disabled: disabled
337
+ }, label), /*#__PURE__*/_react["default"].createElement(HelperText, {
338
+ disabled: disabled
339
+ }, helperText), mode === "file" ? /*#__PURE__*/_react["default"].createElement(FileContainer, {
340
+ multiple: multiple,
341
+ files: files
342
+ }, /*#__PURE__*/_react["default"].createElement(ButtonErrorContainer, null, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
343
+ mode: "secondary",
344
+ label: "Select files",
345
+ onClick: handleClick,
346
+ disabled: disabled,
347
+ size: "medium",
348
+ tabIndex: tabIndex
349
+ }), /*#__PURE__*/_react["default"].createElement("input", {
350
+ id: fileInputId,
351
+ type: "file",
352
+ accept: accept,
353
+ multiple: multiple,
354
+ onChange: selectFiles
355
+ }), files.length === 1 && files.map(function (file) {
356
+ return file.error && mode === "file" && !multiple && /*#__PURE__*/_react["default"].createElement(ErrorMessage, null, file.error);
357
+ })), files.map(function (file) {
358
+ return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(FileItemContainer, {
359
+ mode: mode,
360
+ multiple: multiple,
361
+ files: files
362
+ }, /*#__PURE__*/_react["default"].createElement(_FileItem["default"], {
363
+ mode: mode,
364
+ multiple: multiple,
365
+ name: file.file.name,
366
+ error: file.error,
367
+ showPreview: mode === "file" && !multiple ? false : showPreview,
368
+ numFiles: files.length,
369
+ preview: file.preview,
370
+ type: file.file.type,
371
+ onDelete: onDelete
372
+ })));
373
+ })) : /*#__PURE__*/_react["default"].createElement(Container, null, /*#__PURE__*/_react["default"].createElement(DragDropArea, {
374
+ isDragging: isDragging,
375
+ disabled: disabled,
376
+ mode: mode,
377
+ onDrop: handleDrop,
378
+ onDragEnter: handleDragIn,
379
+ onDragOver: handleDrag,
380
+ onDragLeave: handleDragOut
381
+ }, /*#__PURE__*/_react["default"].createElement(ButtonContainer, {
382
+ mode: mode
383
+ }, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
384
+ mode: "secondary",
385
+ label: "Select",
386
+ onClick: handleClick,
387
+ disabled: disabled,
388
+ size: "fitContent"
389
+ }), /*#__PURE__*/_react["default"].createElement("input", {
390
+ id: fileInputId,
391
+ type: "file",
392
+ accept: accept,
393
+ multiple: multiple,
394
+ onChange: selectFiles
395
+ })), /*#__PURE__*/_react["default"].createElement(DropLabel, {
396
+ disabled: disabled
397
+ }, "or drop files")), files.map(function (file) {
398
+ return /*#__PURE__*/_react["default"].createElement(FileItemContainer, {
399
+ mode: mode,
400
+ multiple: multiple,
401
+ files: files
402
+ }, /*#__PURE__*/_react["default"].createElement(_FileItem["default"], {
403
+ mode: mode,
404
+ multiple: multiple,
405
+ name: file.file.name,
406
+ error: file.error,
407
+ showPreview: showPreview,
408
+ numFiles: files.length,
409
+ preview: file.preview,
410
+ type: file.file.type,
411
+ onDelete: onDelete
412
+ }));
413
+ }))));
414
+ };
415
+
416
+ var FileInputContainer = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n margin: ", ";\n margin-top: ", ";\n margin-right: ", ";\n margin-bottom: ", ";\n margin-left: ", ";\n width: fit-content;\n"])), function (props) {
417
+ return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
418
+ }, function (props) {
419
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.top ? _variables.spaces[props.margin.top] : "";
420
+ }, function (props) {
421
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.right ? _variables.spaces[props.margin.right] : "";
422
+ }, function (props) {
423
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.bottom ? _variables.spaces[props.margin.bottom] : "";
424
+ }, function (props) {
425
+ return props.margin && (0, _typeof2["default"])(props.margin) === "object" && props.margin.left ? _variables.spaces[props.margin.left] : "";
426
+ });
427
+
428
+ var Label = _styledComponents["default"].label(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n line-height: ", ";\n"])), function (props) {
429
+ return props.disabled ? props.theme.disabledLabelFontColor : props.theme.labelFontColor;
430
+ }, function (props) {
431
+ return props.theme.labelFontFamily;
432
+ }, function (props) {
433
+ return props.theme.labelFontSize;
434
+ }, function (props) {
435
+ return props.theme.labelFontWeight;
436
+ }, function (props) {
437
+ return props.theme.labelLineHeight;
438
+ });
439
+
440
+ var HelperText = _styledComponents["default"].span(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n line-height: ", ";\n"])), function (props) {
441
+ return props.disabled ? props.theme.disabledHelperTextFontcolor : props.theme.helperTextFontColor;
442
+ }, function (props) {
443
+ return props.theme.helperTextFontFamily;
444
+ }, function (props) {
445
+ return props.theme.helperTextFontSize;
446
+ }, function (props) {
447
+ return props.theme.helperTextFontWeight;
448
+ }, function (props) {
449
+ return props.theme.helperTextLineHeight;
450
+ });
451
+
452
+ var DragDropArea = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n height: ", ";\n width: calc(320px - 2px);\n display: flex;\n flex-direction: ", ";\n align-items: center;\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n background-color: ", ";\n border-color: ", ";\n cursor: ", ";\n"])), function (props) {
453
+ return props.mode === "filedrop" ? "calc(48px - 2px)" : "calc(160px - 2px)";
454
+ }, function (props) {
455
+ return props.mode === "filedrop" ? "row" : "column";
456
+ }, function (props) {
457
+ return props.theme.dropBorderRadius;
458
+ }, function (props) {
459
+ return !props.isDragging ? props.theme.dropBorderThickness : "2px";
460
+ }, function (props) {
461
+ return !props.isDragging ? props.theme.dropBorderStyle : "solid";
462
+ }, function (props) {
463
+ return props.isDragging && props.theme.dragoverDropBackgroundColor;
464
+ }, function (props) {
465
+ return props.disabled ? props.theme.disabledDropBorderColor : props.isDragging ? props.theme.focusDropBorderColor : props.theme.dropBorderColor;
466
+ }, function (props) {
467
+ return props.disabled && "not-allowed";
468
+ });
469
+
470
+ var FileContainer = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: ", ";\n"])), function (props) {
471
+ return props.multiple || props.files.length > 1 ? "column" : "row";
472
+ });
473
+
474
+ var ButtonErrorContainer = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n margin-top: 0.25rem;\n\n input[type=\"file\"] {\n visibility: hidden;\n position: absolute;\n width: 0px;\n height: 0px;\n }\n"])));
475
+
476
+ var ButtonContainer = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n padding: ", ";\n input[type=\"file\"] {\n visibility: hidden;\n position: absolute;\n width: 0px;\n height: 0px;\n }\n"])), function (props) {
477
+ return props.mode === "filedrop" ? "2px 12px 2px 2px" : "47px 122px 8px 122px";
478
+ });
479
+
480
+ var DropLabel = _styledComponents["default"].span(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n"])), function (props) {
481
+ return props.disabled ? props.theme.disabledDropLabelFontColor : props.theme.dropLabelFontColor;
482
+ }, function (props) {
483
+ return props.theme.dropLabelFontFamily;
484
+ }, function (props) {
485
+ return props.theme.dropLabelFontSize;
486
+ }, function (props) {
487
+ return props.theme.dropLabelFontWeight;
488
+ });
489
+
490
+ var Container = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n margin-top: 0.25rem;\n"])));
491
+
492
+ var FileItemContainer = _styledComponents["default"].div(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2["default"])(["\n margin-top: ", ";\n margin-left: ", ";\n"])), function (props) {
493
+ return (props.multiple || props.files.length > 1 || props.mode !== "file") && "4px";
494
+ }, function (props) {
495
+ return props.mode === "file" && props.files.length === 1 && !props.multiple && "4px";
496
+ });
497
+
498
+ var ErrorMessage = _styledComponents["default"].div(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n line-height: ", ";\n"])), function (props) {
499
+ return props.theme.errorMessageFontColor;
500
+ }, function (props) {
501
+ return props.theme.errorMessageFontFamily;
502
+ }, function (props) {
503
+ return props.theme.errorMessageFontSize;
504
+ }, function (props) {
505
+ return props.theme.errorMessageFontWeight;
506
+ }, function (props) {
507
+ return props.theme.errorMessageLineHeight;
508
+ });
509
+
510
+ DxcFileInput.propTypes = {
511
+ name: _propTypes["default"].string,
512
+ mode: _propTypes["default"].oneOf(["file", "filedrop", "dropzone"]),
513
+ label: _propTypes["default"].string,
514
+ helperText: _propTypes["default"].string,
515
+ accept: _propTypes["default"].array,
516
+ maxSize: _propTypes["default"].number,
517
+ minSize: _propTypes["default"].number,
518
+ multiple: _propTypes["default"].bool,
519
+ showPreview: _propTypes["default"].bool,
520
+ disabled: _propTypes["default"].bool,
521
+ callbackFile: _propTypes["default"].func,
522
+ value: _propTypes["default"].array,
523
+ tabIndex: _propTypes["default"].number,
524
+ margin: _propTypes["default"].oneOfType([_propTypes["default"].shape({
525
+ top: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
526
+ bottom: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
527
+ left: _propTypes["default"].oneOf(Object.keys(_variables.spaces)),
528
+ right: _propTypes["default"].oneOf(Object.keys(_variables.spaces))
529
+ }), _propTypes["default"].oneOf((0, _toConsumableArray2["default"])(Object.keys(_variables.spaces)))])
530
+ };
531
+ var _default = DxcFileInput;
532
+ exports["default"] = _default;