@strapi/upload 0.0.0 → 5.0.0-beta.7

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 (217) hide show
  1. package/README.md +1 -1
  2. package/dist/_chunks/ca-B2_I-q1t.mjs +121 -0
  3. package/dist/_chunks/ca-B2_I-q1t.mjs.map +1 -0
  4. package/dist/_chunks/ca-BUpuZx8N.js +121 -0
  5. package/dist/_chunks/ca-BUpuZx8N.js.map +1 -0
  6. package/dist/_chunks/de-A7mEKx6c.mjs +107 -0
  7. package/dist/_chunks/de-A7mEKx6c.mjs.map +1 -0
  8. package/dist/_chunks/de-uGb_Pkq7.js +107 -0
  9. package/dist/_chunks/de-uGb_Pkq7.js.map +1 -0
  10. package/dist/_chunks/dk-BPfkJb9q.mjs +103 -0
  11. package/dist/_chunks/dk-BPfkJb9q.mjs.map +1 -0
  12. package/dist/_chunks/dk-Cd8oFO-O.js +103 -0
  13. package/dist/_chunks/dk-Cd8oFO-O.js.map +1 -0
  14. package/dist/_chunks/en-BcOqhiNe.js +144 -0
  15. package/dist/_chunks/en-BcOqhiNe.js.map +1 -0
  16. package/dist/_chunks/en-oDx2Gnre.mjs +144 -0
  17. package/dist/_chunks/en-oDx2Gnre.mjs.map +1 -0
  18. package/dist/_chunks/es-CuWi2pOn.mjs +120 -0
  19. package/dist/_chunks/es-CuWi2pOn.mjs.map +1 -0
  20. package/dist/_chunks/es-DWFtw_h4.js +120 -0
  21. package/dist/_chunks/es-DWFtw_h4.js.map +1 -0
  22. package/dist/_chunks/fr-BN6ndmWf.mjs +144 -0
  23. package/dist/_chunks/fr-BN6ndmWf.mjs.map +1 -0
  24. package/dist/_chunks/fr-D2bop66d.js +144 -0
  25. package/dist/_chunks/fr-D2bop66d.js.map +1 -0
  26. package/dist/_chunks/graphql-BVCZSNa2.mjs +71 -0
  27. package/dist/_chunks/graphql-BVCZSNa2.mjs.map +1 -0
  28. package/dist/_chunks/graphql-Beol7Y3b.js +71 -0
  29. package/dist/_chunks/graphql-Beol7Y3b.js.map +1 -0
  30. package/dist/_chunks/he-BpxHjaZg.js +76 -0
  31. package/dist/_chunks/he-BpxHjaZg.js.map +1 -0
  32. package/dist/_chunks/he-C9ZOXBB-.mjs +76 -0
  33. package/dist/_chunks/he-C9ZOXBB-.mjs.map +1 -0
  34. package/dist/_chunks/index-2C3ZYD4e.mjs +856 -0
  35. package/dist/_chunks/index-2C3ZYD4e.mjs.map +1 -0
  36. package/dist/_chunks/index-ASLx4V_D.mjs +6548 -0
  37. package/dist/_chunks/index-ASLx4V_D.mjs.map +1 -0
  38. package/dist/_chunks/index-BbFs7_Gx.js +859 -0
  39. package/dist/_chunks/index-BbFs7_Gx.js.map +1 -0
  40. package/dist/_chunks/index-BxUjcUMp.js +266 -0
  41. package/dist/_chunks/index-BxUjcUMp.js.map +1 -0
  42. package/dist/_chunks/index-CRhNpXFr.js +2632 -0
  43. package/dist/_chunks/index-CRhNpXFr.js.map +1 -0
  44. package/dist/_chunks/index-DJC1L27M.js +238 -0
  45. package/dist/_chunks/index-DJC1L27M.js.map +1 -0
  46. package/dist/_chunks/index-PKgX3DYk.js +6574 -0
  47. package/dist/_chunks/index-PKgX3DYk.js.map +1 -0
  48. package/dist/_chunks/index-VKvfSVC7.mjs +2622 -0
  49. package/dist/_chunks/index-VKvfSVC7.mjs.map +1 -0
  50. package/dist/_chunks/index-fmt8afwE.mjs +262 -0
  51. package/dist/_chunks/index-fmt8afwE.mjs.map +1 -0
  52. package/dist/_chunks/index-q-dRjRbA.mjs +233 -0
  53. package/dist/_chunks/index-q-dRjRbA.mjs.map +1 -0
  54. package/dist/_chunks/it-B7rmoZNx.mjs +76 -0
  55. package/dist/_chunks/it-B7rmoZNx.mjs.map +1 -0
  56. package/dist/_chunks/it-BKCWXl8t.js +76 -0
  57. package/dist/_chunks/it-BKCWXl8t.js.map +1 -0
  58. package/dist/_chunks/ja-DlaJTi_3.mjs +76 -0
  59. package/dist/_chunks/ja-DlaJTi_3.mjs.map +1 -0
  60. package/dist/_chunks/ja-ajHzIJz6.js +76 -0
  61. package/dist/_chunks/ja-ajHzIJz6.js.map +1 -0
  62. package/dist/_chunks/ko-Pzj-818C.js +106 -0
  63. package/dist/_chunks/ko-Pzj-818C.js.map +1 -0
  64. package/dist/_chunks/ko-vJl9kPpn.mjs +106 -0
  65. package/dist/_chunks/ko-vJl9kPpn.mjs.map +1 -0
  66. package/dist/_chunks/ms-CqwG8v8l.mjs +68 -0
  67. package/dist/_chunks/ms-CqwG8v8l.mjs.map +1 -0
  68. package/dist/_chunks/ms-h3gjldBy.js +68 -0
  69. package/dist/_chunks/ms-h3gjldBy.js.map +1 -0
  70. package/dist/_chunks/pl-Cj8jChOO.mjs +105 -0
  71. package/dist/_chunks/pl-Cj8jChOO.mjs.map +1 -0
  72. package/dist/_chunks/pl-esgZ7ltN.js +105 -0
  73. package/dist/_chunks/pl-esgZ7ltN.js.map +1 -0
  74. package/dist/_chunks/pt-BR-B4LJHJIp.mjs +76 -0
  75. package/dist/_chunks/pt-BR-B4LJHJIp.mjs.map +1 -0
  76. package/dist/_chunks/pt-BR-Cazr7Z5I.js +76 -0
  77. package/dist/_chunks/pt-BR-Cazr7Z5I.js.map +1 -0
  78. package/dist/_chunks/pt-CNOOM_7x.mjs +76 -0
  79. package/dist/_chunks/pt-CNOOM_7x.mjs.map +1 -0
  80. package/dist/_chunks/pt-cbUnkHM5.js +76 -0
  81. package/dist/_chunks/pt-cbUnkHM5.js.map +1 -0
  82. package/dist/_chunks/ru-DqglvSUC.mjs +76 -0
  83. package/dist/_chunks/ru-DqglvSUC.mjs.map +1 -0
  84. package/dist/_chunks/ru-H6MzFUxp.js +76 -0
  85. package/dist/_chunks/ru-H6MzFUxp.js.map +1 -0
  86. package/dist/_chunks/sk-CZxC4dFY.js +122 -0
  87. package/dist/_chunks/sk-CZxC4dFY.js.map +1 -0
  88. package/dist/_chunks/sk-Dgpb3lnz.mjs +122 -0
  89. package/dist/_chunks/sk-Dgpb3lnz.mjs.map +1 -0
  90. package/dist/_chunks/th-C6unJZ8j.js +76 -0
  91. package/dist/_chunks/th-C6unJZ8j.js.map +1 -0
  92. package/dist/_chunks/th-DRfzuiFf.mjs +76 -0
  93. package/dist/_chunks/th-DRfzuiFf.mjs.map +1 -0
  94. package/dist/_chunks/tr--GzWXE_A.mjs +122 -0
  95. package/dist/_chunks/tr--GzWXE_A.mjs.map +1 -0
  96. package/dist/_chunks/tr-CY6AwX50.js +122 -0
  97. package/dist/_chunks/tr-CY6AwX50.js.map +1 -0
  98. package/dist/_chunks/uk-BniyNsD4.js +73 -0
  99. package/dist/_chunks/uk-BniyNsD4.js.map +1 -0
  100. package/dist/_chunks/uk-DVMT2Piq.mjs +73 -0
  101. package/dist/_chunks/uk-DVMT2Piq.mjs.map +1 -0
  102. package/dist/_chunks/zh-CsZw0IpM.js +129 -0
  103. package/dist/_chunks/zh-CsZw0IpM.js.map +1 -0
  104. package/dist/_chunks/zh-HOnih0is.mjs +129 -0
  105. package/dist/_chunks/zh-HOnih0is.mjs.map +1 -0
  106. package/dist/_chunks/zh-Hans-Cpmhg8uH.mjs +152 -0
  107. package/dist/_chunks/zh-Hans-Cpmhg8uH.mjs.map +1 -0
  108. package/dist/_chunks/zh-Hans-k_xAc6nm.js +152 -0
  109. package/dist/_chunks/zh-Hans-k_xAc6nm.js.map +1 -0
  110. package/dist/admin/index.js +5 -0
  111. package/dist/admin/index.js.map +1 -0
  112. package/dist/admin/index.mjs +6 -0
  113. package/dist/admin/index.mjs.map +1 -0
  114. package/dist/server/index.js +4 -0
  115. package/dist/server/index.js.map +1 -0
  116. package/dist/server/index.mjs +5 -0
  117. package/dist/server/index.mjs.map +1 -0
  118. package/dist/server/src/bootstrap.d.ts +5 -0
  119. package/dist/server/src/bootstrap.d.ts.map +1 -0
  120. package/dist/server/src/config.d.ts +10 -0
  121. package/dist/server/src/config.d.ts.map +1 -0
  122. package/dist/server/src/constants.d.ts +20 -0
  123. package/dist/server/src/constants.d.ts.map +1 -0
  124. package/dist/server/src/content-types/file.d.ts +110 -0
  125. package/dist/server/src/content-types/file.d.ts.map +1 -0
  126. package/dist/server/src/content-types/folder.d.ts +61 -0
  127. package/dist/server/src/content-types/folder.d.ts.map +1 -0
  128. package/dist/server/src/content-types/index.d.ts +170 -0
  129. package/dist/server/src/content-types/index.d.ts.map +1 -0
  130. package/dist/server/src/controllers/admin-file.d.ts +16 -0
  131. package/dist/server/src/controllers/admin-file.d.ts.map +1 -0
  132. package/dist/server/src/controllers/admin-folder-file.d.ts +7 -0
  133. package/dist/server/src/controllers/admin-folder-file.d.ts.map +1 -0
  134. package/dist/server/src/controllers/admin-folder.d.ts +10 -0
  135. package/dist/server/src/controllers/admin-folder.d.ts.map +1 -0
  136. package/dist/server/src/controllers/admin-settings.d.ts +7 -0
  137. package/dist/server/src/controllers/admin-settings.d.ts.map +1 -0
  138. package/dist/server/src/controllers/admin-upload.d.ts +9 -0
  139. package/dist/server/src/controllers/admin-upload.d.ts.map +1 -0
  140. package/dist/server/src/controllers/content-api.d.ts +15 -0
  141. package/dist/server/src/controllers/content-api.d.ts.map +1 -0
  142. package/dist/server/src/controllers/index.d.ts +53 -0
  143. package/dist/server/src/controllers/index.d.ts.map +1 -0
  144. package/dist/server/src/controllers/utils/find-entity-and-check-permissions.d.ts +6 -0
  145. package/dist/server/src/controllers/utils/find-entity-and-check-permissions.d.ts.map +1 -0
  146. package/dist/server/src/controllers/utils/folders.d.ts +4 -0
  147. package/dist/server/src/controllers/utils/folders.d.ts.map +1 -0
  148. package/dist/server/src/controllers/validation/admin/configureView.d.ts +15 -0
  149. package/dist/server/src/controllers/validation/admin/configureView.d.ts.map +1 -0
  150. package/dist/server/src/controllers/validation/admin/folder-file.d.ts +3 -0
  151. package/dist/server/src/controllers/validation/admin/folder-file.d.ts.map +1 -0
  152. package/dist/server/src/controllers/validation/admin/folder.d.ts +3 -0
  153. package/dist/server/src/controllers/validation/admin/folder.d.ts.map +1 -0
  154. package/dist/server/src/controllers/validation/admin/settings.d.ts +18 -0
  155. package/dist/server/src/controllers/validation/admin/settings.d.ts.map +1 -0
  156. package/dist/server/src/controllers/validation/admin/upload.d.ts +109 -0
  157. package/dist/server/src/controllers/validation/admin/upload.d.ts.map +1 -0
  158. package/dist/server/src/controllers/validation/admin/utils.d.ts +3 -0
  159. package/dist/server/src/controllers/validation/admin/utils.d.ts.map +1 -0
  160. package/dist/server/src/controllers/validation/content-api/upload.d.ts +91 -0
  161. package/dist/server/src/controllers/validation/content-api/upload.d.ts.map +1 -0
  162. package/dist/server/src/controllers/view-configuration.d.ts +7 -0
  163. package/dist/server/src/controllers/view-configuration.d.ts.map +1 -0
  164. package/dist/server/src/graphql.d.ts +5 -0
  165. package/dist/server/src/graphql.d.ts.map +1 -0
  166. package/dist/server/src/index.d.ts +475 -0
  167. package/dist/server/src/index.d.ts.map +1 -0
  168. package/dist/server/src/middlewares/upload.d.ts +9 -0
  169. package/dist/server/src/middlewares/upload.d.ts.map +1 -0
  170. package/dist/server/src/register.d.ts +8 -0
  171. package/dist/server/src/register.d.ts.map +1 -0
  172. package/dist/server/src/routes/admin.d.ts +17 -0
  173. package/dist/server/src/routes/admin.d.ts.map +1 -0
  174. package/dist/server/src/routes/content-api.d.ts +9 -0
  175. package/dist/server/src/routes/content-api.d.ts.map +1 -0
  176. package/dist/server/src/routes/index.d.ts +43 -0
  177. package/dist/server/src/routes/index.d.ts.map +1 -0
  178. package/dist/server/src/routes/view-configuration.d.ts +17 -0
  179. package/dist/server/src/routes/view-configuration.d.ts.map +1 -0
  180. package/dist/server/src/services/api-upload-folder.d.ts +5 -0
  181. package/dist/server/src/services/api-upload-folder.d.ts.map +1 -0
  182. package/dist/server/src/services/extensions/content-manager/entity-manager.d.ts +15 -0
  183. package/dist/server/src/services/extensions/content-manager/entity-manager.d.ts.map +1 -0
  184. package/dist/server/src/services/extensions/content-manager/index.d.ts +4 -0
  185. package/dist/server/src/services/extensions/content-manager/index.d.ts.map +1 -0
  186. package/dist/server/src/services/extensions/core/entity-service.d.ts +4 -0
  187. package/dist/server/src/services/extensions/core/entity-service.d.ts.map +1 -0
  188. package/dist/server/src/services/extensions/core/index.d.ts +4 -0
  189. package/dist/server/src/services/extensions/core/index.d.ts.map +1 -0
  190. package/dist/server/src/services/extensions/index.d.ts +8 -0
  191. package/dist/server/src/services/extensions/index.d.ts.map +1 -0
  192. package/dist/server/src/services/extensions/utils.d.ts +14 -0
  193. package/dist/server/src/services/extensions/utils.d.ts.map +1 -0
  194. package/dist/server/src/services/file.d.ts +8 -0
  195. package/dist/server/src/services/file.d.ts.map +1 -0
  196. package/dist/server/src/services/folder.d.ts +32 -0
  197. package/dist/server/src/services/folder.d.ts.map +1 -0
  198. package/dist/server/src/services/image-manipulation.d.ts +63 -0
  199. package/dist/server/src/services/image-manipulation.d.ts.map +1 -0
  200. package/dist/server/src/services/index.d.ts +196 -0
  201. package/dist/server/src/services/index.d.ts.map +1 -0
  202. package/dist/server/src/services/metrics.d.ts +8 -0
  203. package/dist/server/src/services/metrics.d.ts.map +1 -0
  204. package/dist/server/src/services/provider.d.ts +10 -0
  205. package/dist/server/src/services/provider.d.ts.map +1 -0
  206. package/dist/server/src/services/upload.d.ts +67 -0
  207. package/dist/server/src/services/upload.d.ts.map +1 -0
  208. package/dist/server/src/services/weekly-metrics.d.ts +17 -0
  209. package/dist/server/src/services/weekly-metrics.d.ts.map +1 -0
  210. package/dist/server/src/types.d.ts +74 -0
  211. package/dist/server/src/types.d.ts.map +1 -0
  212. package/dist/server/src/utils/cron.d.ts +3 -0
  213. package/dist/server/src/utils/cron.d.ts.map +1 -0
  214. package/dist/server/src/utils/index.d.ts +23 -0
  215. package/dist/server/src/utils/index.d.ts.map +1 -0
  216. package/package.json +99 -7
  217. package/strapi-server.js +3 -0
