@anji-dashing/dam-solution-v2 5.8.173

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (259) hide show
  1. package/README.md +53 -0
  2. package/build/AssetType/AddFieldProperties.d.ts +10 -0
  3. package/build/AssetType/AddFieldProperties.js +359 -0
  4. package/build/AssetType/AssetTemplatesTable.d.ts +10 -0
  5. package/build/AssetType/AssetTemplatesTable.js +172 -0
  6. package/build/AssetType/CreateAssetTemplate.d.ts +3 -0
  7. package/build/AssetType/CreateAssetTemplate.js +70 -0
  8. package/build/AssetType/CreateOrEditAssetTemplate.d.ts +1 -0
  9. package/build/AssetType/CreateOrEditAssetTemplate.js +100 -0
  10. package/build/AssetType/DraggedField.d.ts +14 -0
  11. package/build/AssetType/DraggedField.js +58 -0
  12. package/build/AssetType/EditAssetTemplate.d.ts +5 -0
  13. package/build/AssetType/EditAssetTemplate.js +257 -0
  14. package/build/AssetType/FieldsSection.d.ts +14 -0
  15. package/build/AssetType/FieldsSection.js +268 -0
  16. package/build/AssetType/assetTemplatesContainer.d.ts +2 -0
  17. package/build/AssetType/assetTemplatesContainer.js +71 -0
  18. package/build/AssetType/fieldProperties/DateField.d.ts +5 -0
  19. package/build/AssetType/fieldProperties/DateField.js +23 -0
  20. package/build/AssetType/fieldProperties/NumberField.d.ts +5 -0
  21. package/build/AssetType/fieldProperties/NumberField.js +91 -0
  22. package/build/AssetType/fieldProperties/OptionsField.d.ts +6 -0
  23. package/build/AssetType/fieldProperties/OptionsField.js +55 -0
  24. package/build/AssetType/fieldProperties/TextField.d.ts +5 -0
  25. package/build/AssetType/fieldProperties/TextField.js +92 -0
  26. package/build/AssetType/index.d.ts +11 -0
  27. package/build/AssetType/index.js +25 -0
  28. package/build/AssetType/routes.d.ts +3 -0
  29. package/build/AssetType/routes.js +17 -0
  30. package/build/BookView/ProductDescription.d.ts +4 -0
  31. package/build/BookView/ProductDescription.js +20 -0
  32. package/build/BookView/bookDetail.d.ts +4 -0
  33. package/build/BookView/bookDetail.js +106 -0
  34. package/build/BookView/bookInfo.d.ts +4 -0
  35. package/build/BookView/bookInfo.js +17 -0
  36. package/build/BookView/description.d.ts +4 -0
  37. package/build/BookView/description.js +5 -0
  38. package/build/BookView/index.d.ts +10 -0
  39. package/build/BookView/index.js +23 -0
  40. package/build/CreateClient/CreateClientBtn.d.ts +14 -0
  41. package/build/CreateClient/CreateClientBtn.js +54 -0
  42. package/build/CreateClient/CreateClientForm.d.ts +15 -0
  43. package/build/CreateClient/CreateClientForm.js +347 -0
  44. package/build/CreateClient/index.d.ts +20 -0
  45. package/build/CreateClient/index.js +18 -0
  46. package/build/ImagePicker/MetaFieldOptions.d.ts +14 -0
  47. package/build/ImagePicker/MetaFieldOptions.js +75 -0
  48. package/build/ImagePicker/TestImagePickerModal.d.ts +8 -0
  49. package/build/ImagePicker/TestImagePickerModal.js +72 -0
  50. package/build/ImagePicker/TestImgFromMetaData.d.ts +7 -0
  51. package/build/ImagePicker/TestImgFromMetaData.js +82 -0
  52. package/build/ImagePicker/imagePickerComponent.d.ts +6 -0
  53. package/build/ImagePicker/imagePickerComponent.js +63 -0
  54. package/build/ImagePicker/index.d.ts +13 -0
  55. package/build/ImagePicker/index.js +24 -0
  56. package/build/ImagePicker/routes.d.ts +6 -0
  57. package/build/ImagePicker/routes.js +17 -0
  58. package/build/ImagePickerFilters/ImagePickerFiltersComponent.d.ts +8 -0
  59. package/build/ImagePickerFilters/ImagePickerFiltersComponent.js +223 -0
  60. package/build/ImagePickerFilters/index.d.ts +12 -0
  61. package/build/ImagePickerFilters/index.js +19 -0
  62. package/build/MyDrive/ActionBar.d.ts +8 -0
  63. package/build/MyDrive/ActionBar.js +190 -0
  64. package/build/MyDrive/AddDrive.d.ts +5 -0
  65. package/build/MyDrive/AddDrive.js +189 -0
  66. package/build/MyDrive/AddFolder.d.ts +11 -0
  67. package/build/MyDrive/AddFolder.js +165 -0
  68. package/build/MyDrive/BreadCrumbList.d.ts +10 -0
  69. package/build/MyDrive/BreadCrumbList.js +81 -0
  70. package/build/MyDrive/BulkUploadModal.d.ts +2 -0
  71. package/build/MyDrive/BulkUploadModal.js +324 -0
  72. package/build/MyDrive/DriveContainer.d.ts +14 -0
  73. package/build/MyDrive/DriveContainer.js +343 -0
  74. package/build/MyDrive/FileDownloadHistory.d.ts +7 -0
  75. package/build/MyDrive/FileDownloadHistory.js +107 -0
  76. package/build/MyDrive/FileMenuOptions.d.ts +11 -0
  77. package/build/MyDrive/FileMenuOptions.js +450 -0
  78. package/build/MyDrive/FilesGridView.d.ts +9 -0
  79. package/build/MyDrive/FilesGridView.js +25 -0
  80. package/build/MyDrive/FolderGridView.d.ts +20 -0
  81. package/build/MyDrive/FolderGridView.js +95 -0
  82. package/build/MyDrive/FolderListView.d.ts +26 -0
  83. package/build/MyDrive/FolderListView.js +226 -0
  84. package/build/MyDrive/FolderMenuOptions.d.ts +5 -0
  85. package/build/MyDrive/FolderMenuOptions.js +350 -0
  86. package/build/MyDrive/FolderTree.d.ts +8 -0
  87. package/build/MyDrive/FolderTree.js +479 -0
  88. package/build/MyDrive/ImageEditor/EditImage.d.ts +6 -0
  89. package/build/MyDrive/ImageEditor/EditImage.js +97 -0
  90. package/build/MyDrive/ImageEditor/EditImageModal.d.ts +8 -0
  91. package/build/MyDrive/ImageEditor/EditImageModal.js +30 -0
  92. package/build/MyDrive/ImageEditor/TuiImageEditor.d.ts +10 -0
  93. package/build/MyDrive/ImageEditor/TuiImageEditor.js +99 -0
  94. package/build/MyDrive/ImagePickerBreadCrumbList.d.ts +8 -0
  95. package/build/MyDrive/ImagePickerBreadCrumbList.js +35 -0
  96. package/build/MyDrive/ImagePickerDrive.d.ts +1 -0
  97. package/build/MyDrive/ImagePickerDrive.js +41 -0
  98. package/build/MyDrive/MyDriveMainContainer.d.ts +6 -0
  99. package/build/MyDrive/MyDriveMainContainer.js +63 -0
  100. package/build/MyDrive/SearchFilter.d.ts +8 -0
  101. package/build/MyDrive/SearchFilter.js +73 -0
  102. package/build/MyDrive/ShareBtn.d.ts +5 -0
  103. package/build/MyDrive/ShareBtn.js +19 -0
  104. package/build/MyDrive/ToggleView.d.ts +4 -0
  105. package/build/MyDrive/ToggleView.js +12 -0
  106. package/build/MyDrive/UploadStatusModal.d.ts +12 -0
  107. package/build/MyDrive/UploadStatusModal.js +52 -0
  108. package/build/MyDrive/fileDetails/CommentEntity.d.ts +8 -0
  109. package/build/MyDrive/fileDetails/CommentEntity.js +102 -0
  110. package/build/MyDrive/fileDetails/Comments.d.ts +6 -0
  111. package/build/MyDrive/fileDetails/Comments.js +65 -0
  112. package/build/MyDrive/fileDetails/Compliance.d.ts +2 -0
  113. package/build/MyDrive/fileDetails/Compliance.js +18 -0
  114. package/build/MyDrive/fileDetails/CreateComment.d.ts +7 -0
  115. package/build/MyDrive/fileDetails/CreateComment.js +48 -0
  116. package/build/MyDrive/fileDetails/Editor.d.ts +6 -0
  117. package/build/MyDrive/fileDetails/Editor.js +55 -0
  118. package/build/MyDrive/fileDetails/EmojiPicker.d.ts +5 -0
  119. package/build/MyDrive/fileDetails/EmojiPicker.js +6 -0
  120. package/build/MyDrive/fileDetails/FileDetails.d.ts +11 -0
  121. package/build/MyDrive/fileDetails/FileDetails.js +125 -0
  122. package/build/MyDrive/fileDetails/FileHeader.d.ts +7 -0
  123. package/build/MyDrive/fileDetails/FileHeader.js +27 -0
  124. package/build/MyDrive/fileDetails/FileViewer.d.ts +10 -0
  125. package/build/MyDrive/fileDetails/FileViewer.js +17 -0
  126. package/build/MyDrive/fileDetails/ImageOptions.d.ts +2 -0
  127. package/build/MyDrive/fileDetails/ImageOptions.js +44 -0
  128. package/build/MyDrive/fileDetails/ImageViewer.d.ts +6 -0
  129. package/build/MyDrive/fileDetails/ImageViewer.js +16 -0
  130. package/build/MyDrive/fileDetails/ManageFile.d.ts +7 -0
  131. package/build/MyDrive/fileDetails/ManageFile.js +34 -0
  132. package/build/MyDrive/fileDetails/MetaForm.d.ts +15 -0
  133. package/build/MyDrive/fileDetails/MetaForm.js +199 -0
  134. package/build/MyDrive/fileDetails/Metadata.d.ts +8 -0
  135. package/build/MyDrive/fileDetails/Metadata.js +52 -0
  136. package/build/MyDrive/fileDetails/PdfOptions.d.ts +9 -0
  137. package/build/MyDrive/fileDetails/PdfOptions.js +35 -0
  138. package/build/MyDrive/fileDetails/PdfViewer.d.ts +8 -0
  139. package/build/MyDrive/fileDetails/PdfViewer.js +18 -0
  140. package/build/MyDrive/fileDetails/Previewdetails.d.ts +10 -0
  141. package/build/MyDrive/fileDetails/Previewdetails.js +53 -0
  142. package/build/MyDrive/fileDetails/VideoPlayer.d.ts +4 -0
  143. package/build/MyDrive/fileDetails/VideoPlayer.js +21 -0
  144. package/build/MyDrive/files/AssetSelectionFormItem.d.ts +7 -0
  145. package/build/MyDrive/files/AssetSelectionFormItem.js +14 -0
  146. package/build/MyDrive/files/FolderTabs.d.ts +6 -0
  147. package/build/MyDrive/files/FolderTabs.js +90 -0
  148. package/build/MyDrive/files/MapFile.d.ts +9 -0
  149. package/build/MyDrive/files/MapFile.js +239 -0
  150. package/build/MyDrive/files/MoveToAnotherFolder.d.ts +9 -0
  151. package/build/MyDrive/files/MoveToAnotherFolder.js +67 -0
  152. package/build/MyDrive/filesListView.d.ts +2 -0
  153. package/build/MyDrive/filesListView.js +57 -0
  154. package/build/MyDrive/index.d.ts +16 -0
  155. package/build/MyDrive/index.js +50 -0
  156. package/build/MyDrive/routes.d.ts +10 -0
  157. package/build/MyDrive/routes.js +12 -0
  158. package/build/PenView/PenDetails.d.ts +4 -0
  159. package/build/PenView/PenDetails.js +114 -0
  160. package/build/PenView/ProductDescription.d.ts +5 -0
  161. package/build/PenView/ProductDescription.js +51 -0
  162. package/build/PenView/index.d.ts +10 -0
  163. package/build/PenView/index.js +23 -0
  164. package/build/RefreshKey/RefreshKeyBtn.d.ts +1 -0
  165. package/build/RefreshKey/RefreshKeyBtn.js +42 -0
  166. package/build/RefreshKey/index.d.ts +9 -0
  167. package/build/RefreshKey/index.js +23 -0
  168. package/build/ShoesView/ProductDescription.d.ts +4 -0
  169. package/build/ShoesView/ProductDescription.js +25 -0
  170. package/build/ShoesView/ShoeDetails.d.ts +4 -0
  171. package/build/ShoesView/ShoeDetails.js +96 -0
  172. package/build/ShoesView/index.d.ts +10 -0
  173. package/build/ShoesView/index.js +23 -0
  174. package/build/common/Button.d.ts +2 -0
  175. package/build/common/Button.js +18 -0
  176. package/build/common/CustomElements.d.ts +98 -0
  177. package/build/common/CustomElements.js +77 -0
  178. package/build/common/LoadMoreItems.d.ts +7 -0
  179. package/build/common/LoadMoreItems.js +33 -0
  180. package/build/common/RenderFormItem.d.ts +42 -0
  181. package/build/common/RenderFormItem.js +98 -0
  182. package/build/common/RenderThumnail.d.ts +7 -0
  183. package/build/common/RenderThumnail.js +6 -0
  184. package/build/common/deleteModal.d.ts +1 -0
  185. package/build/common/deleteModal.js +12 -0
  186. package/build/common/folders/TypeAndDateFilters.d.ts +13 -0
  187. package/build/common/folders/TypeAndDateFilters.js +66 -0
  188. package/build/common/folders/getFolderOrFileIcon.d.ts +2 -0
  189. package/build/common/folders/getFolderOrFileIcon.js +41 -0
  190. package/build/common/loader/CustomLoader.d.ts +7 -0
  191. package/build/common/loader/CustomLoader.js +8 -0
  192. package/build/common/loader/loader.d.ts +1 -0
  193. package/build/common/loader/loader.js +6 -0
  194. package/build/common/notifications.d.ts +2 -0
  195. package/build/common/notifications.js +30 -0
  196. package/build/common/steps.d.ts +4 -0
  197. package/build/common/steps.js +7 -0
  198. package/build/hocs/AppProvider.d.ts +3 -0
  199. package/build/hocs/AppProvider.js +11 -0
  200. package/build/hocs/DamConfigContext.d.ts +2 -0
  201. package/build/hocs/DamConfigContext.js +153 -0
  202. package/build/hocs/ThemeContext.d.ts +15 -0
  203. package/build/hocs/ThemeContext.js +131 -0
  204. package/build/hocs/ToastProvider.d.ts +2 -0
  205. package/build/hocs/ToastProvider.js +6 -0
  206. package/build/hocs/appConstants.d.ts +124 -0
  207. package/build/hocs/appConstants.js +211 -0
  208. package/build/hocs/configureAxios.d.ts +2 -0
  209. package/build/hocs/configureAxios.js +65 -0
  210. package/build/hocs/helpers.d.ts +17 -0
  211. package/build/hocs/helpers.js +201 -0
  212. package/build/index.d.ts +12 -0
  213. package/build/index.js +12 -0
  214. package/build/react-query/hooks/brand-hooks.d.ts +3 -0
  215. package/build/react-query/hooks/brand-hooks.js +10 -0
  216. package/build/react-query/hooks/folder-hooks.d.ts +7 -0
  217. package/build/react-query/hooks/folder-hooks.js +119 -0
  218. package/build/react-query/services/brand-services.d.ts +4 -0
  219. package/build/react-query/services/brand-services.js +41 -0
  220. package/build/react-query/services/file-services.d.ts +43 -0
  221. package/build/react-query/services/file-services.js +69 -0
  222. package/build/react-query/services/folder-services.d.ts +46 -0
  223. package/build/react-query/services/folder-services.js +87 -0
  224. package/build/react-query/services/image-picker-services.d.ts +5 -0
  225. package/build/react-query/services/image-picker-services.js +47 -0
  226. package/build/settings/InviteTeamModal.d.ts +12 -0
  227. package/build/settings/InviteTeamModal.js +174 -0
  228. package/build/settings/UpdateInvitationAccessType.d.ts +9 -0
  229. package/build/settings/UpdateInvitationAccessType.js +96 -0
  230. package/build/settings/getUserAvatar.d.ts +7 -0
  231. package/build/settings/getUserAvatar.js +11 -0
  232. package/build/style.css +1 -0
  233. package/build/types/assetType.d.ts +8 -0
  234. package/build/types/assetType.js +1 -0
  235. package/build/ui/pageTitle.d.ts +3 -0
  236. package/build/ui/pageTitle.js +4 -0
  237. package/build/utilities/FoldersContext.d.ts +16 -0
  238. package/build/utilities/FoldersContext.js +15 -0
  239. package/build/utilities/NavigatorProvider.d.ts +2 -0
  240. package/build/utilities/NavigatorProvider.js +10 -0
  241. package/build/utilities/constants/apiUrls.d.ts +97 -0
  242. package/build/utilities/constants/apiUrls.js +117 -0
  243. package/build/utilities/constants/imageUrls.d.ts +6 -0
  244. package/build/utilities/constants/imageUrls.js +6 -0
  245. package/build/utilities/constants/interface.d.ts +371 -0
  246. package/build/utilities/constants/interface.js +142 -0
  247. package/build/utilities/constants/messages.d.ts +55 -0
  248. package/build/utilities/constants/messages.js +55 -0
  249. package/build/utilities/constants/queryKeys.d.ts +16 -0
  250. package/build/utilities/constants/queryKeys.js +33 -0
  251. package/build/utilities/constants/routes.d.ts +22 -0
  252. package/build/utilities/constants/routes.js +22 -0
  253. package/build/utilities/helpers/validators.d.ts +12 -0
  254. package/build/utilities/helpers/validators.js +89 -0
  255. package/build/utilities/useAppNavigate.d.ts +2 -0
  256. package/build/utilities/useAppNavigate.js +35 -0
  257. package/build/utilities/useAppParams.d.ts +8 -0
  258. package/build/utilities/useAppParams.js +72 -0
  259. package/package.json +93 -0
