@entur/fileupload 0.4.12 → 0.4.13-beta.0

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.
@@ -1,112 +1,2416 @@
1
- import { warnAboutMissingStyles } from '@entur/utils';
2
- import React from 'react';
3
- import { useDropzone } from 'react-dropzone';
4
- import classNames from 'classnames';
5
- import { FileIcon, DeleteIcon } from '@entur/icons';
6
- import { IconButton } from '@entur/button';
7
- import { Label } from '@entur/typography';
8
-
9
- function _extends() {
10
- return _extends = Object.assign ? Object.assign.bind() : function (n) {
11
- for (var e = 1; e < arguments.length; e++) {
12
- var t = arguments[e];
13
- for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]);
14
- }
15
- return n;
16
- }, _extends.apply(null, arguments);
17
- }
18
- function _objectWithoutPropertiesLoose(r, e) {
19
- if (null == r) return {};
20
- var t = {};
21
- for (var n in r) if ({}.hasOwnProperty.call(r, n)) {
22
- if (e.includes(n)) continue;
23
- t[n] = r[n];
24
- }
25
- return t;
26
- }
27
-
28
- var _excluded = ["standbyText", "errorText", "successText", "errorUpload", "onDrop", "onDelete", "accept", "files", "label", "removeFileButtonDescription", "style"];
29
- var FileUpload = function FileUpload(_ref) {
30
- var _ref$standbyText = _ref.standbyText,
31
- standbyText = _ref$standbyText === void 0 ? 'Dra fil eller klikk for å laste opp' : _ref$standbyText,
32
- _ref$errorText = _ref.errorText,
33
- errorText = _ref$errorText === void 0 ? 'Feil ved opplasting av fil' : _ref$errorText,
34
- _ref$successText = _ref.successText,
35
- successText = _ref$successText === void 0 ? 'Opplasting fullført' : _ref$successText,
36
- _ref$errorUpload = _ref.errorUpload,
37
- errorUpload = _ref$errorUpload === void 0 ? false : _ref$errorUpload,
38
- onDrop = _ref.onDrop,
39
- _ref$onDelete = _ref.onDelete,
40
- onDelete = _ref$onDelete === void 0 ? function (file) {
41
- return console.log(file);
42
- } : _ref$onDelete,
43
- _ref$accept = _ref.accept,
44
- accept = _ref$accept === void 0 ? '' : _ref$accept,
45
- _ref$files = _ref.files,
46
- files = _ref$files === void 0 ? [] : _ref$files,
47
- label = _ref.label,
48
- _ref$removeFileButton = _ref.removeFileButtonDescription,
49
- removeFileButtonDescription = _ref$removeFileButton === void 0 ? 'Fjern fil' : _ref$removeFileButton,
50
- style = _ref.style,
51
- rest = _objectWithoutPropertiesLoose(_ref, _excluded);
52
- var _useDropzone = useDropzone(_extends({
53
- onDrop: onDrop,
54
- accept: accept
55
- }, rest)),
56
- getRootProps = _useDropzone.getRootProps,
57
- getInputProps = _useDropzone.getInputProps,
58
- isDragActive = _useDropzone.isDragActive,
59
- isDragReject = _useDropzone.isDragReject;
60
- var success = files.length > 0;
61
- return React.createElement("div", _extends({
62
- className: "eds-file-upload__wrapper"
63
- }, style), React.createElement("div", _extends({
64
- className: "eds-file-upload__input"
65
- }, getRootProps()), label && React.createElement(Label, {
66
- style: {
67
- display: 'flex'
68
- }
69
- }, label), React.createElement("input", _extends({}, getInputProps())), React.createElement("span", {
70
- className: classNames('eds-file-upload__dropzone', {
71
- 'eds-file-upload__dropzone--success': success
72
- }, {
73
- 'eds-file-upload__dropzone--active': isDragActive
74
- }, {
75
- 'eds-file-upload__dropzone--reject': isDragReject
76
- }, {
77
- 'eds-file-upload__dropzone--error': errorUpload
78
- })
79
- }, success ? successText : errorUpload ? errorText : standbyText)), React.createElement("div", {
80
- className: "eds-file-upload__file-list"
81
- }, files.map(function (file, index) {
82
- return React.createElement("div", {
83
- className: "eds-file-upload__file-name",
84
- key: index
85
- }, React.createElement(FileIcon, {
86
- "aria-label": "File icon",
87
- className: "eds-file-upload__file-name-icon"
88
- }), React.createElement("span", {
89
- className: "eds-field-upload__file-name-path"
90
- }, file.name, " - ", convertSizeToHuman(file.size), ' '), React.createElement(IconButton, {
91
- onClick: function onClick() {
92
- return onDelete(file);
93
- },
94
- type: "button",
95
- "aria-label": removeFileButtonDescription + ", " + file.name
96
- }, React.createElement(DeleteIcon, null)));
1
+ import { warnAboutMissingStyles } from "@entur/utils";
2
+ import { jsxs, jsx } from "react/jsx-runtime";
3
+ import React, { useMemo, useRef, useReducer, useEffect, useCallback, forwardRef, useImperativeHandle, Fragment } from "react";
4
+ import { FileIcon, DeleteIcon } from "@entur/icons";
5
+ import { IconButton } from "@entur/button";
6
+ import { Label } from "@entur/typography";
7
+ function getDefaultExportFromCjs(x) {
8
+ return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, "default") ? x["default"] : x;
9
+ }
10
+ var propTypes = { exports: {} };
11
+ var reactIs = { exports: {} };
12
+ var reactIs_production_min = {};
13
+ /** @license React v16.13.1
14
+ * react-is.production.min.js
15
+ *
16
+ * Copyright (c) Facebook, Inc. and its affiliates.
17
+ *
18
+ * This source code is licensed under the MIT license found in the
19
+ * LICENSE file in the root directory of this source tree.
20
+ */
21
+ var hasRequiredReactIs_production_min;
22
+ function requireReactIs_production_min() {
23
+ if (hasRequiredReactIs_production_min) return reactIs_production_min;
24
+ hasRequiredReactIs_production_min = 1;
25
+ var b = "function" === typeof Symbol && Symbol.for, c = b ? Symbol.for("react.element") : 60103, d = b ? Symbol.for("react.portal") : 60106, e = b ? Symbol.for("react.fragment") : 60107, f = b ? Symbol.for("react.strict_mode") : 60108, g = b ? Symbol.for("react.profiler") : 60114, h = b ? Symbol.for("react.provider") : 60109, k = b ? Symbol.for("react.context") : 60110, l = b ? Symbol.for("react.async_mode") : 60111, m = b ? Symbol.for("react.concurrent_mode") : 60111, n = b ? Symbol.for("react.forward_ref") : 60112, p = b ? Symbol.for("react.suspense") : 60113, q = b ? Symbol.for("react.suspense_list") : 60120, r = b ? Symbol.for("react.memo") : 60115, t = b ? Symbol.for("react.lazy") : 60116, v = b ? Symbol.for("react.block") : 60121, w = b ? Symbol.for("react.fundamental") : 60117, x = b ? Symbol.for("react.responder") : 60118, y = b ? Symbol.for("react.scope") : 60119;
26
+ function z(a) {
27
+ if ("object" === typeof a && null !== a) {
28
+ var u = a.$$typeof;
29
+ switch (u) {
30
+ case c:
31
+ switch (a = a.type, a) {
32
+ case l:
33
+ case m:
34
+ case e:
35
+ case g:
36
+ case f:
37
+ case p:
38
+ return a;
39
+ default:
40
+ switch (a = a && a.$$typeof, a) {
41
+ case k:
42
+ case n:
43
+ case t:
44
+ case r:
45
+ case h:
46
+ return a;
47
+ default:
48
+ return u;
49
+ }
50
+ }
51
+ case d:
52
+ return u;
53
+ }
54
+ }
55
+ }
56
+ function A(a) {
57
+ return z(a) === m;
58
+ }
59
+ reactIs_production_min.AsyncMode = l;
60
+ reactIs_production_min.ConcurrentMode = m;
61
+ reactIs_production_min.ContextConsumer = k;
62
+ reactIs_production_min.ContextProvider = h;
63
+ reactIs_production_min.Element = c;
64
+ reactIs_production_min.ForwardRef = n;
65
+ reactIs_production_min.Fragment = e;
66
+ reactIs_production_min.Lazy = t;
67
+ reactIs_production_min.Memo = r;
68
+ reactIs_production_min.Portal = d;
69
+ reactIs_production_min.Profiler = g;
70
+ reactIs_production_min.StrictMode = f;
71
+ reactIs_production_min.Suspense = p;
72
+ reactIs_production_min.isAsyncMode = function(a) {
73
+ return A(a) || z(a) === l;
74
+ };
75
+ reactIs_production_min.isConcurrentMode = A;
76
+ reactIs_production_min.isContextConsumer = function(a) {
77
+ return z(a) === k;
78
+ };
79
+ reactIs_production_min.isContextProvider = function(a) {
80
+ return z(a) === h;
81
+ };
82
+ reactIs_production_min.isElement = function(a) {
83
+ return "object" === typeof a && null !== a && a.$$typeof === c;
84
+ };
85
+ reactIs_production_min.isForwardRef = function(a) {
86
+ return z(a) === n;
87
+ };
88
+ reactIs_production_min.isFragment = function(a) {
89
+ return z(a) === e;
90
+ };
91
+ reactIs_production_min.isLazy = function(a) {
92
+ return z(a) === t;
93
+ };
94
+ reactIs_production_min.isMemo = function(a) {
95
+ return z(a) === r;
96
+ };
97
+ reactIs_production_min.isPortal = function(a) {
98
+ return z(a) === d;
99
+ };
100
+ reactIs_production_min.isProfiler = function(a) {
101
+ return z(a) === g;
102
+ };
103
+ reactIs_production_min.isStrictMode = function(a) {
104
+ return z(a) === f;
105
+ };
106
+ reactIs_production_min.isSuspense = function(a) {
107
+ return z(a) === p;
108
+ };
109
+ reactIs_production_min.isValidElementType = function(a) {
110
+ return "string" === typeof a || "function" === typeof a || a === e || a === m || a === g || a === f || a === p || a === q || "object" === typeof a && null !== a && (a.$$typeof === t || a.$$typeof === r || a.$$typeof === h || a.$$typeof === k || a.$$typeof === n || a.$$typeof === w || a.$$typeof === x || a.$$typeof === y || a.$$typeof === v);
111
+ };
112
+ reactIs_production_min.typeOf = z;
113
+ return reactIs_production_min;
114
+ }
115
+ var reactIs_development = {};
116
+ /** @license React v16.13.1
117
+ * react-is.development.js
118
+ *
119
+ * Copyright (c) Facebook, Inc. and its affiliates.
120
+ *
121
+ * This source code is licensed under the MIT license found in the
122
+ * LICENSE file in the root directory of this source tree.
123
+ */
124
+ var hasRequiredReactIs_development;
125
+ function requireReactIs_development() {
126
+ if (hasRequiredReactIs_development) return reactIs_development;
127
+ hasRequiredReactIs_development = 1;
128
+ if (process.env.NODE_ENV !== "production") {
129
+ (function() {
130
+ var hasSymbol = typeof Symbol === "function" && Symbol.for;
131
+ var REACT_ELEMENT_TYPE = hasSymbol ? Symbol.for("react.element") : 60103;
132
+ var REACT_PORTAL_TYPE = hasSymbol ? Symbol.for("react.portal") : 60106;
133
+ var REACT_FRAGMENT_TYPE = hasSymbol ? Symbol.for("react.fragment") : 60107;
134
+ var REACT_STRICT_MODE_TYPE = hasSymbol ? Symbol.for("react.strict_mode") : 60108;
135
+ var REACT_PROFILER_TYPE = hasSymbol ? Symbol.for("react.profiler") : 60114;
136
+ var REACT_PROVIDER_TYPE = hasSymbol ? Symbol.for("react.provider") : 60109;
137
+ var REACT_CONTEXT_TYPE = hasSymbol ? Symbol.for("react.context") : 60110;
138
+ var REACT_ASYNC_MODE_TYPE = hasSymbol ? Symbol.for("react.async_mode") : 60111;
139
+ var REACT_CONCURRENT_MODE_TYPE = hasSymbol ? Symbol.for("react.concurrent_mode") : 60111;
140
+ var REACT_FORWARD_REF_TYPE = hasSymbol ? Symbol.for("react.forward_ref") : 60112;
141
+ var REACT_SUSPENSE_TYPE = hasSymbol ? Symbol.for("react.suspense") : 60113;
142
+ var REACT_SUSPENSE_LIST_TYPE = hasSymbol ? Symbol.for("react.suspense_list") : 60120;
143
+ var REACT_MEMO_TYPE = hasSymbol ? Symbol.for("react.memo") : 60115;
144
+ var REACT_LAZY_TYPE = hasSymbol ? Symbol.for("react.lazy") : 60116;
145
+ var REACT_BLOCK_TYPE = hasSymbol ? Symbol.for("react.block") : 60121;
146
+ var REACT_FUNDAMENTAL_TYPE = hasSymbol ? Symbol.for("react.fundamental") : 60117;
147
+ var REACT_RESPONDER_TYPE = hasSymbol ? Symbol.for("react.responder") : 60118;
148
+ var REACT_SCOPE_TYPE = hasSymbol ? Symbol.for("react.scope") : 60119;
149
+ function isValidElementType(type) {
150
+ return typeof type === "string" || typeof type === "function" || // Note: its typeof might be other than 'symbol' or 'number' if it's a polyfill.
151
+ type === REACT_FRAGMENT_TYPE || type === REACT_CONCURRENT_MODE_TYPE || type === REACT_PROFILER_TYPE || type === REACT_STRICT_MODE_TYPE || type === REACT_SUSPENSE_TYPE || type === REACT_SUSPENSE_LIST_TYPE || typeof type === "object" && type !== null && (type.$$typeof === REACT_LAZY_TYPE || type.$$typeof === REACT_MEMO_TYPE || type.$$typeof === REACT_PROVIDER_TYPE || type.$$typeof === REACT_CONTEXT_TYPE || type.$$typeof === REACT_FORWARD_REF_TYPE || type.$$typeof === REACT_FUNDAMENTAL_TYPE || type.$$typeof === REACT_RESPONDER_TYPE || type.$$typeof === REACT_SCOPE_TYPE || type.$$typeof === REACT_BLOCK_TYPE);
152
+ }
153
+ function typeOf(object) {
154
+ if (typeof object === "object" && object !== null) {
155
+ var $$typeof = object.$$typeof;
156
+ switch ($$typeof) {
157
+ case REACT_ELEMENT_TYPE:
158
+ var type = object.type;
159
+ switch (type) {
160
+ case REACT_ASYNC_MODE_TYPE:
161
+ case REACT_CONCURRENT_MODE_TYPE:
162
+ case REACT_FRAGMENT_TYPE:
163
+ case REACT_PROFILER_TYPE:
164
+ case REACT_STRICT_MODE_TYPE:
165
+ case REACT_SUSPENSE_TYPE:
166
+ return type;
167
+ default:
168
+ var $$typeofType = type && type.$$typeof;
169
+ switch ($$typeofType) {
170
+ case REACT_CONTEXT_TYPE:
171
+ case REACT_FORWARD_REF_TYPE:
172
+ case REACT_LAZY_TYPE:
173
+ case REACT_MEMO_TYPE:
174
+ case REACT_PROVIDER_TYPE:
175
+ return $$typeofType;
176
+ default:
177
+ return $$typeof;
178
+ }
179
+ }
180
+ case REACT_PORTAL_TYPE:
181
+ return $$typeof;
182
+ }
183
+ }
184
+ return void 0;
185
+ }
186
+ var AsyncMode = REACT_ASYNC_MODE_TYPE;
187
+ var ConcurrentMode = REACT_CONCURRENT_MODE_TYPE;
188
+ var ContextConsumer = REACT_CONTEXT_TYPE;
189
+ var ContextProvider = REACT_PROVIDER_TYPE;
190
+ var Element = REACT_ELEMENT_TYPE;
191
+ var ForwardRef = REACT_FORWARD_REF_TYPE;
192
+ var Fragment2 = REACT_FRAGMENT_TYPE;
193
+ var Lazy = REACT_LAZY_TYPE;
194
+ var Memo = REACT_MEMO_TYPE;
195
+ var Portal = REACT_PORTAL_TYPE;
196
+ var Profiler = REACT_PROFILER_TYPE;
197
+ var StrictMode = REACT_STRICT_MODE_TYPE;
198
+ var Suspense = REACT_SUSPENSE_TYPE;
199
+ var hasWarnedAboutDeprecatedIsAsyncMode = false;
200
+ function isAsyncMode(object) {
201
+ {
202
+ if (!hasWarnedAboutDeprecatedIsAsyncMode) {
203
+ hasWarnedAboutDeprecatedIsAsyncMode = true;
204
+ console["warn"]("The ReactIs.isAsyncMode() alias has been deprecated, and will be removed in React 17+. Update your code to use ReactIs.isConcurrentMode() instead. It has the exact same API.");
205
+ }
206
+ }
207
+ return isConcurrentMode(object) || typeOf(object) === REACT_ASYNC_MODE_TYPE;
208
+ }
209
+ function isConcurrentMode(object) {
210
+ return typeOf(object) === REACT_CONCURRENT_MODE_TYPE;
211
+ }
212
+ function isContextConsumer(object) {
213
+ return typeOf(object) === REACT_CONTEXT_TYPE;
214
+ }
215
+ function isContextProvider(object) {
216
+ return typeOf(object) === REACT_PROVIDER_TYPE;
217
+ }
218
+ function isElement(object) {
219
+ return typeof object === "object" && object !== null && object.$$typeof === REACT_ELEMENT_TYPE;
220
+ }
221
+ function isForwardRef(object) {
222
+ return typeOf(object) === REACT_FORWARD_REF_TYPE;
223
+ }
224
+ function isFragment(object) {
225
+ return typeOf(object) === REACT_FRAGMENT_TYPE;
226
+ }
227
+ function isLazy(object) {
228
+ return typeOf(object) === REACT_LAZY_TYPE;
229
+ }
230
+ function isMemo(object) {
231
+ return typeOf(object) === REACT_MEMO_TYPE;
232
+ }
233
+ function isPortal(object) {
234
+ return typeOf(object) === REACT_PORTAL_TYPE;
235
+ }
236
+ function isProfiler(object) {
237
+ return typeOf(object) === REACT_PROFILER_TYPE;
238
+ }
239
+ function isStrictMode(object) {
240
+ return typeOf(object) === REACT_STRICT_MODE_TYPE;
241
+ }
242
+ function isSuspense(object) {
243
+ return typeOf(object) === REACT_SUSPENSE_TYPE;
244
+ }
245
+ reactIs_development.AsyncMode = AsyncMode;
246
+ reactIs_development.ConcurrentMode = ConcurrentMode;
247
+ reactIs_development.ContextConsumer = ContextConsumer;
248
+ reactIs_development.ContextProvider = ContextProvider;
249
+ reactIs_development.Element = Element;
250
+ reactIs_development.ForwardRef = ForwardRef;
251
+ reactIs_development.Fragment = Fragment2;
252
+ reactIs_development.Lazy = Lazy;
253
+ reactIs_development.Memo = Memo;
254
+ reactIs_development.Portal = Portal;
255
+ reactIs_development.Profiler = Profiler;
256
+ reactIs_development.StrictMode = StrictMode;
257
+ reactIs_development.Suspense = Suspense;
258
+ reactIs_development.isAsyncMode = isAsyncMode;
259
+ reactIs_development.isConcurrentMode = isConcurrentMode;
260
+ reactIs_development.isContextConsumer = isContextConsumer;
261
+ reactIs_development.isContextProvider = isContextProvider;
262
+ reactIs_development.isElement = isElement;
263
+ reactIs_development.isForwardRef = isForwardRef;
264
+ reactIs_development.isFragment = isFragment;
265
+ reactIs_development.isLazy = isLazy;
266
+ reactIs_development.isMemo = isMemo;
267
+ reactIs_development.isPortal = isPortal;
268
+ reactIs_development.isProfiler = isProfiler;
269
+ reactIs_development.isStrictMode = isStrictMode;
270
+ reactIs_development.isSuspense = isSuspense;
271
+ reactIs_development.isValidElementType = isValidElementType;
272
+ reactIs_development.typeOf = typeOf;
273
+ })();
274
+ }
275
+ return reactIs_development;
276
+ }
277
+ var hasRequiredReactIs;
278
+ function requireReactIs() {
279
+ if (hasRequiredReactIs) return reactIs.exports;
280
+ hasRequiredReactIs = 1;
281
+ if (process.env.NODE_ENV === "production") {
282
+ reactIs.exports = requireReactIs_production_min();
283
+ } else {
284
+ reactIs.exports = requireReactIs_development();
285
+ }
286
+ return reactIs.exports;
287
+ }
288
+ /*
289
+ object-assign
290
+ (c) Sindre Sorhus
291
+ @license MIT
292
+ */
293
+ var objectAssign;
294
+ var hasRequiredObjectAssign;
295
+ function requireObjectAssign() {
296
+ if (hasRequiredObjectAssign) return objectAssign;
297
+ hasRequiredObjectAssign = 1;
298
+ var getOwnPropertySymbols = Object.getOwnPropertySymbols;
299
+ var hasOwnProperty = Object.prototype.hasOwnProperty;
300
+ var propIsEnumerable = Object.prototype.propertyIsEnumerable;
301
+ function toObject(val) {
302
+ if (val === null || val === void 0) {
303
+ throw new TypeError("Object.assign cannot be called with null or undefined");
304
+ }
305
+ return Object(val);
306
+ }
307
+ function shouldUseNative() {
308
+ try {
309
+ if (!Object.assign) {
310
+ return false;
311
+ }
312
+ var test1 = new String("abc");
313
+ test1[5] = "de";
314
+ if (Object.getOwnPropertyNames(test1)[0] === "5") {
315
+ return false;
316
+ }
317
+ var test2 = {};
318
+ for (var i = 0; i < 10; i++) {
319
+ test2["_" + String.fromCharCode(i)] = i;
320
+ }
321
+ var order2 = Object.getOwnPropertyNames(test2).map(function(n) {
322
+ return test2[n];
323
+ });
324
+ if (order2.join("") !== "0123456789") {
325
+ return false;
326
+ }
327
+ var test3 = {};
328
+ "abcdefghijklmnopqrst".split("").forEach(function(letter) {
329
+ test3[letter] = letter;
330
+ });
331
+ if (Object.keys(Object.assign({}, test3)).join("") !== "abcdefghijklmnopqrst") {
332
+ return false;
333
+ }
334
+ return true;
335
+ } catch (err) {
336
+ return false;
337
+ }
338
+ }
339
+ objectAssign = shouldUseNative() ? Object.assign : function(target, source) {
340
+ var from;
341
+ var to = toObject(target);
342
+ var symbols;
343
+ for (var s = 1; s < arguments.length; s++) {
344
+ from = Object(arguments[s]);
345
+ for (var key in from) {
346
+ if (hasOwnProperty.call(from, key)) {
347
+ to[key] = from[key];
348
+ }
349
+ }
350
+ if (getOwnPropertySymbols) {
351
+ symbols = getOwnPropertySymbols(from);
352
+ for (var i = 0; i < symbols.length; i++) {
353
+ if (propIsEnumerable.call(from, symbols[i])) {
354
+ to[symbols[i]] = from[symbols[i]];
355
+ }
356
+ }
357
+ }
358
+ }
359
+ return to;
360
+ };
361
+ return objectAssign;
362
+ }
363
+ var ReactPropTypesSecret_1;
364
+ var hasRequiredReactPropTypesSecret;
365
+ function requireReactPropTypesSecret() {
366
+ if (hasRequiredReactPropTypesSecret) return ReactPropTypesSecret_1;
367
+ hasRequiredReactPropTypesSecret = 1;
368
+ var ReactPropTypesSecret = "SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED";
369
+ ReactPropTypesSecret_1 = ReactPropTypesSecret;
370
+ return ReactPropTypesSecret_1;
371
+ }
372
+ var has;
373
+ var hasRequiredHas;
374
+ function requireHas() {
375
+ if (hasRequiredHas) return has;
376
+ hasRequiredHas = 1;
377
+ has = Function.call.bind(Object.prototype.hasOwnProperty);
378
+ return has;
379
+ }
380
+ var checkPropTypes_1;
381
+ var hasRequiredCheckPropTypes;
382
+ function requireCheckPropTypes() {
383
+ if (hasRequiredCheckPropTypes) return checkPropTypes_1;
384
+ hasRequiredCheckPropTypes = 1;
385
+ var printWarning = function() {
386
+ };
387
+ if (process.env.NODE_ENV !== "production") {
388
+ var ReactPropTypesSecret = /* @__PURE__ */ requireReactPropTypesSecret();
389
+ var loggedTypeFailures = {};
390
+ var has2 = /* @__PURE__ */ requireHas();
391
+ printWarning = function(text) {
392
+ var message = "Warning: " + text;
393
+ if (typeof console !== "undefined") {
394
+ console.error(message);
395
+ }
396
+ try {
397
+ throw new Error(message);
398
+ } catch (x) {
399
+ }
400
+ };
401
+ }
402
+ function checkPropTypes(typeSpecs, values, location, componentName, getStack) {
403
+ if (process.env.NODE_ENV !== "production") {
404
+ for (var typeSpecName in typeSpecs) {
405
+ if (has2(typeSpecs, typeSpecName)) {
406
+ var error;
407
+ try {
408
+ if (typeof typeSpecs[typeSpecName] !== "function") {
409
+ var err = Error(
410
+ (componentName || "React class") + ": " + location + " type `" + typeSpecName + "` is invalid; it must be a function, usually from the `prop-types` package, but received `" + typeof typeSpecs[typeSpecName] + "`.This often happens because of typos such as `PropTypes.function` instead of `PropTypes.func`."
411
+ );
412
+ err.name = "Invariant Violation";
413
+ throw err;
414
+ }
415
+ error = typeSpecs[typeSpecName](values, typeSpecName, componentName, location, null, ReactPropTypesSecret);
416
+ } catch (ex) {
417
+ error = ex;
418
+ }
419
+ if (error && !(error instanceof Error)) {
420
+ printWarning(
421
+ (componentName || "React class") + ": type specification of " + location + " `" + typeSpecName + "` is invalid; the type checker function must return `null` or an `Error` but returned a " + typeof error + ". You may have forgotten to pass an argument to the type checker creator (arrayOf, instanceOf, objectOf, oneOf, oneOfType, and shape all require an argument)."
422
+ );
423
+ }
424
+ if (error instanceof Error && !(error.message in loggedTypeFailures)) {
425
+ loggedTypeFailures[error.message] = true;
426
+ var stack = getStack ? getStack() : "";
427
+ printWarning(
428
+ "Failed " + location + " type: " + error.message + (stack != null ? stack : "")
429
+ );
430
+ }
431
+ }
432
+ }
433
+ }
434
+ }
435
+ checkPropTypes.resetWarningCache = function() {
436
+ if (process.env.NODE_ENV !== "production") {
437
+ loggedTypeFailures = {};
438
+ }
439
+ };
440
+ checkPropTypes_1 = checkPropTypes;
441
+ return checkPropTypes_1;
442
+ }
443
+ var factoryWithTypeCheckers;
444
+ var hasRequiredFactoryWithTypeCheckers;
445
+ function requireFactoryWithTypeCheckers() {
446
+ if (hasRequiredFactoryWithTypeCheckers) return factoryWithTypeCheckers;
447
+ hasRequiredFactoryWithTypeCheckers = 1;
448
+ var ReactIs = requireReactIs();
449
+ var assign = requireObjectAssign();
450
+ var ReactPropTypesSecret = /* @__PURE__ */ requireReactPropTypesSecret();
451
+ var has2 = /* @__PURE__ */ requireHas();
452
+ var checkPropTypes = /* @__PURE__ */ requireCheckPropTypes();
453
+ var printWarning = function() {
454
+ };
455
+ if (process.env.NODE_ENV !== "production") {
456
+ printWarning = function(text) {
457
+ var message = "Warning: " + text;
458
+ if (typeof console !== "undefined") {
459
+ console.error(message);
460
+ }
461
+ try {
462
+ throw new Error(message);
463
+ } catch (x) {
464
+ }
465
+ };
466
+ }
467
+ function emptyFunctionThatReturnsNull() {
468
+ return null;
469
+ }
470
+ factoryWithTypeCheckers = function(isValidElement, throwOnDirectAccess) {
471
+ var ITERATOR_SYMBOL = typeof Symbol === "function" && Symbol.iterator;
472
+ var FAUX_ITERATOR_SYMBOL = "@@iterator";
473
+ function getIteratorFn(maybeIterable) {
474
+ var iteratorFn = maybeIterable && (ITERATOR_SYMBOL && maybeIterable[ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL]);
475
+ if (typeof iteratorFn === "function") {
476
+ return iteratorFn;
477
+ }
478
+ }
479
+ var ANONYMOUS = "<<anonymous>>";
480
+ var ReactPropTypes = {
481
+ array: createPrimitiveTypeChecker("array"),
482
+ bigint: createPrimitiveTypeChecker("bigint"),
483
+ bool: createPrimitiveTypeChecker("boolean"),
484
+ func: createPrimitiveTypeChecker("function"),
485
+ number: createPrimitiveTypeChecker("number"),
486
+ object: createPrimitiveTypeChecker("object"),
487
+ string: createPrimitiveTypeChecker("string"),
488
+ symbol: createPrimitiveTypeChecker("symbol"),
489
+ any: createAnyTypeChecker(),
490
+ arrayOf: createArrayOfTypeChecker,
491
+ element: createElementTypeChecker(),
492
+ elementType: createElementTypeTypeChecker(),
493
+ instanceOf: createInstanceTypeChecker,
494
+ node: createNodeChecker(),
495
+ objectOf: createObjectOfTypeChecker,
496
+ oneOf: createEnumTypeChecker,
497
+ oneOfType: createUnionTypeChecker,
498
+ shape: createShapeTypeChecker,
499
+ exact: createStrictShapeTypeChecker
500
+ };
501
+ function is(x, y) {
502
+ if (x === y) {
503
+ return x !== 0 || 1 / x === 1 / y;
504
+ } else {
505
+ return x !== x && y !== y;
506
+ }
507
+ }
508
+ function PropTypeError(message, data) {
509
+ this.message = message;
510
+ this.data = data && typeof data === "object" ? data : {};
511
+ this.stack = "";
512
+ }
513
+ PropTypeError.prototype = Error.prototype;
514
+ function createChainableTypeChecker(validate) {
515
+ if (process.env.NODE_ENV !== "production") {
516
+ var manualPropTypeCallCache = {};
517
+ var manualPropTypeWarningCount = 0;
518
+ }
519
+ function checkType(isRequired, props, propName, componentName, location, propFullName, secret) {
520
+ componentName = componentName || ANONYMOUS;
521
+ propFullName = propFullName || propName;
522
+ if (secret !== ReactPropTypesSecret) {
523
+ if (throwOnDirectAccess) {
524
+ var err = new Error(
525
+ "Calling PropTypes validators directly is not supported by the `prop-types` package. Use `PropTypes.checkPropTypes()` to call them. Read more at http://fb.me/use-check-prop-types"
526
+ );
527
+ err.name = "Invariant Violation";
528
+ throw err;
529
+ } else if (process.env.NODE_ENV !== "production" && typeof console !== "undefined") {
530
+ var cacheKey = componentName + ":" + propName;
531
+ if (!manualPropTypeCallCache[cacheKey] && // Avoid spamming the console because they are often not actionable except for lib authors
532
+ manualPropTypeWarningCount < 3) {
533
+ printWarning(
534
+ "You are manually calling a React.PropTypes validation function for the `" + propFullName + "` prop on `" + componentName + "`. This is deprecated and will throw in the standalone `prop-types` package. You may be seeing this warning due to a third-party PropTypes library. See https://fb.me/react-warning-dont-call-proptypes for details."
535
+ );
536
+ manualPropTypeCallCache[cacheKey] = true;
537
+ manualPropTypeWarningCount++;
538
+ }
539
+ }
540
+ }
541
+ if (props[propName] == null) {
542
+ if (isRequired) {
543
+ if (props[propName] === null) {
544
+ return new PropTypeError("The " + location + " `" + propFullName + "` is marked as required " + ("in `" + componentName + "`, but its value is `null`."));
545
+ }
546
+ return new PropTypeError("The " + location + " `" + propFullName + "` is marked as required in " + ("`" + componentName + "`, but its value is `undefined`."));
547
+ }
548
+ return null;
549
+ } else {
550
+ return validate(props, propName, componentName, location, propFullName);
551
+ }
552
+ }
553
+ var chainedCheckType = checkType.bind(null, false);
554
+ chainedCheckType.isRequired = checkType.bind(null, true);
555
+ return chainedCheckType;
556
+ }
557
+ function createPrimitiveTypeChecker(expectedType) {
558
+ function validate(props, propName, componentName, location, propFullName, secret) {
559
+ var propValue = props[propName];
560
+ var propType = getPropType(propValue);
561
+ if (propType !== expectedType) {
562
+ var preciseType = getPreciseType(propValue);
563
+ return new PropTypeError(
564
+ "Invalid " + location + " `" + propFullName + "` of type " + ("`" + preciseType + "` supplied to `" + componentName + "`, expected ") + ("`" + expectedType + "`."),
565
+ { expectedType }
566
+ );
567
+ }
568
+ return null;
569
+ }
570
+ return createChainableTypeChecker(validate);
571
+ }
572
+ function createAnyTypeChecker() {
573
+ return createChainableTypeChecker(emptyFunctionThatReturnsNull);
574
+ }
575
+ function createArrayOfTypeChecker(typeChecker) {
576
+ function validate(props, propName, componentName, location, propFullName) {
577
+ if (typeof typeChecker !== "function") {
578
+ return new PropTypeError("Property `" + propFullName + "` of component `" + componentName + "` has invalid PropType notation inside arrayOf.");
579
+ }
580
+ var propValue = props[propName];
581
+ if (!Array.isArray(propValue)) {
582
+ var propType = getPropType(propValue);
583
+ return new PropTypeError("Invalid " + location + " `" + propFullName + "` of type " + ("`" + propType + "` supplied to `" + componentName + "`, expected an array."));
584
+ }
585
+ for (var i = 0; i < propValue.length; i++) {
586
+ var error = typeChecker(propValue, i, componentName, location, propFullName + "[" + i + "]", ReactPropTypesSecret);
587
+ if (error instanceof Error) {
588
+ return error;
589
+ }
590
+ }
591
+ return null;
592
+ }
593
+ return createChainableTypeChecker(validate);
594
+ }
595
+ function createElementTypeChecker() {
596
+ function validate(props, propName, componentName, location, propFullName) {
597
+ var propValue = props[propName];
598
+ if (!isValidElement(propValue)) {
599
+ var propType = getPropType(propValue);
600
+ return new PropTypeError("Invalid " + location + " `" + propFullName + "` of type " + ("`" + propType + "` supplied to `" + componentName + "`, expected a single ReactElement."));
601
+ }
602
+ return null;
603
+ }
604
+ return createChainableTypeChecker(validate);
605
+ }
606
+ function createElementTypeTypeChecker() {
607
+ function validate(props, propName, componentName, location, propFullName) {
608
+ var propValue = props[propName];
609
+ if (!ReactIs.isValidElementType(propValue)) {
610
+ var propType = getPropType(propValue);
611
+ return new PropTypeError("Invalid " + location + " `" + propFullName + "` of type " + ("`" + propType + "` supplied to `" + componentName + "`, expected a single ReactElement type."));
612
+ }
613
+ return null;
614
+ }
615
+ return createChainableTypeChecker(validate);
616
+ }
617
+ function createInstanceTypeChecker(expectedClass) {
618
+ function validate(props, propName, componentName, location, propFullName) {
619
+ if (!(props[propName] instanceof expectedClass)) {
620
+ var expectedClassName = expectedClass.name || ANONYMOUS;
621
+ var actualClassName = getClassName(props[propName]);
622
+ return new PropTypeError("Invalid " + location + " `" + propFullName + "` of type " + ("`" + actualClassName + "` supplied to `" + componentName + "`, expected ") + ("instance of `" + expectedClassName + "`."));
623
+ }
624
+ return null;
625
+ }
626
+ return createChainableTypeChecker(validate);
627
+ }
628
+ function createEnumTypeChecker(expectedValues) {
629
+ if (!Array.isArray(expectedValues)) {
630
+ if (process.env.NODE_ENV !== "production") {
631
+ if (arguments.length > 1) {
632
+ printWarning(
633
+ "Invalid arguments supplied to oneOf, expected an array, got " + arguments.length + " arguments. A common mistake is to write oneOf(x, y, z) instead of oneOf([x, y, z])."
634
+ );
635
+ } else {
636
+ printWarning("Invalid argument supplied to oneOf, expected an array.");
637
+ }
638
+ }
639
+ return emptyFunctionThatReturnsNull;
640
+ }
641
+ function validate(props, propName, componentName, location, propFullName) {
642
+ var propValue = props[propName];
643
+ for (var i = 0; i < expectedValues.length; i++) {
644
+ if (is(propValue, expectedValues[i])) {
645
+ return null;
646
+ }
647
+ }
648
+ var valuesString = JSON.stringify(expectedValues, function replacer(key, value) {
649
+ var type = getPreciseType(value);
650
+ if (type === "symbol") {
651
+ return String(value);
652
+ }
653
+ return value;
654
+ });
655
+ return new PropTypeError("Invalid " + location + " `" + propFullName + "` of value `" + String(propValue) + "` " + ("supplied to `" + componentName + "`, expected one of " + valuesString + "."));
656
+ }
657
+ return createChainableTypeChecker(validate);
658
+ }
659
+ function createObjectOfTypeChecker(typeChecker) {
660
+ function validate(props, propName, componentName, location, propFullName) {
661
+ if (typeof typeChecker !== "function") {
662
+ return new PropTypeError("Property `" + propFullName + "` of component `" + componentName + "` has invalid PropType notation inside objectOf.");
663
+ }
664
+ var propValue = props[propName];
665
+ var propType = getPropType(propValue);
666
+ if (propType !== "object") {
667
+ return new PropTypeError("Invalid " + location + " `" + propFullName + "` of type " + ("`" + propType + "` supplied to `" + componentName + "`, expected an object."));
668
+ }
669
+ for (var key in propValue) {
670
+ if (has2(propValue, key)) {
671
+ var error = typeChecker(propValue, key, componentName, location, propFullName + "." + key, ReactPropTypesSecret);
672
+ if (error instanceof Error) {
673
+ return error;
674
+ }
675
+ }
676
+ }
677
+ return null;
678
+ }
679
+ return createChainableTypeChecker(validate);
680
+ }
681
+ function createUnionTypeChecker(arrayOfTypeCheckers) {
682
+ if (!Array.isArray(arrayOfTypeCheckers)) {
683
+ process.env.NODE_ENV !== "production" ? printWarning("Invalid argument supplied to oneOfType, expected an instance of array.") : void 0;
684
+ return emptyFunctionThatReturnsNull;
685
+ }
686
+ for (var i = 0; i < arrayOfTypeCheckers.length; i++) {
687
+ var checker = arrayOfTypeCheckers[i];
688
+ if (typeof checker !== "function") {
689
+ printWarning(
690
+ "Invalid argument supplied to oneOfType. Expected an array of check functions, but received " + getPostfixForTypeWarning(checker) + " at index " + i + "."
691
+ );
692
+ return emptyFunctionThatReturnsNull;
693
+ }
694
+ }
695
+ function validate(props, propName, componentName, location, propFullName) {
696
+ var expectedTypes = [];
697
+ for (var i2 = 0; i2 < arrayOfTypeCheckers.length; i2++) {
698
+ var checker2 = arrayOfTypeCheckers[i2];
699
+ var checkerResult = checker2(props, propName, componentName, location, propFullName, ReactPropTypesSecret);
700
+ if (checkerResult == null) {
701
+ return null;
702
+ }
703
+ if (checkerResult.data && has2(checkerResult.data, "expectedType")) {
704
+ expectedTypes.push(checkerResult.data.expectedType);
705
+ }
706
+ }
707
+ var expectedTypesMessage = expectedTypes.length > 0 ? ", expected one of type [" + expectedTypes.join(", ") + "]" : "";
708
+ return new PropTypeError("Invalid " + location + " `" + propFullName + "` supplied to " + ("`" + componentName + "`" + expectedTypesMessage + "."));
709
+ }
710
+ return createChainableTypeChecker(validate);
711
+ }
712
+ function createNodeChecker() {
713
+ function validate(props, propName, componentName, location, propFullName) {
714
+ if (!isNode(props[propName])) {
715
+ return new PropTypeError("Invalid " + location + " `" + propFullName + "` supplied to " + ("`" + componentName + "`, expected a ReactNode."));
716
+ }
717
+ return null;
718
+ }
719
+ return createChainableTypeChecker(validate);
720
+ }
721
+ function invalidValidatorError(componentName, location, propFullName, key, type) {
722
+ return new PropTypeError(
723
+ (componentName || "React class") + ": " + location + " type `" + propFullName + "." + key + "` is invalid; it must be a function, usually from the `prop-types` package, but received `" + type + "`."
724
+ );
725
+ }
726
+ function createShapeTypeChecker(shapeTypes) {
727
+ function validate(props, propName, componentName, location, propFullName) {
728
+ var propValue = props[propName];
729
+ var propType = getPropType(propValue);
730
+ if (propType !== "object") {
731
+ return new PropTypeError("Invalid " + location + " `" + propFullName + "` of type `" + propType + "` " + ("supplied to `" + componentName + "`, expected `object`."));
732
+ }
733
+ for (var key in shapeTypes) {
734
+ var checker = shapeTypes[key];
735
+ if (typeof checker !== "function") {
736
+ return invalidValidatorError(componentName, location, propFullName, key, getPreciseType(checker));
737
+ }
738
+ var error = checker(propValue, key, componentName, location, propFullName + "." + key, ReactPropTypesSecret);
739
+ if (error) {
740
+ return error;
741
+ }
742
+ }
743
+ return null;
744
+ }
745
+ return createChainableTypeChecker(validate);
746
+ }
747
+ function createStrictShapeTypeChecker(shapeTypes) {
748
+ function validate(props, propName, componentName, location, propFullName) {
749
+ var propValue = props[propName];
750
+ var propType = getPropType(propValue);
751
+ if (propType !== "object") {
752
+ return new PropTypeError("Invalid " + location + " `" + propFullName + "` of type `" + propType + "` " + ("supplied to `" + componentName + "`, expected `object`."));
753
+ }
754
+ var allKeys = assign({}, props[propName], shapeTypes);
755
+ for (var key in allKeys) {
756
+ var checker = shapeTypes[key];
757
+ if (has2(shapeTypes, key) && typeof checker !== "function") {
758
+ return invalidValidatorError(componentName, location, propFullName, key, getPreciseType(checker));
759
+ }
760
+ if (!checker) {
761
+ return new PropTypeError(
762
+ "Invalid " + location + " `" + propFullName + "` key `" + key + "` supplied to `" + componentName + "`.\nBad object: " + JSON.stringify(props[propName], null, " ") + "\nValid keys: " + JSON.stringify(Object.keys(shapeTypes), null, " ")
763
+ );
764
+ }
765
+ var error = checker(propValue, key, componentName, location, propFullName + "." + key, ReactPropTypesSecret);
766
+ if (error) {
767
+ return error;
768
+ }
769
+ }
770
+ return null;
771
+ }
772
+ return createChainableTypeChecker(validate);
773
+ }
774
+ function isNode(propValue) {
775
+ switch (typeof propValue) {
776
+ case "number":
777
+ case "string":
778
+ case "undefined":
779
+ return true;
780
+ case "boolean":
781
+ return !propValue;
782
+ case "object":
783
+ if (Array.isArray(propValue)) {
784
+ return propValue.every(isNode);
785
+ }
786
+ if (propValue === null || isValidElement(propValue)) {
787
+ return true;
788
+ }
789
+ var iteratorFn = getIteratorFn(propValue);
790
+ if (iteratorFn) {
791
+ var iterator = iteratorFn.call(propValue);
792
+ var step;
793
+ if (iteratorFn !== propValue.entries) {
794
+ while (!(step = iterator.next()).done) {
795
+ if (!isNode(step.value)) {
796
+ return false;
797
+ }
798
+ }
799
+ } else {
800
+ while (!(step = iterator.next()).done) {
801
+ var entry = step.value;
802
+ if (entry) {
803
+ if (!isNode(entry[1])) {
804
+ return false;
805
+ }
806
+ }
807
+ }
808
+ }
809
+ } else {
810
+ return false;
811
+ }
812
+ return true;
813
+ default:
814
+ return false;
815
+ }
816
+ }
817
+ function isSymbol(propType, propValue) {
818
+ if (propType === "symbol") {
819
+ return true;
820
+ }
821
+ if (!propValue) {
822
+ return false;
823
+ }
824
+ if (propValue["@@toStringTag"] === "Symbol") {
825
+ return true;
826
+ }
827
+ if (typeof Symbol === "function" && propValue instanceof Symbol) {
828
+ return true;
829
+ }
830
+ return false;
831
+ }
832
+ function getPropType(propValue) {
833
+ var propType = typeof propValue;
834
+ if (Array.isArray(propValue)) {
835
+ return "array";
836
+ }
837
+ if (propValue instanceof RegExp) {
838
+ return "object";
839
+ }
840
+ if (isSymbol(propType, propValue)) {
841
+ return "symbol";
842
+ }
843
+ return propType;
844
+ }
845
+ function getPreciseType(propValue) {
846
+ if (typeof propValue === "undefined" || propValue === null) {
847
+ return "" + propValue;
848
+ }
849
+ var propType = getPropType(propValue);
850
+ if (propType === "object") {
851
+ if (propValue instanceof Date) {
852
+ return "date";
853
+ } else if (propValue instanceof RegExp) {
854
+ return "regexp";
855
+ }
856
+ }
857
+ return propType;
858
+ }
859
+ function getPostfixForTypeWarning(value) {
860
+ var type = getPreciseType(value);
861
+ switch (type) {
862
+ case "array":
863
+ case "object":
864
+ return "an " + type;
865
+ case "boolean":
866
+ case "date":
867
+ case "regexp":
868
+ return "a " + type;
869
+ default:
870
+ return type;
871
+ }
872
+ }
873
+ function getClassName(propValue) {
874
+ if (!propValue.constructor || !propValue.constructor.name) {
875
+ return ANONYMOUS;
876
+ }
877
+ return propValue.constructor.name;
878
+ }
879
+ ReactPropTypes.checkPropTypes = checkPropTypes;
880
+ ReactPropTypes.resetWarningCache = checkPropTypes.resetWarningCache;
881
+ ReactPropTypes.PropTypes = ReactPropTypes;
882
+ return ReactPropTypes;
883
+ };
884
+ return factoryWithTypeCheckers;
885
+ }
886
+ var factoryWithThrowingShims;
887
+ var hasRequiredFactoryWithThrowingShims;
888
+ function requireFactoryWithThrowingShims() {
889
+ if (hasRequiredFactoryWithThrowingShims) return factoryWithThrowingShims;
890
+ hasRequiredFactoryWithThrowingShims = 1;
891
+ var ReactPropTypesSecret = /* @__PURE__ */ requireReactPropTypesSecret();
892
+ function emptyFunction() {
893
+ }
894
+ function emptyFunctionWithReset() {
895
+ }
896
+ emptyFunctionWithReset.resetWarningCache = emptyFunction;
897
+ factoryWithThrowingShims = function() {
898
+ function shim(props, propName, componentName, location, propFullName, secret) {
899
+ if (secret === ReactPropTypesSecret) {
900
+ return;
901
+ }
902
+ var err = new Error(
903
+ "Calling PropTypes validators directly is not supported by the `prop-types` package. Use PropTypes.checkPropTypes() to call them. Read more at http://fb.me/use-check-prop-types"
904
+ );
905
+ err.name = "Invariant Violation";
906
+ throw err;
907
+ }
908
+ shim.isRequired = shim;
909
+ function getShim() {
910
+ return shim;
911
+ }
912
+ var ReactPropTypes = {
913
+ array: shim,
914
+ bigint: shim,
915
+ bool: shim,
916
+ func: shim,
917
+ number: shim,
918
+ object: shim,
919
+ string: shim,
920
+ symbol: shim,
921
+ any: shim,
922
+ arrayOf: getShim,
923
+ element: shim,
924
+ elementType: shim,
925
+ instanceOf: getShim,
926
+ node: shim,
927
+ objectOf: getShim,
928
+ oneOf: getShim,
929
+ oneOfType: getShim,
930
+ shape: getShim,
931
+ exact: getShim,
932
+ checkPropTypes: emptyFunctionWithReset,
933
+ resetWarningCache: emptyFunction
934
+ };
935
+ ReactPropTypes.PropTypes = ReactPropTypes;
936
+ return ReactPropTypes;
937
+ };
938
+ return factoryWithThrowingShims;
939
+ }
940
+ var hasRequiredPropTypes;
941
+ function requirePropTypes() {
942
+ if (hasRequiredPropTypes) return propTypes.exports;
943
+ hasRequiredPropTypes = 1;
944
+ if (process.env.NODE_ENV !== "production") {
945
+ var ReactIs = requireReactIs();
946
+ var throwOnDirectAccess = true;
947
+ propTypes.exports = /* @__PURE__ */ requireFactoryWithTypeCheckers()(ReactIs.isElement, throwOnDirectAccess);
948
+ } else {
949
+ propTypes.exports = /* @__PURE__ */ requireFactoryWithThrowingShims()();
950
+ }
951
+ return propTypes.exports;
952
+ }
953
+ var propTypesExports = /* @__PURE__ */ requirePropTypes();
954
+ const PropTypes = /* @__PURE__ */ getDefaultExportFromCjs(propTypesExports);
955
+ function __awaiter(thisArg, _arguments, P, generator) {
956
+ function adopt(value) {
957
+ return value instanceof P ? value : new P(function(resolve) {
958
+ resolve(value);
959
+ });
960
+ }
961
+ return new (P || (P = Promise))(function(resolve, reject) {
962
+ function fulfilled(value) {
963
+ try {
964
+ step(generator.next(value));
965
+ } catch (e) {
966
+ reject(e);
967
+ }
968
+ }
969
+ function rejected(value) {
970
+ try {
971
+ step(generator["throw"](value));
972
+ } catch (e) {
973
+ reject(e);
974
+ }
975
+ }
976
+ function step(result) {
977
+ result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);
978
+ }
979
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
980
+ });
981
+ }
982
+ function __generator(thisArg, body) {
983
+ var _ = { label: 0, sent: function() {
984
+ if (t[0] & 1) throw t[1];
985
+ return t[1];
986
+ }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
987
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() {
988
+ return this;
989
+ }), g;
990
+ function verb(n) {
991
+ return function(v) {
992
+ return step([n, v]);
993
+ };
994
+ }
995
+ function step(op) {
996
+ if (f) throw new TypeError("Generator is already executing.");
997
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
998
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
999
+ if (y = 0, t) op = [op[0] & 2, t.value];
1000
+ switch (op[0]) {
1001
+ case 0:
1002
+ case 1:
1003
+ t = op;
1004
+ break;
1005
+ case 4:
1006
+ _.label++;
1007
+ return { value: op[1], done: false };
1008
+ case 5:
1009
+ _.label++;
1010
+ y = op[1];
1011
+ op = [0];
1012
+ continue;
1013
+ case 7:
1014
+ op = _.ops.pop();
1015
+ _.trys.pop();
1016
+ continue;
1017
+ default:
1018
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
1019
+ _ = 0;
1020
+ continue;
1021
+ }
1022
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
1023
+ _.label = op[1];
1024
+ break;
1025
+ }
1026
+ if (op[0] === 6 && _.label < t[1]) {
1027
+ _.label = t[1];
1028
+ t = op;
1029
+ break;
1030
+ }
1031
+ if (t && _.label < t[2]) {
1032
+ _.label = t[2];
1033
+ _.ops.push(op);
1034
+ break;
1035
+ }
1036
+ if (t[2]) _.ops.pop();
1037
+ _.trys.pop();
1038
+ continue;
1039
+ }
1040
+ op = body.call(thisArg, _);
1041
+ } catch (e) {
1042
+ op = [6, e];
1043
+ y = 0;
1044
+ } finally {
1045
+ f = t = 0;
1046
+ }
1047
+ if (op[0] & 5) throw op[1];
1048
+ return { value: op[0] ? op[1] : void 0, done: true };
1049
+ }
1050
+ }
1051
+ function __read(o, n) {
1052
+ var m = typeof Symbol === "function" && o[Symbol.iterator];
1053
+ if (!m) return o;
1054
+ var i = m.call(o), r, ar = [], e;
1055
+ try {
1056
+ while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
1057
+ } catch (error) {
1058
+ e = { error };
1059
+ } finally {
1060
+ try {
1061
+ if (r && !r.done && (m = i["return"])) m.call(i);
1062
+ } finally {
1063
+ if (e) throw e.error;
1064
+ }
1065
+ }
1066
+ return ar;
1067
+ }
1068
+ function __spread() {
1069
+ for (var ar = [], i = 0; i < arguments.length; i++)
1070
+ ar = ar.concat(__read(arguments[i]));
1071
+ return ar;
1072
+ }
1073
+ typeof SuppressedError === "function" ? SuppressedError : function(error, suppressed, message) {
1074
+ var e = new Error(message);
1075
+ return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
1076
+ };
1077
+ var COMMON_MIME_TYPES = /* @__PURE__ */ new Map([
1078
+ // https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/MIME_types/Common_types
1079
+ ["aac", "audio/aac"],
1080
+ ["abw", "application/x-abiword"],
1081
+ ["arc", "application/x-freearc"],
1082
+ ["avif", "image/avif"],
1083
+ ["avi", "video/x-msvideo"],
1084
+ ["azw", "application/vnd.amazon.ebook"],
1085
+ ["bin", "application/octet-stream"],
1086
+ ["bmp", "image/bmp"],
1087
+ ["bz", "application/x-bzip"],
1088
+ ["bz2", "application/x-bzip2"],
1089
+ ["cda", "application/x-cdf"],
1090
+ ["csh", "application/x-csh"],
1091
+ ["css", "text/css"],
1092
+ ["csv", "text/csv"],
1093
+ ["doc", "application/msword"],
1094
+ ["docx", "application/vnd.openxmlformats-officedocument.wordprocessingml.document"],
1095
+ ["eot", "application/vnd.ms-fontobject"],
1096
+ ["epub", "application/epub+zip"],
1097
+ ["gz", "application/gzip"],
1098
+ ["gif", "image/gif"],
1099
+ ["htm", "text/html"],
1100
+ ["html", "text/html"],
1101
+ ["ico", "image/vnd.microsoft.icon"],
1102
+ ["ics", "text/calendar"],
1103
+ ["jar", "application/java-archive"],
1104
+ ["jpeg", "image/jpeg"],
1105
+ ["jpg", "image/jpeg"],
1106
+ ["js", "text/javascript"],
1107
+ ["json", "application/json"],
1108
+ ["jsonld", "application/ld+json"],
1109
+ ["mid", "audio/midi"],
1110
+ ["midi", "audio/midi"],
1111
+ ["mjs", "text/javascript"],
1112
+ ["mp3", "audio/mpeg"],
1113
+ ["mp4", "video/mp4"],
1114
+ ["mpeg", "video/mpeg"],
1115
+ ["mpkg", "application/vnd.apple.installer+xml"],
1116
+ ["odp", "application/vnd.oasis.opendocument.presentation"],
1117
+ ["ods", "application/vnd.oasis.opendocument.spreadsheet"],
1118
+ ["odt", "application/vnd.oasis.opendocument.text"],
1119
+ ["oga", "audio/ogg"],
1120
+ ["ogv", "video/ogg"],
1121
+ ["ogx", "application/ogg"],
1122
+ ["opus", "audio/opus"],
1123
+ ["otf", "font/otf"],
1124
+ ["png", "image/png"],
1125
+ ["pdf", "application/pdf"],
1126
+ ["php", "application/x-httpd-php"],
1127
+ ["ppt", "application/vnd.ms-powerpoint"],
1128
+ ["pptx", "application/vnd.openxmlformats-officedocument.presentationml.presentation"],
1129
+ ["rar", "application/vnd.rar"],
1130
+ ["rtf", "application/rtf"],
1131
+ ["sh", "application/x-sh"],
1132
+ ["svg", "image/svg+xml"],
1133
+ ["swf", "application/x-shockwave-flash"],
1134
+ ["tar", "application/x-tar"],
1135
+ ["tif", "image/tiff"],
1136
+ ["tiff", "image/tiff"],
1137
+ ["ts", "video/mp2t"],
1138
+ ["ttf", "font/ttf"],
1139
+ ["txt", "text/plain"],
1140
+ ["vsd", "application/vnd.visio"],
1141
+ ["wav", "audio/wav"],
1142
+ ["weba", "audio/webm"],
1143
+ ["webm", "video/webm"],
1144
+ ["webp", "image/webp"],
1145
+ ["woff", "font/woff"],
1146
+ ["woff2", "font/woff2"],
1147
+ ["xhtml", "application/xhtml+xml"],
1148
+ ["xls", "application/vnd.ms-excel"],
1149
+ ["xlsx", "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"],
1150
+ ["xml", "application/xml"],
1151
+ ["xul", "application/vnd.mozilla.xul+xml"],
1152
+ ["zip", "application/zip"],
1153
+ ["7z", "application/x-7z-compressed"],
1154
+ // Others
1155
+ ["mkv", "video/x-matroska"],
1156
+ ["mov", "video/quicktime"],
1157
+ ["msg", "application/vnd.ms-outlook"]
1158
+ ]);
1159
+ function toFileWithPath(file, path) {
1160
+ var f = withMimeType(file);
1161
+ if (typeof f.path !== "string") {
1162
+ var webkitRelativePath = file.webkitRelativePath;
1163
+ Object.defineProperty(f, "path", {
1164
+ value: typeof path === "string" ? path : typeof webkitRelativePath === "string" && webkitRelativePath.length > 0 ? webkitRelativePath : file.name,
1165
+ writable: false,
1166
+ configurable: false,
1167
+ enumerable: true
1168
+ });
1169
+ }
1170
+ return f;
1171
+ }
1172
+ function withMimeType(file) {
1173
+ var name = file.name;
1174
+ var hasExtension = name && name.lastIndexOf(".") !== -1;
1175
+ if (hasExtension && !file.type) {
1176
+ var ext = name.split(".").pop().toLowerCase();
1177
+ var type = COMMON_MIME_TYPES.get(ext);
1178
+ if (type) {
1179
+ Object.defineProperty(file, "type", {
1180
+ value: type,
1181
+ writable: false,
1182
+ configurable: false,
1183
+ enumerable: true
1184
+ });
1185
+ }
1186
+ }
1187
+ return file;
1188
+ }
1189
+ var FILES_TO_IGNORE = [
1190
+ // Thumbnail cache files for macOS and Windows
1191
+ ".DS_Store",
1192
+ "Thumbs.db"
1193
+ // Windows
1194
+ ];
1195
+ function fromEvent(evt) {
1196
+ return __awaiter(this, void 0, void 0, function() {
1197
+ return __generator(this, function(_a) {
1198
+ if (isObject(evt) && isDataTransfer(evt)) {
1199
+ return [2, getDataTransferFiles(evt.dataTransfer, evt.type)];
1200
+ } else if (isChangeEvt(evt)) {
1201
+ return [2, getInputFiles(evt)];
1202
+ } else if (Array.isArray(evt) && evt.every(function(item) {
1203
+ return "getFile" in item && typeof item.getFile === "function";
1204
+ })) {
1205
+ return [2, getFsHandleFiles(evt)];
1206
+ }
1207
+ return [2, []];
1208
+ });
1209
+ });
1210
+ }
1211
+ function isDataTransfer(value) {
1212
+ return isObject(value.dataTransfer);
1213
+ }
1214
+ function isChangeEvt(value) {
1215
+ return isObject(value) && isObject(value.target);
1216
+ }
1217
+ function isObject(v) {
1218
+ return typeof v === "object" && v !== null;
1219
+ }
1220
+ function getInputFiles(evt) {
1221
+ return fromList(evt.target.files).map(function(file) {
1222
+ return toFileWithPath(file);
1223
+ });
1224
+ }
1225
+ function getFsHandleFiles(handles) {
1226
+ return __awaiter(this, void 0, void 0, function() {
1227
+ var files;
1228
+ return __generator(this, function(_a) {
1229
+ switch (_a.label) {
1230
+ case 0:
1231
+ return [4, Promise.all(handles.map(function(h) {
1232
+ return h.getFile();
1233
+ }))];
1234
+ case 1:
1235
+ files = _a.sent();
1236
+ return [2, files.map(function(file) {
1237
+ return toFileWithPath(file);
1238
+ })];
1239
+ }
1240
+ });
1241
+ });
1242
+ }
1243
+ function getDataTransferFiles(dt, type) {
1244
+ return __awaiter(this, void 0, void 0, function() {
1245
+ var items, files;
1246
+ return __generator(this, function(_a) {
1247
+ switch (_a.label) {
1248
+ case 0:
1249
+ if (dt === null) {
1250
+ return [2, []];
1251
+ }
1252
+ if (!dt.items) return [3, 2];
1253
+ items = fromList(dt.items).filter(function(item) {
1254
+ return item.kind === "file";
1255
+ });
1256
+ if (type !== "drop") {
1257
+ return [2, items];
1258
+ }
1259
+ return [4, Promise.all(items.map(toFilePromises))];
1260
+ case 1:
1261
+ files = _a.sent();
1262
+ return [2, noIgnoredFiles(flatten(files))];
1263
+ case 2:
1264
+ return [2, noIgnoredFiles(fromList(dt.files).map(function(file) {
1265
+ return toFileWithPath(file);
1266
+ }))];
1267
+ }
1268
+ });
1269
+ });
1270
+ }
1271
+ function noIgnoredFiles(files) {
1272
+ return files.filter(function(file) {
1273
+ return FILES_TO_IGNORE.indexOf(file.name) === -1;
1274
+ });
1275
+ }
1276
+ function fromList(items) {
1277
+ if (items === null) {
1278
+ return [];
1279
+ }
1280
+ var files = [];
1281
+ for (var i = 0; i < items.length; i++) {
1282
+ var file = items[i];
1283
+ files.push(file);
1284
+ }
1285
+ return files;
1286
+ }
1287
+ function toFilePromises(item) {
1288
+ if (typeof item.webkitGetAsEntry !== "function") {
1289
+ return fromDataTransferItem(item);
1290
+ }
1291
+ var entry = item.webkitGetAsEntry();
1292
+ if (entry && entry.isDirectory) {
1293
+ return fromDirEntry(entry);
1294
+ }
1295
+ return fromDataTransferItem(item);
1296
+ }
1297
+ function flatten(items) {
1298
+ return items.reduce(function(acc, files) {
1299
+ return __spread(acc, Array.isArray(files) ? flatten(files) : [files]);
1300
+ }, []);
1301
+ }
1302
+ function fromDataTransferItem(item) {
1303
+ var file = item.getAsFile();
1304
+ if (!file) {
1305
+ return Promise.reject(item + " is not a File");
1306
+ }
1307
+ var fwp = toFileWithPath(file);
1308
+ return Promise.resolve(fwp);
1309
+ }
1310
+ function fromEntry(entry) {
1311
+ return __awaiter(this, void 0, void 0, function() {
1312
+ return __generator(this, function(_a) {
1313
+ return [2, entry.isDirectory ? fromDirEntry(entry) : fromFileEntry(entry)];
1314
+ });
1315
+ });
1316
+ }
1317
+ function fromDirEntry(entry) {
1318
+ var reader = entry.createReader();
1319
+ return new Promise(function(resolve, reject) {
1320
+ var entries = [];
1321
+ function readEntries() {
1322
+ var _this = this;
1323
+ reader.readEntries(function(batch) {
1324
+ return __awaiter(_this, void 0, void 0, function() {
1325
+ var files, err_1, items;
1326
+ return __generator(this, function(_a) {
1327
+ switch (_a.label) {
1328
+ case 0:
1329
+ if (!!batch.length) return [3, 5];
1330
+ _a.label = 1;
1331
+ case 1:
1332
+ _a.trys.push([1, 3, , 4]);
1333
+ return [4, Promise.all(entries)];
1334
+ case 2:
1335
+ files = _a.sent();
1336
+ resolve(files);
1337
+ return [3, 4];
1338
+ case 3:
1339
+ err_1 = _a.sent();
1340
+ reject(err_1);
1341
+ return [3, 4];
1342
+ case 4:
1343
+ return [3, 6];
1344
+ case 5:
1345
+ items = Promise.all(batch.map(fromEntry));
1346
+ entries.push(items);
1347
+ readEntries();
1348
+ _a.label = 6;
1349
+ case 6:
1350
+ return [
1351
+ 2
1352
+ /*return*/
1353
+ ];
1354
+ }
1355
+ });
1356
+ });
1357
+ }, function(err) {
1358
+ reject(err);
1359
+ });
1360
+ }
1361
+ readEntries();
1362
+ });
1363
+ }
1364
+ function fromFileEntry(entry) {
1365
+ return __awaiter(this, void 0, void 0, function() {
1366
+ return __generator(this, function(_a) {
1367
+ return [2, new Promise(function(resolve, reject) {
1368
+ entry.file(function(file) {
1369
+ var fwp = toFileWithPath(file, entry.fullPath);
1370
+ resolve(fwp);
1371
+ }, function(err) {
1372
+ reject(err);
1373
+ });
1374
+ })];
1375
+ });
1376
+ });
1377
+ }
1378
+ var es = {};
1379
+ var hasRequiredEs;
1380
+ function requireEs() {
1381
+ if (hasRequiredEs) return es;
1382
+ hasRequiredEs = 1;
1383
+ es.__esModule = true;
1384
+ es.default = function(file, acceptedFiles) {
1385
+ if (file && acceptedFiles) {
1386
+ var acceptedFilesArray = Array.isArray(acceptedFiles) ? acceptedFiles : acceptedFiles.split(",");
1387
+ if (acceptedFilesArray.length === 0) {
1388
+ return true;
1389
+ }
1390
+ var fileName = file.name || "";
1391
+ var mimeType = (file.type || "").toLowerCase();
1392
+ var baseMimeType = mimeType.replace(/\/.*$/, "");
1393
+ return acceptedFilesArray.some(function(type) {
1394
+ var validType = type.trim().toLowerCase();
1395
+ if (validType.charAt(0) === ".") {
1396
+ return fileName.toLowerCase().endsWith(validType);
1397
+ } else if (validType.endsWith("/*")) {
1398
+ return baseMimeType === validType.replace(/\/.*$/, "");
1399
+ }
1400
+ return mimeType === validType;
1401
+ });
1402
+ }
1403
+ return true;
1404
+ };
1405
+ return es;
1406
+ }
1407
+ var esExports = requireEs();
1408
+ const accepts = /* @__PURE__ */ getDefaultExportFromCjs(esExports);
1409
+ function ownKeys$1(object, enumerableOnly) {
1410
+ var keys = Object.keys(object);
1411
+ if (Object.getOwnPropertySymbols) {
1412
+ var symbols = Object.getOwnPropertySymbols(object);
1413
+ enumerableOnly && (symbols = symbols.filter(function(sym) {
1414
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
1415
+ })), keys.push.apply(keys, symbols);
1416
+ }
1417
+ return keys;
1418
+ }
1419
+ function _objectSpread$1(target) {
1420
+ for (var i = 1; i < arguments.length; i++) {
1421
+ var source = null != arguments[i] ? arguments[i] : {};
1422
+ i % 2 ? ownKeys$1(Object(source), true).forEach(function(key) {
1423
+ _defineProperty$1(target, key, source[key]);
1424
+ }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$1(Object(source)).forEach(function(key) {
1425
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
1426
+ });
1427
+ }
1428
+ return target;
1429
+ }
1430
+ function _defineProperty$1(obj, key, value) {
1431
+ if (key in obj) {
1432
+ Object.defineProperty(obj, key, { value, enumerable: true, configurable: true, writable: true });
1433
+ } else {
1434
+ obj[key] = value;
1435
+ }
1436
+ return obj;
1437
+ }
1438
+ function _slicedToArray$1(arr, i) {
1439
+ return _arrayWithHoles$1(arr) || _iterableToArrayLimit$1(arr, i) || _unsupportedIterableToArray$1(arr, i) || _nonIterableRest$1();
1440
+ }
1441
+ function _nonIterableRest$1() {
1442
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
1443
+ }
1444
+ function _unsupportedIterableToArray$1(o, minLen) {
1445
+ if (!o) return;
1446
+ if (typeof o === "string") return _arrayLikeToArray$1(o, minLen);
1447
+ var n = Object.prototype.toString.call(o).slice(8, -1);
1448
+ if (n === "Object" && o.constructor) n = o.constructor.name;
1449
+ if (n === "Map" || n === "Set") return Array.from(o);
1450
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray$1(o, minLen);
1451
+ }
1452
+ function _arrayLikeToArray$1(arr, len) {
1453
+ if (len == null || len > arr.length) len = arr.length;
1454
+ for (var i = 0, arr2 = new Array(len); i < len; i++) {
1455
+ arr2[i] = arr[i];
1456
+ }
1457
+ return arr2;
1458
+ }
1459
+ function _iterableToArrayLimit$1(arr, i) {
1460
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
1461
+ if (_i == null) return;
1462
+ var _arr = [];
1463
+ var _n = true;
1464
+ var _d = false;
1465
+ var _s, _e;
1466
+ try {
1467
+ for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {
1468
+ _arr.push(_s.value);
1469
+ if (i && _arr.length === i) break;
1470
+ }
1471
+ } catch (err) {
1472
+ _d = true;
1473
+ _e = err;
1474
+ } finally {
1475
+ try {
1476
+ if (!_n && _i["return"] != null) _i["return"]();
1477
+ } finally {
1478
+ if (_d) throw _e;
1479
+ }
1480
+ }
1481
+ return _arr;
1482
+ }
1483
+ function _arrayWithHoles$1(arr) {
1484
+ if (Array.isArray(arr)) return arr;
1485
+ }
1486
+ var FILE_INVALID_TYPE = "file-invalid-type";
1487
+ var FILE_TOO_LARGE = "file-too-large";
1488
+ var FILE_TOO_SMALL = "file-too-small";
1489
+ var TOO_MANY_FILES = "too-many-files";
1490
+ var getInvalidTypeRejectionErr = function getInvalidTypeRejectionErr2(accept) {
1491
+ accept = Array.isArray(accept) && accept.length === 1 ? accept[0] : accept;
1492
+ var messageSuffix = Array.isArray(accept) ? "one of ".concat(accept.join(", ")) : accept;
1493
+ return {
1494
+ code: FILE_INVALID_TYPE,
1495
+ message: "File type must be ".concat(messageSuffix)
1496
+ };
1497
+ };
1498
+ var getTooLargeRejectionErr = function getTooLargeRejectionErr2(maxSize) {
1499
+ return {
1500
+ code: FILE_TOO_LARGE,
1501
+ message: "File is larger than ".concat(maxSize, " ").concat(maxSize === 1 ? "byte" : "bytes")
1502
+ };
1503
+ };
1504
+ var getTooSmallRejectionErr = function getTooSmallRejectionErr2(minSize) {
1505
+ return {
1506
+ code: FILE_TOO_SMALL,
1507
+ message: "File is smaller than ".concat(minSize, " ").concat(minSize === 1 ? "byte" : "bytes")
1508
+ };
1509
+ };
1510
+ var TOO_MANY_FILES_REJECTION = {
1511
+ code: TOO_MANY_FILES,
1512
+ message: "Too many files"
1513
+ };
1514
+ function fileAccepted(file, accept) {
1515
+ var isAcceptable = file.type === "application/x-moz-file" || accepts(file, accept);
1516
+ return [isAcceptable, isAcceptable ? null : getInvalidTypeRejectionErr(accept)];
1517
+ }
1518
+ function fileMatchSize(file, minSize, maxSize) {
1519
+ if (isDefined(file.size)) {
1520
+ if (isDefined(minSize) && isDefined(maxSize)) {
1521
+ if (file.size > maxSize) return [false, getTooLargeRejectionErr(maxSize)];
1522
+ if (file.size < minSize) return [false, getTooSmallRejectionErr(minSize)];
1523
+ } else if (isDefined(minSize) && file.size < minSize) return [false, getTooSmallRejectionErr(minSize)];
1524
+ else if (isDefined(maxSize) && file.size > maxSize) return [false, getTooLargeRejectionErr(maxSize)];
1525
+ }
1526
+ return [true, null];
1527
+ }
1528
+ function isDefined(value) {
1529
+ return value !== void 0 && value !== null;
1530
+ }
1531
+ function allFilesAccepted(_ref) {
1532
+ var files = _ref.files, accept = _ref.accept, minSize = _ref.minSize, maxSize = _ref.maxSize, multiple = _ref.multiple, maxFiles = _ref.maxFiles;
1533
+ if (!multiple && files.length > 1 || multiple && maxFiles >= 1 && files.length > maxFiles) {
1534
+ return false;
1535
+ }
1536
+ return files.every(function(file) {
1537
+ var _fileAccepted = fileAccepted(file, accept), _fileAccepted2 = _slicedToArray$1(_fileAccepted, 1), accepted = _fileAccepted2[0];
1538
+ var _fileMatchSize = fileMatchSize(file, minSize, maxSize), _fileMatchSize2 = _slicedToArray$1(_fileMatchSize, 1), sizeMatch = _fileMatchSize2[0];
1539
+ return accepted && sizeMatch;
1540
+ });
1541
+ }
1542
+ function isPropagationStopped(event) {
1543
+ if (typeof event.isPropagationStopped === "function") {
1544
+ return event.isPropagationStopped();
1545
+ } else if (typeof event.cancelBubble !== "undefined") {
1546
+ return event.cancelBubble;
1547
+ }
1548
+ return false;
1549
+ }
1550
+ function isEvtWithFiles(event) {
1551
+ if (!event.dataTransfer) {
1552
+ return !!event.target && !!event.target.files;
1553
+ }
1554
+ return Array.prototype.some.call(event.dataTransfer.types, function(type) {
1555
+ return type === "Files" || type === "application/x-moz-file";
1556
+ });
1557
+ }
1558
+ function onDocumentDragOver(event) {
1559
+ event.preventDefault();
1560
+ }
1561
+ function isIe(userAgent) {
1562
+ return userAgent.indexOf("MSIE") !== -1 || userAgent.indexOf("Trident/") !== -1;
1563
+ }
1564
+ function isEdge(userAgent) {
1565
+ return userAgent.indexOf("Edge/") !== -1;
1566
+ }
1567
+ function isIeOrEdge() {
1568
+ var userAgent = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : window.navigator.userAgent;
1569
+ return isIe(userAgent) || isEdge(userAgent);
1570
+ }
1571
+ function composeEventHandlers() {
1572
+ for (var _len = arguments.length, fns = new Array(_len), _key = 0; _key < _len; _key++) {
1573
+ fns[_key] = arguments[_key];
1574
+ }
1575
+ return function(event) {
1576
+ for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {
1577
+ args[_key2 - 1] = arguments[_key2];
1578
+ }
1579
+ return fns.some(function(fn) {
1580
+ if (!isPropagationStopped(event) && fn) {
1581
+ fn.apply(void 0, [event].concat(args));
1582
+ }
1583
+ return isPropagationStopped(event);
1584
+ });
1585
+ };
1586
+ }
1587
+ function canUseFileSystemAccessAPI() {
1588
+ return "showOpenFilePicker" in window;
1589
+ }
1590
+ function filePickerOptionsTypes(accept) {
1591
+ accept = typeof accept === "string" ? accept.split(",") : accept;
1592
+ return [{
1593
+ description: "everything",
1594
+ // TODO: Need to handle filtering more elegantly than this!
1595
+ accept: Array.isArray(accept) ? accept.filter(function(item) {
1596
+ return item === "audio/*" || item === "video/*" || item === "image/*" || item === "text/*" || /\w+\/[-+.\w]+/g.test(item);
1597
+ }).reduce(function(a, b) {
1598
+ return _objectSpread$1(_objectSpread$1({}, a), {}, _defineProperty$1({}, b, []));
1599
+ }, {}) : {}
1600
+ }];
1601
+ }
1602
+ var _excluded = ["children"], _excluded2 = ["open"], _excluded3 = ["refKey", "role", "onKeyDown", "onFocus", "onBlur", "onClick", "onDragEnter", "onDragOver", "onDragLeave", "onDrop"], _excluded4 = ["refKey", "onChange", "onClick"];
1603
+ function _toConsumableArray(arr) {
1604
+ return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();
1605
+ }
1606
+ function _nonIterableSpread() {
1607
+ throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
1608
+ }
1609
+ function _iterableToArray(iter) {
1610
+ if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
1611
+ }
1612
+ function _arrayWithoutHoles(arr) {
1613
+ if (Array.isArray(arr)) return _arrayLikeToArray(arr);
1614
+ }
1615
+ function _slicedToArray(arr, i) {
1616
+ return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();
1617
+ }
1618
+ function _nonIterableRest() {
1619
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
1620
+ }
1621
+ function _unsupportedIterableToArray(o, minLen) {
1622
+ if (!o) return;
1623
+ if (typeof o === "string") return _arrayLikeToArray(o, minLen);
1624
+ var n = Object.prototype.toString.call(o).slice(8, -1);
1625
+ if (n === "Object" && o.constructor) n = o.constructor.name;
1626
+ if (n === "Map" || n === "Set") return Array.from(o);
1627
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
1628
+ }
1629
+ function _arrayLikeToArray(arr, len) {
1630
+ if (len == null || len > arr.length) len = arr.length;
1631
+ for (var i = 0, arr2 = new Array(len); i < len; i++) {
1632
+ arr2[i] = arr[i];
1633
+ }
1634
+ return arr2;
1635
+ }
1636
+ function _iterableToArrayLimit(arr, i) {
1637
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
1638
+ if (_i == null) return;
1639
+ var _arr = [];
1640
+ var _n = true;
1641
+ var _d = false;
1642
+ var _s, _e;
1643
+ try {
1644
+ for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {
1645
+ _arr.push(_s.value);
1646
+ if (i && _arr.length === i) break;
1647
+ }
1648
+ } catch (err) {
1649
+ _d = true;
1650
+ _e = err;
1651
+ } finally {
1652
+ try {
1653
+ if (!_n && _i["return"] != null) _i["return"]();
1654
+ } finally {
1655
+ if (_d) throw _e;
1656
+ }
1657
+ }
1658
+ return _arr;
1659
+ }
1660
+ function _arrayWithHoles(arr) {
1661
+ if (Array.isArray(arr)) return arr;
1662
+ }
1663
+ function ownKeys(object, enumerableOnly) {
1664
+ var keys = Object.keys(object);
1665
+ if (Object.getOwnPropertySymbols) {
1666
+ var symbols = Object.getOwnPropertySymbols(object);
1667
+ enumerableOnly && (symbols = symbols.filter(function(sym) {
1668
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
1669
+ })), keys.push.apply(keys, symbols);
1670
+ }
1671
+ return keys;
1672
+ }
1673
+ function _objectSpread(target) {
1674
+ for (var i = 1; i < arguments.length; i++) {
1675
+ var source = null != arguments[i] ? arguments[i] : {};
1676
+ i % 2 ? ownKeys(Object(source), true).forEach(function(key) {
1677
+ _defineProperty(target, key, source[key]);
1678
+ }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function(key) {
1679
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
1680
+ });
1681
+ }
1682
+ return target;
1683
+ }
1684
+ function _defineProperty(obj, key, value) {
1685
+ if (key in obj) {
1686
+ Object.defineProperty(obj, key, { value, enumerable: true, configurable: true, writable: true });
1687
+ } else {
1688
+ obj[key] = value;
1689
+ }
1690
+ return obj;
1691
+ }
1692
+ function _objectWithoutProperties(source, excluded) {
1693
+ if (source == null) return {};
1694
+ var target = _objectWithoutPropertiesLoose(source, excluded);
1695
+ var key, i;
1696
+ if (Object.getOwnPropertySymbols) {
1697
+ var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
1698
+ for (i = 0; i < sourceSymbolKeys.length; i++) {
1699
+ key = sourceSymbolKeys[i];
1700
+ if (excluded.indexOf(key) >= 0) continue;
1701
+ if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
1702
+ target[key] = source[key];
1703
+ }
1704
+ }
1705
+ return target;
1706
+ }
1707
+ function _objectWithoutPropertiesLoose(source, excluded) {
1708
+ if (source == null) return {};
1709
+ var target = {};
1710
+ var sourceKeys = Object.keys(source);
1711
+ var key, i;
1712
+ for (i = 0; i < sourceKeys.length; i++) {
1713
+ key = sourceKeys[i];
1714
+ if (excluded.indexOf(key) >= 0) continue;
1715
+ target[key] = source[key];
1716
+ }
1717
+ return target;
1718
+ }
1719
+ var Dropzone = /* @__PURE__ */ forwardRef(function(_ref, ref) {
1720
+ var children = _ref.children, params = _objectWithoutProperties(_ref, _excluded);
1721
+ var _useDropzone = useDropzone(params), open = _useDropzone.open, props = _objectWithoutProperties(_useDropzone, _excluded2);
1722
+ useImperativeHandle(ref, function() {
1723
+ return {
1724
+ open
1725
+ };
1726
+ }, [open]);
1727
+ return /* @__PURE__ */ React.createElement(Fragment, null, children(_objectSpread(_objectSpread({}, props), {}, {
1728
+ open
97
1729
  })));
1730
+ });
1731
+ Dropzone.displayName = "Dropzone";
1732
+ var defaultProps = {
1733
+ disabled: false,
1734
+ getFilesFromEvent: fromEvent,
1735
+ maxSize: Infinity,
1736
+ minSize: 0,
1737
+ multiple: true,
1738
+ maxFiles: 0,
1739
+ preventDropOnDocument: true,
1740
+ noClick: false,
1741
+ noKeyboard: false,
1742
+ noDrag: false,
1743
+ noDragEventsBubbling: false,
1744
+ validator: null,
1745
+ useFsAccessApi: false
1746
+ };
1747
+ Dropzone.defaultProps = defaultProps;
1748
+ Dropzone.propTypes = {
1749
+ /**
1750
+ * Render function that exposes the dropzone state and prop getter fns
1751
+ *
1752
+ * @param {object} params
1753
+ * @param {Function} params.getRootProps Returns the props you should apply to the root drop container you render
1754
+ * @param {Function} params.getInputProps Returns the props you should apply to hidden file input you render
1755
+ * @param {Function} params.open Open the native file selection dialog
1756
+ * @param {boolean} params.isFocused Dropzone area is in focus
1757
+ * @param {boolean} params.isFileDialogActive File dialog is opened
1758
+ * @param {boolean} params.isDragActive Active drag is in progress
1759
+ * @param {boolean} params.isDragAccept Dragged files are accepted
1760
+ * @param {boolean} params.isDragReject Some dragged files are rejected
1761
+ * @param {File[]} params.draggedFiles Files in active drag
1762
+ * @param {File[]} params.acceptedFiles Accepted files
1763
+ * @param {FileRejection[]} params.fileRejections Rejected files and why they were rejected
1764
+ */
1765
+ children: PropTypes.func,
1766
+ /**
1767
+ * Set accepted file types.
1768
+ * See https://github.com/okonet/attr-accept for more information.
1769
+ * Keep in mind that mime type determination is not reliable across platforms. CSV files,
1770
+ * for example, are reported as text/plain under macOS but as application/vnd.ms-excel under
1771
+ * Windows. In some cases there might not be a mime type set at all.
1772
+ * See: https://github.com/react-dropzone/react-dropzone/issues/276
1773
+ */
1774
+ accept: PropTypes.oneOfType([PropTypes.string, PropTypes.arrayOf(PropTypes.string)]),
1775
+ /**
1776
+ * Allow drag 'n' drop (or selection from the file dialog) of multiple files
1777
+ */
1778
+ multiple: PropTypes.bool,
1779
+ /**
1780
+ * If false, allow dropped items to take over the current browser window
1781
+ */
1782
+ preventDropOnDocument: PropTypes.bool,
1783
+ /**
1784
+ * If true, disables click to open the native file selection dialog
1785
+ */
1786
+ noClick: PropTypes.bool,
1787
+ /**
1788
+ * If true, disables SPACE/ENTER to open the native file selection dialog.
1789
+ * Note that it also stops tracking the focus state.
1790
+ */
1791
+ noKeyboard: PropTypes.bool,
1792
+ /**
1793
+ * If true, disables drag 'n' drop
1794
+ */
1795
+ noDrag: PropTypes.bool,
1796
+ /**
1797
+ * If true, stops drag event propagation to parents
1798
+ */
1799
+ noDragEventsBubbling: PropTypes.bool,
1800
+ /**
1801
+ * Minimum file size (in bytes)
1802
+ */
1803
+ minSize: PropTypes.number,
1804
+ /**
1805
+ * Maximum file size (in bytes)
1806
+ */
1807
+ maxSize: PropTypes.number,
1808
+ /**
1809
+ * Maximum accepted number of files
1810
+ * The default value is 0 which means there is no limitation to how many files are accepted.
1811
+ */
1812
+ maxFiles: PropTypes.number,
1813
+ /**
1814
+ * Enable/disable the dropzone
1815
+ */
1816
+ disabled: PropTypes.bool,
1817
+ /**
1818
+ * Use this to provide a custom file aggregator
1819
+ *
1820
+ * @param {(DragEvent|Event)} event A drag event or input change event (if files were selected via the file dialog)
1821
+ */
1822
+ getFilesFromEvent: PropTypes.func,
1823
+ /**
1824
+ * Cb for when closing the file dialog with no selection
1825
+ */
1826
+ onFileDialogCancel: PropTypes.func,
1827
+ /**
1828
+ * Cb for when opening the file dialog
1829
+ */
1830
+ onFileDialogOpen: PropTypes.func,
1831
+ /**
1832
+ * Set to true to use the https://developer.mozilla.org/en-US/docs/Web/API/File_System_Access_API
1833
+ * to open the file picker instead of using an `<input type="file">` click event.
1834
+ */
1835
+ useFsAccessApi: PropTypes.bool,
1836
+ /**
1837
+ * Cb for when the `dragenter` event occurs.
1838
+ *
1839
+ * @param {DragEvent} event
1840
+ */
1841
+ onDragEnter: PropTypes.func,
1842
+ /**
1843
+ * Cb for when the `dragleave` event occurs
1844
+ *
1845
+ * @param {DragEvent} event
1846
+ */
1847
+ onDragLeave: PropTypes.func,
1848
+ /**
1849
+ * Cb for when the `dragover` event occurs
1850
+ *
1851
+ * @param {DragEvent} event
1852
+ */
1853
+ onDragOver: PropTypes.func,
1854
+ /**
1855
+ * Cb for when the `drop` event occurs.
1856
+ * Note that this callback is invoked after the `getFilesFromEvent` callback is done.
1857
+ *
1858
+ * Files are accepted or rejected based on the `accept`, `multiple`, `minSize` and `maxSize` props.
1859
+ * `accept` must be a valid [MIME type](http://www.iana.org/assignments/media-types/media-types.xhtml) according to [input element specification](https://www.w3.org/wiki/HTML/Elements/input/file) or a valid file extension.
1860
+ * If `multiple` is set to false and additional files are dropped,
1861
+ * all files besides the first will be rejected.
1862
+ * Any file which does not have a size in the [`minSize`, `maxSize`] range, will be rejected as well.
1863
+ *
1864
+ * Note that the `onDrop` callback will always be invoked regardless if the dropped files were accepted or rejected.
1865
+ * If you'd like to react to a specific scenario, use the `onDropAccepted`/`onDropRejected` props.
1866
+ *
1867
+ * `onDrop` will provide you with an array of [File](https://developer.mozilla.org/en-US/docs/Web/API/File) objects which you can then process and send to a server.
1868
+ * For example, with [SuperAgent](https://github.com/visionmedia/superagent) as a http/ajax library:
1869
+ *
1870
+ * ```js
1871
+ * function onDrop(acceptedFiles) {
1872
+ * const req = request.post('/upload')
1873
+ * acceptedFiles.forEach(file => {
1874
+ * req.attach(file.name, file)
1875
+ * })
1876
+ * req.end(callback)
1877
+ * }
1878
+ * ```
1879
+ *
1880
+ * @param {File[]} acceptedFiles
1881
+ * @param {FileRejection[]} fileRejections
1882
+ * @param {(DragEvent|Event)} event A drag event or input change event (if files were selected via the file dialog)
1883
+ */
1884
+ onDrop: PropTypes.func,
1885
+ /**
1886
+ * Cb for when the `drop` event occurs.
1887
+ * Note that if no files are accepted, this callback is not invoked.
1888
+ *
1889
+ * @param {File[]} files
1890
+ * @param {(DragEvent|Event)} event
1891
+ */
1892
+ onDropAccepted: PropTypes.func,
1893
+ /**
1894
+ * Cb for when the `drop` event occurs.
1895
+ * Note that if no files are rejected, this callback is not invoked.
1896
+ *
1897
+ * @param {FileRejection[]} fileRejections
1898
+ * @param {(DragEvent|Event)} event
1899
+ */
1900
+ onDropRejected: PropTypes.func,
1901
+ /**
1902
+ * Custom validation function
1903
+ * @param {File} file
1904
+ * @returns {FileError|FileError[]}
1905
+ */
1906
+ validator: PropTypes.func
1907
+ };
1908
+ var initialState = {
1909
+ isFocused: false,
1910
+ isFileDialogActive: false,
1911
+ isDragActive: false,
1912
+ isDragAccept: false,
1913
+ isDragReject: false,
1914
+ draggedFiles: [],
1915
+ acceptedFiles: [],
1916
+ fileRejections: []
1917
+ };
1918
+ function useDropzone() {
1919
+ var options = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {};
1920
+ var _defaultProps$options = _objectSpread(_objectSpread({}, defaultProps), options), accept = _defaultProps$options.accept, disabled = _defaultProps$options.disabled, getFilesFromEvent = _defaultProps$options.getFilesFromEvent, maxSize = _defaultProps$options.maxSize, minSize = _defaultProps$options.minSize, multiple = _defaultProps$options.multiple, maxFiles = _defaultProps$options.maxFiles, onDragEnter = _defaultProps$options.onDragEnter, onDragLeave = _defaultProps$options.onDragLeave, onDragOver = _defaultProps$options.onDragOver, onDrop = _defaultProps$options.onDrop, onDropAccepted = _defaultProps$options.onDropAccepted, onDropRejected = _defaultProps$options.onDropRejected, onFileDialogCancel = _defaultProps$options.onFileDialogCancel, onFileDialogOpen = _defaultProps$options.onFileDialogOpen, useFsAccessApi = _defaultProps$options.useFsAccessApi, preventDropOnDocument = _defaultProps$options.preventDropOnDocument, noClick = _defaultProps$options.noClick, noKeyboard = _defaultProps$options.noKeyboard, noDrag = _defaultProps$options.noDrag, noDragEventsBubbling = _defaultProps$options.noDragEventsBubbling, validator = _defaultProps$options.validator;
1921
+ var onFileDialogOpenCb = useMemo(function() {
1922
+ return typeof onFileDialogOpen === "function" ? onFileDialogOpen : noop;
1923
+ }, [onFileDialogOpen]);
1924
+ var onFileDialogCancelCb = useMemo(function() {
1925
+ return typeof onFileDialogCancel === "function" ? onFileDialogCancel : noop;
1926
+ }, [onFileDialogCancel]);
1927
+ var rootRef = useRef(null);
1928
+ var inputRef = useRef(null);
1929
+ var _useReducer = useReducer(reducer, initialState), _useReducer2 = _slicedToArray(_useReducer, 2), state = _useReducer2[0], dispatch = _useReducer2[1];
1930
+ var isFocused = state.isFocused, isFileDialogActive = state.isFileDialogActive, draggedFiles = state.draggedFiles;
1931
+ var onWindowFocus = function onWindowFocus2() {
1932
+ if (isFileDialogActive) {
1933
+ setTimeout(function() {
1934
+ if (inputRef.current) {
1935
+ var files = inputRef.current.files;
1936
+ if (!files.length) {
1937
+ dispatch({
1938
+ type: "closeDialog"
1939
+ });
1940
+ onFileDialogCancelCb();
1941
+ }
1942
+ }
1943
+ }, 300);
1944
+ }
1945
+ };
1946
+ useEffect(function() {
1947
+ if (useFsAccessApi && canUseFileSystemAccessAPI()) {
1948
+ return function() {
1949
+ };
1950
+ }
1951
+ window.addEventListener("focus", onWindowFocus, false);
1952
+ return function() {
1953
+ window.removeEventListener("focus", onWindowFocus, false);
1954
+ };
1955
+ }, [inputRef, isFileDialogActive, onFileDialogCancelCb, useFsAccessApi]);
1956
+ var dragTargetsRef = useRef([]);
1957
+ var onDocumentDrop = function onDocumentDrop2(event) {
1958
+ if (rootRef.current && rootRef.current.contains(event.target)) {
1959
+ return;
1960
+ }
1961
+ event.preventDefault();
1962
+ dragTargetsRef.current = [];
1963
+ };
1964
+ useEffect(function() {
1965
+ if (preventDropOnDocument) {
1966
+ document.addEventListener("dragover", onDocumentDragOver, false);
1967
+ document.addEventListener("drop", onDocumentDrop, false);
1968
+ }
1969
+ return function() {
1970
+ if (preventDropOnDocument) {
1971
+ document.removeEventListener("dragover", onDocumentDragOver);
1972
+ document.removeEventListener("drop", onDocumentDrop);
1973
+ }
1974
+ };
1975
+ }, [rootRef, preventDropOnDocument]);
1976
+ var onDragEnterCb = useCallback(function(event) {
1977
+ event.preventDefault();
1978
+ event.persist();
1979
+ stopPropagation(event);
1980
+ dragTargetsRef.current = [].concat(_toConsumableArray(dragTargetsRef.current), [event.target]);
1981
+ if (isEvtWithFiles(event)) {
1982
+ Promise.resolve(getFilesFromEvent(event)).then(function(draggedFiles2) {
1983
+ if (isPropagationStopped(event) && !noDragEventsBubbling) {
1984
+ return;
1985
+ }
1986
+ dispatch({
1987
+ draggedFiles: draggedFiles2,
1988
+ isDragActive: true,
1989
+ type: "setDraggedFiles"
1990
+ });
1991
+ if (onDragEnter) {
1992
+ onDragEnter(event);
1993
+ }
1994
+ });
1995
+ }
1996
+ }, [getFilesFromEvent, onDragEnter, noDragEventsBubbling]);
1997
+ var onDragOverCb = useCallback(function(event) {
1998
+ event.preventDefault();
1999
+ event.persist();
2000
+ stopPropagation(event);
2001
+ var hasFiles = isEvtWithFiles(event);
2002
+ if (hasFiles && event.dataTransfer) {
2003
+ try {
2004
+ event.dataTransfer.dropEffect = "copy";
2005
+ } catch (_unused) {
2006
+ }
2007
+ }
2008
+ if (hasFiles && onDragOver) {
2009
+ onDragOver(event);
2010
+ }
2011
+ return false;
2012
+ }, [onDragOver, noDragEventsBubbling]);
2013
+ var onDragLeaveCb = useCallback(function(event) {
2014
+ event.preventDefault();
2015
+ event.persist();
2016
+ stopPropagation(event);
2017
+ var targets = dragTargetsRef.current.filter(function(target) {
2018
+ return rootRef.current && rootRef.current.contains(target);
2019
+ });
2020
+ var targetIdx = targets.indexOf(event.target);
2021
+ if (targetIdx !== -1) {
2022
+ targets.splice(targetIdx, 1);
2023
+ }
2024
+ dragTargetsRef.current = targets;
2025
+ if (targets.length > 0) {
2026
+ return;
2027
+ }
2028
+ dispatch({
2029
+ isDragActive: false,
2030
+ type: "setDraggedFiles",
2031
+ draggedFiles: []
2032
+ });
2033
+ if (isEvtWithFiles(event) && onDragLeave) {
2034
+ onDragLeave(event);
2035
+ }
2036
+ }, [rootRef, onDragLeave, noDragEventsBubbling]);
2037
+ var setFiles = useCallback(function(files, event) {
2038
+ var acceptedFiles = [];
2039
+ var fileRejections = [];
2040
+ files.forEach(function(file) {
2041
+ var _fileAccepted = fileAccepted(file, accept), _fileAccepted2 = _slicedToArray(_fileAccepted, 2), accepted = _fileAccepted2[0], acceptError = _fileAccepted2[1];
2042
+ var _fileMatchSize = fileMatchSize(file, minSize, maxSize), _fileMatchSize2 = _slicedToArray(_fileMatchSize, 2), sizeMatch = _fileMatchSize2[0], sizeError = _fileMatchSize2[1];
2043
+ var customErrors = validator ? validator(file) : null;
2044
+ if (accepted && sizeMatch && !customErrors) {
2045
+ acceptedFiles.push(file);
2046
+ } else {
2047
+ var errors = [acceptError, sizeError];
2048
+ if (customErrors) {
2049
+ errors = errors.concat(customErrors);
2050
+ }
2051
+ fileRejections.push({
2052
+ file,
2053
+ errors: errors.filter(function(e) {
2054
+ return e;
2055
+ })
2056
+ });
2057
+ }
2058
+ });
2059
+ if (!multiple && acceptedFiles.length > 1 || multiple && maxFiles >= 1 && acceptedFiles.length > maxFiles) {
2060
+ acceptedFiles.forEach(function(file) {
2061
+ fileRejections.push({
2062
+ file,
2063
+ errors: [TOO_MANY_FILES_REJECTION]
2064
+ });
2065
+ });
2066
+ acceptedFiles.splice(0);
2067
+ }
2068
+ dispatch({
2069
+ acceptedFiles,
2070
+ fileRejections,
2071
+ type: "setFiles"
2072
+ });
2073
+ if (onDrop) {
2074
+ onDrop(acceptedFiles, fileRejections, event);
2075
+ }
2076
+ if (fileRejections.length > 0 && onDropRejected) {
2077
+ onDropRejected(fileRejections, event);
2078
+ }
2079
+ if (acceptedFiles.length > 0 && onDropAccepted) {
2080
+ onDropAccepted(acceptedFiles, event);
2081
+ }
2082
+ }, [dispatch, multiple, accept, minSize, maxSize, maxFiles, onDrop, onDropAccepted, onDropRejected, validator]);
2083
+ var onDropCb = useCallback(function(event) {
2084
+ event.preventDefault();
2085
+ event.persist();
2086
+ stopPropagation(event);
2087
+ dragTargetsRef.current = [];
2088
+ if (isEvtWithFiles(event)) {
2089
+ Promise.resolve(getFilesFromEvent(event)).then(function(files) {
2090
+ if (isPropagationStopped(event) && !noDragEventsBubbling) {
2091
+ return;
2092
+ }
2093
+ setFiles(files, event);
2094
+ });
2095
+ }
2096
+ dispatch({
2097
+ type: "reset"
2098
+ });
2099
+ }, [getFilesFromEvent, setFiles, noDragEventsBubbling]);
2100
+ var openFileDialog = useCallback(function() {
2101
+ if (useFsAccessApi && canUseFileSystemAccessAPI()) {
2102
+ dispatch({
2103
+ type: "openDialog"
2104
+ });
2105
+ onFileDialogOpenCb();
2106
+ var opts = {
2107
+ multiple,
2108
+ types: filePickerOptionsTypes(accept)
2109
+ };
2110
+ window.showOpenFilePicker(opts).then(function(handles) {
2111
+ return getFilesFromEvent(handles);
2112
+ }).then(function(files) {
2113
+ return setFiles(files, null);
2114
+ }).catch(function(e) {
2115
+ return onFileDialogCancelCb(e);
2116
+ }).finally(function() {
2117
+ return dispatch({
2118
+ type: "closeDialog"
2119
+ });
2120
+ });
2121
+ return;
2122
+ }
2123
+ if (inputRef.current) {
2124
+ dispatch({
2125
+ type: "openDialog"
2126
+ });
2127
+ onFileDialogOpenCb();
2128
+ inputRef.current.value = null;
2129
+ inputRef.current.click();
2130
+ }
2131
+ }, [dispatch, onFileDialogOpenCb, onFileDialogCancelCb, useFsAccessApi, setFiles, accept, multiple]);
2132
+ var onKeyDownCb = useCallback(function(event) {
2133
+ if (!rootRef.current || !rootRef.current.isEqualNode(event.target)) {
2134
+ return;
2135
+ }
2136
+ if (event.keyCode === 32 || event.keyCode === 13) {
2137
+ event.preventDefault();
2138
+ openFileDialog();
2139
+ }
2140
+ }, [rootRef, inputRef, openFileDialog]);
2141
+ var onFocusCb = useCallback(function() {
2142
+ dispatch({
2143
+ type: "focus"
2144
+ });
2145
+ }, []);
2146
+ var onBlurCb = useCallback(function() {
2147
+ dispatch({
2148
+ type: "blur"
2149
+ });
2150
+ }, []);
2151
+ var onClickCb = useCallback(function() {
2152
+ if (noClick) {
2153
+ return;
2154
+ }
2155
+ if (isIeOrEdge()) {
2156
+ setTimeout(openFileDialog, 0);
2157
+ } else {
2158
+ openFileDialog();
2159
+ }
2160
+ }, [inputRef, noClick, openFileDialog]);
2161
+ var composeHandler = function composeHandler2(fn) {
2162
+ return disabled ? null : fn;
2163
+ };
2164
+ var composeKeyboardHandler = function composeKeyboardHandler2(fn) {
2165
+ return noKeyboard ? null : composeHandler(fn);
2166
+ };
2167
+ var composeDragHandler = function composeDragHandler2(fn) {
2168
+ return noDrag ? null : composeHandler(fn);
2169
+ };
2170
+ var stopPropagation = function stopPropagation2(event) {
2171
+ if (noDragEventsBubbling) {
2172
+ event.stopPropagation();
2173
+ }
2174
+ };
2175
+ var getRootProps = useMemo(function() {
2176
+ return function() {
2177
+ var _ref2 = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, _ref2$refKey = _ref2.refKey, refKey = _ref2$refKey === void 0 ? "ref" : _ref2$refKey, role = _ref2.role, onKeyDown = _ref2.onKeyDown, onFocus = _ref2.onFocus, onBlur = _ref2.onBlur, onClick = _ref2.onClick, onDragEnter2 = _ref2.onDragEnter, onDragOver2 = _ref2.onDragOver, onDragLeave2 = _ref2.onDragLeave, onDrop2 = _ref2.onDrop, rest = _objectWithoutProperties(_ref2, _excluded3);
2178
+ return _objectSpread(_objectSpread(_defineProperty({
2179
+ onKeyDown: composeKeyboardHandler(composeEventHandlers(onKeyDown, onKeyDownCb)),
2180
+ onFocus: composeKeyboardHandler(composeEventHandlers(onFocus, onFocusCb)),
2181
+ onBlur: composeKeyboardHandler(composeEventHandlers(onBlur, onBlurCb)),
2182
+ onClick: composeHandler(composeEventHandlers(onClick, onClickCb)),
2183
+ onDragEnter: composeDragHandler(composeEventHandlers(onDragEnter2, onDragEnterCb)),
2184
+ onDragOver: composeDragHandler(composeEventHandlers(onDragOver2, onDragOverCb)),
2185
+ onDragLeave: composeDragHandler(composeEventHandlers(onDragLeave2, onDragLeaveCb)),
2186
+ onDrop: composeDragHandler(composeEventHandlers(onDrop2, onDropCb)),
2187
+ role: typeof role === "string" && role !== "" ? role : "button"
2188
+ }, refKey, rootRef), !disabled && !noKeyboard ? {
2189
+ tabIndex: 0
2190
+ } : {}), rest);
2191
+ };
2192
+ }, [rootRef, onKeyDownCb, onFocusCb, onBlurCb, onClickCb, onDragEnterCb, onDragOverCb, onDragLeaveCb, onDropCb, noKeyboard, noDrag, disabled]);
2193
+ var onInputElementClick = useCallback(function(event) {
2194
+ event.stopPropagation();
2195
+ }, []);
2196
+ var getInputProps = useMemo(function() {
2197
+ return function() {
2198
+ var _ref3 = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}, _ref3$refKey = _ref3.refKey, refKey = _ref3$refKey === void 0 ? "ref" : _ref3$refKey, onChange = _ref3.onChange, onClick = _ref3.onClick, rest = _objectWithoutProperties(_ref3, _excluded4);
2199
+ var inputProps = _defineProperty({
2200
+ accept,
2201
+ multiple,
2202
+ type: "file",
2203
+ style: {
2204
+ display: "none"
2205
+ },
2206
+ onChange: composeHandler(composeEventHandlers(onChange, onDropCb)),
2207
+ onClick: composeHandler(composeEventHandlers(onClick, onInputElementClick)),
2208
+ autoComplete: "off",
2209
+ tabIndex: -1
2210
+ }, refKey, inputRef);
2211
+ return _objectSpread(_objectSpread({}, inputProps), rest);
2212
+ };
2213
+ }, [inputRef, accept, multiple, onDropCb, disabled]);
2214
+ var fileCount = draggedFiles.length;
2215
+ var isDragAccept = fileCount > 0 && allFilesAccepted({
2216
+ files: draggedFiles,
2217
+ accept,
2218
+ minSize,
2219
+ maxSize,
2220
+ multiple,
2221
+ maxFiles
2222
+ });
2223
+ var isDragReject = fileCount > 0 && !isDragAccept;
2224
+ return _objectSpread(_objectSpread({}, state), {}, {
2225
+ isDragAccept,
2226
+ isDragReject,
2227
+ isFocused: isFocused && !disabled,
2228
+ getRootProps,
2229
+ getInputProps,
2230
+ rootRef,
2231
+ inputRef,
2232
+ open: composeHandler(openFileDialog)
2233
+ });
2234
+ }
2235
+ function reducer(state, action) {
2236
+ switch (action.type) {
2237
+ case "focus":
2238
+ return _objectSpread(_objectSpread({}, state), {}, {
2239
+ isFocused: true
2240
+ });
2241
+ case "blur":
2242
+ return _objectSpread(_objectSpread({}, state), {}, {
2243
+ isFocused: false
2244
+ });
2245
+ case "openDialog":
2246
+ return _objectSpread(_objectSpread({}, initialState), {}, {
2247
+ isFileDialogActive: true
2248
+ });
2249
+ case "closeDialog":
2250
+ return _objectSpread(_objectSpread({}, state), {}, {
2251
+ isFileDialogActive: false
2252
+ });
2253
+ case "setDraggedFiles":
2254
+ var isDragActive = action.isDragActive, draggedFiles = action.draggedFiles;
2255
+ return _objectSpread(_objectSpread({}, state), {}, {
2256
+ draggedFiles,
2257
+ isDragActive
2258
+ });
2259
+ case "setFiles":
2260
+ return _objectSpread(_objectSpread({}, state), {}, {
2261
+ acceptedFiles: action.acceptedFiles,
2262
+ fileRejections: action.fileRejections
2263
+ });
2264
+ case "reset":
2265
+ return _objectSpread({}, initialState);
2266
+ default:
2267
+ return state;
2268
+ }
2269
+ }
2270
+ function noop() {
2271
+ }
2272
+ var classnames = { exports: {} };
2273
+ /*!
2274
+ Copyright (c) 2018 Jed Watson.
2275
+ Licensed under the MIT License (MIT), see
2276
+ http://jedwatson.github.io/classnames
2277
+ */
2278
+ var hasRequiredClassnames;
2279
+ function requireClassnames() {
2280
+ if (hasRequiredClassnames) return classnames.exports;
2281
+ hasRequiredClassnames = 1;
2282
+ (function(module) {
2283
+ (function() {
2284
+ var hasOwn = {}.hasOwnProperty;
2285
+ function classNames2() {
2286
+ var classes = "";
2287
+ for (var i = 0; i < arguments.length; i++) {
2288
+ var arg = arguments[i];
2289
+ if (arg) {
2290
+ classes = appendClass(classes, parseValue(arg));
2291
+ }
2292
+ }
2293
+ return classes;
2294
+ }
2295
+ function parseValue(arg) {
2296
+ if (typeof arg === "string" || typeof arg === "number") {
2297
+ return arg;
2298
+ }
2299
+ if (typeof arg !== "object") {
2300
+ return "";
2301
+ }
2302
+ if (Array.isArray(arg)) {
2303
+ return classNames2.apply(null, arg);
2304
+ }
2305
+ if (arg.toString !== Object.prototype.toString && !arg.toString.toString().includes("[native code]")) {
2306
+ return arg.toString();
2307
+ }
2308
+ var classes = "";
2309
+ for (var key in arg) {
2310
+ if (hasOwn.call(arg, key) && arg[key]) {
2311
+ classes = appendClass(classes, key);
2312
+ }
2313
+ }
2314
+ return classes;
2315
+ }
2316
+ function appendClass(value, newClass) {
2317
+ if (!newClass) {
2318
+ return value;
2319
+ }
2320
+ if (value) {
2321
+ return value + " " + newClass;
2322
+ }
2323
+ return value + newClass;
2324
+ }
2325
+ if (module.exports) {
2326
+ classNames2.default = classNames2;
2327
+ module.exports = classNames2;
2328
+ } else {
2329
+ window.classNames = classNames2;
2330
+ }
2331
+ })();
2332
+ })(classnames);
2333
+ return classnames.exports;
2334
+ }
2335
+ var classnamesExports = requireClassnames();
2336
+ const classNames = /* @__PURE__ */ getDefaultExportFromCjs(classnamesExports);
2337
+ const FileUpload = ({
2338
+ standbyText = "Dra fil eller klikk for å laste opp",
2339
+ errorText = "Feil ved opplasting av fil",
2340
+ successText = "Opplasting fullført",
2341
+ errorUpload = false,
2342
+ onDrop,
2343
+ onDelete = (file) => console.log(file),
2344
+ accept = "",
2345
+ files = [],
2346
+ label,
2347
+ removeFileButtonDescription = "Fjern fil",
2348
+ style,
2349
+ ...rest
2350
+ }) => {
2351
+ const { getRootProps, getInputProps, isDragActive, isDragReject } = useDropzone({
2352
+ onDrop,
2353
+ accept,
2354
+ ...rest
2355
+ });
2356
+ const success = files.length > 0;
2357
+ return /* @__PURE__ */ jsxs("div", { className: "eds-file-upload__wrapper", ...style, children: [
2358
+ /* @__PURE__ */ jsxs("div", { className: "eds-file-upload__input", ...getRootProps(), children: [
2359
+ label && /* @__PURE__ */ jsx(Label, { style: { display: "flex" }, children: label }),
2360
+ /* @__PURE__ */ jsx("input", { ...getInputProps() }),
2361
+ /* @__PURE__ */ jsx(
2362
+ "span",
2363
+ {
2364
+ className: classNames(
2365
+ "eds-file-upload__dropzone",
2366
+ {
2367
+ "eds-file-upload__dropzone--success": success
2368
+ },
2369
+ { "eds-file-upload__dropzone--active": isDragActive },
2370
+ { "eds-file-upload__dropzone--reject": isDragReject },
2371
+ { "eds-file-upload__dropzone--error": errorUpload }
2372
+ ),
2373
+ children: success ? successText : errorUpload ? errorText : standbyText
2374
+ }
2375
+ )
2376
+ ] }),
2377
+ /* @__PURE__ */ jsx("div", { className: "eds-file-upload__file-list", children: files.map((file, index) => /* @__PURE__ */ jsxs("div", { className: "eds-file-upload__file-name", children: [
2378
+ /* @__PURE__ */ jsx(
2379
+ FileIcon,
2380
+ {
2381
+ "aria-label": "File icon",
2382
+ className: "eds-file-upload__file-name-icon"
2383
+ }
2384
+ ),
2385
+ /* @__PURE__ */ jsxs("span", { className: "eds-field-upload__file-name-path", children: [
2386
+ file.name,
2387
+ " - ",
2388
+ convertSizeToHuman(file.size),
2389
+ " "
2390
+ ] }),
2391
+ /* @__PURE__ */ jsx(
2392
+ IconButton,
2393
+ {
2394
+ onClick: () => onDelete(file),
2395
+ type: "button",
2396
+ "aria-label": `${removeFileButtonDescription}, ${file.name}`,
2397
+ children: /* @__PURE__ */ jsx(DeleteIcon, {})
2398
+ }
2399
+ )
2400
+ ] }, index)) })
2401
+ ] });
98
2402
  };
99
2403
  function convertSizeToHuman(size) {
100
- if (size < 1000) {
101
- return size + 'bytes;';
102
- } else if (size < 1000000) {
103
- return size / 1000 + " KB";
2404
+ if (size < 1e3) {
2405
+ return size + "bytes;";
2406
+ } else if (size < 1e6) {
2407
+ return `${size / 1e3} KB`;
104
2408
  } else {
105
- return (size / 1000000).toPrecision(4) + " MB";
2409
+ return `${(size / 1e6).toPrecision(4)} MB`;
106
2410
  }
107
2411
  }
108
-
109
- warnAboutMissingStyles('fileupload');
110
-
111
- export { FileUpload };
2412
+ warnAboutMissingStyles("fileupload");
2413
+ export {
2414
+ FileUpload
2415
+ };
112
2416
  //# sourceMappingURL=fileupload.esm.js.map