@dxc-technology/halstack-react 0.0.0-d3554d7 → 0.0.0-d3ac293

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 (267) hide show
  1. package/BackgroundColorContext.d.ts +2 -2
  2. package/BackgroundColorContext.js +1 -1
  3. package/HalstackContext.d.ts +1336 -0
  4. package/HalstackContext.js +335 -0
  5. package/accordion/Accordion.d.ts +1 -1
  6. package/accordion/Accordion.js +118 -126
  7. package/accordion/Accordion.stories.tsx +115 -27
  8. package/accordion/Accordion.test.js +26 -12
  9. package/accordion/types.d.ts +9 -4
  10. package/accordion-group/AccordionGroup.d.ts +1 -1
  11. package/accordion-group/AccordionGroup.js +17 -38
  12. package/accordion-group/AccordionGroup.stories.tsx +28 -2
  13. package/accordion-group/AccordionGroup.test.js +31 -38
  14. package/accordion-group/types.d.ts +14 -3
  15. package/alert/Alert.js +7 -4
  16. package/alert/Alert.stories.tsx +28 -0
  17. package/alert/Alert.test.js +1 -1
  18. package/badge/Badge.d.ts +1 -1
  19. package/badge/Badge.js +5 -3
  20. package/badge/types.d.ts +1 -0
  21. package/bleed/Bleed.js +1 -34
  22. package/bleed/Bleed.stories.tsx +94 -95
  23. package/bleed/types.d.ts +25 -1
  24. package/box/Box.js +25 -37
  25. package/box/Box.stories.tsx +15 -0
  26. package/box/Box.test.js +1 -1
  27. package/box/types.d.ts +1 -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/button/Button.js +52 -69
  33. package/button/Button.stories.tsx +159 -8
  34. package/button/Button.test.js +1 -1
  35. package/button/types.d.ts +7 -7
  36. package/card/Card.js +25 -28
  37. package/card/Card.test.js +1 -1
  38. package/card/types.d.ts +1 -0
  39. package/checkbox/Checkbox.d.ts +2 -2
  40. package/checkbox/Checkbox.js +107 -110
  41. package/checkbox/Checkbox.stories.tsx +198 -130
  42. package/checkbox/Checkbox.test.js +101 -11
  43. package/checkbox/types.d.ts +13 -5
  44. package/chip/Chip.js +18 -24
  45. package/chip/Chip.stories.tsx +96 -9
  46. package/chip/Chip.test.js +3 -5
  47. package/chip/types.d.ts +1 -1
  48. package/common/utils.d.ts +1 -0
  49. package/common/utils.js +4 -4
  50. package/common/variables.d.ts +1625 -0
  51. package/common/variables.js +483 -352
  52. package/date-input/Calendar.d.ts +4 -0
  53. package/date-input/Calendar.js +258 -0
  54. package/date-input/DateInput.js +169 -258
  55. package/date-input/DateInput.stories.tsx +199 -33
  56. package/date-input/DateInput.test.js +521 -155
  57. package/date-input/DatePicker.d.ts +4 -0
  58. package/date-input/DatePicker.js +146 -0
  59. package/date-input/Icons.d.ts +6 -0
  60. package/date-input/Icons.js +75 -0
  61. package/date-input/YearPicker.d.ts +4 -0
  62. package/date-input/YearPicker.js +126 -0
  63. package/date-input/types.d.ts +67 -9
  64. package/dialog/Dialog.js +76 -93
  65. package/dialog/Dialog.stories.tsx +230 -123
  66. package/dialog/Dialog.test.js +334 -5
  67. package/dialog/types.d.ts +3 -2
  68. package/dropdown/Dropdown.d.ts +1 -1
  69. package/dropdown/Dropdown.js +246 -253
  70. package/dropdown/Dropdown.stories.tsx +245 -56
  71. package/dropdown/Dropdown.test.js +507 -110
  72. package/dropdown/DropdownMenu.d.ts +4 -0
  73. package/dropdown/DropdownMenu.js +70 -0
  74. package/dropdown/DropdownMenuItem.d.ts +4 -0
  75. package/dropdown/DropdownMenuItem.js +81 -0
  76. package/dropdown/types.d.ts +25 -5
  77. package/file-input/FileInput.d.ts +2 -2
  78. package/file-input/FileInput.js +181 -223
  79. package/file-input/FileInput.stories.tsx +122 -11
  80. package/file-input/FileInput.test.js +14 -14
  81. package/file-input/FileItem.d.ts +4 -14
  82. package/file-input/FileItem.js +44 -66
  83. package/file-input/types.d.ts +17 -0
  84. package/flex/Flex.d.ts +4 -0
  85. package/flex/Flex.js +69 -0
  86. package/flex/Flex.stories.tsx +103 -0
  87. package/flex/types.d.ts +32 -0
  88. package/footer/Footer.js +16 -89
  89. package/footer/Footer.stories.tsx +99 -1
  90. package/footer/Footer.test.js +14 -26
  91. package/footer/Icons.js +1 -1
  92. package/footer/types.d.ts +2 -1
  93. package/header/Header.js +108 -129
  94. package/header/Header.stories.tsx +189 -36
  95. package/header/Header.test.js +20 -4
  96. package/header/Icons.js +2 -2
  97. package/header/types.d.ts +3 -2
  98. package/heading/Heading.js +1 -1
  99. package/heading/Heading.test.js +1 -1
  100. package/inset/Inset.js +1 -34
  101. package/inset/Inset.stories.tsx +36 -36
  102. package/inset/types.d.ts +25 -1
  103. package/layout/ApplicationLayout.d.ts +16 -6
  104. package/layout/ApplicationLayout.js +72 -132
  105. package/layout/ApplicationLayout.stories.tsx +84 -93
  106. package/layout/Icons.d.ts +5 -0
  107. package/layout/Icons.js +13 -2
  108. package/layout/SidenavContext.d.ts +5 -0
  109. package/layout/SidenavContext.js +19 -0
  110. package/layout/types.d.ts +18 -33
  111. package/link/Link.d.ts +3 -2
  112. package/link/Link.js +59 -76
  113. package/link/Link.stories.tsx +155 -53
  114. package/link/Link.test.js +9 -19
  115. package/link/types.d.ts +7 -23
  116. package/main.d.ts +8 -10
  117. package/main.js +46 -56
  118. package/nav-tabs/NavTabs.d.ts +8 -0
  119. package/nav-tabs/NavTabs.js +125 -0
  120. package/nav-tabs/NavTabs.stories.tsx +260 -0
  121. package/nav-tabs/NavTabs.test.js +82 -0
  122. package/nav-tabs/Tab.d.ts +4 -0
  123. package/nav-tabs/Tab.js +150 -0
  124. package/nav-tabs/types.d.ts +53 -0
  125. package/number-input/NumberInput.js +11 -18
  126. package/number-input/NumberInput.stories.tsx +5 -5
  127. package/number-input/NumberInput.test.js +46 -12
  128. package/number-input/types.d.ts +17 -10
  129. package/package.json +20 -23
  130. package/paginator/Icons.d.ts +5 -0
  131. package/paginator/Icons.js +16 -28
  132. package/paginator/Paginator.js +19 -46
  133. package/paginator/Paginator.stories.tsx +24 -0
  134. package/paginator/Paginator.test.js +78 -39
  135. package/paragraph/Paragraph.d.ts +6 -0
  136. package/paragraph/Paragraph.js +38 -0
  137. package/paragraph/Paragraph.stories.tsx +44 -0
  138. package/password-input/PasswordInput.js +7 -4
  139. package/password-input/PasswordInput.test.js +17 -19
  140. package/password-input/types.d.ts +14 -11
  141. package/progress-bar/ProgressBar.d.ts +2 -2
  142. package/progress-bar/ProgressBar.js +61 -55
  143. package/progress-bar/ProgressBar.stories.jsx +47 -12
  144. package/progress-bar/ProgressBar.test.js +68 -23
  145. package/progress-bar/types.d.ts +3 -4
  146. package/quick-nav/QuickNav.d.ts +4 -0
  147. package/quick-nav/QuickNav.js +117 -0
  148. package/quick-nav/QuickNav.stories.tsx +356 -0
  149. package/quick-nav/types.d.ts +21 -0
  150. package/radio-group/Radio.d.ts +1 -1
  151. package/radio-group/Radio.js +43 -28
  152. package/radio-group/RadioGroup.js +32 -28
  153. package/radio-group/RadioGroup.stories.tsx +135 -17
  154. package/radio-group/RadioGroup.test.js +145 -117
  155. package/radio-group/types.d.ts +79 -2
  156. package/resultsetTable/Icons.d.ts +7 -0
  157. package/resultsetTable/Icons.js +51 -0
  158. package/resultsetTable/ResultsetTable.js +49 -108
  159. package/resultsetTable/ResultsetTable.stories.tsx +50 -25
  160. package/resultsetTable/ResultsetTable.test.js +61 -42
  161. package/resultsetTable/types.d.ts +2 -2
  162. package/select/Icons.d.ts +10 -0
  163. package/select/Icons.js +93 -0
  164. package/select/Listbox.d.ts +4 -0
  165. package/select/Listbox.js +169 -0
  166. package/select/Option.d.ts +4 -0
  167. package/select/Option.js +97 -0
  168. package/select/Select.js +179 -384
  169. package/select/Select.stories.tsx +531 -142
  170. package/select/Select.test.js +652 -324
  171. package/select/types.d.ts +53 -13
  172. package/sidenav/Sidenav.d.ts +6 -5
  173. package/sidenav/Sidenav.js +183 -53
  174. package/sidenav/Sidenav.stories.tsx +249 -149
  175. package/sidenav/Sidenav.test.js +25 -37
  176. package/sidenav/types.d.ts +50 -27
  177. package/slider/Slider.d.ts +2 -2
  178. package/slider/Slider.js +124 -98
  179. package/slider/Slider.stories.tsx +72 -9
  180. package/slider/Slider.test.js +143 -22
  181. package/slider/types.d.ts +10 -2
  182. package/spinner/Spinner.js +4 -4
  183. package/spinner/Spinner.stories.jsx +27 -1
  184. package/spinner/Spinner.test.js +1 -1
  185. package/switch/Switch.d.ts +2 -2
  186. package/switch/Switch.js +152 -69
  187. package/switch/Switch.stories.tsx +53 -42
  188. package/switch/Switch.test.js +156 -4
  189. package/switch/types.d.ts +12 -4
  190. package/table/Table.js +3 -3
  191. package/table/Table.stories.jsx +80 -1
  192. package/table/Table.test.js +2 -2
  193. package/tabs/Tab.d.ts +4 -0
  194. package/tabs/Tab.js +133 -0
  195. package/tabs/Tabs.d.ts +1 -1
  196. package/tabs/Tabs.js +363 -109
  197. package/tabs/Tabs.stories.tsx +119 -13
  198. package/tabs/Tabs.test.js +241 -14
  199. package/tabs/types.d.ts +19 -5
  200. package/tag/Tag.js +17 -22
  201. package/tag/Tag.stories.tsx +25 -8
  202. package/tag/Tag.test.js +1 -1
  203. package/tag/types.d.ts +1 -1
  204. package/text-input/Icons.d.ts +8 -0
  205. package/text-input/Icons.js +60 -0
  206. package/text-input/Suggestion.d.ts +4 -0
  207. package/text-input/Suggestion.js +84 -0
  208. package/text-input/Suggestions.d.ts +4 -0
  209. package/text-input/Suggestions.js +134 -0
  210. package/text-input/TextInput.js +221 -344
  211. package/text-input/TextInput.stories.tsx +290 -195
  212. package/text-input/TextInput.test.js +763 -731
  213. package/text-input/types.d.ts +50 -12
  214. package/textarea/Textarea.js +17 -26
  215. package/textarea/Textarea.stories.jsx +65 -6
  216. package/textarea/Textarea.test.js +38 -37
  217. package/textarea/types.d.ts +18 -11
  218. package/toggle-group/ToggleGroup.d.ts +1 -1
  219. package/toggle-group/ToggleGroup.js +6 -5
  220. package/toggle-group/ToggleGroup.stories.tsx +46 -4
  221. package/toggle-group/ToggleGroup.test.js +36 -5
  222. package/toggle-group/types.d.ts +9 -1
  223. package/typography/Typography.d.ts +4 -0
  224. package/typography/Typography.js +32 -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 +1234 -1
  229. package/useTheme.js +3 -3
  230. package/useTranslatedLabels.d.ts +85 -0
  231. package/useTranslatedLabels.js +20 -0
  232. package/utils/BaseTypography.d.ts +21 -0
  233. package/utils/BaseTypography.js +108 -0
  234. package/utils/FocusLock.d.ts +13 -0
  235. package/utils/FocusLock.js +139 -0
  236. package/wizard/Wizard.d.ts +1 -1
  237. package/wizard/Wizard.js +59 -55
  238. package/wizard/Wizard.stories.tsx +48 -19
  239. package/wizard/Wizard.test.js +37 -24
  240. package/wizard/types.d.ts +10 -5
  241. package/ThemeContext.d.ts +0 -10
  242. package/ThemeContext.js +0 -243
  243. package/common/RequiredComponent.js +0 -32
  244. package/list/List.d.ts +0 -4
  245. package/list/List.js +0 -47
  246. package/list/List.stories.tsx +0 -95
  247. package/list/types.d.ts +0 -7
  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/Radio.test.js +0 -71
  252. package/radio/types.d.ts +0 -54
  253. package/row/Row.d.ts +0 -3
  254. package/row/Row.js +0 -127
  255. package/row/Row.stories.tsx +0 -237
  256. package/row/types.d.ts +0 -10
  257. package/stack/Stack.d.ts +0 -3
  258. package/stack/Stack.js +0 -97
  259. package/stack/Stack.stories.tsx +0 -164
  260. package/stack/types.d.ts +0 -9
  261. package/text/Text.d.ts +0 -7
  262. package/text/Text.js +0 -30
  263. package/text/Text.stories.tsx +0 -19
  264. /package/{list → bulleted-list}/types.js +0 -0
  265. /package/{radio → flex}/types.js +0 -0
  266. /package/{row → nav-tabs}/types.js +0 -0
  267. /package/{stack → quick-nav}/types.js +0 -0