@@ -0,0 +1,2 @@
1
+ declare const BulkUploadModal: ({ toggleUpload, userEmail, folderId, thumbnailsOnly, }: any) => JSX.Element;
2
+ export default BulkUploadModal;
@@ -0,0 +1,324 @@
1
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
+ return new (P || (P = Promise))(function (resolve, reject) {
4
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
8
+ });
9
+ };
10
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
11
+ import { Form, Modal, Button, Upload, Select, Input, Radio, Typography, Tooltip, Checkbox, Popover, } from "antd";
12
+ import { useEffect, useMemo, useState } from "react";
13
+ import { UploadOutlined, InfoCircleOutlined, QuestionCircleOutlined } from "@ant-design/icons";
14
+ import { useDamConfig } from "../hocs/DamConfigContext";
15
+ import { createApiClient } from "../hocs/configureAxios";
16
+ import { BULK_UPLOAD_URL, FETCH_ASSETS_URL, FILE_UPLOAD_URL, GENERATE_THUMBNAILS_URL, SAMPLE_FILE_DOWNLOAD_URL, } from "../utilities/constants/apiUrls";
17
+ import { showNotification } from "../common/notifications";
18
+ import { EMAIL_NOT_VALID, ENTITY_REQUIRED, SOMETHING_WENT_WRONG, } from "../utilities/constants/messages";
19
+ import { NotificationStatus } from "../utilities/constants/interface";
20
+ import { filter, get } from "lodash";
21
+ import { humanFileSize } from "../hocs/helpers";
22
+ import { invalidateData, QueryKeys } from "../utilities/constants/queryKeys";
23
+ import { useQueryClient } from "react-query";
24
+ import { validateEmail } from "../utilities/helpers/validators";
25
+ const BulkUploadModal = ({ toggleUpload, userEmail, folderId, thumbnailsOnly, }) => {
26
+ const damConfig = useDamConfig();
27
+ const queryClient = useQueryClient();
28
+ const { brand, styles } = damConfig;
29
+ const brandId = get(brand, "_id");
30
+ const api = useMemo(() => createApiClient(damConfig), [damConfig]);
31
+ const [metaFile, setMetaFile] = useState(null);
32
+ const [assetTypeId, setAssetTypeId] = useState(null);
33
+ const [assetTypes, setAssetTypes] = useState([]);
34
+ const [fileError, setFileError] = useState("");
35
+ const [assetsSourceType, setAssetsSourceType] = useState("zip");
36
+ const [assetFileError, setAssetFileError] = useState("");
37
+ const [assetFile, setAssetFile] = useState(null);
38
+ const [sampleFileLoading, setSampleFileLoading] = useState(false);
39
+ const assetTypeOptions = assetTypes === null || assetTypes === void 0 ? void 0 : assetTypes.map((type) => {
40
+ return { label: type === null || type === void 0 ? void 0 : type.name, value: type === null || type === void 0 ? void 0 : type._id };
41
+ });
42
+ const [loading, setLoading] = useState(false);
43
+ const [form] = Form.useForm();
44
+ const emailValue = Form.useWatch("email", form);
45
+ const zipFileUrlValue = Form.useWatch("zip_file_url", form);
46
+ const emailsValue = Form.useWatch("emails", form);
47
+ const isSubmitDisabled = useMemo(() => {
48
+ if (loading)
49
+ return true;
50
+ if (thumbnailsOnly) {
51
+ const hasAssetFile = assetsSourceType === "zip"
52
+ ? assetFile && !assetFileError
53
+ : !!(zipFileUrlValue === null || zipFileUrlValue === void 0 ? void 0 : zipFileUrlValue.trim());
54
+ const hasEmails = Array.isArray(emailsValue) &&
55
+ emailsValue.length > 0 &&
56
+ emailsValue.every((e) => get(validateEmail(e), "valid"));
57
+ return !hasAssetFile || !hasEmails;
58
+ }
59
+ const hasAssetType = !!assetTypeId;
60
+ const hasMetaFile = metaFile && !fileError;
61
+ const hasAssetFile = assetsSourceType === "zip"
62
+ ? assetFile && !assetFileError
63
+ : !!(zipFileUrlValue === null || zipFileUrlValue === void 0 ? void 0 : zipFileUrlValue.trim());
64
+ const hasEmail = !!(emailValue === null || emailValue === void 0 ? void 0 : emailValue.trim());
65
+ return !hasAssetType || !hasMetaFile || !hasAssetFile || !hasEmail;
66
+ }, [
67
+ loading,
68
+ thumbnailsOnly,
69
+ assetTypeId,
70
+ metaFile,
71
+ fileError,
72
+ assetFile,
73
+ assetFileError,
74
+ assetsSourceType,
75
+ emailValue,
76
+ zipFileUrlValue,
77
+ emailsValue,
78
+ ]);
79
+ useEffect(() => {
80
+ onFetchAssetTemplates();
81
+ }, []);
82
+ const onFetchAssetTemplates = () => __awaiter(void 0, void 0, void 0, function* () {
83
+ try {
84
+ const response = yield api.get(`${FETCH_ASSETS_URL.replace(":brandId", get(brand, "_id"))}`);
85
+ setAssetTypes(get(response, "data.data", []));
86
+ }
87
+ catch (error) {
88
+ showNotification(get(error, "message", SOMETHING_WENT_WRONG), NotificationStatus.ERROR);
89
+ }
90
+ });
91
+ const onFinish = (values) => {
92
+ if (!fileError && !assetFileError) {
93
+ if (assetsSourceType == "zip") {
94
+ getBulkUploadFilePresignedUrl(values);
95
+ }
96
+ else {
97
+ bulkUpload(values);
98
+ }
99
+ }
100
+ };
101
+ const getBulkUploadFilePresignedUrl = (values) => __awaiter(void 0, void 0, void 0, function* () {
102
+ setLoading(true);
103
+ try {
104
+ const response = yield api.post(FILE_UPLOAD_URL, {
105
+ brandId,
106
+ folderId: folderId,
107
+ files: [
108
+ {
109
+ name: assetFile.name,
110
+ size: assetFile.size,
111
+ },
112
+ ],
113
+ });
114
+ const filePath = get(response, "data.0.filePath");
115
+ const url = get(response, "data.0.url");
116
+ fetch(url, {
117
+ method: "PUT",
118
+ body: assetFile,
119
+ })
120
+ .then((response) => {
121
+ bulkUpload(values, filePath);
122
+ })
123
+ .catch((err) => {
124
+ console.log(err);
125
+ setLoading(false);
126
+ showNotification(get(err, "message", SOMETHING_WENT_WRONG), NotificationStatus.ERROR);
127
+ toggleUpload();
128
+ });
129
+ }
130
+ catch (error) {
131
+ setLoading(false);
132
+ showNotification(get(error, "message", SOMETHING_WENT_WRONG), NotificationStatus.ERROR);
133
+ toggleUpload();
134
+ }
135
+ });
136
+ const bulkUpload = (values_1, ...args_1) => __awaiter(void 0, [values_1, ...args_1], void 0, function* (values, key = null) {
137
+ var _a, _b;
138
+ // console.log(key);
139
+ setLoading(true);
140
+ try {
141
+ let response;
142
+ if (thumbnailsOnly) {
143
+ const payload = {
144
+ email: get(values, "email"),
145
+ sourceType: assetsSourceType,
146
+ };
147
+ if (assetsSourceType === "zip" && key) {
148
+ payload["zipFileKey"] = key;
149
+ }
150
+ else {
151
+ payload["zipFileUrl"] = get(values, "zip_file_url", "");
152
+ }
153
+ response = yield api.post(GENERATE_THUMBNAILS_URL, payload);
154
+ }
155
+ else {
156
+ const formData = new FormData();
157
+ formData.append("assetId", values === null || values === void 0 ? void 0 : values.asset_type_id);
158
+ formData.append("rejectInvalidMetaFile", (values === null || values === void 0 ? void 0 : values.reject_invalid_meta_file) ? "true" : "false");
159
+ formData.append("file", metaFile);
160
+ formData.append("folderId", folderId);
161
+ formData.append("email", values === null || values === void 0 ? void 0 : values.email);
162
+ formData.append("sourceType", assetsSourceType);
163
+ if (key) {
164
+ formData.append("zipFileKey", key);
165
+ }
166
+ else if (assetsSourceType === "zipUrl") {
167
+ formData.append("zipFileUrl", (values === null || values === void 0 ? void 0 : values.zip_file_url) || "");
168
+ }
169
+ response = yield api.post(BULK_UPLOAD_URL, formData);
170
+ }
171
+ // console.log(response);
172
+ showNotification((_b = (_a = response === null || response === void 0 ? void 0 : response.data) === null || _a === void 0 ? void 0 : _a.message) !== null && _b !== void 0 ? _b : "Successfully uploaded files", NotificationStatus.SUCCESS);
173
+ toggleUpload();
174
+ invalidateData(queryClient, QueryKeys.FOLDERS, folderId);
175
+ }
176
+ catch (error) {
177
+ console.log(error);
178
+ showNotification(get(error, "message", SOMETHING_WENT_WRONG), NotificationStatus.ERROR);
179
+ toggleUpload();
180
+ }
181
+ finally {
182
+ setLoading(false);
183
+ }
184
+ });
185
+ const handleDownloadSampleFile = (assetId) => __awaiter(void 0, void 0, void 0, function* () {
186
+ setSampleFileLoading(true);
187
+ try {
188
+ const response = yield api.post(SAMPLE_FILE_DOWNLOAD_URL.replace(":assetId", assetId), {});
189
+ if (get(response, "data.url"))
190
+ window.open(get(response, "data.url", "_blank"));
191
+ setSampleFileLoading(false);
192
+ }
193
+ catch (error) {
194
+ setSampleFileLoading(false);
195
+ showNotification(get(error, "message", SOMETHING_WENT_WRONG));
196
+ }
197
+ });
198
+ return (_jsx(Modal, { open: true, onCancel: toggleUpload, title: thumbnailsOnly ? "Generate Thumbnails" : "Bulk upload", footer: null, maskClosable: false, okText: thumbnailsOnly ? "Generate" : "Save", children: _jsxs(Form, { form: form, layout: "vertical", onFinish: onFinish, initialValues: {
199
+ assets_source_type: assetsSourceType,
200
+ email: userEmail,
201
+ }, children: [!thumbnailsOnly && (_jsxs(_Fragment, { children: [_jsx(Form.Item, { label: _jsxs("div", { className: "bulk-upload-info", children: [_jsx(Typography.Text, { children: "Asset Type" }), " ", _jsx(Tooltip, { title: "Select from dropdown below, or refer to the Asset Templates to see what asset types currently exist.", children: _jsx(InfoCircleOutlined, {}) })] }), name: "asset_type_id", rules: [
202
+ {
203
+ required: true,
204
+ message: "Asset type is required",
205
+ },
206
+ ], children: _jsx(Select, { options: assetTypeOptions, placeholder: "Select Asset Type", onChange: (e) => {
207
+ setAssetTypeId(e);
208
+ // setDownloadSampleFileError(null);
209
+ }, optionFilterProp: "label", showSearch: true }) }), assetTypeId && (_jsx("div", { children: _jsx("a", { onClick: sampleFileLoading
210
+ ? () => { }
211
+ : () => handleDownloadSampleFile(assetTypeId), className: "md-lib-font-semibold md-lib-text-primaryColor md-lib-flex md-lib-justify-end", children: sampleFileLoading
212
+ ? "Downloading..."
213
+ : "Download Sample File" }) })), _jsx(Form.Item, { label: "Meta File", name: "meta_file", rules: [
214
+ {
215
+ required: true,
216
+ message: "Meta File is required",
217
+ },
218
+ ], extra: "Maximum allowed file size is 5MB", children: _jsx(Upload, { beforeUpload: (file) => {
219
+ var _a;
220
+ const [name, extension] = (_a = file.name) === null || _a === void 0 ? void 0 : _a.split(".");
221
+ if (extension !== "csv" &&
222
+ extension !== "xlsx" &&
223
+ extension !== "xls") {
224
+ setFileError("Invalid file format");
225
+ }
226
+ else {
227
+ const fileSize = humanFileSize(file === null || file === void 0 ? void 0 : file.size);
228
+ if ((fileSize === null || fileSize === void 0 ? void 0 : fileSize.sizeType) !== "GB" &&
229
+ (fileSize === null || fileSize === void 0 ? void 0 : fileSize.sizeType) !== "TB") {
230
+ if ((fileSize === null || fileSize === void 0 ? void 0 : fileSize.sizeType) == "MB") {
231
+ if ((fileSize === null || fileSize === void 0 ? void 0 : fileSize.size) < 5) {
232
+ setMetaFile(file);
233
+ setFileError("");
234
+ return false;
235
+ }
236
+ else {
237
+ setFileError("File size should be less than 5MB");
238
+ }
239
+ }
240
+ else {
241
+ setMetaFile(file);
242
+ setFileError("");
243
+ return false;
244
+ }
245
+ }
246
+ else {
247
+ setFileError("File size should be less than 5MB");
248
+ }
249
+ }
250
+ return false;
251
+ }, disabled: !assetTypeId, onRemove: () => {
252
+ setMetaFile(null);
253
+ setFileError("Meta File is required");
254
+ }, accept: ".csv,.xlsx,.xls", maxCount: 1, children: _jsx(Button, { icon: _jsx(UploadOutlined, {}), disabled: !assetTypeId, children: "Upload" }) }) }), fileError && (_jsx(Typography.Text, { style: { color: "red" }, children: fileError }))] })), _jsx(Form.Item, { label: "Upload your DAM Files (must be zipped)", name: "assets_source_type", children: _jsxs(Radio.Group, { onChange: (e) => setAssetsSourceType(e.target.value), value: assetsSourceType, disabled: thumbnailsOnly ? false : !assetTypeId, children: [_jsx(Radio, { value: "zip", children: "Zip file" }), _jsx(Radio, { value: "zipUrl", children: "Zip file url" })] }) }), assetsSourceType == "zip" ? (_jsxs(_Fragment, { children: [_jsx(Form.Item, { label: "Assets zip file", name: "assets_zip_file", rules: [
255
+ {
256
+ required: true,
257
+ message: "Asset zip file is required",
258
+ },
259
+ ], extra: "Maximum allowed file size is 5GB", children: _jsx(Upload, { beforeUpload: (file) => {
260
+ var _a;
261
+ const [name, extension] = (_a = file.name) === null || _a === void 0 ? void 0 : _a.split(".");
262
+ if (extension !== "zip") {
263
+ setAssetFileError("Invalid file format");
264
+ }
265
+ else {
266
+ const fileSize = humanFileSize(file === null || file === void 0 ? void 0 : file.size);
267
+ if ((fileSize === null || fileSize === void 0 ? void 0 : fileSize.sizeType) !== "TB") {
268
+ if ((fileSize === null || fileSize === void 0 ? void 0 : fileSize.sizeType) == "GB") {
269
+ if ((fileSize === null || fileSize === void 0 ? void 0 : fileSize.size) < 5) {
270
+ setAssetFile(file);
271
+ setAssetFileError("");
272
+ return false;
273
+ }
274
+ else {
275
+ setAssetFileError("File size should be less than 5GB");
276
+ }
277
+ }
278
+ else {
279
+ setAssetFile(file);
280
+ setAssetFileError("");
281
+ return false;
282
+ }
283
+ }
284
+ else {
285
+ setAssetFileError("File size should be less than 5GB");
286
+ }
287
+ }
288
+ return false;
289
+ }, disabled: thumbnailsOnly ? false : !assetTypeId, onRemove: () => {
290
+ setAssetFile(null);
291
+ setAssetFileError("Zip File is required");
292
+ }, accept: ".zip", maxCount: 1, children: _jsx(Button, { icon: _jsx(UploadOutlined, {}), style: { width: "100%" }, children: "Upload" }) }) }), assetFileError && (_jsx(Typography.Text, { style: { color: "red" }, children: assetFileError }))] })) : (_jsx(Form.Item, { label: "Assets zip file url", name: "zip_file_url", rules: [
293
+ {
294
+ required: true,
295
+ message: "Zip file url is required",
296
+ },
297
+ ], children: _jsx(Input, { placeholder: "Zip file url", disabled: thumbnailsOnly ? false : !assetTypeId }) })), thumbnailsOnly ? (_jsx(Form.Item, { name: "email", label: "Emails", rules: [
298
+ {
299
+ required: true,
300
+ message: "",
301
+ },
302
+ {
303
+ validator: (_, value) => {
304
+ if (!value || value.length === 0) {
305
+ return Promise.reject(ENTITY_REQUIRED.replace(":entity", "Emails").replace("is", "are"));
306
+ }
307
+ const invalids = filter(value, (v) => !get(validateEmail(v), "valid"));
308
+ if (invalids.length > 0) {
309
+ return Promise.reject(EMAIL_NOT_VALID);
310
+ }
311
+ return Promise.resolve();
312
+ },
313
+ },
314
+ ], children: _jsx(Select, { mode: "tags", className: `share-link-dropdown md-lib-w-full`, placeholder: "Press enter to add email", tokenSeparators: [","], optionFilterProp: "children", suffixIcon: null, open: false }) })) : (_jsx(Form.Item, { label: "Email (you will receive an upload confirmation receipt)", name: "email", rules: [
315
+ {
316
+ required: true,
317
+ message: "Email is required",
318
+ },
319
+ ], children: _jsx(Input, { placeholder: "Email", disabled: !assetTypeId }) })), !thumbnailsOnly && (_jsx(Form.Item, { name: "reject_invalid_meta_file", valuePropName: "checked", children: _jsxs(Checkbox, { name: "reject_invalid_meta_file", children: ["Reject invalid meta file", _jsx(Popover, { content: _jsxs("span", { style: { color: "grey", padding: "5px" }, children: ["When this option is selected the uploaded metadata", _jsx("br", {}), " file will be rejected if it contains invalid values"] }), children: _jsx(QuestionCircleOutlined, { style: { marginLeft: "5px", color: "silver" } }) })] }) })), _jsx(Form.Item, { children: _jsx(Button, { block: true, type: "primary", htmlType: "submit", style: {
320
+ marginBottom: "10px",
321
+ backgroundColor: styles === null || styles === void 0 ? void 0 : styles.primaryColor,
322
+ }, loading: loading, disabled: isSubmitDisabled, children: "Submit" }) })] }) }));
323
+ };
324
+ export default BulkUploadModal;
@@ -0,0 +1,14 @@
1
+ import { SetStateAction } from "react";
2
+ import { FileEntity, ImagePickerEntity } from "../utilities/constants/interface";
3
+ declare function DriveContainer({ parentFolderId, setSelectedFile, setParentFolderId, pickerFolderId, selectedPickerFile, imagePicker, globalSearch, setGlobalSearch, setSelectedKeys, }: {
4
+ parentFolderId?: string;
5
+ setSelectedFile?: (file: FileEntity, localFile?: boolean) => void;
6
+ setParentFolderId?: (id: string) => void;
7
+ pickerFolderId?: string;
8
+ selectedPickerFile?: FileEntity;
9
+ imagePicker?: ImagePickerEntity | {};
10
+ globalSearch?: string;
11
+ setGlobalSearch?: React.Dispatch<SetStateAction<string>>;
12
+ setSelectedKeys?: (keys: string | string[]) => void;
13
+ }): JSX.Element;
14
+ export default DriveContainer;