@sps-woodland/file-upload 8.35.3 → 8.35.5
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.
- package/lib/index.js +118 -92
- package/lib/index.umd.cjs +2 -2
- package/lib/mime-type.enum.d.ts +20 -0
- package/lib/style.css +1 -1
- package/package.json +16 -16
package/lib/index.js
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import * as e from "react";
|
|
2
|
-
import { Metadata as ve, cl as
|
|
2
|
+
import { Metadata as ve, cl as R, Spinner as we } from "@sps-woodland/core";
|
|
3
3
|
import { parseFileSize as ge, code as _ } from "@spscommerce/utils";
|
|
4
|
-
import { Button as
|
|
4
|
+
import { Button as I } from "@sps-woodland/buttons";
|
|
5
5
|
import { GENERAL_ERROR_LARGE as Fe, UPLOAD_LARGE as Ee } from "@sps-woodland/illustrations";
|
|
6
6
|
import { useWoodlandLanguage as xe } from "@spscommerce/i18n";
|
|
7
|
-
const
|
|
7
|
+
const W = {
|
|
8
8
|
"7Z": ["application/x-7z-compressed"],
|
|
9
9
|
AAC: ["audio/aac"],
|
|
10
10
|
ABW: ["application/x-abiword"],
|
|
@@ -20,8 +20,18 @@ const z = {
|
|
|
20
20
|
CSS: ["text/css"],
|
|
21
21
|
CSV: ["text/csv", "application/vnd.ms-excel"],
|
|
22
22
|
DOC: ["application/msword"],
|
|
23
|
+
DOT: ["application/msword"],
|
|
23
24
|
DOCX: ["application/vnd.openxmlformats-officedocument.wordprocessingml.document"],
|
|
24
|
-
|
|
25
|
+
DOTX: ["application/vnd.openxmlformats-officedocument.wordprocessingml.template"],
|
|
26
|
+
DOCM: ["application/vnd.ms-word.document.macroEnabled.12"],
|
|
27
|
+
DOTM: ["application/vnd.ms-word.template.macroEnabled.12"],
|
|
28
|
+
EML: [
|
|
29
|
+
"application/octet-stream",
|
|
30
|
+
"message/rfc822",
|
|
31
|
+
"multipart/mixed",
|
|
32
|
+
"message/rfc5322",
|
|
33
|
+
"message/rfc6532"
|
|
34
|
+
],
|
|
25
35
|
EOT: ["application/vnd.ms-fontobject"],
|
|
26
36
|
EPUB: ["application/epub+zip"],
|
|
27
37
|
ES: ["application/ecmascript"],
|
|
@@ -54,7 +64,16 @@ const z = {
|
|
|
54
64
|
OTF: ["font/otf"],
|
|
55
65
|
PNG: ["image/png"],
|
|
56
66
|
PDF: ["application/pdf"],
|
|
67
|
+
POT: ["application/vnd.ms-powerpoint"],
|
|
68
|
+
POTM: ["application/vnd.ms-powerpoint.template.macroEnabled.12"],
|
|
69
|
+
POTX: ["application/vnd.openxmlformats-officedocument.presentationml.template"],
|
|
70
|
+
PPA: ["application/vnd.ms-powerpoint"],
|
|
71
|
+
PPAM: ["application/vnd.ms-powerpoint.addin.macroEnabled.12"],
|
|
72
|
+
PPS: ["application/vnd.ms-powerpoint"],
|
|
73
|
+
PPSM: ["application/vnd.ms-powerpoint.slideshow.macroEnabled.12"],
|
|
57
74
|
PPT: ["application/vnd.ms-powerpoint"],
|
|
75
|
+
PPTM: ["application/vnd.ms-powerpoint.presentation.macroEnabled.12"],
|
|
76
|
+
PPSX: ["application/vnd.openxmlformats-officedocument.presentationml.slideshow"],
|
|
58
77
|
PPTX: ["application/vnd.openxmlformats-officedocument.presentationml.presentation"],
|
|
59
78
|
RAR: ["application/x-rar-compressed"],
|
|
60
79
|
RTF: ["application/rtf"],
|
|
@@ -75,76 +94,83 @@ const z = {
|
|
|
75
94
|
WOFF: ["font/woff"],
|
|
76
95
|
WOFF2: ["font/woff2"],
|
|
77
96
|
XHTML: ["application/xhtml+xml"],
|
|
97
|
+
XLA: ["application/vnd.ms-excel"],
|
|
78
98
|
XLS: ["application/vnd.ms-excel"],
|
|
99
|
+
XLSB: ["application/vnd.ms-excel.sheet.binary.macroEnabled.12"],
|
|
100
|
+
XLT: ["application/vnd.ms-excel"],
|
|
101
|
+
XLAM: ["application/vnd.ms-excel.addin.macroEnabled.12"],
|
|
102
|
+
XLSM: ["application/vnd.ms-excel.sheet.macroEnabled.12"],
|
|
79
103
|
XLSX: ["application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"],
|
|
104
|
+
XLTM: ["application/vnd.ms-excel.template.macroEnabled.12"],
|
|
105
|
+
XLTX: ["application/vnd.openxmlformats-officedocument.spreadsheetml.template"],
|
|
80
106
|
XML: ["application/xml"],
|
|
81
107
|
XUL: ["application/vnd.mozilla.xul+xml"],
|
|
82
108
|
ZIP: ["application/zip"]
|
|
83
109
|
};
|
|
84
|
-
function be(
|
|
85
|
-
return i in
|
|
86
|
-
value:
|
|
110
|
+
function be(o, i, l) {
|
|
111
|
+
return i in o ? Object.defineProperty(o, i, {
|
|
112
|
+
value: l,
|
|
87
113
|
enumerable: !0,
|
|
88
114
|
configurable: !0,
|
|
89
115
|
writable: !0
|
|
90
|
-
}) :
|
|
116
|
+
}) : o[i] = l, o;
|
|
91
117
|
}
|
|
92
|
-
function
|
|
93
|
-
var
|
|
118
|
+
function z(o, i) {
|
|
119
|
+
var l = Object.keys(o);
|
|
94
120
|
if (Object.getOwnPropertySymbols) {
|
|
95
|
-
var t = Object.getOwnPropertySymbols(
|
|
121
|
+
var t = Object.getOwnPropertySymbols(o);
|
|
96
122
|
i && (t = t.filter(function(r) {
|
|
97
|
-
return Object.getOwnPropertyDescriptor(
|
|
98
|
-
})),
|
|
123
|
+
return Object.getOwnPropertyDescriptor(o, r).enumerable;
|
|
124
|
+
})), l.push.apply(l, t);
|
|
99
125
|
}
|
|
100
|
-
return
|
|
126
|
+
return l;
|
|
101
127
|
}
|
|
102
|
-
function
|
|
128
|
+
function G(o) {
|
|
103
129
|
for (var i = 1; i < arguments.length; i++) {
|
|
104
|
-
var
|
|
105
|
-
i % 2 ?
|
|
106
|
-
be(
|
|
107
|
-
}) : Object.getOwnPropertyDescriptors ? Object.defineProperties(
|
|
108
|
-
Object.defineProperty(
|
|
130
|
+
var l = arguments[i] != null ? arguments[i] : {};
|
|
131
|
+
i % 2 ? z(Object(l), !0).forEach(function(t) {
|
|
132
|
+
be(o, t, l[t]);
|
|
133
|
+
}) : Object.getOwnPropertyDescriptors ? Object.defineProperties(o, Object.getOwnPropertyDescriptors(l)) : z(Object(l)).forEach(function(t) {
|
|
134
|
+
Object.defineProperty(o, t, Object.getOwnPropertyDescriptor(l, t));
|
|
109
135
|
});
|
|
110
136
|
}
|
|
111
|
-
return
|
|
137
|
+
return o;
|
|
112
138
|
}
|
|
113
|
-
var
|
|
114
|
-
for (var t of Object.keys(
|
|
139
|
+
var ye = (o, i, l) => {
|
|
140
|
+
for (var t of Object.keys(o)) {
|
|
115
141
|
var r;
|
|
116
|
-
if (
|
|
142
|
+
if (o[t] !== ((r = i[t]) !== null && r !== void 0 ? r : l[t]))
|
|
117
143
|
return !1;
|
|
118
144
|
}
|
|
119
145
|
return !0;
|
|
120
|
-
},
|
|
121
|
-
var
|
|
146
|
+
}, O = (o) => (i) => {
|
|
147
|
+
var l = o.defaultClassName, t = G(G({}, o.defaultVariants), i);
|
|
122
148
|
for (var r in t) {
|
|
123
|
-
var m, g = (m = t[r]) !== null && m !== void 0 ? m :
|
|
149
|
+
var m, g = (m = t[r]) !== null && m !== void 0 ? m : o.defaultVariants[r];
|
|
124
150
|
if (g != null) {
|
|
125
151
|
var p = g;
|
|
126
152
|
typeof p == "boolean" && (p = p === !0 ? "true" : "false");
|
|
127
153
|
var s = (
|
|
128
154
|
// @ts-expect-error
|
|
129
|
-
|
|
155
|
+
o.variantClassNames[r][p]
|
|
130
156
|
);
|
|
131
|
-
s && (
|
|
157
|
+
s && (l += " " + s);
|
|
132
158
|
}
|
|
133
159
|
}
|
|
134
|
-
for (var [b,
|
|
135
|
-
|
|
136
|
-
return
|
|
137
|
-
},
|
|
138
|
-
function H({ list:
|
|
139
|
-
return /* @__PURE__ */ e.createElement(e.Fragment, null,
|
|
160
|
+
for (var [b, T] of o.compoundVariants)
|
|
161
|
+
ye(b, t, o.defaultVariants) && (l += " " + T);
|
|
162
|
+
return l;
|
|
163
|
+
}, Ue = O({ defaultClassName: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw0", variantClassNames: { active: { true: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw1", false: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw2" }, mini: { true: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw3", false: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw4" }, error: { true: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw5", false: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw6" }, shown: { true: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw7", false: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw8" }, disabled: { true: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw9", false: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwa" } }, defaultVariants: { active: !1, mini: !1, error: !1, shown: !0, disabled: !1 }, compoundVariants: [] }), Se = O({ defaultClassName: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwb", variantClassNames: { constrainContentWidth: { true: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwc", false: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwd" }, disabled: { true: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwe", false: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwf" } }, defaultVariants: { constrainContentWidth: !1, disabled: !1 }, compoundVariants: [] }), Z = "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwg", je = O({ defaultClassName: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwh", variantClassNames: { mini: { true: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwi", false: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwj" }, error: { true: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwk", false: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwl" }, disabled: { true: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwm", false: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwn" } }, defaultVariants: { mini: !1, error: !1, disabled: !1 }, compoundVariants: [] }), Ce = O({ defaultClassName: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwo", variantClassNames: { mini: { true: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwp", false: "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwq" } }, defaultVariants: { mini: !1 }, compoundVariants: [] }), ke = "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwr", Oe = "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jws", $ = "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwt", q = "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwu", Te = "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwv", De = "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jww", Pe = "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwx", Me = "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwy", Le = "pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwz";
|
|
164
|
+
function H({ list: o }) {
|
|
165
|
+
return /* @__PURE__ */ e.createElement(e.Fragment, null, o.map((i, l) => {
|
|
140
166
|
const t = Math.floor(i.length / 2);
|
|
141
|
-
return /* @__PURE__ */ e.createElement("div", { className:
|
|
167
|
+
return /* @__PURE__ */ e.createElement("div", { className: Oe, key: i }, /* @__PURE__ */ e.createElement("span", { className: $ }, i.substring(0, t)), /* @__PURE__ */ e.createElement("div", { className: $ }, /* @__PURE__ */ e.createElement("span", null, i.substring(t))), l < o.length - 1 ? "," : "");
|
|
142
168
|
}));
|
|
143
169
|
}
|
|
144
170
|
function J({
|
|
145
|
-
constrainContentWidth:
|
|
171
|
+
constrainContentWidth: o,
|
|
146
172
|
description: i,
|
|
147
|
-
multiple:
|
|
173
|
+
multiple: l = !1,
|
|
148
174
|
dismissable: t,
|
|
149
175
|
processing: r,
|
|
150
176
|
mini: m,
|
|
@@ -152,77 +178,77 @@ function J({
|
|
|
152
178
|
acceptExtensions: p,
|
|
153
179
|
maxSize: s,
|
|
154
180
|
customRequirement: b,
|
|
155
|
-
onSelection:
|
|
156
|
-
onDismiss:
|
|
157
|
-
download:
|
|
158
|
-
shown:
|
|
181
|
+
onSelection: T,
|
|
182
|
+
onDismiss: D,
|
|
183
|
+
download: P,
|
|
184
|
+
shown: y,
|
|
159
185
|
className: K,
|
|
160
186
|
disabled: d,
|
|
161
|
-
children:
|
|
187
|
+
children: Ae,
|
|
162
188
|
...Y
|
|
163
189
|
}) {
|
|
164
|
-
const
|
|
190
|
+
const U = e.useRef(/* @__PURE__ */ new Set()), [Q, M] = e.useState(y), [Ve, ee] = e.useState([]), [oe, ae] = e.useState(""), [L, le] = e.useState(), [te, S] = e.useState(!1), [F, j] = e.useState(!1), [h, N] = e.useState([]), [v, A] = e.useState([]), [E, ie] = e.useState(""), V = e.useMemo(() => (/* @__PURE__ */ new Set([...h, ...v])).size, [h, v]), { t: c } = xe(), C = (l ? c("fileUpload.instructions.other", {
|
|
165
191
|
defaultValue: "Drag and drop your files here or |browse for files| on your desktop."
|
|
166
192
|
}) : c("fileUpload.instructions.one", {
|
|
167
193
|
defaultValue: "Drag and drop your file here or |browse for a file| on your desktop."
|
|
168
|
-
})).split("|"), B = i || (
|
|
194
|
+
})).split("|"), B = i || (l ? "Files" : "File"), f = e.useRef(null);
|
|
169
195
|
e.useEffect(() => {
|
|
170
|
-
|
|
171
|
-
}, [
|
|
196
|
+
y && M(y);
|
|
197
|
+
}, [y]), e.useEffect(() => {
|
|
172
198
|
s && se(s);
|
|
173
199
|
}, [s]), e.useEffect(() => {
|
|
174
200
|
p && re(p);
|
|
175
201
|
}, [p]);
|
|
176
202
|
function ne() {
|
|
177
|
-
t && (
|
|
203
|
+
t && (M(!1), D && D());
|
|
178
204
|
}
|
|
179
|
-
function se(
|
|
205
|
+
function se(a) {
|
|
180
206
|
try {
|
|
181
|
-
|
|
207
|
+
le(ge(a));
|
|
182
208
|
} catch {
|
|
183
|
-
throw new Error(`Could not parse "${
|
|
209
|
+
throw new Error(`Could not parse "${a}" as a file size.`);
|
|
184
210
|
}
|
|
185
211
|
}
|
|
186
|
-
function re(
|
|
187
|
-
const w = (Array.isArray(
|
|
212
|
+
function re(a) {
|
|
213
|
+
const w = (Array.isArray(a) ? a : a.trim().split(/\s?,\s?/)).map((n) => n.replace(/^\./, "")), u = w.map((n) => `.${n}`.toLowerCase());
|
|
188
214
|
ie(
|
|
189
215
|
u.map((n, k) => k > 0 && k === u.length - 1 ? `or ${n}` : n).join(u.length > 2 ? ", " : " ")
|
|
190
|
-
),
|
|
216
|
+
), U.current.clear();
|
|
191
217
|
for (const n of w) {
|
|
192
|
-
const k = Object.keys(
|
|
218
|
+
const k = Object.keys(W).includes(n.toUpperCase()) ? W[n.toUpperCase()] : [];
|
|
193
219
|
for (const he of k)
|
|
194
|
-
|
|
220
|
+
U.current.add(he);
|
|
195
221
|
}
|
|
196
|
-
|
|
222
|
+
ae(u.concat(Array.from(U.current)).join(","));
|
|
197
223
|
}
|
|
198
|
-
function
|
|
199
|
-
|
|
224
|
+
function X(a) {
|
|
225
|
+
N([]), A([]);
|
|
200
226
|
let x = [], w = [];
|
|
201
|
-
const u =
|
|
227
|
+
const u = a ? Array.from(a) : [];
|
|
202
228
|
for (const n of u)
|
|
203
|
-
p && !
|
|
204
|
-
x.length || w.length ? (j(!0), f.current && f.current.value && (f.current.value = "")) : (ee(u),
|
|
229
|
+
p && !U.current.has(n.type) && w.push(n.name), s && L && n.size > L && x.push(n.name);
|
|
230
|
+
x.length || w.length ? (j(!0), f.current && f.current.value && (f.current.value = "")) : (ee(u), T(u)), N(x), A(w);
|
|
205
231
|
}
|
|
206
|
-
function pe(
|
|
207
|
-
|
|
232
|
+
function pe(a) {
|
|
233
|
+
a.preventDefault(), j(!1), f.current && f.current.click();
|
|
208
234
|
}
|
|
209
235
|
function de() {
|
|
210
|
-
|
|
236
|
+
P && P();
|
|
211
237
|
}
|
|
212
|
-
function ce(
|
|
213
|
-
|
|
238
|
+
function ce(a) {
|
|
239
|
+
a.stopPropagation(), X(a.target.files), f.current && f.current.value && (f.current.value = "");
|
|
214
240
|
}
|
|
215
|
-
function _e(
|
|
216
|
-
|
|
241
|
+
function _e(a) {
|
|
242
|
+
a.preventDefault(), a.stopPropagation(), S(!0), j(!1);
|
|
217
243
|
}
|
|
218
|
-
function fe(
|
|
219
|
-
|
|
244
|
+
function fe(a) {
|
|
245
|
+
a.preventDefault(), S(!0), j(!1);
|
|
220
246
|
}
|
|
221
|
-
function ue(
|
|
222
|
-
|
|
247
|
+
function ue(a) {
|
|
248
|
+
a.preventDefault(), S(!1);
|
|
223
249
|
}
|
|
224
|
-
function me(
|
|
225
|
-
|
|
250
|
+
function me(a) {
|
|
251
|
+
a.preventDefault(), a.stopPropagation(), S(!1), a.dataTransfer.files && X(a.dataTransfer.files);
|
|
226
252
|
}
|
|
227
253
|
return /* @__PURE__ */ e.createElement(
|
|
228
254
|
"div",
|
|
@@ -235,20 +261,20 @@ function J({
|
|
|
235
261
|
} : ue,
|
|
236
262
|
onDragEnter: d ? () => {
|
|
237
263
|
} : fe,
|
|
238
|
-
className:
|
|
264
|
+
className: R(Ue({ active: te, mini: m, error: F, shown: Q, disabled: d }), K),
|
|
239
265
|
...Y
|
|
240
266
|
},
|
|
241
|
-
/* @__PURE__ */ e.createElement("div", { className:
|
|
267
|
+
/* @__PURE__ */ e.createElement("div", { className: R(Se({ constrainContentWidth: o, disabled: d })) }, r ? /* @__PURE__ */ e.createElement("div", null, /* @__PURE__ */ e.createElement(we, { size: "md", "aria-hidden": "true" }), /* @__PURE__ */ e.createElement("div", { className: Z }, c("fileUpload.processing", { defaultValue: "Processing Upload..." }))) : /* @__PURE__ */ e.createElement("div", null, /* @__PURE__ */ e.createElement("div", { className: je({ mini: m, error: F, disabled: d }), "aria-hidden": "true" }, /* @__PURE__ */ e.createElement(
|
|
242
268
|
"img",
|
|
243
269
|
{
|
|
244
|
-
className:
|
|
270
|
+
className: Le,
|
|
245
271
|
src: F ? Fe : Ee,
|
|
246
272
|
alt: "Upload Icon"
|
|
247
273
|
}
|
|
248
274
|
)), /* @__PURE__ */ e.createElement("div", { className: Ce({ mini: m }) }, F ? /* @__PURE__ */ e.createElement("div", null, c(
|
|
249
|
-
|
|
275
|
+
V > 1 ? "fileUpload.cancelled.other" : "fileUpload.cancelled.one",
|
|
250
276
|
{
|
|
251
|
-
defaultValue:
|
|
277
|
+
defaultValue: V > 1 ? "File Upload(s) Failed" : "File Upload Failed"
|
|
252
278
|
}
|
|
253
279
|
)) : /* @__PURE__ */ e.createElement("div", null, c("fileUpload.title", {
|
|
254
280
|
description: B,
|
|
@@ -265,14 +291,14 @@ function J({
|
|
|
265
291
|
fileTypes: E,
|
|
266
292
|
defaultValue: v.length === 1 ? `Selected file is not an accepted file type: ${E}.` : `Selected files are not accepted file types: ${E}.`
|
|
267
293
|
}
|
|
268
|
-
)))) : /* @__PURE__ */ e.createElement("span", null), /* @__PURE__ */ e.createElement("div", { className: Z }, /* @__PURE__ */ e.createElement("div", null, /* @__PURE__ */ e.createElement("span", null, C[0]), d ? /* @__PURE__ */ e.createElement("u", null, C[1]) : /* @__PURE__ */ e.createElement("a", { href: "", onClick: pe }, C[1]), /* @__PURE__ */ e.createElement("span", null, C[2]))), /* @__PURE__ */ e.createElement("div", { className:
|
|
294
|
+
)))) : /* @__PURE__ */ e.createElement("span", null), /* @__PURE__ */ e.createElement("div", { className: Z }, /* @__PURE__ */ e.createElement("div", null, /* @__PURE__ */ e.createElement("span", null, C[0]), d ? /* @__PURE__ */ e.createElement("u", null, C[1]) : /* @__PURE__ */ e.createElement("a", { href: "", onClick: pe }, C[1]), /* @__PURE__ */ e.createElement("span", null, C[2]))), /* @__PURE__ */ e.createElement("div", { className: Te }, p ? /* @__PURE__ */ e.createElement("span", null, "(", " ", c("fileUpload.acceptedTypes", {
|
|
269
295
|
fileTypes: E,
|
|
270
296
|
defaultValue: `${E} format accepted`
|
|
271
297
|
}), " ", ")") : "", s ? /* @__PURE__ */ e.createElement("span", null, "(", " ", c("fileUpload.maximumSize", {
|
|
272
298
|
size: s,
|
|
273
299
|
defaultValue: `${s} maximum`
|
|
274
|
-
}), " ", ")") : "", b ? /* @__PURE__ */ e.createElement("span", null, " ", b, " ") : ""), g && /* @__PURE__ */ e.createElement("div", { className:
|
|
275
|
-
|
|
300
|
+
}), " ", ")") : "", b ? /* @__PURE__ */ e.createElement("span", null, " ", b, " ") : ""), g && /* @__PURE__ */ e.createElement("div", { className: De }, /* @__PURE__ */ e.createElement(
|
|
301
|
+
I,
|
|
276
302
|
{
|
|
277
303
|
disabled: d,
|
|
278
304
|
kind: "link",
|
|
@@ -281,8 +307,8 @@ function J({
|
|
|
281
307
|
},
|
|
282
308
|
g
|
|
283
309
|
)))),
|
|
284
|
-
t && !r && /* @__PURE__ */ e.createElement("div", { className:
|
|
285
|
-
|
|
310
|
+
t && !r && /* @__PURE__ */ e.createElement("div", { className: Pe }, /* @__PURE__ */ e.createElement(
|
|
311
|
+
I,
|
|
286
312
|
{
|
|
287
313
|
disabled: d,
|
|
288
314
|
kind: "icon",
|
|
@@ -291,13 +317,13 @@ function J({
|
|
|
291
317
|
onClick: ne
|
|
292
318
|
}
|
|
293
319
|
)),
|
|
294
|
-
/* @__PURE__ */ e.createElement("form", { className:
|
|
320
|
+
/* @__PURE__ */ e.createElement("form", { className: Me }, /* @__PURE__ */ e.createElement(
|
|
295
321
|
"input",
|
|
296
322
|
{
|
|
297
323
|
ref: f,
|
|
298
324
|
type: "file",
|
|
299
|
-
accept:
|
|
300
|
-
multiple:
|
|
325
|
+
accept: oe || "*/*",
|
|
326
|
+
multiple: l || void 0,
|
|
301
327
|
onChange: ce
|
|
302
328
|
}
|
|
303
329
|
))
|
|
@@ -321,7 +347,7 @@ ve.set(J, {
|
|
|
321
347
|
disabled: { type: "boolean" }
|
|
322
348
|
}
|
|
323
349
|
});
|
|
324
|
-
const
|
|
350
|
+
const Ne = {
|
|
325
351
|
components: [J],
|
|
326
352
|
examples: {
|
|
327
353
|
basic: {
|
|
@@ -575,10 +601,10 @@ const Le = {
|
|
|
575
601
|
}
|
|
576
602
|
}
|
|
577
603
|
}
|
|
578
|
-
},
|
|
579
|
-
"File Upload":
|
|
604
|
+
}, ze = {
|
|
605
|
+
"File Upload": Ne
|
|
580
606
|
};
|
|
581
607
|
export {
|
|
582
608
|
J as FileUpload,
|
|
583
|
-
|
|
609
|
+
ze as MANIFEST
|
|
584
610
|
};
|
package/lib/index.umd.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
(function(s,F){typeof exports=="object"&&typeof module<"u"?F(exports,require("react"),require("@sps-woodland/core"),require("@spscommerce/utils"),require("@sps-woodland/buttons"),require("@sps-woodland/illustrations"),require("@spscommerce/i18n")):typeof define=="function"&&define.amd?define(["exports","react","@sps-woodland/core","@spscommerce/utils","@sps-woodland/buttons","@sps-woodland/illustrations","@spscommerce/i18n"],F):(s=typeof globalThis<"u"?globalThis:s||self,F(s.FileUpload={},s.React,s.core,s.utils,s.buttons,s.illustrations,s.i18n))})(this,function(s,F,U,d,V,A,ee){"use strict";function oe(o){const a=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(o){for(const l in o)if(l!=="default"){const t=Object.getOwnPropertyDescriptor(o,l);Object.defineProperty(a,l,t.get?t:{enumerable:!0,get:()=>o[l]})}}return a.default=o,Object.freeze(a)}const e=oe(F),L={"7Z":["application/x-7z-compressed"],AAC:["audio/aac"],ABW:["application/x-abiword"],ARC:["application/octet-stream"],AVI:["video/x-msvideo"],AZW:["application/vnd.amazon.ebook"],BIN:["application/octet-stream"],BMP:["image/bmp"],BZ:["application/x-bzip"],BZ2:["application/x-bzip2"],CER:["application/pkix-cert","application/x-x509-ca-cert"],CSH:["application/x-csh"],CSS:["text/css"],CSV:["text/csv","application/vnd.ms-excel"],DOC:["application/msword"],DOCX:["application/vnd.openxmlformats-officedocument.wordprocessingml.document"],EML:["application/octet-stream","message/rfc822","multipart/mixed","message/rfc5322","message/rfc6532"],EOT:["application/vnd.ms-fontobject"],EPUB:["application/epub+zip"],ES:["application/ecmascript"],FLV:["video/x-flv"],GIF:["image/gif"],GZ:["application/x-gzip"],HTM:["text/html"],HTML:["text/html"],ICO:["image/x-icon"],ICS:["text/calendar"],JAR:["application/java-archive"],JPEG:["image/jpeg"],JPG:["image/jpeg"],JS:["application/javascript"],JSON:["application/json"],M3U:["audio/x-mpequrl"],MID:["audio/midi"],MIDI:["audio/midi"],MOV:["video/quicktime"],MP3:["audio/mpeg3"],MP4:["video/mp4"],MPEG:["video/mpeg"],MPKG:["application/vnd.apple.installer+xml"],ODP:["application/vnd.oasis.opendocument.presentation"],ODS:["application/vnd.oasis.opendocument.spreadsheet"],ODT:["application/vnd.oasis.opendocument.text"],OGA:["audio/ogg"],OGV:["video/ogg"],OGX:["application/ogg"],OTF:["font/otf"],PNG:["image/png"],PDF:["application/pdf"],PPT:["application/vnd.ms-powerpoint"],PPTX:["application/vnd.openxmlformats-officedocument.presentationml.presentation"],RAR:["application/x-rar-compressed"],RTF:["application/rtf"],SH:["application/x-sh"],SVG:["image/svg+xml"],SWF:["application/x-shockwave-flash"],TAR:["application/x-tar"],TIF:["image/tiff"],TIFF:["image/tiff"],TS:["application/typescript"],TTF:["font/ttf"],TXT:["text/plain"],VSD:["application/vnd.visio"],WAV:["audio/wav"],WEBA:["audio/webm"],WEBM:["video/webm"],WEBP:["image/webp"],WOFF:["font/woff"],WOFF2:["font/woff2"],XHTML:["application/xhtml+xml"],XLS:["application/vnd.ms-excel"],XLSX:["application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"],XML:["application/xml"],XUL:["application/vnd.mozilla.xul+xml"],ZIP:["application/zip"]};function le(o,a,l){return a in o?Object.defineProperty(o,a,{value:l,enumerable:!0,configurable:!0,writable:!0}):o[a]=l,o}function B(o,a){var l=Object.keys(o);if(Object.getOwnPropertySymbols){var t=Object.getOwnPropertySymbols(o);a&&(t=t.filter(function(p){return Object.getOwnPropertyDescriptor(o,p).enumerable})),l.push.apply(l,t)}return l}function R(o){for(var a=1;a<arguments.length;a++){var l=arguments[a]!=null?arguments[a]:{};a%2?B(Object(l),!0).forEach(function(t){le(o,t,l[t])}):Object.getOwnPropertyDescriptors?Object.defineProperties(o,Object.getOwnPropertyDescriptors(l)):B(Object(l)).forEach(function(t){Object.defineProperty(o,t,Object.getOwnPropertyDescriptor(l,t))})}return o}var ae=(o,a,l)=>{for(var t of Object.keys(o)){var p;if(o[t]!==((p=a[t])!==null&&p!==void 0?p:l[t]))return!1}return!0},S=o=>a=>{var l=o.defaultClassName,t=R(R({},o.defaultVariants),a);for(var p in t){var h,E=(h=t[p])!==null&&h!==void 0?h:o.defaultVariants[p];if(E!=null){var c=E;typeof c=="boolean"&&(c=c===!0?"true":"false");var r=o.variantClassNames[p][c];r&&(l+=" "+r)}}for(var[j,M]of o.compoundVariants)ae(j,t,o.defaultVariants)&&(l+=" "+M);return l},te=S({defaultClassName:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jw0",variantClassNames:{active:{true:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jw1",false:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jw2"},mini:{true:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jw3",false:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jw4"},error:{true:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jw5",false:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jw6"},shown:{true:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jw7",false:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jw8"},disabled:{true:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jw9",false:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwa"}},defaultVariants:{active:!1,mini:!1,error:!1,shown:!0,disabled:!1},compoundVariants:[]}),ie=S({defaultClassName:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwb",variantClassNames:{constrainContentWidth:{true:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwc",false:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwd"},disabled:{true:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwe",false:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwf"}},defaultVariants:{constrainContentWidth:!1,disabled:!1},compoundVariants:[]}),I="pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwg",ne=S({defaultClassName:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwh",variantClassNames:{mini:{true:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwi",false:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwj"},error:{true:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwk",false:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwl"},disabled:{true:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwm",false:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwn"}},defaultVariants:{mini:!1,error:!1,disabled:!1},compoundVariants:[]}),se=S({defaultClassName:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwo",variantClassNames:{mini:{true:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwp",false:"pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwq"}},defaultVariants:{mini:!1},compoundVariants:[]}),re="pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwr",pe="pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jws",W="pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwt",z="pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwu",de="pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwv",ce="pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jww",_e="pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwx",fe="pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwy",ue="pkg_sps-woodland_file-upload__version_8_35_3__hash_rh07jwz";function G({list:o}){return e.createElement(e.Fragment,null,o.map((a,l)=>{const t=Math.floor(a.length/2);return e.createElement("div",{className:pe,key:a},e.createElement("span",{className:W},a.substring(0,t)),e.createElement("div",{className:W},e.createElement("span",null,a.substring(t))),l<o.length-1?",":"")}))}function P({constrainContentWidth:o,description:a,multiple:l=!1,dismissable:t,processing:p,mini:h,downloadLabel:E,acceptExtensions:c,maxSize:r,customRequirement:j,onSelection:M,onDismiss:X,download:q,shown:k,className:he,disabled:_,children:Ae,...we}){const C=e.useRef(new Set),[ve,Z]=e.useState(k),[Le,ge]=e.useState([]),[Fe,Ee]=e.useState(""),[$,be]=e.useState(),[ye,O]=e.useState(!1),[b,D]=e.useState(!1),[w,H]=e.useState([]),[v,J]=e.useState([]),[y,xe]=e.useState(""),K=e.useMemo(()=>new Set([...w,...v]).size,[w,v]),{t:f}=ee.useWoodlandLanguage(),T=(l?f("fileUpload.instructions.other",{defaultValue:"Drag and drop your files here or |browse for files| on your desktop."}):f("fileUpload.instructions.one",{defaultValue:"Drag and drop your file here or |browse for a file| on your desktop."})).split("|"),Y=a||(l?"Files":"File"),u=e.useRef(null);e.useEffect(()=>{k&&Z(k)},[k]),e.useEffect(()=>{r&&Se(r)},[r]),e.useEffect(()=>{c&&je(c)},[c]);function Ue(){t&&(Z(!1),X&&X())}function Se(i){try{be(d.parseFileSize(i))}catch{throw new Error(`Could not parse "${i}" as a file size.`)}}function je(i){const g=(Array.isArray(i)?i:i.trim().split(/\s?,\s?/)).map(n=>n.replace(/^\./,"")),m=g.map(n=>`.${n}`.toLowerCase());xe(m.map((n,N)=>N>0&&N===m.length-1?`or ${n}`:n).join(m.length>2?", ":" ")),C.current.clear();for(const n of g){const N=Object.keys(L).includes(n.toUpperCase())?L[n.toUpperCase()]:[];for(const Me of N)C.current.add(Me)}Ee(m.concat(Array.from(C.current)).join(","))}function Q(i){H([]),J([]);let x=[],g=[];const m=i?Array.from(i):[];for(const n of m)c&&!C.current.has(n.type)&&g.push(n.name),r&&$&&n.size>$&&x.push(n.name);x.length||g.length?(D(!0),u.current&&u.current.value&&(u.current.value="")):(ge(m),M(m)),H(x),J(g)}function ke(i){i.preventDefault(),D(!1),u.current&&u.current.click()}function Ce(){q&&q()}function Oe(i){i.stopPropagation(),Q(i.target.files),u.current&&u.current.value&&(u.current.value="")}function De(i){i.preventDefault(),i.stopPropagation(),O(!0),D(!1)}function Te(i){i.preventDefault(),O(!0),D(!1)}function Ne(i){i.preventDefault(),O(!1)}function Pe(i){i.preventDefault(),i.stopPropagation(),O(!1),i.dataTransfer.files&&Q(i.dataTransfer.files)}return e.createElement("div",{onDrop:_?()=>{}:Pe,onDragOver:_?()=>{}:De,onDragLeave:_?()=>{}:Ne,onDragEnter:_?()=>{}:Te,className:U.cl(te({active:ye,mini:h,error:b,shown:ve,disabled:_}),he),...we},e.createElement("div",{className:U.cl(ie({constrainContentWidth:o,disabled:_}))},p?e.createElement("div",null,e.createElement(U.Spinner,{size:"md","aria-hidden":"true"}),e.createElement("div",{className:I},f("fileUpload.processing",{defaultValue:"Processing Upload..."}))):e.createElement("div",null,e.createElement("div",{className:ne({mini:h,error:b,disabled:_}),"aria-hidden":"true"},e.createElement("img",{className:ue,src:b?A.GENERAL_ERROR_LARGE:A.UPLOAD_LARGE,alt:"Upload Icon"})),e.createElement("div",{className:se({mini:h})},b?e.createElement("div",null,f(K>1?"fileUpload.cancelled.other":"fileUpload.cancelled.one",{defaultValue:K>1?"File Upload(s) Failed":"File Upload Failed"})):e.createElement("div",null,f("fileUpload.title",{description:Y,defaultValue:`Upload your ${Y}`}))),b?e.createElement("div",{className:re},w.length>0&&e.createElement(e.Fragment,null,e.createElement(G,{list:w}),e.createElement("div",{className:z},f(w.length===1?"fileUpload.error.tooLarge.one":"fileUpload.error.tooLarge.other",{size:r,defaultValue:w.length===1?`Selected file is larger than the size limit of ${r}.`:`Selected files are larger than the size limit of ${r}.`}))),v.length>0&&e.createElement(e.Fragment,null,e.createElement(G,{list:v}),e.createElement("div",{className:z},f(v.length===1?"fileUpload.error.wrongType.one":"fileUpload.error.wrongType.other",{fileTypes:y,defaultValue:v.length===1?`Selected file is not an accepted file type: ${y}.`:`Selected files are not accepted file types: ${y}.`})))):e.createElement("span",null),e.createElement("div",{className:I},e.createElement("div",null,e.createElement("span",null,T[0]),_?e.createElement("u",null,T[1]):e.createElement("a",{href:"",onClick:ke},T[1]),e.createElement("span",null,T[2]))),e.createElement("div",{className:de},c?e.createElement("span",null,"("," ",f("fileUpload.acceptedTypes",{fileTypes:y,defaultValue:`${y} format accepted`})," ",")"):"",r?e.createElement("span",null,"("," ",f("fileUpload.maximumSize",{size:r,defaultValue:`${r} maximum`})," ",")"):"",j?e.createElement("span",null," ",j," "):""),E&&e.createElement("div",{className:ce},e.createElement(V.Button,{disabled:_,kind:"link",icon:"download-cloud",onClick:Ce},E)))),t&&!p&&e.createElement("div",{className:_e},e.createElement(V.Button,{disabled:_,kind:"icon",icon:"x",title:f("fileUpload.close",{defaultValue:"Close"}),onClick:Ue})),e.createElement("form",{className:fe},e.createElement("input",{ref:u,type:"file",accept:Fe||"*/*",multiple:l||void 0,onChange:Oe})))}U.Metadata.set(P,{name:"FileUpload",props:{constrainContentWidth:{type:"boolean"},description:{type:"string"},multiple:{type:"boolean"},dismissable:{type:"boolean"},mini:{type:"boolean"},downloadLabel:{type:"string"},acceptExtensions:{type:"string[] | string"},maxSize:{type:"string"},customRequirement:{type:"string"},onSelection:{type:"(files: File[]) => void",required:!0},dismissal:{type:"() => void"},download:{type:"() => void"},disabled:{type:"boolean"}}});const me={"File Upload":{components:[P],examples:{basic:{label:"Basic File Upload",description:"Simply allow the user to drag-and-drop or select a single file or multiple files at once.",examples:{basic:{description:"Single file upload",react:d.code`
|
|
1
|
+
(function(s,F){typeof exports=="object"&&typeof module<"u"?F(exports,require("react"),require("@sps-woodland/core"),require("@spscommerce/utils"),require("@sps-woodland/buttons"),require("@sps-woodland/illustrations"),require("@spscommerce/i18n")):typeof define=="function"&&define.amd?define(["exports","react","@sps-woodland/core","@spscommerce/utils","@sps-woodland/buttons","@sps-woodland/illustrations","@spscommerce/i18n"],F):(s=typeof globalThis<"u"?globalThis:s||self,F(s.FileUpload={},s.React,s.core,s.utils,s.buttons,s.illustrations,s.i18n))})(this,function(s,F,S,d,L,A,ee){"use strict";function oe(o){const l=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(o){for(const a in o)if(a!=="default"){const t=Object.getOwnPropertyDescriptor(o,a);Object.defineProperty(l,a,t.get?t:{enumerable:!0,get:()=>o[a]})}}return l.default=o,Object.freeze(l)}const e=oe(F),V={"7Z":["application/x-7z-compressed"],AAC:["audio/aac"],ABW:["application/x-abiword"],ARC:["application/octet-stream"],AVI:["video/x-msvideo"],AZW:["application/vnd.amazon.ebook"],BIN:["application/octet-stream"],BMP:["image/bmp"],BZ:["application/x-bzip"],BZ2:["application/x-bzip2"],CER:["application/pkix-cert","application/x-x509-ca-cert"],CSH:["application/x-csh"],CSS:["text/css"],CSV:["text/csv","application/vnd.ms-excel"],DOC:["application/msword"],DOT:["application/msword"],DOCX:["application/vnd.openxmlformats-officedocument.wordprocessingml.document"],DOTX:["application/vnd.openxmlformats-officedocument.wordprocessingml.template"],DOCM:["application/vnd.ms-word.document.macroEnabled.12"],DOTM:["application/vnd.ms-word.template.macroEnabled.12"],EML:["application/octet-stream","message/rfc822","multipart/mixed","message/rfc5322","message/rfc6532"],EOT:["application/vnd.ms-fontobject"],EPUB:["application/epub+zip"],ES:["application/ecmascript"],FLV:["video/x-flv"],GIF:["image/gif"],GZ:["application/x-gzip"],HTM:["text/html"],HTML:["text/html"],ICO:["image/x-icon"],ICS:["text/calendar"],JAR:["application/java-archive"],JPEG:["image/jpeg"],JPG:["image/jpeg"],JS:["application/javascript"],JSON:["application/json"],M3U:["audio/x-mpequrl"],MID:["audio/midi"],MIDI:["audio/midi"],MOV:["video/quicktime"],MP3:["audio/mpeg3"],MP4:["video/mp4"],MPEG:["video/mpeg"],MPKG:["application/vnd.apple.installer+xml"],ODP:["application/vnd.oasis.opendocument.presentation"],ODS:["application/vnd.oasis.opendocument.spreadsheet"],ODT:["application/vnd.oasis.opendocument.text"],OGA:["audio/ogg"],OGV:["video/ogg"],OGX:["application/ogg"],OTF:["font/otf"],PNG:["image/png"],PDF:["application/pdf"],POT:["application/vnd.ms-powerpoint"],POTM:["application/vnd.ms-powerpoint.template.macroEnabled.12"],POTX:["application/vnd.openxmlformats-officedocument.presentationml.template"],PPA:["application/vnd.ms-powerpoint"],PPAM:["application/vnd.ms-powerpoint.addin.macroEnabled.12"],PPS:["application/vnd.ms-powerpoint"],PPSM:["application/vnd.ms-powerpoint.slideshow.macroEnabled.12"],PPT:["application/vnd.ms-powerpoint"],PPTM:["application/vnd.ms-powerpoint.presentation.macroEnabled.12"],PPSX:["application/vnd.openxmlformats-officedocument.presentationml.slideshow"],PPTX:["application/vnd.openxmlformats-officedocument.presentationml.presentation"],RAR:["application/x-rar-compressed"],RTF:["application/rtf"],SH:["application/x-sh"],SVG:["image/svg+xml"],SWF:["application/x-shockwave-flash"],TAR:["application/x-tar"],TIF:["image/tiff"],TIFF:["image/tiff"],TS:["application/typescript"],TTF:["font/ttf"],TXT:["text/plain"],VSD:["application/vnd.visio"],WAV:["audio/wav"],WEBA:["audio/webm"],WEBM:["video/webm"],WEBP:["image/webp"],WOFF:["font/woff"],WOFF2:["font/woff2"],XHTML:["application/xhtml+xml"],XLA:["application/vnd.ms-excel"],XLS:["application/vnd.ms-excel"],XLSB:["application/vnd.ms-excel.sheet.binary.macroEnabled.12"],XLT:["application/vnd.ms-excel"],XLAM:["application/vnd.ms-excel.addin.macroEnabled.12"],XLSM:["application/vnd.ms-excel.sheet.macroEnabled.12"],XLSX:["application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"],XLTM:["application/vnd.ms-excel.template.macroEnabled.12"],XLTX:["application/vnd.openxmlformats-officedocument.spreadsheetml.template"],XML:["application/xml"],XUL:["application/vnd.mozilla.xul+xml"],ZIP:["application/zip"]};function ae(o,l,a){return l in o?Object.defineProperty(o,l,{value:a,enumerable:!0,configurable:!0,writable:!0}):o[l]=a,o}function B(o,l){var a=Object.keys(o);if(Object.getOwnPropertySymbols){var t=Object.getOwnPropertySymbols(o);l&&(t=t.filter(function(p){return Object.getOwnPropertyDescriptor(o,p).enumerable})),a.push.apply(a,t)}return a}function R(o){for(var l=1;l<arguments.length;l++){var a=arguments[l]!=null?arguments[l]:{};l%2?B(Object(a),!0).forEach(function(t){ae(o,t,a[t])}):Object.getOwnPropertyDescriptors?Object.defineProperties(o,Object.getOwnPropertyDescriptors(a)):B(Object(a)).forEach(function(t){Object.defineProperty(o,t,Object.getOwnPropertyDescriptor(a,t))})}return o}var le=(o,l,a)=>{for(var t of Object.keys(o)){var p;if(o[t]!==((p=l[t])!==null&&p!==void 0?p:a[t]))return!1}return!0},U=o=>l=>{var a=o.defaultClassName,t=R(R({},o.defaultVariants),l);for(var p in t){var h,E=(h=t[p])!==null&&h!==void 0?h:o.defaultVariants[p];if(E!=null){var c=E;typeof c=="boolean"&&(c=c===!0?"true":"false");var r=o.variantClassNames[p][c];r&&(a+=" "+r)}}for(var[j,N]of o.compoundVariants)le(j,t,o.defaultVariants)&&(a+=" "+N);return a},te=U({defaultClassName:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw0",variantClassNames:{active:{true:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw1",false:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw2"},mini:{true:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw3",false:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw4"},error:{true:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw5",false:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw6"},shown:{true:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw7",false:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw8"},disabled:{true:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw9",false:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwa"}},defaultVariants:{active:!1,mini:!1,error:!1,shown:!0,disabled:!1},compoundVariants:[]}),ie=U({defaultClassName:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwb",variantClassNames:{constrainContentWidth:{true:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwc",false:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwd"},disabled:{true:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwe",false:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwf"}},defaultVariants:{constrainContentWidth:!1,disabled:!1},compoundVariants:[]}),X="pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwg",ne=U({defaultClassName:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwh",variantClassNames:{mini:{true:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwi",false:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwj"},error:{true:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwk",false:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwl"},disabled:{true:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwm",false:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwn"}},defaultVariants:{mini:!1,error:!1,disabled:!1},compoundVariants:[]}),se=U({defaultClassName:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwo",variantClassNames:{mini:{true:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwp",false:"pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwq"}},defaultVariants:{mini:!1},compoundVariants:[]}),re="pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwr",pe="pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jws",I="pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwt",W="pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwu",de="pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwv",ce="pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jww",fe="pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwx",_e="pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwy",ue="pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwz";function z({list:o}){return e.createElement(e.Fragment,null,o.map((l,a)=>{const t=Math.floor(l.length/2);return e.createElement("div",{className:pe,key:l},e.createElement("span",{className:I},l.substring(0,t)),e.createElement("div",{className:I},e.createElement("span",null,l.substring(t))),a<o.length-1?",":"")}))}function M({constrainContentWidth:o,description:l,multiple:a=!1,dismissable:t,processing:p,mini:h,downloadLabel:E,acceptExtensions:c,maxSize:r,customRequirement:j,onSelection:N,onDismiss:G,download:q,shown:O,className:he,disabled:f,children:Ae,...ve}){const T=e.useRef(new Set),[we,Z]=e.useState(O),[Ve,ge]=e.useState([]),[Fe,Ee]=e.useState(""),[$,be]=e.useState(),[xe,C]=e.useState(!1),[b,k]=e.useState(!1),[v,H]=e.useState([]),[w,J]=e.useState([]),[x,ye]=e.useState(""),K=e.useMemo(()=>new Set([...v,...w]).size,[v,w]),{t:_}=ee.useWoodlandLanguage(),D=(a?_("fileUpload.instructions.other",{defaultValue:"Drag and drop your files here or |browse for files| on your desktop."}):_("fileUpload.instructions.one",{defaultValue:"Drag and drop your file here or |browse for a file| on your desktop."})).split("|"),Y=l||(a?"Files":"File"),u=e.useRef(null);e.useEffect(()=>{O&&Z(O)},[O]),e.useEffect(()=>{r&&Ue(r)},[r]),e.useEffect(()=>{c&&je(c)},[c]);function Se(){t&&(Z(!1),G&&G())}function Ue(i){try{be(d.parseFileSize(i))}catch{throw new Error(`Could not parse "${i}" as a file size.`)}}function je(i){const g=(Array.isArray(i)?i:i.trim().split(/\s?,\s?/)).map(n=>n.replace(/^\./,"")),m=g.map(n=>`.${n}`.toLowerCase());ye(m.map((n,P)=>P>0&&P===m.length-1?`or ${n}`:n).join(m.length>2?", ":" ")),T.current.clear();for(const n of g){const P=Object.keys(V).includes(n.toUpperCase())?V[n.toUpperCase()]:[];for(const Ne of P)T.current.add(Ne)}Ee(m.concat(Array.from(T.current)).join(","))}function Q(i){H([]),J([]);let y=[],g=[];const m=i?Array.from(i):[];for(const n of m)c&&!T.current.has(n.type)&&g.push(n.name),r&&$&&n.size>$&&y.push(n.name);y.length||g.length?(k(!0),u.current&&u.current.value&&(u.current.value="")):(ge(m),N(m)),H(y),J(g)}function Oe(i){i.preventDefault(),k(!1),u.current&&u.current.click()}function Te(){q&&q()}function Ce(i){i.stopPropagation(),Q(i.target.files),u.current&&u.current.value&&(u.current.value="")}function ke(i){i.preventDefault(),i.stopPropagation(),C(!0),k(!1)}function De(i){i.preventDefault(),C(!0),k(!1)}function Pe(i){i.preventDefault(),C(!1)}function Me(i){i.preventDefault(),i.stopPropagation(),C(!1),i.dataTransfer.files&&Q(i.dataTransfer.files)}return e.createElement("div",{onDrop:f?()=>{}:Me,onDragOver:f?()=>{}:ke,onDragLeave:f?()=>{}:Pe,onDragEnter:f?()=>{}:De,className:S.cl(te({active:xe,mini:h,error:b,shown:we,disabled:f}),he),...ve},e.createElement("div",{className:S.cl(ie({constrainContentWidth:o,disabled:f}))},p?e.createElement("div",null,e.createElement(S.Spinner,{size:"md","aria-hidden":"true"}),e.createElement("div",{className:X},_("fileUpload.processing",{defaultValue:"Processing Upload..."}))):e.createElement("div",null,e.createElement("div",{className:ne({mini:h,error:b,disabled:f}),"aria-hidden":"true"},e.createElement("img",{className:ue,src:b?A.GENERAL_ERROR_LARGE:A.UPLOAD_LARGE,alt:"Upload Icon"})),e.createElement("div",{className:se({mini:h})},b?e.createElement("div",null,_(K>1?"fileUpload.cancelled.other":"fileUpload.cancelled.one",{defaultValue:K>1?"File Upload(s) Failed":"File Upload Failed"})):e.createElement("div",null,_("fileUpload.title",{description:Y,defaultValue:`Upload your ${Y}`}))),b?e.createElement("div",{className:re},v.length>0&&e.createElement(e.Fragment,null,e.createElement(z,{list:v}),e.createElement("div",{className:W},_(v.length===1?"fileUpload.error.tooLarge.one":"fileUpload.error.tooLarge.other",{size:r,defaultValue:v.length===1?`Selected file is larger than the size limit of ${r}.`:`Selected files are larger than the size limit of ${r}.`}))),w.length>0&&e.createElement(e.Fragment,null,e.createElement(z,{list:w}),e.createElement("div",{className:W},_(w.length===1?"fileUpload.error.wrongType.one":"fileUpload.error.wrongType.other",{fileTypes:x,defaultValue:w.length===1?`Selected file is not an accepted file type: ${x}.`:`Selected files are not accepted file types: ${x}.`})))):e.createElement("span",null),e.createElement("div",{className:X},e.createElement("div",null,e.createElement("span",null,D[0]),f?e.createElement("u",null,D[1]):e.createElement("a",{href:"",onClick:Oe},D[1]),e.createElement("span",null,D[2]))),e.createElement("div",{className:de},c?e.createElement("span",null,"("," ",_("fileUpload.acceptedTypes",{fileTypes:x,defaultValue:`${x} format accepted`})," ",")"):"",r?e.createElement("span",null,"("," ",_("fileUpload.maximumSize",{size:r,defaultValue:`${r} maximum`})," ",")"):"",j?e.createElement("span",null," ",j," "):""),E&&e.createElement("div",{className:ce},e.createElement(L.Button,{disabled:f,kind:"link",icon:"download-cloud",onClick:Te},E)))),t&&!p&&e.createElement("div",{className:fe},e.createElement(L.Button,{disabled:f,kind:"icon",icon:"x",title:_("fileUpload.close",{defaultValue:"Close"}),onClick:Se})),e.createElement("form",{className:_e},e.createElement("input",{ref:u,type:"file",accept:Fe||"*/*",multiple:a||void 0,onChange:Ce})))}S.Metadata.set(M,{name:"FileUpload",props:{constrainContentWidth:{type:"boolean"},description:{type:"string"},multiple:{type:"boolean"},dismissable:{type:"boolean"},mini:{type:"boolean"},downloadLabel:{type:"string"},acceptExtensions:{type:"string[] | string"},maxSize:{type:"string"},customRequirement:{type:"string"},onSelection:{type:"(files: File[]) => void",required:!0},dismissal:{type:"() => void"},download:{type:"() => void"},disabled:{type:"boolean"}}});const me={"File Upload":{components:[M],examples:{basic:{label:"Basic File Upload",description:"Simply allow the user to drag-and-drop or select a single file or multiple files at once.",examples:{basic:{description:"Single file upload",react:d.code`
|
|
2
2
|
import { FileUpload } from "@sps-woodland/file-upload";
|
|
3
3
|
|
|
4
4
|
function Component() {
|
|
@@ -170,4 +170,4 @@
|
|
|
170
170
|
onSelection={selectFile} />
|
|
171
171
|
)
|
|
172
172
|
}
|
|
173
|
-
`}}}}}};s.FileUpload=
|
|
173
|
+
`}}}}}};s.FileUpload=M,s.MANIFEST=me,Object.defineProperty(s,Symbol.toStringTag,{value:"Module"})});
|
package/lib/mime-type.enum.d.ts
CHANGED
|
@@ -14,7 +14,11 @@ export declare const MIMEType: {
|
|
|
14
14
|
CSS: string[];
|
|
15
15
|
CSV: string[];
|
|
16
16
|
DOC: string[];
|
|
17
|
+
DOT: string[];
|
|
17
18
|
DOCX: string[];
|
|
19
|
+
DOTX: string[];
|
|
20
|
+
DOCM: string[];
|
|
21
|
+
DOTM: string[];
|
|
18
22
|
EML: string[];
|
|
19
23
|
EOT: string[];
|
|
20
24
|
EPUB: string[];
|
|
@@ -48,7 +52,16 @@ export declare const MIMEType: {
|
|
|
48
52
|
OTF: string[];
|
|
49
53
|
PNG: string[];
|
|
50
54
|
PDF: string[];
|
|
55
|
+
POT: string[];
|
|
56
|
+
POTM: string[];
|
|
57
|
+
POTX: string[];
|
|
58
|
+
PPA: string[];
|
|
59
|
+
PPAM: string[];
|
|
60
|
+
PPS: string[];
|
|
61
|
+
PPSM: string[];
|
|
51
62
|
PPT: string[];
|
|
63
|
+
PPTM: string[];
|
|
64
|
+
PPSX: string[];
|
|
52
65
|
PPTX: string[];
|
|
53
66
|
RAR: string[];
|
|
54
67
|
RTF: string[];
|
|
@@ -69,8 +82,15 @@ export declare const MIMEType: {
|
|
|
69
82
|
WOFF: string[];
|
|
70
83
|
WOFF2: string[];
|
|
71
84
|
XHTML: string[];
|
|
85
|
+
XLA: string[];
|
|
72
86
|
XLS: string[];
|
|
87
|
+
XLSB: string[];
|
|
88
|
+
XLT: string[];
|
|
89
|
+
XLAM: string[];
|
|
90
|
+
XLSM: string[];
|
|
73
91
|
XLSX: string[];
|
|
92
|
+
XLTM: string[];
|
|
93
|
+
XLTX: string[];
|
|
74
94
|
XML: string[];
|
|
75
95
|
XUL: string[];
|
|
76
96
|
ZIP: string[];
|
package/lib/style.css
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
.pkg_sps-woodland_file-
|
|
1
|
+
.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw0{border-width:.0625rem;border-style:dashed;border-radius:.25rem;display:block;padding:1rem;position:relative}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw1{background-color:#f4ecf2;border-color:#91467f;border-style:solid}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw3{padding:1rem}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw5{border-color:#de002e}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw8{display:none}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jw9{border-color:#d2d4d4}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwb{color:#4b5356;margin:0 auto;text-align:center}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwc{width:50%}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwe{color:#717779}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwg{font-size:.75rem;line-height:1.25rem}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwh{color:#717779;display:block;margin-bottom:1rem}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwi{font-size:1.5rem;line-height:1.5rem}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwj{font-size:3rem;line-height:3rem}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwk{color:#de002e}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwm{opacity:.5}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwo{font-weight:600;margin-bottom:.25rem}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwp{font-size:1rem;line-height:1.25rem}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwq{font-size:1.125rem;line-height:1.25rem}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwr{font-size:.875rem;font-weight:600;line-height:1.25rem}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jws{display:flex;justify-content:center;white-space:nowrap}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwt{max-width:50%;overflow:hidden}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwt:first-child{text-overflow:ellipsis}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwt:last-child{float:right}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwu{font-weight:400}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwv{font-size:.75rem;line-height:1.125rem;margin-top:.25rem}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwv>span+span{margin-left:.125rem}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jww{margin-top:1rem}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwx{position:absolute;right:.5rem;top:.5rem}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwy{display:none}.pkg_sps-woodland_file-upload__version_8_35_5__hash_rh07jwz{height:3rem}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@sps-woodland/file-upload",
|
|
3
3
|
"description": "SPS Woodland Design System file upload component",
|
|
4
|
-
"version": "8.35.
|
|
4
|
+
"version": "8.35.5",
|
|
5
5
|
"author": "SPS Commerce",
|
|
6
6
|
"license": "UNLICENSED",
|
|
7
7
|
"repository": "https://github.com/SPSCommerce/woodland/tree/main/packages/@sps-woodland/file-upload",
|
|
@@ -30,13 +30,13 @@
|
|
|
30
30
|
"@spscommerce/utils": "^7.0.0 || ^8.0.0",
|
|
31
31
|
"react": "^16.14.0 || ^17.0.0 || ^18.0.0 || ^19.0.0",
|
|
32
32
|
"react-dom": "^16.14.0 || ^17.0.0 || ^18.0.0 || ^19.0.0",
|
|
33
|
-
"@sps-woodland/buttons": "8.35.
|
|
34
|
-
"@sps-woodland/core": "8.35.
|
|
35
|
-
"@sps-woodland/illustrations": "8.35.
|
|
36
|
-
"@sps-woodland/tokens": "8.35.
|
|
37
|
-
"@spscommerce/ds-react": "8.35.
|
|
38
|
-
"@spscommerce/ds-shared": "8.35.
|
|
39
|
-
"@spscommerce/i18n": "8.35.
|
|
33
|
+
"@sps-woodland/buttons": "8.35.5",
|
|
34
|
+
"@sps-woodland/core": "8.35.5",
|
|
35
|
+
"@sps-woodland/illustrations": "8.35.5",
|
|
36
|
+
"@sps-woodland/tokens": "8.35.5",
|
|
37
|
+
"@spscommerce/ds-react": "8.35.5",
|
|
38
|
+
"@spscommerce/ds-shared": "8.35.5",
|
|
39
|
+
"@spscommerce/i18n": "8.35.5"
|
|
40
40
|
},
|
|
41
41
|
"devDependencies": {
|
|
42
42
|
"@spscommerce/ds-illustrations": "^6.12.1",
|
|
@@ -45,14 +45,14 @@
|
|
|
45
45
|
"@vanilla-extract/recipes": "^0.2.5",
|
|
46
46
|
"react": "^16.14.0",
|
|
47
47
|
"react-dom": "^16.14.0",
|
|
48
|
-
"@sps-woodland/buttons": "8.35.
|
|
49
|
-
"@sps-woodland/core": "8.35.
|
|
50
|
-
"@sps-woodland/illustrations": "8.35.
|
|
51
|
-
"@sps-woodland/tokens": "8.35.
|
|
52
|
-
"@spscommerce/ds-colors": "8.35.
|
|
53
|
-
"@spscommerce/ds-react": "8.35.
|
|
54
|
-
"@spscommerce/ds-shared": "8.35.
|
|
55
|
-
"@spscommerce/i18n": "8.35.
|
|
48
|
+
"@sps-woodland/buttons": "8.35.5",
|
|
49
|
+
"@sps-woodland/core": "8.35.5",
|
|
50
|
+
"@sps-woodland/illustrations": "8.35.5",
|
|
51
|
+
"@sps-woodland/tokens": "8.35.5",
|
|
52
|
+
"@spscommerce/ds-colors": "8.35.5",
|
|
53
|
+
"@spscommerce/ds-react": "8.35.5",
|
|
54
|
+
"@spscommerce/ds-shared": "8.35.5",
|
|
55
|
+
"@spscommerce/i18n": "8.35.5"
|
|
56
56
|
},
|
|
57
57
|
"scripts": {
|
|
58
58
|
"build": "pnpm run build:js && pnpm run build:types",
|