@@ -15,10 +15,10 @@ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/hel
15
15
 
16
16
  var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
17
17
 
18
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
19
-
20
18
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
21
19
 
20
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
21
+
22
22
  var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
23
23
 
24
24
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
@@ -29,15 +29,17 @@ var _styledComponents = _interopRequireWildcard(require("styled-components"));
29
29
 
30
30
  var _uuid = require("uuid");
31
31
 
32
- var _variables = require("../common/variables.js");
32
+ var _variables = require("../common/variables");
33
33
 
34
34
  var _useTheme = _interopRequireDefault(require("../useTheme"));
35
35
 
36
+ var _useTranslatedLabels = _interopRequireDefault(require("../useTranslatedLabels"));
37
+
36
38
  var _Button = _interopRequireDefault(require("../button/Button"));
37
39
 
38
40
  var _FileItem = _interopRequireDefault(require("./FileItem"));
39
41
 
40
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11, _templateObject12;
42
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11;
41
43
 
42
44
  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
45
 
@@ -86,7 +88,18 @@ var fileIcon = /*#__PURE__*/_react["default"].createElement("svg", {
86
88
  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"
87
89
  }));
88
90
 
89
- var DxcFileInput = function DxcFileInput(_ref) {
91
+ var getFilePreview = function getFilePreview(file) {
92
+ if (file.type.includes("video")) return videoIcon;else if (file.type.includes("audio")) return audioIcon;else if (file.type.includes("image")) return new Promise(function (resolve) {
93
+ var reader = new FileReader();
94
+ reader.readAsDataURL(file);
95
+
96
+ reader.onload = function (e) {
97
+ resolve(e.target.result);
98
+ };
99
+ });else return fileIcon;
100
+ };
101
+
102
+ var DxcFileInput = /*#__PURE__*/_react["default"].forwardRef(function (_ref, ref) {
90
103
  var _ref$name = _ref.name,
91
104
  name = _ref$name === void 0 ? "" : _ref$name,
92
105
  _ref$mode = _ref.mode,
@@ -127,129 +140,27 @@ var DxcFileInput = function DxcFileInput(_ref) {
127
140
  fileInputId = _useState6[0];
128
141
 
129
142
  var colorsTheme = (0, _useTheme["default"])();
130
- (0, _react.useEffect)(function () {
131
- var getFiles = /*#__PURE__*/function () {
132
- var _ref2 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2() {
133
- var valueFiles;
134
- return _regenerator["default"].wrap(function _callee2$(_context2) {
135
- while (1) {
136
- switch (_context2.prev = _context2.next) {
137
- case 0:
138
- if (!value) {
139
- _context2.next = 5;
140
- break;
141
- }
142
-
143
- _context2.next = 3;
144
- return Promise.all(value.map( /*#__PURE__*/function () {
145
- var _ref3 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(file) {
146
- var preview;
147
- return _regenerator["default"].wrap(function _callee$(_context) {
148
- while (1) {
149
- switch (_context.prev = _context.next) {
150
- case 0:
151
- if (!file.preview) {
152
- _context.next = 4;
153
- break;
154
- }
155
-
156
- return _context.abrupt("return", file);
157
-
158
- case 4:
159
- _context.next = 6;
160
- return getFilePreview(file.file);
161
-
162
- case 6:
163
- preview = _context.sent;
164
- return _context.abrupt("return", _objectSpread(_objectSpread({}, file), {}, {
165
- preview: preview
166
- }));
167
-
168
- case 8:
169
- case "end":
170
- return _context.stop();
171
- }
172
- }
173
- }, _callee);
174
- }));
175
-
176
- return function (_x) {
177
- return _ref3.apply(this, arguments);
178
- };
179
- }()));
180
-
181
- case 3:
182
- valueFiles = _context2.sent;
183
- setFiles(valueFiles);
184
-
185
- case 5:
186
- case "end":
187
- return _context2.stop();
188
- }
189
- }
190
- }, _callee2);
191
- }));
192
-
193
- return function getFiles() {
194
- return _ref2.apply(this, arguments);
195
- };
196
- }();
197
-
198
- getFiles();
199
- }, [value]);
200
-
201
- var handleClick = function handleClick() {
202
- document.getElementById(fileInputId).click();
203
- };
143
+ var translatedLabels = (0, _useTranslatedLabels["default"])();
204
144
 