@@ -0,0 +1,856 @@
1
+ import { jsx, jsxs, Fragment } from "react/jsx-runtime";
2
+ import { useState, useRef, lazy, useEffect, Suspense } from "react";
3
+ import { ConfirmDialog, useNotification, useFetchClient, useTracking, useQueryParams, Layouts, Page, SearchInput, Pagination } from "@strapi/admin/strapi-admin";
4
+ import { useIntl } from "react-intl";
5
+ import { useLocation, useNavigate, Link as Link$1, Routes, Route } from "react-router-dom";
6
+ import { g as getTrad, a as getFolderURL, u as useFolderCard, A as AssetDefinition, F as FolderDefinition, b as useBulkRemove, p as pluginId, c as useFolderStructure, S as SelectTree, n as normalizeAPIError, E as EmptyAssets, d as FilterPopover, e as displayedFilters, f as FilterList, B as BreadcrumbsDefinition, h as Breadcrumbs, i as useMediaLibraryPermissions, j as usePersistentState, v as viewOptions, l as localStorageKeys, k as useAssets, m as useFolders, o as containsAssetFilter, q as useFolder, r as useSelectionState, s as SortPicker, T as TableList, t as FolderGridList, w as FolderCard, x as FolderCardBody, y as FolderCardBodyAction, z as AssetGridList, U as UploadAssetDialog, C as EditFolderDialog, D as EditAssetDialog, G as useConfig } from "./index-ASLx4V_D.mjs";
7
+ import "byte-size";
8
+ import "date-fns";
9
+ import { stringify } from "qs";
10
+ import { Box, BaseCheckbox, Button, ModalLayout, ModalBody, Flex, Loader, ModalHeader, Typography, Grid, GridItem, Field, ModalFooter, Link, IconButton, VisuallyHidden, Divider } from "@strapi/design-system";
11
+ import { Trash, Folder, Plus, Filter, ArrowLeft, Cog, List, GridFour, Pencil } from "@strapi/icons";
12
+ import { styled } from "styled-components";
13
+ import PropTypes from "prop-types";
14
+ import { Formik, Form } from "formik";
15
+ import isEmpty from "lodash/isEmpty";
16
+ import { useQueryClient, useMutation } from "react-query";
17
+ import { EmptyPermissions } from "@strapi/icons/symbols";
18
+ const getBreadcrumbDataML = (folder, { pathname, query }) => {
19
+ let data = [
20
+ {
21
+ id: null,
22
+ label: { id: getTrad("plugin.name"), defaultMessage: "Media Library" },
23
+ href: folder ? getFolderURL(pathname, query) : void 0
24
+ }
25
+ ];
26
+ if (folder?.parent?.parent) {
27
+ data.push([]);
28
+ }
29
+ if (folder?.parent) {
30
+ data.push({
31
+ id: folder.parent.id,
32
+ label: folder.parent.name,
33
+ href: getFolderURL(pathname, query, {
34
+ folder: folder.parent.id,
35
+ folderPath: folder.parent.path
36
+ })
37
+ });
38
+ }
39
+ if (folder) {
40
+ data.push({
41
+ id: folder.id,
42
+ label: folder.name
43
+ });
44
+ }
45
+ return data;
46
+ };
47
+ const FolderCardCheckbox = (props) => {
48
+ const { id } = useFolderCard();
49
+ return /* @__PURE__ */ jsx(Box, { position: "relative", zIndex: 2, children: /* @__PURE__ */ jsx(BaseCheckbox, { "aria-labelledby": `${id}-title`, ...props }) });
50
+ };
51
+ const BulkDeleteButton = ({ selected, onSuccess }) => {
52
+ const { formatMessage } = useIntl();
53
+ const [showConfirmDialog, setShowConfirmDialog] = useState(false);
54
+ const { remove } = useBulkRemove();
55
+ const handleConfirmRemove = async () => {
56
+ await remove(selected);
57
+ onSuccess();
58
+ };
59
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
60
+ /* @__PURE__ */ jsx(
61
+ Button,
62
+ {
63
+ variant: "danger-light",
64
+ size: "S",
65
+ startIcon: /* @__PURE__ */ jsx(Trash, {}),
66
+ onClick: () => setShowConfirmDialog(true),
67
+ children: formatMessage({ id: "global.delete", defaultMessage: "Delete" })
68
+ }
69
+ ),
70
+ /* @__PURE__ */ jsx(
71
+ ConfirmDialog,
72
+ {
73
+ isOpen: showConfirmDialog,
74
+ onClose: () => setShowConfirmDialog(false),
75
+ onConfirm: handleConfirmRemove
76
+ }
77
+ )
78
+ ] });
79
+ };
80
+ BulkDeleteButton.propTypes = {
81
+ selected: PropTypes.arrayOf(AssetDefinition, FolderDefinition).isRequired,
82
+ onSuccess: PropTypes.func.isRequired
83
+ };
84
+ const useBulkMove = () => {
85
+ const { formatMessage } = useIntl();
86
+ const { toggleNotification } = useNotification();
87
+ const queryClient = useQueryClient();
88
+ const { post } = useFetchClient();
89
+ const bulkMoveQuery = ({ destinationFolderId, filesAndFolders }) => {
90
+ const payload = filesAndFolders.reduce((acc, selected) => {
91
+ const { id, type } = selected;
92
+ const key = type === "asset" ? "fileIds" : "folderIds";
93
+ if (!acc[key]) {
94
+ acc[key] = [];
95
+ }
96
+ acc[key].push(id);
97
+ return acc;
98
+ }, {});
99
+ return post("/upload/actions/bulk-move", { ...payload, destinationFolderId });
100
+ };
101
+ const mutation = useMutation(bulkMoveQuery, {
102
+ onSuccess(res) {
103
+ const {
104
+ data: { data }
105
+ } = res;
106
+ if (data?.files?.length > 0) {
107
+ queryClient.refetchQueries([pluginId, "assets"], { active: true });
108
+ queryClient.refetchQueries([pluginId, "asset-count"], { active: true });
109
+ }
110
+ queryClient.refetchQueries([pluginId, "folders"], { active: true });
111
+ toggleNotification({
112
+ type: "success",
113
+ message: formatMessage({
114
+ id: getTrad("modal.move.success-label"),
115
+ defaultMessage: "Elements have been moved successfully."
116
+ })
117
+ });
118
+ }
119
+ });
120
+ const move = (destinationFolderId, filesAndFolders) => mutation.mutateAsync({ destinationFolderId, filesAndFolders });
121
+ return { ...mutation, move };
122
+ };
123
+ const BulkMoveDialog = ({ onClose, selected, currentFolder }) => {
124
+ const { formatMessage } = useIntl();
125
+ const { data: folderStructure, isLoading } = useFolderStructure();
126
+ const { move } = useBulkMove();
127
+ if (!folderStructure) {
128
+ return null;
129
+ }
130
+ const handleSubmit = async (values, { setErrors }) => {
131
+ try {
132
+ await move(values.destination.value, selected);
133
+ onClose();
134
+ } catch (error) {
135
+ const normalizedError = normalizeAPIError(error);
136
+ const formikErrors = normalizedError.errors.reduce((acc, error2) => {
137
+ acc[error2.values?.path?.length || "destination"] = error2.defaultMessage;
138
+ return acc;
139
+ }, {});
140
+ if (!isEmpty(formikErrors)) {
141
+ setErrors(formikErrors);
142
+ }
143
+ }
144
+ };
145
+ const handleClose = () => {
146
+ onClose();
147
+ };
148
+ if (isLoading) {
149
+ return /* @__PURE__ */ jsx(ModalLayout, { onClose: handleClose, labelledBy: "title", children: /* @__PURE__ */ jsx(ModalBody, { children: /* @__PURE__ */ jsx(Flex, { justifyContent: "center", paddingTop: 4, paddingBottom: 4, children: /* @__PURE__ */ jsx(Loader, { children: formatMessage({
150
+ id: getTrad("content.isLoading"),
151
+ defaultMessage: "Content is loading."
152
+ }) }) }) }) });
153
+ }
154
+ const initialFormData = {
155
+ destination: {
156
+ value: currentFolder?.id || "",
157
+ label: currentFolder?.name || folderStructure[0].label
158
+ }
159
+ };
160
+ return /* @__PURE__ */ jsx(ModalLayout, { onClose: handleClose, labelledBy: "title", children: /* @__PURE__ */ jsx(Formik, { validateOnChange: false, onSubmit: handleSubmit, initialValues: initialFormData, children: ({ values, errors, setFieldValue }) => /* @__PURE__ */ jsxs(Form, { noValidate: true, children: [
161
+ /* @__PURE__ */ jsx(ModalHeader, { children: /* @__PURE__ */ jsx(Typography, { fontWeight: "bold", textColor: "neutral800", tag: "h2", id: "title", children: formatMessage({
162
+ id: getTrad("modal.folder.move.title"),
163
+ defaultMessage: "Move elements to"
164
+ }) }) }),
165
+ /* @__PURE__ */ jsx(ModalBody, { children: /* @__PURE__ */ jsx(Grid, { gap: 4, children: /* @__PURE__ */ jsx(GridItem, { xs: 12, col: 12, children: /* @__PURE__ */ jsxs(Field.Root, { id: "folder-destination", children: [
166
+ /* @__PURE__ */ jsx(Field.Label, { children: formatMessage({
167
+ id: getTrad("form.input.label.folder-location"),
168
+ defaultMessage: "Location"
169
+ }) }),
170
+ /* @__PURE__ */ jsx(
171
+ SelectTree,
172
+ {
173
+ options: folderStructure,
174
+ onChange: (value) => {
175
+ setFieldValue("destination", value);
176
+ },
177
+ defaultValue: values.destination,
178
+ name: "destination",
179
+ menuPortalTarget: document.querySelector("body"),
180
+ inputId: "folder-destination",
181
+ error: errors?.destination,
182
+ ariaErrorMessage: "destination-error"
183
+ }
184
+ ),
185
+ errors.destination && /* @__PURE__ */ jsx(Typography, { variant: "pi", tag: "p", textColor: "danger600", children: errors.destination })
186
+ ] }) }) }) }),
187
+ /* @__PURE__ */ jsx(
188
+ ModalFooter,
189
+ {
190
+ startActions: /* @__PURE__ */ jsx(Button, { onClick: handleClose, variant: "tertiary", name: "cancel", children: formatMessage({ id: "cancel", defaultMessage: "Cancel" }) }),
191
+ endActions: /* @__PURE__ */ jsx(Button, { type: "submit", loading: isLoading, children: formatMessage({ id: "modal.folder.move.submit", defaultMessage: "Move" }) })
192
+ }
193
+ )
194
+ ] }) }) });
195
+ };
196
+ BulkMoveDialog.defaultProps = {
197
+ currentFolder: void 0
198
+ };
199
+ BulkMoveDialog.propTypes = {
200
+ onClose: PropTypes.func.isRequired,
201
+ currentFolder: FolderDefinition,
202
+ selected: PropTypes.arrayOf(FolderDefinition, AssetDefinition).isRequired
203
+ };
204
+ const BulkMoveButton = ({ selected, onSuccess, currentFolder }) => {
205
+ const { formatMessage } = useIntl();
206
+ const [showConfirmDialog, setShowConfirmDialog] = useState(false);
207
+ const handleConfirmMove = () => {
208
+ setShowConfirmDialog(false);
209
+ onSuccess();
210
+ };
211
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
212
+ /* @__PURE__ */ jsx(
213
+ Button,
214
+ {
215
+ variant: "secondary",
216
+ size: "S",
217
+ startIcon: /* @__PURE__ */ jsx(Folder, {}),
218
+ onClick: () => setShowConfirmDialog(true),
219
+ children: formatMessage({ id: "global.move", defaultMessage: "Move" })
220
+ }
221
+ ),
222
+ showConfirmDialog && /* @__PURE__ */ jsx(
223
+ BulkMoveDialog,
224
+ {
225
+ currentFolder,
226
+ onClose: handleConfirmMove,
227
+ selected
228
+ }
229
+ )
230
+ ] });
231
+ };
232
+ BulkMoveButton.defaultProps = {
233
+ currentFolder: void 0
234
+ };
235
+ BulkMoveButton.propTypes = {
236
+ onSuccess: PropTypes.func.isRequired,
237
+ currentFolder: FolderDefinition,
238
+ selected: PropTypes.arrayOf(AssetDefinition, FolderDefinition).isRequired
239
+ };
240
+ const BulkActions = ({ selected, onSuccess, currentFolder }) => {
241
+ const { formatMessage } = useIntl();
242
+ return /* @__PURE__ */ jsxs(Flex, { gap: 2, paddingBottom: 5, children: [
243
+ /* @__PURE__ */ jsx(Typography, { variant: "epsilon", textColor: "neutral600", children: formatMessage(
244
+ {
245
+ id: getTrad("list.assets.selected"),
246
+ defaultMessage: "{numberFolders, plural, one {1 folder} other {# folders}} - {numberAssets, plural, one {1 asset} other {# assets}} selected"
247
+ },
248
+ {
249
+ numberFolders: selected.filter(({ type }) => type === "folder").length,
250
+ numberAssets: selected.filter(({ type }) => type === "asset").length
251
+ }
252
+ ) }),
253
+ /* @__PURE__ */ jsx(BulkDeleteButton, { selected, onSuccess }),
254
+ /* @__PURE__ */ jsx(BulkMoveButton, { currentFolder, selected, onSuccess })
255
+ ] });
256
+ };
257
+ BulkActions.defaultProps = {
258
+ currentFolder: void 0
259
+ };
260
+ BulkActions.propTypes = {
261
+ onSuccess: PropTypes.func.isRequired,
262
+ currentFolder: FolderDefinition,
263
+ selected: PropTypes.arrayOf(AssetDefinition, FolderDefinition).isRequired
264
+ };
265
+ const getContentIntlMessage = ({ isFiltering, canCreate, canRead }) => {
266
+ if (isFiltering) {
267
+ return {
268
+ id: "list.assets-empty.title-withSearch",
269
+ defaultMessage: "There are no elements with the applied filters"
270
+ };
271
+ }
272
+ if (canRead) {
273
+ if (canCreate) {
274
+ return {
275
+ id: "list.assets.empty-upload",
276
+ defaultMessage: "Upload your first assets..."
277
+ };
278
+ }
279
+ return {
280
+ id: "list.assets.empty",
281
+ defaultMessage: "Media Library is empty"
282
+ };
283
+ }
284
+ return {
285
+ id: "header.actions.no-permissions",
286
+ defaultMessage: "No permissions to view"
287
+ };
288
+ };
289
+ const EmptyOrNoPermissions = ({ canCreate, isFiltering, canRead, onActionClick }) => {
290
+ const { formatMessage } = useIntl();
291
+ const content = getContentIntlMessage({ isFiltering, canCreate, canRead });
292
+ return /* @__PURE__ */ jsx(
293
+ EmptyAssets,
294
+ {
295
+ icon: !canRead ? EmptyPermissions : void 0,
296
+ action: canCreate && !isFiltering && /* @__PURE__ */ jsx(Button, { variant: "secondary", startIcon: /* @__PURE__ */ jsx(Plus, {}), onClick: onActionClick, children: formatMessage({
297
+ id: getTrad("header.actions.add-assets"),
298
+ defaultMessage: "Add new assets"
299
+ }) }),
300
+ content: formatMessage({
301
+ ...content,
302
+ id: getTrad(content.id)
303
+ })
304
+ }
305
+ );
306
+ };
307
+ EmptyOrNoPermissions.propTypes = {
308
+ canCreate: PropTypes.bool.isRequired,
309
+ canRead: PropTypes.bool.isRequired,
310
+ isFiltering: PropTypes.bool.isRequired,
311
+ onActionClick: PropTypes.func.isRequired
312
+ };
313
+ const Filters = () => {
314
+ const buttonRef = useRef(null);
315
+ const [isVisible, setVisible] = useState(false);
316
+ const { formatMessage } = useIntl();
317
+ const { trackUsage } = useTracking();
318
+ const [{ query }, setQuery] = useQueryParams();
319
+ const filters = query?.filters?.$and || [];
320
+ const toggleFilter = () => setVisible((prev) => !prev);
321
+ const handleRemoveFilter = (nextFilters) => {
322
+ setQuery({ filters: { $and: nextFilters }, page: 1 });
323
+ };
324
+ const handleSubmit = (filters2) => {
325
+ trackUsage("didFilterMediaLibraryElements", {
326
+ location: "content-manager",
327
+ filter: Object.keys(filters2[filters2.length - 1])[0]
328
+ });
329
+ setQuery({ filters: { $and: filters2 }, page: 1 });
330
+ };
331
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
332
+ /* @__PURE__ */ jsx(
333
+ Button,
334
+ {
335
+ variant: "tertiary",
336
+ ref: buttonRef,
337
+ startIcon: /* @__PURE__ */ jsx(Filter, {}),
338
+ onClick: toggleFilter,
339
+ size: "S",
340
+ children: formatMessage({ id: "app.utils.filters", defaultMessage: "Filters" })
341
+ }
342
+ ),
343
+ isVisible && /* @__PURE__ */ jsx(
344
+ FilterPopover,
345
+ {
346
+ displayedFilters,
347
+ filters,
348
+ onSubmit: handleSubmit,
349
+ onToggle: toggleFilter,
350
+ source: buttonRef
351
+ }
352
+ ),
353
+ /* @__PURE__ */ jsx(
354
+ FilterList,
355
+ {
356
+ appliedFilters: filters,
357
+ filtersSchema: displayedFilters,
358
+ onRemoveFilter: handleRemoveFilter
359
+ }
360
+ )
361
+ ] });
362
+ };
363
+ const Header = ({
364
+ breadcrumbs,
365
+ canCreate,
366
+ folder,
367
+ onToggleEditFolderDialog,
368
+ onToggleUploadAssetDialog
369
+ }) => {
370
+ const { formatMessage } = useIntl();
371
+ const { pathname } = useLocation();
372
+ const [{ query }] = useQueryParams();
373
+ const backQuery = {
374
+ ...query,
375
+ folder: folder?.parent?.id ?? void 0,
376
+ folderPath: folder?.parent?.path ?? void 0
377
+ };
378
+ return /* @__PURE__ */ jsx(
379
+ Layouts.Header,
380
+ {
381
+ title: formatMessage({
382
+ id: getTrad("plugin.name"),
383
+ defaultMessage: `Media Library`
384
+ }),
385
+ subtitle: breadcrumbs && folder && /* @__PURE__ */ jsx(
386
+ Breadcrumbs,
387
+ {
388
+ tag: "nav",
389
+ label: formatMessage({
390
+ id: getTrad("header.breadcrumbs.nav.label"),
391
+ defaultMessage: "Folders navigation"
392
+ }),
393
+ breadcrumbs,
394
+ currentFolderId: folder?.id
395
+ }
396
+ ),
397
+ navigationAction: folder && /* @__PURE__ */ jsx(
398
+ Link,
399
+ {
400
+ startIcon: /* @__PURE__ */ jsx(ArrowLeft, {}),
401
+ to: `${pathname}?${stringify(backQuery, { encode: false })}`,
402
+ children: formatMessage({
403
+ id: getTrad("header.actions.folder-level-up"),
404
+ defaultMessage: "Back"
405
+ })
406
+ }
407
+ ),
408
+ primaryAction: canCreate && /* @__PURE__ */ jsxs(Flex, { gap: 2, children: [
409
+ /* @__PURE__ */ jsx(Button, { startIcon: /* @__PURE__ */ jsx(Plus, {}), variant: "secondary", onClick: onToggleEditFolderDialog, children: formatMessage({
410
+ id: getTrad("header.actions.add-folder"),
411
+ defaultMessage: "Add new folder"
412
+ }) }),
413
+ /* @__PURE__ */ jsx(Button, { startIcon: /* @__PURE__ */ jsx(Plus, {}), onClick: onToggleUploadAssetDialog, children: formatMessage({
414
+ id: getTrad("header.actions.add-assets"),
415
+ defaultMessage: "Add new assets"
416
+ }) })
417
+ ] })
418
+ }
419
+ );
420
+ };
421
+ Header.defaultProps = {
422
+ breadcrumbs: false,
423
+ folder: null
424
+ };
425
+ Header.propTypes = {
426
+ breadcrumbs: PropTypes.oneOfType([BreadcrumbsDefinition, PropTypes.bool]),
427
+ canCreate: PropTypes.bool.isRequired,
428
+ folder: FolderDefinition,
429
+ onToggleEditFolderDialog: PropTypes.func.isRequired,
430
+ onToggleUploadAssetDialog: PropTypes.func.isRequired
431
+ };
432
+ const BoxWithHeight = styled(Box)`
433
+ height: 3.2rem;
434
+ display: flex;
435
+ align-items: center;
436
+ `;
437
+ const TypographyMaxWidth = styled(Typography)`
438
+ max-width: 100%;
439
+ `;
440
+ const ActionContainer = styled(Box)`
441
+ svg {
442
+ path {
443
+ fill: ${({ theme }) => theme.colors.neutral500};
444
+ }
445
+ }
446
+ `;
447
+ const MediaLibrary = () => {
448
+ const navigate = useNavigate();
449
+ const {
450
+ canRead,
451
+ canCreate,
452
+ canUpdate,
453
+ canCopyLink,
454
+ canDownload,
455
+ canConfigureView,
456
+ isLoading: permissionsLoading
457
+ } = useMediaLibraryPermissions();
458
+ const currentFolderToEditRef = useRef();
459
+ const { formatMessage } = useIntl();
460
+ const { pathname } = useLocation();
461
+ const { trackUsage } = useTracking();
462
+ const [{ query }, setQuery] = useQueryParams();
463
+ const isFiltering = Boolean(query._q || query.filters);
464
+ const [view, setView] = usePersistentState(localStorageKeys.view, viewOptions.GRID);
465
+ const isGridView = view === viewOptions.GRID;
466
+ const {
467
+ data: assetsData,
468
+ isLoading: assetsLoading,
469
+ errors: assetsError
470
+ } = useAssets({
471
+ skipWhen: !canRead,
472
+ query
473
+ });
474
+ const {
475
+ data: foldersData,
476
+ isLoading: foldersLoading,
477
+ errors: foldersError
478
+ } = useFolders({
479
+ enabled: canRead && assetsData?.pagination?.page === 1 && !containsAssetFilter(query),
480
+ query
481
+ });
482
+ const {
483
+ data: currentFolder,
484
+ isLoading: isCurrentFolderLoading,
485
+ error: currentFolderError
486
+ } = useFolder(query?.folder, {
487
+ enabled: canRead && !!query?.folder
488
+ });
489
+ if (currentFolderError?.response?.status === 404) {
490
+ navigate(pathname);
491
+ }
492
+ const folders = foldersData?.map((folder) => ({
493
+ ...folder,
494
+ type: "folder",
495
+ folderURL: getFolderURL(pathname, query, folder.id),
496
+ isSelectable: canUpdate
497
+ })) ?? [];
498
+ const folderCount = folders?.length || 0;
499
+ const assets = assetsData?.results?.map((asset) => ({ ...asset, type: "asset", isSelectable: canUpdate })) || [];
500
+ const assetCount = assets?.length ?? 0;
501
+ const totalAssetCount = assetsData?.pagination?.total;
502
+ const isLoading = isCurrentFolderLoading || foldersLoading || permissionsLoading || assetsLoading;
503
+ const [showUploadAssetDialog, setShowUploadAssetDialog] = useState(false);
504
+ const [showEditFolderDialog, setShowEditFolderDialog] = useState(false);
505
+ const [assetToEdit, setAssetToEdit] = useState(void 0);
506
+ const [folderToEdit, setFolderToEdit] = useState(void 0);
507
+ const [selected, { selectOne, selectAll }] = useSelectionState(["type", "id"], []);
508
+ const indeterminateBulkSelect = selected?.length > 0 && selected?.length !== assetCount + folderCount;
509
+ const toggleUploadAssetDialog = () => setShowUploadAssetDialog((prev) => !prev);
510
+ const toggleEditFolderDialog = ({ created = false } = {}) => {
511
+ if (created && query?.page !== "1") {
512
+ setQuery({
513
+ ...query,
514
+ page: 1
515
+ });
516
+ }
517
+ setShowEditFolderDialog((prev) => !prev);
518
+ };
519
+ const handleBulkSelect = (event, elements) => {
520
+ if (event.target.checked) {
521
+ trackUsage("didSelectAllMediaLibraryElements");
522
+ }
523
+ selectAll(elements);
524
+ };
525
+ const handleChangeSort = (value) => {
526
+ trackUsage("didSortMediaLibraryElements", {
527
+ location: "upload",
528
+ sort: value
529
+ });
530
+ setQuery({ sort: value });
531
+ };
532
+ const handleEditFolder = (folder) => {
533
+ setFolderToEdit(folder);
534
+ setShowEditFolderDialog(true);
535
+ };
536
+ const handleEditFolderClose = (payload) => {
537
+ setFolderToEdit(null);
538
+ toggleEditFolderDialog(payload);
539
+ if (currentFolderToEditRef.current) {
540
+ currentFolderToEditRef.current.focus();
541
+ }
542
+ };
543
+ const handleAssetDeleted = (numberOfAssets) => {
544
+ if (numberOfAssets === assetCount && assetsData.pagination.page === assetsData.pagination.pageCount && assetsData.pagination.page > 1) {
545
+ setQuery({
546
+ ...query,
547
+ page: assetsData.pagination.page - 1
548
+ });
549
+ }
550
+ };
551
+ const handleBulkActionSuccess = () => {
552
+ selectAll();
553
+ handleAssetDeleted(selected.length);
554
+ };
555
+ if (isLoading) {
556
+ return /* @__PURE__ */ jsx(Page.Loading, {});
557
+ }
558
+ if (assetsError || foldersError) {
559
+ return /* @__PURE__ */ jsx(Page.Error, {});
560
+ }
561
+ return /* @__PURE__ */ jsxs(Layouts.Root, { children: [
562
+ /* @__PURE__ */ jsxs(Page.Main, { children: [
563
+ /* @__PURE__ */ jsx(
564
+ Header,
565
+ {
566
+ breadcrumbs: !isCurrentFolderLoading && getBreadcrumbDataML(currentFolder, { pathname, query }),
567
+ canCreate,
568
+ onToggleEditFolderDialog: toggleEditFolderDialog,
569
+ onToggleUploadAssetDialog: toggleUploadAssetDialog,
570
+ folder: currentFolder
571
+ }
572
+ ),
573
+ /* @__PURE__ */ jsx(
574
+ Layouts.Action,
575
+ {
576
+ startActions: /* @__PURE__ */ jsxs(Fragment, { children: [
577
+ canUpdate && isGridView && (assetCount > 0 || folderCount > 0) && /* @__PURE__ */ jsx(
578
+ BoxWithHeight,
579
+ {
580
+ paddingLeft: 2,
581
+ paddingRight: 2,
582
+ background: "neutral0",
583
+ hasRadius: true,
584
+ borderColor: "neutral200",
585
+ children: /* @__PURE__ */ jsx(
586
+ BaseCheckbox,
587
+ {
588
+ "aria-label": formatMessage({
589
+ id: getTrad("bulk.select.label"),
590
+ defaultMessage: "Select all folders & assets"
591
+ }),
592
+ indeterminate: indeterminateBulkSelect,
593
+ value: (assetCount > 0 || folderCount > 0) && selected.length === assetCount + folderCount,
594
+ onChange: (e) => handleBulkSelect(e, [...assets, ...folders])
595
+ }
596
+ )
597
+ }
598
+ ),
599
+ canRead && isGridView && /* @__PURE__ */ jsx(SortPicker, { value: query?.sort, onChangeSort: handleChangeSort }),
600
+ canRead && /* @__PURE__ */ jsx(Filters, {})
601
+ ] }),
602
+ endActions: /* @__PURE__ */ jsxs(Fragment, { children: [
603
+ canConfigureView ? /* @__PURE__ */ jsx(ActionContainer, { paddingTop: 1, paddingBottom: 1, children: /* @__PURE__ */ jsx(
604
+ IconButton,
605
+ {
606
+ tag: Link$1,
607
+ to: {
608
+ pathname: `${pathname}/configuration`,
609
+ search: stringify(query, { encode: false })
610
+ },
611
+ icon: /* @__PURE__ */ jsx(Cog, {}),
612
+ label: formatMessage({
613
+ id: "app.links.configure-view",
614
+ defaultMessage: "Configure the view"
615
+ })
616
+ }
617
+ ) }) : null,
618
+ /* @__PURE__ */ jsx(ActionContainer, { paddingTop: 1, paddingBottom: 1, children: /* @__PURE__ */ jsx(
619
+ IconButton,
620
+ {
621
+ icon: isGridView ? /* @__PURE__ */ jsx(List, {}) : /* @__PURE__ */ jsx(GridFour, {}),
622
+ label: isGridView ? formatMessage({
623
+ id: getTrad("view-switch.list"),
624
+ defaultMessage: "List View"
625
+ }) : formatMessage({
626
+ id: getTrad("view-switch.grid"),
627
+ defaultMessage: "Grid View"
628
+ }),
629
+ onClick: () => setView(isGridView ? viewOptions.LIST : viewOptions.GRID)
630
+ }
631
+ ) }),
632
+ /* @__PURE__ */ jsx(
633
+ SearchInput,
634
+ {
635
+ label: formatMessage({
636
+ id: getTrad("search.label"),
637
+ defaultMessage: "Search for an asset"
638
+ }),
639
+ trackedEvent: "didSearchMediaLibraryElements",
640
+ trackedEventDetails: { location: "upload" }
641
+ }
642
+ )
643
+ ] })
644
+ }
645
+ ),
646
+ /* @__PURE__ */ jsxs(Layouts.Content, { children: [
647
+ selected.length > 0 && /* @__PURE__ */ jsx(
648
+ BulkActions,
649
+ {
650
+ currentFolder,
651
+ selected,
652
+ onSuccess: handleBulkActionSuccess
653
+ }
654
+ ),
655
+ folderCount === 0 && assetCount === 0 && /* @__PURE__ */ jsx(
656
+ EmptyOrNoPermissions,
657
+ {
658
+ canCreate,
659
+ canRead,
660
+ isFiltering,
661
+ onActionClick: toggleUploadAssetDialog
662
+ }
663
+ ),
664
+ canRead && !isGridView && (assetCount > 0 || folderCount > 0) && /* @__PURE__ */ jsx(
665
+ TableList,
666
+ {
667
+ assetCount,
668
+ folderCount,
669
+ indeterminate: indeterminateBulkSelect,
670
+ onChangeSort: handleChangeSort,
671
+ onChangeFolder: (folderID, folderPath) => navigate(getFolderURL(pathname, query, { folder: folderID, folderPath })),
672
+ onEditAsset: setAssetToEdit,
673
+ onEditFolder: handleEditFolder,
674
+ onSelectOne: selectOne,
675
+ onSelectAll: handleBulkSelect,
676
+ rows: [...folders, ...assets],
677
+ selected,
678
+ shouldDisableBulkSelect: !canUpdate,
679
+ sortQuery: query?.sort ?? ""
680
+ }
681
+ ),
682
+ canRead && isGridView && /* @__PURE__ */ jsxs(Fragment, { children: [
683
+ folderCount > 0 && /* @__PURE__ */ jsx(
684
+ FolderGridList,
685
+ {
686
+ title: (
687
+ // Folders title should only appear if:
688
+ // user is filtering and there are assets to display, to divide both type of elements
689
+ // user is not filtering
690
+ (isFiltering && assetCount > 0 || !isFiltering) && formatMessage(
691
+ {
692
+ id: getTrad("list.folders.title"),
693
+ defaultMessage: "Folders ({count})"
694
+ },
695
+ { count: folderCount }
696
+ ) || ""
697
+ ),
698
+ children: folders.map((folder) => {
699
+ const selectedFolders = selected.filter(({ type }) => type === "folder");
700
+ const isSelected = !!selectedFolders.find(
701
+ (currentFolder2) => currentFolder2.id === folder.id
702
+ );
703
+ const url = getFolderURL(pathname, query, {
704
+ folder: folder?.id,
705
+ folderPath: folder?.path
706
+ });
707
+ return /* @__PURE__ */ jsx(GridItem, { col: 3, children: /* @__PURE__ */ jsx(
708
+ FolderCard,
709
+ {
710
+ ref: folderToEdit && folder.id === folderToEdit.id ? currentFolderToEditRef : void 0,
711
+ ariaLabel: folder.name,
712
+ id: `folder-${folder.id}`,
713
+ to: url,
714
+ startAction: selectOne && folder.isSelectable ? /* @__PURE__ */ jsx(
715
+ FolderCardCheckbox,
716
+ {
717
+ "data-testid": `folder-checkbox-${folder.id}`,
718
+ value: isSelected,
719
+ onChange: () => selectOne(folder)
720
+ }
721
+ ) : null,
722
+ cardActions: /* @__PURE__ */ jsx(
723
+ IconButton,
724
+ {
725
+ icon: /* @__PURE__ */ jsx(Pencil, {}),
726
+ "aria-label": formatMessage({
727
+ id: getTrad("list.folder.edit"),
728
+ defaultMessage: "Edit folder"
729
+ }),
730
+ onClick: () => handleEditFolder(folder)
731
+ }
732
+ ),
733
+ children: /* @__PURE__ */ jsx(FolderCardBody, { children: /* @__PURE__ */ jsx(FolderCardBodyAction, { to: url, children: /* @__PURE__ */ jsxs(Flex, { tag: "h2", direction: "column", alignItems: "start", maxWidth: "100%", children: [
734
+ /* @__PURE__ */ jsxs(TypographyMaxWidth, { fontWeight: "semiBold", ellipsis: true, children: [
735
+ folder.name,
736
+ /* @__PURE__ */ jsx(VisuallyHidden, { children: ":" })
737
+ ] }),
738
+ /* @__PURE__ */ jsx(
739
+ TypographyMaxWidth,
740
+ {
741
+ tag: "span",
742
+ textColor: "neutral600",
743
+ variant: "pi",
744
+ ellipsis: true,
745
+ children: formatMessage(
746
+ {
747
+ id: getTrad("list.folder.subtitle"),
748
+ defaultMessage: "{folderCount, plural, =0 {# folder} one {# folder} other {# folders}}, {filesCount, plural, =0 {# asset} one {# asset} other {# assets}}"
749
+ },
750
+ {
751
+ folderCount: folder.children.count,
752
+ filesCount: folder.files.count
753
+ }
754
+ )
755
+ }
756
+ )
757
+ ] }) }) })
758
+ }
759
+ ) }, `folder-${folder.id}`);
760
+ })
761
+ }
762
+ ),
763
+ assetCount > 0 && folderCount > 0 && /* @__PURE__ */ jsx(Box, { paddingTop: 6, paddingBottom: 4, children: /* @__PURE__ */ jsx(Divider, {}) }),
764
+ assetCount > 0 && /* @__PURE__ */ jsx(
765
+ AssetGridList,
766
+ {
767
+ assets,
768
+ onEditAsset: setAssetToEdit,
769
+ onSelectAsset: selectOne,
770
+ selectedAssets: selected.filter(({ type }) => type === "asset"),
771
+ title: (
772
+ // Assets title should only appear if:
773
+ // - user is not filtering
774
+ // - user is filtering and there are folders to display, to separate them
775
+ // - user is on page 1 since folders won't appear on any other page than the first one (no need to visually separate them)
776
+ (!isFiltering || isFiltering && folderCount > 0) && assetsData?.pagination?.page === 1 && formatMessage(
777
+ {
778
+ id: getTrad("list.assets.title"),
779
+ defaultMessage: "Assets ({count})"
780
+ },
781
+ { count: totalAssetCount }
782
+ ) || ""
783
+ )
784
+ }
785
+ )
786
+ ] }),
787
+ /* @__PURE__ */ jsxs(Pagination.Root, { ...assetsData.pagination, children: [
788
+ /* @__PURE__ */ jsx(Pagination.PageSize, {}),
789
+ /* @__PURE__ */ jsx(Pagination.Links, {})
790
+ ] })
791
+ ] })
792
+ ] }),
793
+ showUploadAssetDialog && /* @__PURE__ */ jsx(
794
+ UploadAssetDialog,
795
+ {
796
+ onClose: toggleUploadAssetDialog,
797
+ trackedLocation: "upload",
798
+ folderId: query?.folder
799
+ }
800
+ ),
801
+ showEditFolderDialog && /* @__PURE__ */ jsx(
802
+ EditFolderDialog,
803
+ {
804
+ onClose: handleEditFolderClose,
805
+ folder: folderToEdit,
806
+ parentFolderId: query?.folder,
807
+ location: "upload"
808
+ }
809
+ ),
810
+ assetToEdit && /* @__PURE__ */ jsx(
811
+ EditAssetDialog,
812
+ {
813
+ onClose: (editedAsset) => {
814
+ if (editedAsset === null) {
815
+ handleAssetDeleted(1);
816
+ }
817
+ setAssetToEdit(void 0);
818
+ },
819
+ asset: assetToEdit,
820
+ canUpdate,
821
+ canCopyLink,
822
+ canDownload,
823
+ trackedLocation: "upload"
824
+ }
825
+ )
826
+ ] });
827
+ };
828
+ const ConfigureTheView = lazy(() => import("./index-q-dRjRbA.mjs"));
829
+ const Upload = () => {
830
+ const {
831
+ config: { isLoading, isError, data: config }
832
+ } = useConfig();
833
+ const [{ rawQuery }, setQuery] = useQueryParams();
834
+ const { formatMessage } = useIntl();
835
+ const title = formatMessage({ id: getTrad("plugin.name"), defaultMessage: "Media Library" });
836
+ useEffect(() => {
837
+ if (isLoading || isError || rawQuery) {
838
+ return;
839
+ }
840
+ setQuery({ sort: config.sort, page: 1, pageSize: config.pageSize });
841
+ }, [isLoading, isError, config, rawQuery, setQuery]);
842
+ if (isLoading) {
843
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
844
+ /* @__PURE__ */ jsx(Page.Title, { children: title }),
845
+ /* @__PURE__ */ jsx(Page.Loading, {})
846
+ ] });
847
+ }
848
+ return /* @__PURE__ */ jsx(Page.Main, { children: rawQuery ? /* @__PURE__ */ jsx(Suspense, { fallback: /* @__PURE__ */ jsx(Page.Loading, {}), children: /* @__PURE__ */ jsxs(Routes, { children: [
849
+ /* @__PURE__ */ jsx(Route, { index: true, element: /* @__PURE__ */ jsx(MediaLibrary, {}) }),
850
+ /* @__PURE__ */ jsx(Route, { path: "configuration", element: /* @__PURE__ */ jsx(ConfigureTheView, { config }) })
851
+ ] }) }) : null });
852
+ };
853
+ export {
854
+ Upload as default
855
+ };
856
+ //# sourceMappingURL=index-2C3ZYD4e.mjs.map