mimir-ui-kit 1.38.38 → 1.38.39
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,106 +1,113 @@
|
|
1
|
-
import { jsxs as
|
2
|
-
import { c as
|
3
|
-
import { forwardRef as
|
4
|
-
import { imageTypes as
|
1
|
+
import { jsxs as F, jsx as m, Fragment as B } from "react/jsx-runtime";
|
2
|
+
import { c as _ } from "../../index-DIxK0V-G.js";
|
3
|
+
import { forwardRef as j, useState as A, useEffect as C, useMemo as O } from "react";
|
4
|
+
import { imageTypes as v } from "./constants.js";
|
5
5
|
import "../Button/Button.js";
|
6
|
-
import { EButtonVariantDefault as
|
7
|
-
import { ListFiles as
|
8
|
-
import { EFileItemVariant as
|
9
|
-
import { ListPhotos as
|
10
|
-
import { Uploader as
|
6
|
+
import { EButtonVariantDefault as k } from "../Button/constants.js";
|
7
|
+
import { ListFiles as q } from "../ListFiles/ListFiles.js";
|
8
|
+
import { EFileItemVariant as G } from "../ListFiles/constants.js";
|
9
|
+
import { ListPhotos as H } from "../ListPhotos/ListPhotos.js";
|
10
|
+
import { Uploader as J } from "../Uploader/Uploader.js";
|
11
11
|
import '../../assets/UploaderPhotos.css';const x = {
|
12
12
|
"upload-file-wrapper": "_upload-file-wrapper_1a115_2"
|
13
|
-
},
|
14
|
-
(i,
|
13
|
+
}, u = (i) => "file" in i && i.file instanceof File ? v.includes(i.file.type) : "type" in i && typeof i.type == "string" ? v.includes(i.type) : !1, se = j(
|
14
|
+
(i, g) => {
|
15
15
|
const {
|
16
|
-
type:
|
17
|
-
filesType:
|
18
|
-
arrayName:
|
19
|
-
maxSize:
|
20
|
-
onChange:
|
21
|
-
value:
|
16
|
+
type: s,
|
17
|
+
filesType: w,
|
18
|
+
arrayName: z,
|
19
|
+
maxSize: I,
|
20
|
+
onChange: a,
|
21
|
+
value: l,
|
22
22
|
maxFiles: n,
|
23
|
-
titleUploader:
|
23
|
+
titleUploader: P,
|
24
24
|
buttonText: U = "Выберите файлы",
|
25
|
-
showOnlyUploadButton:
|
26
|
-
uploadButtonVariant: b =
|
27
|
-
buttonSize:
|
28
|
-
buttonClassName:
|
29
|
-
variantListFiles:
|
30
|
-
onMaxFilesExceeded:
|
31
|
-
onMaxSizeExceeded:
|
25
|
+
showOnlyUploadButton: c = !1,
|
26
|
+
uploadButtonVariant: b = k.SecondaryAsphalt,
|
27
|
+
buttonSize: E = "m",
|
28
|
+
buttonClassName: S,
|
29
|
+
variantListFiles: V = G.white,
|
30
|
+
onMaxFilesExceeded: D,
|
31
|
+
onMaxSizeExceeded: L,
|
32
32
|
onInvalidFileType: M
|
33
|
-
} = i, [
|
34
|
-
|
35
|
-
),
|
33
|
+
} = i, [r, p] = A(
|
34
|
+
l || []
|
35
|
+
), h = !!n && r.length >= n;
|
36
36
|
C(() => {
|
37
|
-
|
38
|
-
}, [
|
37
|
+
l && p(l);
|
38
|
+
}, [l]);
|
39
39
|
const N = (t) => {
|
40
|
-
const o = t.value.map((e) =>
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
40
|
+
const o = t.value.map((e) => u(e.file) ? new Promise((d) => {
|
41
|
+
const f = new FileReader();
|
42
|
+
f.onload = () => {
|
43
|
+
d({
|
44
|
+
id: e.id,
|
45
|
+
url: f.result,
|
46
|
+
type: e.file.type,
|
47
|
+
name: e.file.name,
|
48
|
+
size: e.file.size
|
49
|
+
});
|
50
|
+
}, f.readAsDataURL(e.file);
|
51
|
+
}) : Promise.resolve({
|
47
52
|
id: e.id,
|
48
53
|
url: "",
|
49
54
|
size: e.file.size,
|
50
55
|
name: e.file.name,
|
51
56
|
type: e.file.type
|
57
|
+
}));
|
58
|
+
Promise.all(o).then((e) => {
|
59
|
+
p((d) => [...d, ...e]), a == null || a({ type: "add", data: t.value });
|
52
60
|
});
|
53
|
-
|
54
|
-
|
55
|
-
p((o) => o.filter((e) => e.id !== t)), s == null || s({ type: "delete", data: t });
|
61
|
+
}, y = (t) => {
|
62
|
+
p((o) => o.filter((e) => e.id !== t)), a == null || a({ type: "delete", data: t });
|
56
63
|
}, { photos: R, files: T } = O(() => {
|
57
|
-
const t = () =>
|
58
|
-
return
|
59
|
-
}, [
|
60
|
-
return /* @__PURE__ */
|
64
|
+
const t = () => r.filter((e) => !u(e)), o = () => r.filter(u);
|
65
|
+
return s === "all" ? { files: t(), photos: o() } : s === "files" ? { photos: [], files: t() } : s === "photos" ? { files: [], photos: o() } : { files: [], photos: [] };
|
66
|
+
}, [r, s]);
|
67
|
+
return /* @__PURE__ */ F(
|
61
68
|
"div",
|
62
69
|
{
|
63
70
|
"data-testid": "universal-uploader",
|
64
|
-
className:
|
71
|
+
className: _(
|
65
72
|
x["upload-file-wrapper"],
|
66
|
-
|
73
|
+
h && x.disabled
|
67
74
|
),
|
68
75
|
children: [
|
69
|
-
/* @__PURE__ */
|
70
|
-
|
76
|
+
/* @__PURE__ */ m(
|
77
|
+
J,
|
71
78
|
{
|
72
|
-
filesType:
|
73
|
-
arrayName:
|
74
|
-
maxSize:
|
79
|
+
filesType: w,
|
80
|
+
arrayName: z,
|
81
|
+
maxSize: I,
|
75
82
|
onChangeValue: N,
|
76
|
-
ref:
|
77
|
-
maxFiles: n && n -
|
78
|
-
isDisabled:
|
79
|
-
titleUploader:
|
80
|
-
showOnlyUploadButton:
|
83
|
+
ref: g,
|
84
|
+
maxFiles: n && n - r.length,
|
85
|
+
isDisabled: h,
|
86
|
+
titleUploader: P,
|
87
|
+
showOnlyUploadButton: c,
|
81
88
|
buttonText: U,
|
82
89
|
uploadButtonVariant: b,
|
83
|
-
buttonSize:
|
84
|
-
buttonClassName:
|
85
|
-
onMaxFilesExceeded:
|
86
|
-
onMaxSizeExceeded:
|
90
|
+
buttonSize: E,
|
91
|
+
buttonClassName: S,
|
92
|
+
onMaxFilesExceeded: D,
|
93
|
+
onMaxSizeExceeded: L,
|
87
94
|
onInvalidFileType: M
|
88
95
|
}
|
89
96
|
),
|
90
|
-
!
|
91
|
-
(
|
92
|
-
|
97
|
+
!c && /* @__PURE__ */ F(B, { children: [
|
98
|
+
(s === "files" || s === "all") && /* @__PURE__ */ m(
|
99
|
+
q,
|
93
100
|
{
|
94
101
|
value: T,
|
95
|
-
onChange: (t) =>
|
96
|
-
variant:
|
102
|
+
onChange: (t) => y(t.deleteId),
|
103
|
+
variant: V
|
97
104
|
}
|
98
105
|
),
|
99
|
-
(
|
100
|
-
|
106
|
+
(s === "photos" || s === "all") && /* @__PURE__ */ m(
|
107
|
+
H,
|
101
108
|
{
|
102
109
|
value: R,
|
103
|
-
onChange: (t) =>
|
110
|
+
onChange: (t) => y(t.deleteId)
|
104
111
|
}
|
105
112
|
)
|
106
113
|
] })
|
@@ -110,5 +117,5 @@ import '../../assets/UploaderPhotos.css';const x = {
|
|
110
117
|
}
|
111
118
|
);
|
112
119
|
export {
|
113
|
-
|
120
|
+
se as UniversalUploader
|
114
121
|
};
|