205
145
  var checkFileSize = function checkFileSize(file) {
206
- if (file.size < minSize) {
207
- return "File size must be greater than min size.";
208
- }
209
-
210
- if (file.size > maxSize) {
211
- return "File size must be less than max size.";
212
- }
213
- };
214
-
215
- var getFilePreview = function getFilePreview(file) {
216
- if (file.type.includes("video")) {
217
- return videoIcon;
218
- }
219
-
220
- if (file.type.includes("audio")) {
221
- return audioIcon;
222
- }
223
-
224
- if (file.type.includes("image")) {
225
- return new Promise(function (resolve) {
226
- var reader = new FileReader();
227
- reader.readAsDataURL(file);
228
-
229
- reader.onload = function (e) {
230
- resolve(e.target.result);
231
- };
232
- });
233
- }
234
-
235
- return fileIcon;
146
+ if (file.size < minSize) return translatedLabels.fileInput.fileSizeGreaterThanErrorMessage;else if (file.size > maxSize) return translatedLabels.fileInput.fileSizeLessThanErrorMessage;
236
147
  };
237
148
 
238
149
  var getFilesToAdd = /*#__PURE__*/function () {
239
- var _ref4 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3(selectedFiles) {
150
+ var _ref2 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(selectedFiles) {
240
151
  var filesToAdd;
241
- return _regenerator["default"].wrap(function _callee3$(_context3) {
152
+ return _regenerator["default"].wrap(function _callee$(_context) {
242
153
  while (1) {
243
- switch (_context3.prev = _context3.next) {
154
+ switch (_context.prev = _context.next) {
244
155
  case 0:
245
- _context3.next = 2;
156
+ _context.next = 2;
246
157
  return Promise.all(selectedFiles.map(function (selectedFile) {
247
158
  return getFilePreview(selectedFile);
248
159
  })).then(function (previews) {
249
- return selectedFiles.map(function (selectedFile, index) {
160
+ return selectedFiles.map(function (file, index) {
250
161
  var fileInfo = {
251
- file: selectedFile,
252
- error: checkFileSize(selectedFile),
162
+ file: file,
163
+ error: checkFileSize(file),
253
164
  preview: previews[index]
254
165
  };
255
166
  return fileInfo;
@@ -257,86 +168,79 @@ var DxcFileInput = function DxcFileInput(_ref) {
257
168
  });
258
169
 
259
170
  case 2:
260
- filesToAdd = _context3.sent;
261
- return _context3.abrupt("return", filesToAdd);
171
+ filesToAdd = _context.sent;
172
+ return _context.abrupt("return", filesToAdd);
262
173
 
263
174
  case 4:
264
175
  case "end":
265
- return _context3.stop();
176
+ return _context.stop();
266
177
  }
267
178
  }
268
- }, _callee3);
179
+ }, _callee);
269
180
  }));
270
181
 
271
- return function getFilesToAdd(_x2) {
272
- return _ref4.apply(this, arguments);
182
+ return function getFilesToAdd(_x) {
183
+ return _ref2.apply(this, arguments);
273
184
  };
274
185
  }();
275
186
 
276
187
  var addFile = /*#__PURE__*/function () {
277
- var _ref5 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4(selectedFiles) {
188
+ var _ref3 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee2(selectedFiles) {
278
189
  var filesToAdd, finalFiles, fileToAdd;
279
- return _regenerator["default"].wrap(function _callee4$(_context4) {
190
+ return _regenerator["default"].wrap(function _callee2$(_context2) {
280
191
  while (1) {
281
- switch (_context4.prev = _context4.next) {
192
+ switch (_context2.prev = _context2.next) {
282
193
  case 0:
283
194
  if (!multiple) {
284
- _context4.next = 8;
195
+ _context2.next = 8;
285
196
  break;
286
197
  }
287
198
 
288
- _context4.next = 3;
199
+ _context2.next = 3;
289
200
  return getFilesToAdd(selectedFiles);
290
201
 
291
202
  case 3:
292
- filesToAdd = _context4.sent;
203
+ filesToAdd = _context2.sent;
293
204
  finalFiles = [].concat((0, _toConsumableArray2["default"])(files), (0, _toConsumableArray2["default"])(filesToAdd));
294
-
295
- if (typeof callbackFile === "function") {
296
- callbackFile(finalFiles);
297
- }
298
-
299
- _context4.next = 19;
205
+ callbackFile === null || callbackFile === void 0 ? void 0 : callbackFile(finalFiles);
206
+ _context2.next = 19;
300
207
  break;
301
208
 
302
209
  case 8:
303
210
  if (!(selectedFiles.length === 1)) {
304
- _context4.next = 14;
211
+ _context2.next = 14;
305
212
  break;
306
213
  }
307
214
 
308
- _context4.next = 11;
215
+ _context2.next = 11;
309
216
  return getFilesToAdd(selectedFiles);
310
217
 
311
218
  case 11:
312
- _context4.t0 = _context4.sent;
313
- _context4.next = 17;
219
+ _context2.t0 = _context2.sent;
220
+ _context2.next = 17;
314
221
  break;
315
222
 
316
223
  case 14:
317
- _context4.next = 16;
224
+ _context2.next = 16;
318
225
  return getFilesToAdd([selectedFiles[0]]);
319
226
 
320
227
  case 16:
321
- _context4.t0 = _context4.sent;
228
+ _context2.t0 = _context2.sent;
322
229
 
323
230
  case 17:
324
- fileToAdd = _context4.t0;
325
-
326
- if (typeof callbackFile === "function") {
327
- callbackFile(fileToAdd);
328
- }
231
+ fileToAdd = _context2.t0;
232
+ callbackFile === null || callbackFile === void 0 ? void 0 : callbackFile(fileToAdd);
329
233
 
330
234
  case 19:
331
235
  case "end":
332
- return _context4.stop();
236
+ return _context2.stop();
333
237
  }
334
238
  }
335
- }, _callee4);
239
+ }, _callee2);
336
240
  }));
337
241
 
338
- return function addFile(_x3) {
339
- return _ref5.apply(this, arguments);
242
+ return function addFile(_x2) {
243
+ return _ref3.apply(this, arguments);
340
244
  };
341
245
  }();
342
246
 
@@ -346,19 +250,21 @@ var DxcFileInput = function DxcFileInput(_ref) {
346
250
  return selectedFiles[key];
347
251
  });
348
252
  addFile(filesArray);
253
+ e.target.value = null;
349
254
  };
350
255
 
351
- var onDelete = function onDelete(fileName) {
256
+ var onDelete = (0, _react.useCallback)(function (fileName) {
352
257
  var filesCopy = (0, _toConsumableArray2["default"])(files);
353
258
  var fileToRemove = filesCopy.find(function (file) {
354
259
  return file.file.name === fileName;
355
260
  });
356
261
  var fileIndex = filesCopy.indexOf(fileToRemove);
357
262
  filesCopy.splice(fileIndex, 1);
263
+ callbackFile === null || callbackFile === void 0 ? void 0 : callbackFile(filesCopy);
264
+ }, [files, callbackFile]);
358
265
 
359
- if (typeof callbackFile === "function") {
360
- callbackFile(filesCopy);
361
- }
266
+ var handleClick = function handleClick() {
267
+ document.getElementById(fileInputId).click();
362
268
  };
363
269
 
364
270
  var handleDrag = function handleDrag(e) {
@@ -367,7 +273,9 @@ var DxcFileInput = function DxcFileInput(_ref) {
367
273
  };
368
274
 
369
275
  var handleDragIn = function handleDragIn(e) {
370
- if (e.dataTransfer.items && e.dataTransfer.items.length > 0) setIsDragging(true);
276
+ var _e$dataTransfer$items;
277
+
278
+ if (((_e$dataTransfer$items = e.dataTransfer.items) === null || _e$dataTransfer$items === void 0 ? void 0 : _e$dataTransfer$items.length) > 0) setIsDragging(true);
371
279
  };
372
280
 
373
281
  var handleDragOut = function handleDragOut(e) {
@@ -381,7 +289,7 @@ var DxcFileInput = function DxcFileInput(_ref) {
381
289
  setIsDragging(false);
382
290
  var filesObject = e.dataTransfer.files;
383
291
 
384
- if (filesObject && filesObject.length > 0) {
292
+ if ((filesObject === null || filesObject === void 0 ? void 0 : filesObject.length) > 0) {
385
293
  var filesArray = Object.keys(filesObject).map(function (key) {
386
294
  return filesObject[key];
387
295
  });
@@ -389,55 +297,124 @@ var DxcFileInput = function DxcFileInput(_ref) {
389
297
  }
390
298
  };
391
299
 
300
+ (0, _react.useEffect)(function () {
301
+ var getFiles = /*#__PURE__*/function () {
302
+ var _ref4 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee4() {
303
+ var valueFiles;
304
+ return _regenerator["default"].wrap(function _callee4$(_context4) {
305
+ while (1) {
306
+ switch (_context4.prev = _context4.next) {
307
+ case 0:
308
+ if (!value) {
309
+ _context4.next = 5;
310
+ break;
311
+ }
312
+
313
+ _context4.next = 3;
314
+ return Promise.all(value.map( /*#__PURE__*/function () {
315
+ var _ref5 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee3(file) {
316
+ var preview;
317
+ return _regenerator["default"].wrap(function _callee3$(_context3) {
318
+ while (1) {
319
+ switch (_context3.prev = _context3.next) {
320
+ case 0:
321
+ if (!file.preview) {
322
+ _context3.next = 4;
323
+ break;
324
+ }
325
+
326
+ return _context3.abrupt("return", file);
327
+
328
+ case 4:
329
+ _context3.next = 6;
330
+ return getFilePreview(file.file);
331
+
332
+ case 6:
333
+ preview = _context3.sent;
334
+ return _context3.abrupt("return", _objectSpread(_objectSpread({}, file), {}, {
335
+ preview: preview
336
+ }));
337
+
338
+ case 8:
339
+ case "end":
340
+ return _context3.stop();
341
+ }
342
+ }
343
+ }, _callee3);
344
+ }));
345
+
346
+ return function (_x3) {
347
+ return _ref5.apply(this, arguments);
348
+ };
349
+ }()));
350
+
351
+ case 3:
352
+ valueFiles = _context4.sent;
353
+ setFiles(valueFiles);
354
+
355
+ case 5:
356
+ case "end":
357
+ return _context4.stop();
358
+ }
359
+ }
360
+ }, _callee4);
361
+ }));
362
+
363
+ return function getFiles() {
364
+ return _ref4.apply(this, arguments);
365
+ };
366
+ }();
367
+
368
+ getFiles();
369
+ }, [value]);
392
370
  return /*#__PURE__*/_react["default"].createElement(_styledComponents.ThemeProvider, {
393
371
  theme: colorsTheme.fileInput
394
372
  }, /*#__PURE__*/_react["default"].createElement(FileInputContainer, {
395
373
  margin: margin,
396
- name: name
374
+ name: name,
375
+ ref: ref
397
376
  }, /*#__PURE__*/_react["default"].createElement(Label, {
398
377
  htmlFor: fileInputId,
399
378
  disabled: disabled
400
379
  }, label), /*#__PURE__*/_react["default"].createElement(HelperText, {
401
380
  disabled: disabled
402
381
  }, helperText), mode === "file" ? /*#__PURE__*/_react["default"].createElement(FileContainer, {
403
- multiple: multiple,
404
- files: files
405
- }, /*#__PURE__*/_react["default"].createElement(HiddenInputFile, {
382
+ singleFileMode: !multiple && files.length === 1
383
+ }, /*#__PURE__*/_react["default"].createElement(ValueInput, {
406
384
  id: fileInputId,
407
385
  type: "file",
408
386
  accept: accept,
409
387
  multiple: multiple,
410
- onChange: selectFiles
388
+ onChange: selectFiles,
389
+ disabled: disabled,
390
+ readOnly: true
411
391
  }), /*#__PURE__*/_react["default"].createElement(_Button["default"], {
412
392
  mode: "secondary",
413
- label: buttonLabel !== null && buttonLabel !== void 0 ? buttonLabel : multiple ? "Select files" : "Select file",
393
+ label: buttonLabel !== null && buttonLabel !== void 0 ? buttonLabel : multiple ? translatedLabels.fileInput.multipleButtonLabelDefault : translatedLabels.fileInput.singleButtonLabelDefault,
414
394
  onClick: handleClick,
415
395
  disabled: disabled,
416
- size: "medium",
396
+ size: "fitContent",
417
397
  tabIndex: tabIndex
418
- }), files.map(function (file) {
419
- return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement(FileItemContainer, {
420
- mode: mode,
421
- multiple: multiple,
422
- files: files
423
- }, /*#__PURE__*/_react["default"].createElement(_FileItem["default"], {
424
- mode: mode,
425
- multiple: multiple,
426
- name: file.file.name,
398
+ }), files.length > 0 && /*#__PURE__*/_react["default"].createElement(FileItemListContainer, null, files.map(function (file, index) {
399
+ return /*#__PURE__*/_react["default"].createElement(_FileItem["default"], {
400
+ fileName: file.file.name,
427
401
  error: file.error,
402
+ singleFileMode: !multiple && files.length === 1,
428
403
  showPreview: mode === "file" && !multiple ? false : showPreview,
429
- numFiles: files.length,
430
404
  preview: file.preview,
431
405
  type: file.file.type,
432
406
  onDelete: onDelete,
433
- tabIndex: tabIndex
434
- })));
435
- })) : /*#__PURE__*/_react["default"].createElement(Container, null, /*#__PURE__*/_react["default"].createElement(HiddenInputFile, {
407
+ tabIndex: tabIndex,
408
+ key: "file-".concat(index)
409
+ });
410
+ }))) : /*#__PURE__*/_react["default"].createElement(Container, null, /*#__PURE__*/_react["default"].createElement(ValueInput, {
436
411
  id: fileInputId,
437
412
  type: "file",
438
413
  accept: accept,
439
414
  multiple: multiple,
440
- onChange: selectFiles
415
+ onChange: selectFiles,
416
+ disabled: disabled,
417
+ readOnly: true
441
418
  }), /*#__PURE__*/_react["default"].createElement(DragDropArea, {
442
419
  isDragging: isDragging,
443
420
  disabled: disabled,
@@ -446,39 +423,30 @@ var DxcFileInput = function DxcFileInput(_ref) {
446
423
  onDragEnter: handleDragIn,
447
424
  onDragOver: handleDrag,
448
425
  onDragLeave: handleDragOut
449
- }, /*#__PURE__*/_react["default"].createElement(ButtonContainer, {
450
- mode: mode
451
426
  }, /*#__PURE__*/_react["default"].createElement(_Button["default"], {
452
427
  mode: "secondary",
453
- label: buttonLabel !== null && buttonLabel !== void 0 ? buttonLabel : "Select",
428
+ label: buttonLabel !== null && buttonLabel !== void 0 ? buttonLabel : translatedLabels.fileInput.dropAreaButtonLabelDefault,
454
429
  onClick: handleClick,
455
430
  disabled: disabled,
456
431
  size: "fitContent"
457
- })), mode === "dropzone" ? /*#__PURE__*/_react["default"].createElement(DropzoneLabel, {
432
+ }), mode === "dropzone" ? /*#__PURE__*/_react["default"].createElement(DropzoneLabel, {
458
433
  disabled: disabled
459
- }, dropAreaLabel !== null && dropAreaLabel !== void 0 ? dropAreaLabel : multiple ? "or drop files" : "or drop a file") : /*#__PURE__*/_react["default"].createElement(FiledropLabel, {
434
+ }, dropAreaLabel !== null && dropAreaLabel !== void 0 ? dropAreaLabel : multiple ? translatedLabels.fileInput.multipleDropAreaLabelDefault : translatedLabels.fileInput.singleDropAreaLabelDefault) : /*#__PURE__*/_react["default"].createElement(FiledropLabel, {
460
435
  disabled: disabled
461
- }, dropAreaLabel !== null && dropAreaLabel !== void 0 ? dropAreaLabel : multiple ? "or drop files" : "or drop a file")), files.map(function (file) {
462
- return /*#__PURE__*/_react["default"].createElement(FileItemContainer, {
463
- mode: mode,
464
- multiple: multiple,
465
- files: files
466
- }, /*#__PURE__*/_react["default"].createElement(_FileItem["default"], {
467
- mode: mode,
468
- multiple: multiple,
469
- name: file.file.name,
436
+ }, dropAreaLabel !== null && dropAreaLabel !== void 0 ? dropAreaLabel : multiple ? translatedLabels.fileInput.multipleDropAreaLabelDefault : translatedLabels.fileInput.singleDropAreaLabelDefault)), files.length > 0 && /*#__PURE__*/_react["default"].createElement(FileItemListContainer, null, files.map(function (file, index) {
437
+ return /*#__PURE__*/_react["default"].createElement(_FileItem["default"], {
438
+ fileName: file.file.name,
470
439
  error: file.error,
440
+ singleFileMode: false,
471
441
  showPreview: showPreview,
472
- numFiles: files.length,
473
442
  preview: file.preview,
474
443
  type: file.file.type,
475
444
  onDelete: onDelete,
476
- tabIndex: tabIndex
477
- }));
478
- })), files.length === 1 && files.map(function (file) {
479
- return file.error && mode === "file" && !multiple && /*#__PURE__*/_react["default"].createElement(ErrorMessage, null, file.error);
480
- })));
481
- };
445
+ tabIndex: tabIndex,
446
+ key: "file-".concat(index)
447
+ });
448
+ }))), mode === "file" && !multiple && files.length === 1 && files[0].error && /*#__PURE__*/_react["default"].createElement(ErrorMessage, null, files[0].error)));
449
+ });
482
450
 
