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