-
Notifications
You must be signed in to change notification settings - Fork 5
Expand file tree
/
Copy pathfileUploader.js
More file actions
110 lines (86 loc) · 2.73 KB
/
fileUploader.js
File metadata and controls
110 lines (86 loc) · 2.73 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
import { t } from "i18next";
import { isPresent } from "neetocist";
import { Toastr } from "neetoui";
import { convertToFileSize } from "components/Editor/MediaUploader/utils";
const getFileExtension = filename => {
if (!filename) return "";
const parts = filename.split(".");
return parts.length > 1 ? `.${parts.pop()}` : "";
};
const showWarningToastr = ({
selectedFiles,
initialFiles,
config,
largeFilesCount,
unSupportedFilesCount,
}) => {
const { maxNumberOfFiles, maxFileSize } = config.restrictions;
if (unSupportedFilesCount > 0 || largeFilesCount > 0) {
if (unSupportedFilesCount > 0) {
Toastr.error(t("neetoEditor.error.fileNotAllowed"));
}
if (largeFilesCount > 0) {
Toastr.error(
t("neetoEditor.error.fileIsTooLarge", {
maxFileSize: convertToFileSize(maxFileSize),
})
);
}
} else if (selectedFiles.length < initialFiles.length) {
Toastr.warning(
t("neetoEditor.attachments.maxNumberOfFiles", {
entity: maxNumberOfFiles,
})
);
}
};
export const shouldAddFile = config => file => {
const { maxFileSize, allowedFileTypes } = config.restrictions;
if (isPresent(maxFileSize) && file.size > maxFileSize) {
return { canAdd: false };
}
if (isPresent(allowedFileTypes)) {
const fileExtension = getFileExtension(file.name);
const mimeType = file.type;
const extensionAllowed = allowedFileTypes.includes(fileExtension);
const mimeAllowed = allowedFileTypes.includes(mimeType);
const canAdd = extensionAllowed || mimeAllowed;
return { canAdd, isUnsupportedFile: !canAdd };
}
return { canAdd: true };
};
export const selectFiles = ({ previousAttachmentsCount, config, files }) => {
let addedFilesCount = 0,
largeFilesCount = 0,
unSupportedFilesCount = 0;
const fallbackMaxNumberOfFiles = previousAttachmentsCount + files.length;
const { maxNumberOfFiles = fallbackMaxNumberOfFiles } = config.restrictions;
const canAddFile = shouldAddFile(config);
const remainingAttachments = maxNumberOfFiles - previousAttachmentsCount;
if (remainingAttachments <= 0) {
Toastr.warning(
t("neetoEditor.attachments.maxNumberOfFiles", {
entity: maxNumberOfFiles,
})
);
return [];
}
const selectedFiles = files.filter(file => {
const { canAdd, isUnsupportedFile } = canAddFile(file);
if (canAdd && addedFilesCount + 1 <= remainingAttachments) {
addedFilesCount += 1;
return true;
}
if (isUnsupportedFile) unSupportedFilesCount += 1;
else if (!canAdd) largeFilesCount += 1;
return false;
});
showWarningToastr({
selectedFiles,
initialFiles: files,
config,
unSupportedFilesCount,
largeFilesCount,
});
return selectedFiles;
};