483
451
  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) {
484
452
  return props.margin && (0, _typeof2["default"])(props.margin) !== "object" ? _variables.spaces[props.margin] : "0px";
@@ -516,12 +484,20 @@ var HelperText = _styledComponents["default"].span(_templateObject3 || (_templat
516
484
  return props.theme.helperTextLineHeight;
517
485
  });
518
486
 
519
- var DragDropArea = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n overflow: hidden;\n box-sizing: border-box;\n flex-direction: ", ";\n ", ";\n align-items: center;\n height: ", ";\n width: 320px;\n\n box-shadow: 0 0 0 2px transparent;\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n\n ", "\n\n cursor: ", ";\n"])), function (props) {
520
- return props.mode === "filedrop" ? "row" : "column";
521
- }, function (props) {
522
- return props.mode === "dropzone" && "justify-content: center; padding: 1rem;";
487
+ var FileContainer = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n ", "\n margin-top: 0.25rem;\n"])), function (props) {
488
+ return props.singleFileMode ? "flex-direction: row; column-gap: 0.25rem;" : "flex-direction: column; row-gap: 0.25rem;";
489
+ });
490
+
491
+ var ValueInput = _styledComponents["default"].input(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: none;\n"])));
492
+
493
+ var FileItemListContainer = _styledComponents["default"].div(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n row-gap: 0.25rem;\n"])));
494
+
495
+ var Container = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n row-gap: 0.25rem;\n margin-top: 0.25rem;\n"])));
496
+
497
+ var DragDropArea = _styledComponents["default"].div(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n box-sizing: border-box;\n display: flex;\n ", "\n align-items: center;\n width: 320px;\n padding: ", ";\n overflow: hidden;\n box-shadow: 0 0 0 2px transparent;\n border-radius: ", ";\n border-width: ", ";\n border-style: ", ";\n border-color: ", ";\n ", "\n cursor: ", ";\n"])), function (props) {
498
+ return props.mode === "filedrop" ? "flex-direction: row; column-gap: 0.75rem; height: 48px;" : "justify-content: center; flex-direction: column; row-gap: 0.5rem; height: 160px;";
523
499
  }, function (props) {
524
- return props.mode === "filedrop" ? "48px" : "160px";
500
+ return props.mode === "filedrop" ? "calc(4px - ".concat(props.theme.dropBorderThickness, ") 1rem calc(4px - ").concat(props.theme.dropBorderThickness, ") calc(4px - ").concat(props.theme.dropBorderThickness, ")") : "1rem";
525
501
  }, function (props) {
526
502
  return props.theme.dropBorderRadius;
527
503
  }, function (props) {
@@ -536,17 +512,7 @@ var DragDropArea = _styledComponents["default"].div(_templateObject4 || (_templa
536
512
  return props.disabled && "not-allowed";
537
513
  });
538
514
 
539
- var FileContainer = _styledComponents["default"].div(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: ", ";\n margin-top: 0.25rem;\n"])), function (props) {
540
- return props.multiple || props.files.length > 1 ? "column" : "row";
541
- });
542
-
543
- var HiddenInputFile = _styledComponents["default"].input(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n visibility: hidden;\n position: absolute;\n width: 0px;\n height: 0px;\n"])));
544
-
545
- var ButtonContainer = _styledComponents["default"].div(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n ", ";\n"])), function (props) {
546
- return props.mode === "filedrop" && "padding: 2px 12px 2px 3px";
547
- });
548
-
549
- var DropzoneLabel = _styledComponents["default"].div(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n display: -webkit-box;\n -webkit-box-orient: vertical;\n overflow: hidden;\n text-overflow: ellipsis;\n -webkit-line-clamp: 3;\n text-align: center;\n margin-top: 0.5rem;\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n"])), function (props) {
515
+ var DropzoneLabel = _styledComponents["default"].div(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n display: -webkit-box;\n -webkit-box-orient: vertical;\n overflow: hidden;\n text-overflow: ellipsis;\n -webkit-line-clamp: 3;\n text-align: center;\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n"])), function (props) {
550
516
  return props.disabled ? props.theme.disabledDropLabelFontColor : props.theme.dropLabelFontColor;
551
517
  }, function (props) {
552
518
  return props.theme.dropLabelFontFamily;
@@ -556,7 +522,7 @@ var DropzoneLabel = _styledComponents["default"].div(_templateObject8 || (_templ
556
522
  return props.theme.dropLabelFontWeight;
557
523
  });
558
524
 
559
- var FiledropLabel = _styledComponents["default"].span(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2["default"])(["\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n margin-right: 1rem;\n"])), function (props) {
525
+ var FiledropLabel = _styledComponents["default"].span(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2["default"])(["\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n"])), function (props) {
560
526
  return props.disabled ? props.theme.disabledDropLabelFontColor : props.theme.dropLabelFontColor;
561
527
  }, function (props) {
562
528
  return props.theme.dropLabelFontFamily;
@@ -566,15 +532,7 @@ var FiledropLabel = _styledComponents["default"].span(_templateObject9 || (_temp
566
532
  return props.theme.dropLabelFontWeight;
567
533
  });
568
534
 
569
- var Container = _styledComponents["default"].div(_templateObject10 || (_templateObject10 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n margin-top: 0.25rem;\n"])));
570
-
571
- var FileItemContainer = _styledComponents["default"].div(_templateObject11 || (_templateObject11 = (0, _taggedTemplateLiteral2["default"])(["\n margin-top: ", ";\n margin-left: ", ";\n"])), function (props) {
572
- return (props.multiple || props.files.length > 1 || props.mode !== "file") && "4px";
573
- }, function (props) {
574
- return props.mode === "file" && props.files.length === 1 && !props.multiple && "4px";
575
- });
576
-
577
- var ErrorMessage = _styledComponents["default"].div(_templateObject12 || (_templateObject12 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n font-family: ", ";\n font-size: ", ";\n font-weight: ", ";\n line-height: ", ";\n margin-top: 0.25rem;\n"])), function (props) {
535
+ 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 margin-top: 0.25rem;\n"])), function (props) {
578
536
  return props.theme.errorMessageFontColor;
579
537
  }, function (props) {
580
538
  return props.theme.errorMessageFontFamily;