@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.
- package/README.md +1 -1
- package/dist/_chunks/ca-B2_I-q1t.mjs +121 -0
- package/dist/_chunks/ca-B2_I-q1t.mjs.map +1 -0
- package/dist/_chunks/ca-BUpuZx8N.js +121 -0
- package/dist/_chunks/ca-BUpuZx8N.js.map +1 -0
- package/dist/_chunks/de-A7mEKx6c.mjs +107 -0
- package/dist/_chunks/de-A7mEKx6c.mjs.map +1 -0
- package/dist/_chunks/de-uGb_Pkq7.js +107 -0
- package/dist/_chunks/de-uGb_Pkq7.js.map +1 -0
- package/dist/_chunks/dk-BPfkJb9q.mjs +103 -0
- package/dist/_chunks/dk-BPfkJb9q.mjs.map +1 -0
- package/dist/_chunks/dk-Cd8oFO-O.js +103 -0
- package/dist/_chunks/dk-Cd8oFO-O.js.map +1 -0
- package/dist/_chunks/en-BcOqhiNe.js +144 -0
- package/dist/_chunks/en-BcOqhiNe.js.map +1 -0
- package/dist/_chunks/en-oDx2Gnre.mjs +144 -0
- package/dist/_chunks/en-oDx2Gnre.mjs.map +1 -0
- package/dist/_chunks/es-CuWi2pOn.mjs +120 -0
- package/dist/_chunks/es-CuWi2pOn.mjs.map +1 -0
- package/dist/_chunks/es-DWFtw_h4.js +120 -0
- package/dist/_chunks/es-DWFtw_h4.js.map +1 -0
- package/dist/_chunks/fr-BN6ndmWf.mjs +144 -0
- package/dist/_chunks/fr-BN6ndmWf.mjs.map +1 -0
- package/dist/_chunks/fr-D2bop66d.js +144 -0
- package/dist/_chunks/fr-D2bop66d.js.map +1 -0
- package/dist/_chunks/graphql-BVCZSNa2.mjs +71 -0
- package/dist/_chunks/graphql-BVCZSNa2.mjs.map +1 -0
- package/dist/_chunks/graphql-Beol7Y3b.js +71 -0
- package/dist/_chunks/graphql-Beol7Y3b.js.map +1 -0
- package/dist/_chunks/he-BpxHjaZg.js +76 -0
- package/dist/_chunks/he-BpxHjaZg.js.map +1 -0
- package/dist/_chunks/he-C9ZOXBB-.mjs +76 -0
- package/dist/_chunks/he-C9ZOXBB-.mjs.map +1 -0
- package/dist/_chunks/index-2C3ZYD4e.mjs +856 -0
- package/dist/_chunks/index-2C3ZYD4e.mjs.map +1 -0
- package/dist/_chunks/index-ASLx4V_D.mjs +6548 -0
- package/dist/_chunks/index-ASLx4V_D.mjs.map +1 -0
- package/dist/_chunks/index-BbFs7_Gx.js +859 -0
- package/dist/_chunks/index-BbFs7_Gx.js.map +1 -0
- package/dist/_chunks/index-BxUjcUMp.js +266 -0
- package/dist/_chunks/index-BxUjcUMp.js.map +1 -0
- package/dist/_chunks/index-CRhNpXFr.js +2632 -0
- package/dist/_chunks/index-CRhNpXFr.js.map +1 -0
- package/dist/_chunks/index-DJC1L27M.js +238 -0
- package/dist/_chunks/index-DJC1L27M.js.map +1 -0
- package/dist/_chunks/index-PKgX3DYk.js +6574 -0
- package/dist/_chunks/index-PKgX3DYk.js.map +1 -0
- package/dist/_chunks/index-VKvfSVC7.mjs +2622 -0
- package/dist/_chunks/index-VKvfSVC7.mjs.map +1 -0
- package/dist/_chunks/index-fmt8afwE.mjs +262 -0
- package/dist/_chunks/index-fmt8afwE.mjs.map +1 -0
- package/dist/_chunks/index-q-dRjRbA.mjs +233 -0
- package/dist/_chunks/index-q-dRjRbA.mjs.map +1 -0
- package/dist/_chunks/it-B7rmoZNx.mjs +76 -0
- package/dist/_chunks/it-B7rmoZNx.mjs.map +1 -0
- package/dist/_chunks/it-BKCWXl8t.js +76 -0
- package/dist/_chunks/it-BKCWXl8t.js.map +1 -0
- package/dist/_chunks/ja-DlaJTi_3.mjs +76 -0
- package/dist/_chunks/ja-DlaJTi_3.mjs.map +1 -0
- package/dist/_chunks/ja-ajHzIJz6.js +76 -0
- package/dist/_chunks/ja-ajHzIJz6.js.map +1 -0
- package/dist/_chunks/ko-Pzj-818C.js +106 -0
- package/dist/_chunks/ko-Pzj-818C.js.map +1 -0
- package/dist/_chunks/ko-vJl9kPpn.mjs +106 -0
- package/dist/_chunks/ko-vJl9kPpn.mjs.map +1 -0
- package/dist/_chunks/ms-CqwG8v8l.mjs +68 -0
- package/dist/_chunks/ms-CqwG8v8l.mjs.map +1 -0
- package/dist/_chunks/ms-h3gjldBy.js +68 -0
- package/dist/_chunks/ms-h3gjldBy.js.map +1 -0
- package/dist/_chunks/pl-Cj8jChOO.mjs +105 -0
- package/dist/_chunks/pl-Cj8jChOO.mjs.map +1 -0
- package/dist/_chunks/pl-esgZ7ltN.js +105 -0
- package/dist/_chunks/pl-esgZ7ltN.js.map +1 -0
- package/dist/_chunks/pt-BR-B4LJHJIp.mjs +76 -0
- package/dist/_chunks/pt-BR-B4LJHJIp.mjs.map +1 -0
- package/dist/_chunks/pt-BR-Cazr7Z5I.js +76 -0
- package/dist/_chunks/pt-BR-Cazr7Z5I.js.map +1 -0
- package/dist/_chunks/pt-CNOOM_7x.mjs +76 -0
- package/dist/_chunks/pt-CNOOM_7x.mjs.map +1 -0
- package/dist/_chunks/pt-cbUnkHM5.js +76 -0
- package/dist/_chunks/pt-cbUnkHM5.js.map +1 -0
- package/dist/_chunks/ru-DqglvSUC.mjs +76 -0
- package/dist/_chunks/ru-DqglvSUC.mjs.map +1 -0
- package/dist/_chunks/ru-H6MzFUxp.js +76 -0
- package/dist/_chunks/ru-H6MzFUxp.js.map +1 -0
- package/dist/_chunks/sk-CZxC4dFY.js +122 -0
- package/dist/_chunks/sk-CZxC4dFY.js.map +1 -0
- package/dist/_chunks/sk-Dgpb3lnz.mjs +122 -0
- package/dist/_chunks/sk-Dgpb3lnz.mjs.map +1 -0
- package/dist/_chunks/th-C6unJZ8j.js +76 -0
- package/dist/_chunks/th-C6unJZ8j.js.map +1 -0
- package/dist/_chunks/th-DRfzuiFf.mjs +76 -0
- package/dist/_chunks/th-DRfzuiFf.mjs.map +1 -0
- package/dist/_chunks/tr--GzWXE_A.mjs +122 -0
- package/dist/_chunks/tr--GzWXE_A.mjs.map +1 -0
- package/dist/_chunks/tr-CY6AwX50.js +122 -0
- package/dist/_chunks/tr-CY6AwX50.js.map +1 -0
- package/dist/_chunks/uk-BniyNsD4.js +73 -0
- package/dist/_chunks/uk-BniyNsD4.js.map +1 -0
- package/dist/_chunks/uk-DVMT2Piq.mjs +73 -0
- package/dist/_chunks/uk-DVMT2Piq.mjs.map +1 -0
- package/dist/_chunks/zh-CsZw0IpM.js +129 -0
- package/dist/_chunks/zh-CsZw0IpM.js.map +1 -0
- package/dist/_chunks/zh-HOnih0is.mjs +129 -0
- package/dist/_chunks/zh-HOnih0is.mjs.map +1 -0
- package/dist/_chunks/zh-Hans-Cpmhg8uH.mjs +152 -0
- package/dist/_chunks/zh-Hans-Cpmhg8uH.mjs.map +1 -0
- package/dist/_chunks/zh-Hans-k_xAc6nm.js +152 -0
- package/dist/_chunks/zh-Hans-k_xAc6nm.js.map +1 -0
- package/dist/admin/index.js +5 -0
- package/dist/admin/index.js.map +1 -0
- package/dist/admin/index.mjs +6 -0
- package/dist/admin/index.mjs.map +1 -0
- package/dist/server/index.js +4 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/index.mjs +5 -0
- package/dist/server/index.mjs.map +1 -0
- package/dist/server/src/bootstrap.d.ts +5 -0
- package/dist/server/src/bootstrap.d.ts.map +1 -0
- package/dist/server/src/config.d.ts +10 -0
- package/dist/server/src/config.d.ts.map +1 -0
- package/dist/server/src/constants.d.ts +20 -0
- package/dist/server/src/constants.d.ts.map +1 -0
- package/dist/server/src/content-types/file.d.ts +110 -0
- package/dist/server/src/content-types/file.d.ts.map +1 -0
- package/dist/server/src/content-types/folder.d.ts +61 -0
- package/dist/server/src/content-types/folder.d.ts.map +1 -0
- package/dist/server/src/content-types/index.d.ts +170 -0
- package/dist/server/src/content-types/index.d.ts.map +1 -0
- package/dist/server/src/controllers/admin-file.d.ts +16 -0
- package/dist/server/src/controllers/admin-file.d.ts.map +1 -0
- package/dist/server/src/controllers/admin-folder-file.d.ts +7 -0
- package/dist/server/src/controllers/admin-folder-file.d.ts.map +1 -0
- package/dist/server/src/controllers/admin-folder.d.ts +10 -0
- package/dist/server/src/controllers/admin-folder.d.ts.map +1 -0
- package/dist/server/src/controllers/admin-settings.d.ts +7 -0
- package/dist/server/src/controllers/admin-settings.d.ts.map +1 -0
- package/dist/server/src/controllers/admin-upload.d.ts +9 -0
- package/dist/server/src/controllers/admin-upload.d.ts.map +1 -0
- package/dist/server/src/controllers/content-api.d.ts +15 -0
- package/dist/server/src/controllers/content-api.d.ts.map +1 -0
- package/dist/server/src/controllers/index.d.ts +53 -0
- package/dist/server/src/controllers/index.d.ts.map +1 -0
- package/dist/server/src/controllers/utils/find-entity-and-check-permissions.d.ts +6 -0
- package/dist/server/src/controllers/utils/find-entity-and-check-permissions.d.ts.map +1 -0
- package/dist/server/src/controllers/utils/folders.d.ts +4 -0
- package/dist/server/src/controllers/utils/folders.d.ts.map +1 -0
- package/dist/server/src/controllers/validation/admin/configureView.d.ts +15 -0
- package/dist/server/src/controllers/validation/admin/configureView.d.ts.map +1 -0
- package/dist/server/src/controllers/validation/admin/folder-file.d.ts +3 -0
- package/dist/server/src/controllers/validation/admin/folder-file.d.ts.map +1 -0
- package/dist/server/src/controllers/validation/admin/folder.d.ts +3 -0
- package/dist/server/src/controllers/validation/admin/folder.d.ts.map +1 -0
- package/dist/server/src/controllers/validation/admin/settings.d.ts +18 -0
- package/dist/server/src/controllers/validation/admin/settings.d.ts.map +1 -0
- package/dist/server/src/controllers/validation/admin/upload.d.ts +109 -0
- package/dist/server/src/controllers/validation/admin/upload.d.ts.map +1 -0
- package/dist/server/src/controllers/validation/admin/utils.d.ts +3 -0
- package/dist/server/src/controllers/validation/admin/utils.d.ts.map +1 -0
- package/dist/server/src/controllers/validation/content-api/upload.d.ts +91 -0
- package/dist/server/src/controllers/validation/content-api/upload.d.ts.map +1 -0
- package/dist/server/src/controllers/view-configuration.d.ts +7 -0
- package/dist/server/src/controllers/view-configuration.d.ts.map +1 -0
- package/dist/server/src/graphql.d.ts +5 -0
- package/dist/server/src/graphql.d.ts.map +1 -0
- package/dist/server/src/index.d.ts +475 -0
- package/dist/server/src/index.d.ts.map +1 -0
- package/dist/server/src/middlewares/upload.d.ts +9 -0
- package/dist/server/src/middlewares/upload.d.ts.map +1 -0
- package/dist/server/src/register.d.ts +8 -0
- package/dist/server/src/register.d.ts.map +1 -0
- package/dist/server/src/routes/admin.d.ts +17 -0
- package/dist/server/src/routes/admin.d.ts.map +1 -0
- package/dist/server/src/routes/content-api.d.ts +9 -0
- package/dist/server/src/routes/content-api.d.ts.map +1 -0
- package/dist/server/src/routes/index.d.ts +43 -0
- package/dist/server/src/routes/index.d.ts.map +1 -0
- package/dist/server/src/routes/view-configuration.d.ts +17 -0
- package/dist/server/src/routes/view-configuration.d.ts.map +1 -0
- package/dist/server/src/services/api-upload-folder.d.ts +5 -0
- package/dist/server/src/services/api-upload-folder.d.ts.map +1 -0
- package/dist/server/src/services/extensions/content-manager/entity-manager.d.ts +15 -0
- package/dist/server/src/services/extensions/content-manager/entity-manager.d.ts.map +1 -0
- package/dist/server/src/services/extensions/content-manager/index.d.ts +4 -0
- package/dist/server/src/services/extensions/content-manager/index.d.ts.map +1 -0
- package/dist/server/src/services/extensions/core/entity-service.d.ts +4 -0
- package/dist/server/src/services/extensions/core/entity-service.d.ts.map +1 -0
- package/dist/server/src/services/extensions/core/index.d.ts +4 -0
- package/dist/server/src/services/extensions/core/index.d.ts.map +1 -0
- package/dist/server/src/services/extensions/index.d.ts +8 -0
- package/dist/server/src/services/extensions/index.d.ts.map +1 -0
- package/dist/server/src/services/extensions/utils.d.ts +14 -0
- package/dist/server/src/services/extensions/utils.d.ts.map +1 -0
- package/dist/server/src/services/file.d.ts +8 -0
- package/dist/server/src/services/file.d.ts.map +1 -0
- package/dist/server/src/services/folder.d.ts +32 -0
- package/dist/server/src/services/folder.d.ts.map +1 -0
- package/dist/server/src/services/image-manipulation.d.ts +63 -0
- package/dist/server/src/services/image-manipulation.d.ts.map +1 -0
- package/dist/server/src/services/index.d.ts +196 -0
- package/dist/server/src/services/index.d.ts.map +1 -0
- package/dist/server/src/services/metrics.d.ts +8 -0
- package/dist/server/src/services/metrics.d.ts.map +1 -0
- package/dist/server/src/services/provider.d.ts +10 -0
- package/dist/server/src/services/provider.d.ts.map +1 -0
- package/dist/server/src/services/upload.d.ts +67 -0
- package/dist/server/src/services/upload.d.ts.map +1 -0
- package/dist/server/src/services/weekly-metrics.d.ts +17 -0
- package/dist/server/src/services/weekly-metrics.d.ts.map +1 -0
- package/dist/server/src/types.d.ts +74 -0
- package/dist/server/src/types.d.ts.map +1 -0
- package/dist/server/src/utils/cron.d.ts +3 -0
- package/dist/server/src/utils/cron.d.ts.map +1 -0
- package/dist/server/src/utils/index.d.ts +23 -0
- package/dist/server/src/utils/index.d.ts.map +1 -0
- package/package.json +99 -7
- package/strapi-server.js +3 -0
|
@@ -0,0 +1,262 @@
|
|
|
1
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
2
|
+
import React__default, { useReducer } from "react";
|
|
3
|
+
import { useNotification, useFetchClient, Page, Layouts } from "@strapi/admin/strapi-admin";
|
|
4
|
+
import { Button, Flex, Box, Typography, Grid, GridItem, Field, Toggle } from "@strapi/design-system";
|
|
5
|
+
import { Check } from "@strapi/icons";
|
|
6
|
+
import isEqual from "lodash/isEqual";
|
|
7
|
+
import { useIntl } from "react-intl";
|
|
8
|
+
import { useQuery, useMutation } from "react-query";
|
|
9
|
+
import { g as getTrad, P as PERMISSIONS } from "./index-ASLx4V_D.mjs";
|
|
10
|
+
import "byte-size";
|
|
11
|
+
import "date-fns";
|
|
12
|
+
import "qs";
|
|
13
|
+
import { produce } from "immer";
|
|
14
|
+
import set from "lodash/set";
|
|
15
|
+
const init = (initialState2) => {
|
|
16
|
+
return initialState2;
|
|
17
|
+
};
|
|
18
|
+
const initialState = {
|
|
19
|
+
initialData: {
|
|
20
|
+
responsiveDimensions: true,
|
|
21
|
+
sizeOptimization: true,
|
|
22
|
+
autoOrientation: false,
|
|
23
|
+
videoPreview: false
|
|
24
|
+
},
|
|
25
|
+
modifiedData: {
|
|
26
|
+
responsiveDimensions: true,
|
|
27
|
+
sizeOptimization: true,
|
|
28
|
+
autoOrientation: false,
|
|
29
|
+
videoPreview: false
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
const reducer = (state, action) => (
|
|
33
|
+
// eslint-disable-next-line consistent-return
|
|
34
|
+
produce(state, (drafState) => {
|
|
35
|
+
switch (action.type) {
|
|
36
|
+
case "GET_DATA_SUCCEEDED": {
|
|
37
|
+
drafState.initialData = action.data;
|
|
38
|
+
drafState.modifiedData = action.data;
|
|
39
|
+
break;
|
|
40
|
+
}
|
|
41
|
+
case "ON_CHANGE": {
|
|
42
|
+
set(drafState, ["modifiedData", ...action.keys.split(".")], action.value);
|
|
43
|
+
break;
|
|
44
|
+
}
|
|
45
|
+
default:
|
|
46
|
+
return state;
|
|
47
|
+
}
|
|
48
|
+
})
|
|
49
|
+
);
|
|
50
|
+
const SettingsPage = () => {
|
|
51
|
+
const { formatMessage } = useIntl();
|
|
52
|
+
const { toggleNotification } = useNotification();
|
|
53
|
+
const { get, put } = useFetchClient();
|
|
54
|
+
const [{ initialData, modifiedData }, dispatch] = useReducer(reducer, initialState, init);
|
|
55
|
+
const { data, isLoading, refetch } = useQuery({
|
|
56
|
+
queryKey: ["upload", "settings"],
|
|
57
|
+
async queryFn() {
|
|
58
|
+
const {
|
|
59
|
+
data: { data: data2 }
|
|
60
|
+
} = await get("/upload/settings");
|
|
61
|
+
return data2;
|
|
62
|
+
}
|
|
63
|
+
});
|
|
64
|
+
React__default.useEffect(() => {
|
|
65
|
+
if (data) {
|
|
66
|
+
dispatch({
|
|
67
|
+
type: "GET_DATA_SUCCEEDED",
|
|
68
|
+
data
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
}, [data]);
|
|
72
|
+
const isSaveButtonDisabled = isEqual(initialData, modifiedData);
|
|
73
|
+
const { mutateAsync, isLoading: isSubmiting } = useMutation({
|
|
74
|
+
async mutationFn(body) {
|
|
75
|
+
return put("/upload/settings", body);
|
|
76
|
+
},
|
|
77
|
+
onSuccess() {
|
|
78
|
+
refetch();
|
|
79
|
+
toggleNotification({
|
|
80
|
+
type: "success",
|
|
81
|
+
message: formatMessage({ id: "notification.form.success.fields" })
|
|
82
|
+
});
|
|
83
|
+
},
|
|
84
|
+
onError(err) {
|
|
85
|
+
console.error(err);
|
|
86
|
+
}
|
|
87
|
+
});
|
|
88
|
+
const handleSubmit = async (e) => {
|
|
89
|
+
e.preventDefault();
|
|
90
|
+
if (isSaveButtonDisabled) {
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
await mutateAsync(modifiedData);
|
|
94
|
+
};
|
|
95
|
+
const handleChange = ({ target: { name, value } }) => {
|
|
96
|
+
dispatch({
|
|
97
|
+
type: "ON_CHANGE",
|
|
98
|
+
keys: name,
|
|
99
|
+
value
|
|
100
|
+
});
|
|
101
|
+
};
|
|
102
|
+
if (isLoading) {
|
|
103
|
+
return /* @__PURE__ */ jsx(Page.Loading, {});
|
|
104
|
+
}
|
|
105
|
+
return /* @__PURE__ */ jsxs(Page.Main, { tabIndex: -1, children: [
|
|
106
|
+
/* @__PURE__ */ jsx(Page.Title, { children: formatMessage({
|
|
107
|
+
id: getTrad("page.title"),
|
|
108
|
+
defaultMessage: "Settings - Media Libray"
|
|
109
|
+
}) }),
|
|
110
|
+
/* @__PURE__ */ jsxs("form", { onSubmit: handleSubmit, children: [
|
|
111
|
+
/* @__PURE__ */ jsx(
|
|
112
|
+
Layouts.Header,
|
|
113
|
+
{
|
|
114
|
+
title: formatMessage({
|
|
115
|
+
id: getTrad("settings.header.label"),
|
|
116
|
+
defaultMessage: "Media Library"
|
|
117
|
+
}),
|
|
118
|
+
primaryAction: /* @__PURE__ */ jsx(
|
|
119
|
+
Button,
|
|
120
|
+
{
|
|
121
|
+
disabled: isSaveButtonDisabled,
|
|
122
|
+
loading: isSubmiting,
|
|
123
|
+
type: "submit",
|
|
124
|
+
startIcon: /* @__PURE__ */ jsx(Check, {}),
|
|
125
|
+
size: "S",
|
|
126
|
+
children: formatMessage({
|
|
127
|
+
id: "global.save",
|
|
128
|
+
defaultMessage: "Save"
|
|
129
|
+
})
|
|
130
|
+
}
|
|
131
|
+
),
|
|
132
|
+
subtitle: formatMessage({
|
|
133
|
+
id: getTrad("settings.sub-header.label"),
|
|
134
|
+
defaultMessage: "Configure the settings for the Media Library"
|
|
135
|
+
})
|
|
136
|
+
}
|
|
137
|
+
),
|
|
138
|
+
/* @__PURE__ */ jsx(Layouts.Content, { children: /* @__PURE__ */ jsx(Layouts.Root, { children: /* @__PURE__ */ jsx(Flex, { direction: "column", alignItems: "stretch", gap: 12, children: /* @__PURE__ */ jsx(Box, { background: "neutral0", padding: 6, shadow: "filterShadow", hasRadius: true, children: /* @__PURE__ */ jsxs(Flex, { direction: "column", alignItems: "stretch", gap: 4, children: [
|
|
139
|
+
/* @__PURE__ */ jsx(Flex, { children: /* @__PURE__ */ jsx(Typography, { variant: "delta", tag: "h2", children: formatMessage({
|
|
140
|
+
id: getTrad("settings.blockTitle"),
|
|
141
|
+
defaultMessage: "Asset management"
|
|
142
|
+
}) }) }),
|
|
143
|
+
/* @__PURE__ */ jsxs(Grid, { gap: 6, children: [
|
|
144
|
+
/* @__PURE__ */ jsx(GridItem, { col: 6, s: 12, children: /* @__PURE__ */ jsxs(
|
|
145
|
+
Field.Root,
|
|
146
|
+
{
|
|
147
|
+
hint: formatMessage({
|
|
148
|
+
id: getTrad("settings.form.responsiveDimensions.description"),
|
|
149
|
+
defaultMessage: "Enabling this option will generate multiple formats (small, medium and large) of the uploaded asset."
|
|
150
|
+
}),
|
|
151
|
+
name: "responsiveDimensions",
|
|
152
|
+
children: [
|
|
153
|
+
/* @__PURE__ */ jsx(Field.Label, { children: formatMessage({
|
|
154
|
+
id: getTrad("settings.form.responsiveDimensions.label"),
|
|
155
|
+
defaultMessage: "Responsive friendly upload"
|
|
156
|
+
}) }),
|
|
157
|
+
/* @__PURE__ */ jsx(
|
|
158
|
+
Toggle,
|
|
159
|
+
{
|
|
160
|
+
checked: modifiedData.responsiveDimensions,
|
|
161
|
+
offLabel: formatMessage({
|
|
162
|
+
id: "app.components.ToggleCheckbox.off-label",
|
|
163
|
+
defaultMessage: "Off"
|
|
164
|
+
}),
|
|
165
|
+
onLabel: formatMessage({
|
|
166
|
+
id: "app.components.ToggleCheckbox.on-label",
|
|
167
|
+
defaultMessage: "On"
|
|
168
|
+
}),
|
|
169
|
+
onChange: (e) => {
|
|
170
|
+
handleChange({
|
|
171
|
+
target: { name: "responsiveDimensions", value: e.target.checked }
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
),
|
|
176
|
+
/* @__PURE__ */ jsx(Field.Hint, {})
|
|
177
|
+
]
|
|
178
|
+
}
|
|
179
|
+
) }),
|
|
180
|
+
/* @__PURE__ */ jsx(GridItem, { col: 6, s: 12, children: /* @__PURE__ */ jsxs(
|
|
181
|
+
Field.Root,
|
|
182
|
+
{
|
|
183
|
+
hint: formatMessage({
|
|
184
|
+
id: getTrad("settings.form.sizeOptimization.description"),
|
|
185
|
+
defaultMessage: "Enabling this option will reduce the image size and slightly reduce its quality."
|
|
186
|
+
}),
|
|
187
|
+
name: "sizeOptimization",
|
|
188
|
+
children: [
|
|
189
|
+
/* @__PURE__ */ jsx(Field.Label, { children: formatMessage({
|
|
190
|
+
id: getTrad("settings.form.sizeOptimization.label"),
|
|
191
|
+
defaultMessage: "Size optimization"
|
|
192
|
+
}) }),
|
|
193
|
+
/* @__PURE__ */ jsx(
|
|
194
|
+
Toggle,
|
|
195
|
+
{
|
|
196
|
+
checked: modifiedData.sizeOptimization,
|
|
197
|
+
offLabel: formatMessage({
|
|
198
|
+
id: "app.components.ToggleCheckbox.off-label",
|
|
199
|
+
defaultMessage: "Off"
|
|
200
|
+
}),
|
|
201
|
+
onLabel: formatMessage({
|
|
202
|
+
id: "app.components.ToggleCheckbox.on-label",
|
|
203
|
+
defaultMessage: "On"
|
|
204
|
+
}),
|
|
205
|
+
onChange: (e) => {
|
|
206
|
+
handleChange({
|
|
207
|
+
target: { name: "sizeOptimization", value: e.target.checked }
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
),
|
|
212
|
+
/* @__PURE__ */ jsx(Field.Hint, {})
|
|
213
|
+
]
|
|
214
|
+
}
|
|
215
|
+
) }),
|
|
216
|
+
/* @__PURE__ */ jsx(GridItem, { col: 6, s: 12, children: /* @__PURE__ */ jsxs(
|
|
217
|
+
Field.Root,
|
|
218
|
+
{
|
|
219
|
+
hint: formatMessage({
|
|
220
|
+
id: getTrad("settings.form.autoOrientation.description"),
|
|
221
|
+
defaultMessage: "Enabling this option will automatically rotate the image according to EXIF orientation tag."
|
|
222
|
+
}),
|
|
223
|
+
name: "autoOrientation",
|
|
224
|
+
children: [
|
|
225
|
+
/* @__PURE__ */ jsx(Field.Label, { children: formatMessage({
|
|
226
|
+
id: getTrad("settings.form.autoOrientation.label"),
|
|
227
|
+
defaultMessage: "Auto orientation"
|
|
228
|
+
}) }),
|
|
229
|
+
/* @__PURE__ */ jsx(
|
|
230
|
+
Toggle,
|
|
231
|
+
{
|
|
232
|
+
checked: modifiedData.autoOrientation,
|
|
233
|
+
offLabel: formatMessage({
|
|
234
|
+
id: "app.components.ToggleCheckbox.off-label",
|
|
235
|
+
defaultMessage: "Off"
|
|
236
|
+
}),
|
|
237
|
+
onLabel: formatMessage({
|
|
238
|
+
id: "app.components.ToggleCheckbox.on-label",
|
|
239
|
+
defaultMessage: "On"
|
|
240
|
+
}),
|
|
241
|
+
onChange: (e) => {
|
|
242
|
+
handleChange({
|
|
243
|
+
target: { name: "autoOrientation", value: e.target.checked }
|
|
244
|
+
});
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
),
|
|
248
|
+
/* @__PURE__ */ jsx(Field.Hint, {})
|
|
249
|
+
]
|
|
250
|
+
}
|
|
251
|
+
) })
|
|
252
|
+
] })
|
|
253
|
+
] }) }) }) }) })
|
|
254
|
+
] })
|
|
255
|
+
] });
|
|
256
|
+
};
|
|
257
|
+
const ProtectedSettingsPage = () => /* @__PURE__ */ jsx(Page.Protect, { permissions: PERMISSIONS.settings, children: /* @__PURE__ */ jsx(SettingsPage, {}) });
|
|
258
|
+
export {
|
|
259
|
+
SettingsPage,
|
|
260
|
+
ProtectedSettingsPage as default
|
|
261
|
+
};
|
|
262
|
+
//# sourceMappingURL=index-fmt8afwE.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-fmt8afwE.mjs","sources":["../../admin/src/pages/SettingsPage/init.js","../../admin/src/pages/SettingsPage/reducer.js","../../admin/src/pages/SettingsPage/index.jsx"],"sourcesContent":["const init = (initialState) => {\n return initialState;\n};\n\nexport default init;\n","import { produce } from 'immer';\nimport set from 'lodash/set';\n\nconst initialState = {\n initialData: {\n responsiveDimensions: true,\n sizeOptimization: true,\n autoOrientation: false,\n videoPreview: false,\n },\n modifiedData: {\n responsiveDimensions: true,\n sizeOptimization: true,\n autoOrientation: false,\n videoPreview: false,\n },\n};\n\nconst reducer = (state, action) =>\n // eslint-disable-next-line consistent-return\n produce(state, (drafState) => {\n switch (action.type) {\n case 'GET_DATA_SUCCEEDED': {\n drafState.initialData = action.data;\n drafState.modifiedData = action.data;\n break;\n }\n case 'ON_CHANGE': {\n set(drafState, ['modifiedData', ...action.keys.split('.')], action.value);\n break;\n }\n default:\n return state;\n }\n });\n\nexport default reducer;\nexport { initialState };\n","import React, { useReducer } from 'react';\n\nimport { Page, useNotification, useFetchClient, Layouts } from '@strapi/admin/strapi-admin';\nimport {\n Box,\n Button,\n Flex,\n Grid,\n GridItem,\n Toggle,\n Typography,\n Field,\n} from '@strapi/design-system';\nimport { Check } from '@strapi/icons';\nimport isEqual from 'lodash/isEqual';\nimport { useIntl } from 'react-intl';\nimport { useMutation, useQuery } from 'react-query';\n\nimport { PERMISSIONS } from '../../constants';\nimport { getTrad } from '../../utils';\n\nimport init from './init';\nimport reducer, { initialState } from './reducer';\n\nexport const SettingsPage = () => {\n const { formatMessage } = useIntl();\n const { toggleNotification } = useNotification();\n const { get, put } = useFetchClient();\n\n const [{ initialData, modifiedData }, dispatch] = useReducer(reducer, initialState, init);\n\n const { data, isLoading, refetch } = useQuery({\n queryKey: ['upload', 'settings'],\n async queryFn() {\n const {\n data: { data },\n } = await get('/upload/settings');\n\n return data;\n },\n });\n\n React.useEffect(() => {\n if (data) {\n dispatch({\n type: 'GET_DATA_SUCCEEDED',\n data,\n });\n }\n }, [data]);\n\n const isSaveButtonDisabled = isEqual(initialData, modifiedData);\n\n const { mutateAsync, isLoading: isSubmiting } = useMutation({\n async mutationFn(body) {\n return put('/upload/settings', body);\n },\n onSuccess() {\n refetch();\n\n toggleNotification({\n type: 'success',\n message: formatMessage({ id: 'notification.form.success.fields' }),\n });\n },\n onError(err) {\n console.error(err);\n },\n });\n\n const handleSubmit = async (e) => {\n e.preventDefault();\n\n if (isSaveButtonDisabled) {\n return;\n }\n\n await mutateAsync(modifiedData);\n };\n\n const handleChange = ({ target: { name, value } }) => {\n dispatch({\n type: 'ON_CHANGE',\n keys: name,\n value,\n });\n };\n\n if (isLoading) {\n return <Page.Loading />;\n }\n\n return (\n <Page.Main tabIndex={-1}>\n <Page.Title>\n {formatMessage({\n id: getTrad('page.title'),\n defaultMessage: 'Settings - Media Libray',\n })}\n </Page.Title>\n <form onSubmit={handleSubmit}>\n <Layouts.Header\n title={formatMessage({\n id: getTrad('settings.header.label'),\n defaultMessage: 'Media Library',\n })}\n primaryAction={\n <Button\n disabled={isSaveButtonDisabled}\n loading={isSubmiting}\n type=\"submit\"\n startIcon={<Check />}\n size=\"S\"\n >\n {formatMessage({\n id: 'global.save',\n defaultMessage: 'Save',\n })}\n </Button>\n }\n subtitle={formatMessage({\n id: getTrad('settings.sub-header.label'),\n defaultMessage: 'Configure the settings for the Media Library',\n })}\n />\n <Layouts.Content>\n <Layouts.Root>\n <Flex direction=\"column\" alignItems=\"stretch\" gap={12}>\n <Box background=\"neutral0\" padding={6} shadow=\"filterShadow\" hasRadius>\n <Flex direction=\"column\" alignItems=\"stretch\" gap={4}>\n <Flex>\n <Typography variant=\"delta\" tag=\"h2\">\n {formatMessage({\n id: getTrad('settings.blockTitle'),\n defaultMessage: 'Asset management',\n })}\n </Typography>\n </Flex>\n <Grid gap={6}>\n <GridItem col={6} s={12}>\n <Field.Root\n hint={formatMessage({\n id: getTrad('settings.form.responsiveDimensions.description'),\n defaultMessage:\n 'Enabling this option will generate multiple formats (small, medium and large) of the uploaded asset.',\n })}\n name=\"responsiveDimensions\"\n >\n <Field.Label>\n {formatMessage({\n id: getTrad('settings.form.responsiveDimensions.label'),\n defaultMessage: 'Responsive friendly upload',\n })}\n </Field.Label>\n <Toggle\n checked={modifiedData.responsiveDimensions}\n offLabel={formatMessage({\n id: 'app.components.ToggleCheckbox.off-label',\n defaultMessage: 'Off',\n })}\n onLabel={formatMessage({\n id: 'app.components.ToggleCheckbox.on-label',\n defaultMessage: 'On',\n })}\n onChange={(e) => {\n handleChange({\n target: { name: 'responsiveDimensions', value: e.target.checked },\n });\n }}\n />\n <Field.Hint />\n </Field.Root>\n </GridItem>\n <GridItem col={6} s={12}>\n <Field.Root\n hint={formatMessage({\n id: getTrad('settings.form.sizeOptimization.description'),\n defaultMessage:\n 'Enabling this option will reduce the image size and slightly reduce its quality.',\n })}\n name=\"sizeOptimization\"\n >\n <Field.Label>\n {formatMessage({\n id: getTrad('settings.form.sizeOptimization.label'),\n defaultMessage: 'Size optimization',\n })}\n </Field.Label>\n <Toggle\n checked={modifiedData.sizeOptimization}\n offLabel={formatMessage({\n id: 'app.components.ToggleCheckbox.off-label',\n defaultMessage: 'Off',\n })}\n onLabel={formatMessage({\n id: 'app.components.ToggleCheckbox.on-label',\n defaultMessage: 'On',\n })}\n onChange={(e) => {\n handleChange({\n target: { name: 'sizeOptimization', value: e.target.checked },\n });\n }}\n />\n <Field.Hint />\n </Field.Root>\n </GridItem>\n <GridItem col={6} s={12}>\n <Field.Root\n hint={formatMessage({\n id: getTrad('settings.form.autoOrientation.description'),\n defaultMessage:\n 'Enabling this option will automatically rotate the image according to EXIF orientation tag.',\n })}\n name=\"autoOrientation\"\n >\n <Field.Label>\n {formatMessage({\n id: getTrad('settings.form.autoOrientation.label'),\n defaultMessage: 'Auto orientation',\n })}\n </Field.Label>\n <Toggle\n checked={modifiedData.autoOrientation}\n offLabel={formatMessage({\n id: 'app.components.ToggleCheckbox.off-label',\n defaultMessage: 'Off',\n })}\n onLabel={formatMessage({\n id: 'app.components.ToggleCheckbox.on-label',\n defaultMessage: 'On',\n })}\n onChange={(e) => {\n handleChange({\n target: { name: 'autoOrientation', value: e.target.checked },\n });\n }}\n />\n <Field.Hint />\n </Field.Root>\n </GridItem>\n </Grid>\n </Flex>\n </Box>\n </Flex>\n </Layouts.Root>\n </Layouts.Content>\n </form>\n </Page.Main>\n );\n};\n\nconst ProtectedSettingsPage = () => (\n <Page.Protect permissions={PERMISSIONS.settings}>\n <SettingsPage />\n </Page.Protect>\n);\n\nexport default ProtectedSettingsPage;\n"],"names":["initialState","data","React"],"mappings":"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"}
|
|
@@ -0,0 +1,233 @@
|
|
|
1
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useState, useReducer } from "react";
|
|
3
|
+
import { useTracking, useNotification, Layouts, Page, ConfirmDialog } from "@strapi/admin/strapi-admin";
|
|
4
|
+
import { Box, Grid, GridItem, Field, SingleSelect, SingleSelectOption, Link, Button } from "@strapi/design-system";
|
|
5
|
+
import { ArrowLeft, Check } from "@strapi/icons";
|
|
6
|
+
import isEqual from "lodash/isEqual";
|
|
7
|
+
import PropTypes from "prop-types";
|
|
8
|
+
import { useIntl } from "react-intl";
|
|
9
|
+
import { NavLink } from "react-router-dom";
|
|
10
|
+
import { g as getTrad, H as pageSizes, I as sortOptions, p as pluginId, G as useConfig } from "./index-ASLx4V_D.mjs";
|
|
11
|
+
import { produce } from "immer";
|
|
12
|
+
import get from "lodash/get";
|
|
13
|
+
import set from "lodash/set";
|
|
14
|
+
const Settings = ({ sort = "", pageSize = 10, onChange: onChange2 }) => {
|
|
15
|
+
const { formatMessage } = useIntl();
|
|
16
|
+
return /* @__PURE__ */ jsx(
|
|
17
|
+
Box,
|
|
18
|
+
{
|
|
19
|
+
background: "neutral0",
|
|
20
|
+
hasRadius: true,
|
|
21
|
+
shadow: "tableShadow",
|
|
22
|
+
paddingTop: 6,
|
|
23
|
+
paddingBottom: 6,
|
|
24
|
+
paddingLeft: 7,
|
|
25
|
+
paddingRight: 7,
|
|
26
|
+
children: /* @__PURE__ */ jsxs(Grid, { gap: 4, children: [
|
|
27
|
+
/* @__PURE__ */ jsx(GridItem, { s: 12, col: 6, children: /* @__PURE__ */ jsxs(
|
|
28
|
+
Field.Root,
|
|
29
|
+
{
|
|
30
|
+
hint: formatMessage({
|
|
31
|
+
id: getTrad("config.entries.note"),
|
|
32
|
+
defaultMessage: "Number of assets displayed by default in the Media Library"
|
|
33
|
+
}),
|
|
34
|
+
name: "pageSize",
|
|
35
|
+
children: [
|
|
36
|
+
/* @__PURE__ */ jsx(Field.Label, { children: formatMessage({
|
|
37
|
+
id: getTrad("config.entries.title"),
|
|
38
|
+
defaultMessage: "Entries per page"
|
|
39
|
+
}) }),
|
|
40
|
+
/* @__PURE__ */ jsx(
|
|
41
|
+
SingleSelect,
|
|
42
|
+
{
|
|
43
|
+
onChange: (value) => onChange2({ target: { name: "pageSize", value } }),
|
|
44
|
+
value: pageSize,
|
|
45
|
+
children: pageSizes.map((pageSize2) => /* @__PURE__ */ jsx(SingleSelectOption, { value: pageSize2, children: pageSize2 }, pageSize2))
|
|
46
|
+
}
|
|
47
|
+
),
|
|
48
|
+
/* @__PURE__ */ jsx(Field.Hint, {})
|
|
49
|
+
]
|
|
50
|
+
}
|
|
51
|
+
) }),
|
|
52
|
+
/* @__PURE__ */ jsx(GridItem, { s: 12, col: 6, children: /* @__PURE__ */ jsxs(
|
|
53
|
+
Field.Root,
|
|
54
|
+
{
|
|
55
|
+
hint: formatMessage({
|
|
56
|
+
id: getTrad("config.note"),
|
|
57
|
+
defaultMessage: "Note: You can override this value in the media library."
|
|
58
|
+
}),
|
|
59
|
+
name: "sort",
|
|
60
|
+
children: [
|
|
61
|
+
/* @__PURE__ */ jsx(Field.Label, { children: formatMessage({
|
|
62
|
+
id: getTrad("config.sort.title"),
|
|
63
|
+
defaultMessage: "Default sort order"
|
|
64
|
+
}) }),
|
|
65
|
+
/* @__PURE__ */ jsx(
|
|
66
|
+
SingleSelect,
|
|
67
|
+
{
|
|
68
|
+
onChange: (value) => onChange2({ target: { name: "sort", value } }),
|
|
69
|
+
value: sort,
|
|
70
|
+
"test-sort": sort,
|
|
71
|
+
"data-testid": "sort-select",
|
|
72
|
+
children: sortOptions.map((filter) => /* @__PURE__ */ jsx(
|
|
73
|
+
SingleSelectOption,
|
|
74
|
+
{
|
|
75
|
+
"data-testid": `sort-option-${filter.value}`,
|
|
76
|
+
value: filter.value,
|
|
77
|
+
children: formatMessage({ id: getTrad(filter.key), defaultMessage: `${filter.value}` })
|
|
78
|
+
},
|
|
79
|
+
filter.key
|
|
80
|
+
))
|
|
81
|
+
}
|
|
82
|
+
),
|
|
83
|
+
/* @__PURE__ */ jsx(Field.Hint, {})
|
|
84
|
+
]
|
|
85
|
+
}
|
|
86
|
+
) })
|
|
87
|
+
] })
|
|
88
|
+
}
|
|
89
|
+
);
|
|
90
|
+
};
|
|
91
|
+
Settings.propTypes = {
|
|
92
|
+
sort: PropTypes.string.isRequired,
|
|
93
|
+
pageSize: PropTypes.number.isRequired,
|
|
94
|
+
onChange: PropTypes.func.isRequired
|
|
95
|
+
};
|
|
96
|
+
const ON_CHANGE = `${pluginId}/ON_CHANGE`;
|
|
97
|
+
const SET_LOADED = `${pluginId}/SET_LOADED`;
|
|
98
|
+
const onChange = ({ name, value }) => ({
|
|
99
|
+
type: ON_CHANGE,
|
|
100
|
+
keys: name,
|
|
101
|
+
value
|
|
102
|
+
});
|
|
103
|
+
const setLoaded = () => ({
|
|
104
|
+
type: SET_LOADED
|
|
105
|
+
});
|
|
106
|
+
const initialState = {
|
|
107
|
+
initialData: {},
|
|
108
|
+
modifiedData: {}
|
|
109
|
+
};
|
|
110
|
+
const init = (configData) => {
|
|
111
|
+
return {
|
|
112
|
+
...initialState,
|
|
113
|
+
initialData: configData,
|
|
114
|
+
modifiedData: configData
|
|
115
|
+
};
|
|
116
|
+
};
|
|
117
|
+
const reducer = (state = initialState, action) => (
|
|
118
|
+
// eslint-disable-next-line consistent-return
|
|
119
|
+
produce(state, (draftState) => {
|
|
120
|
+
switch (action.type) {
|
|
121
|
+
case ON_CHANGE: {
|
|
122
|
+
set(draftState, ["modifiedData", ...action.keys.split(".")], action.value);
|
|
123
|
+
break;
|
|
124
|
+
}
|
|
125
|
+
case SET_LOADED: {
|
|
126
|
+
const reInitialise = init(get(draftState, ["modifiedData"], {}));
|
|
127
|
+
draftState.initialData = reInitialise.initialData;
|
|
128
|
+
draftState.modifiedData = reInitialise.modifiedData;
|
|
129
|
+
break;
|
|
130
|
+
}
|
|
131
|
+
default:
|
|
132
|
+
return draftState;
|
|
133
|
+
}
|
|
134
|
+
})
|
|
135
|
+
);
|
|
136
|
+
const ConfigureTheView = ({ config }) => {
|
|
137
|
+
const { trackUsage } = useTracking();
|
|
138
|
+
const { formatMessage } = useIntl();
|
|
139
|
+
const { toggleNotification } = useNotification();
|
|
140
|
+
const { mutateConfig } = useConfig();
|
|
141
|
+
const { isLoading: isSubmittingForm } = mutateConfig;
|
|
142
|
+
const [showWarningSubmit, setWarningSubmit] = useState(false);
|
|
143
|
+
const toggleWarningSubmit = () => setWarningSubmit((prevState) => !prevState);
|
|
144
|
+
const [reducerState, dispatch] = useReducer(reducer, initialState, () => init(config));
|
|
145
|
+
const { initialData, modifiedData } = reducerState;
|
|
146
|
+
const handleSubmit = (e) => {
|
|
147
|
+
e.preventDefault();
|
|
148
|
+
toggleWarningSubmit();
|
|
149
|
+
};
|
|
150
|
+
const handleConfirm = async () => {
|
|
151
|
+
trackUsage("willEditMediaLibraryConfig");
|
|
152
|
+
await mutateConfig.mutateAsync(modifiedData);
|
|
153
|
+
toggleWarningSubmit();
|
|
154
|
+
dispatch(setLoaded());
|
|
155
|
+
toggleNotification({
|
|
156
|
+
type: "success",
|
|
157
|
+
message: formatMessage({
|
|
158
|
+
id: "notification.form.success.fields",
|
|
159
|
+
defaultMessage: "Changes saved"
|
|
160
|
+
})
|
|
161
|
+
});
|
|
162
|
+
};
|
|
163
|
+
const handleChange = ({ target: { name, value } }) => {
|
|
164
|
+
dispatch(onChange({ name, value }));
|
|
165
|
+
};
|
|
166
|
+
return /* @__PURE__ */ jsx(Layouts.Root, { children: /* @__PURE__ */ jsx(Page.Main, { "aria-busy": isSubmittingForm, children: /* @__PURE__ */ jsxs("form", { onSubmit: handleSubmit, children: [
|
|
167
|
+
/* @__PURE__ */ jsx(
|
|
168
|
+
Layouts.Header,
|
|
169
|
+
{
|
|
170
|
+
navigationAction: /* @__PURE__ */ jsx(
|
|
171
|
+
Link,
|
|
172
|
+
{
|
|
173
|
+
tag: NavLink,
|
|
174
|
+
startIcon: /* @__PURE__ */ jsx(ArrowLeft, {}),
|
|
175
|
+
to: `/plugins/${pluginId}`,
|
|
176
|
+
id: "go-back",
|
|
177
|
+
children: formatMessage({ id: getTrad("config.back"), defaultMessage: "Back" })
|
|
178
|
+
}
|
|
179
|
+
),
|
|
180
|
+
primaryAction: /* @__PURE__ */ jsx(
|
|
181
|
+
Button,
|
|
182
|
+
{
|
|
183
|
+
size: "S",
|
|
184
|
+
startIcon: /* @__PURE__ */ jsx(Check, {}),
|
|
185
|
+
disabled: isEqual(modifiedData, initialData),
|
|
186
|
+
type: "submit",
|
|
187
|
+
children: formatMessage({ id: "global.save", defaultMessage: "Save" })
|
|
188
|
+
}
|
|
189
|
+
),
|
|
190
|
+
subtitle: formatMessage({
|
|
191
|
+
id: getTrad("config.subtitle"),
|
|
192
|
+
defaultMessage: "Define the view settings of the media library."
|
|
193
|
+
}),
|
|
194
|
+
title: formatMessage({
|
|
195
|
+
id: getTrad("config.title"),
|
|
196
|
+
defaultMessage: "Configure the view - Media Library"
|
|
197
|
+
})
|
|
198
|
+
}
|
|
199
|
+
),
|
|
200
|
+
/* @__PURE__ */ jsx(Layouts.Content, { children: /* @__PURE__ */ jsx(
|
|
201
|
+
Settings,
|
|
202
|
+
{
|
|
203
|
+
"data-testid": "settings",
|
|
204
|
+
pageSize: modifiedData.pageSize || "",
|
|
205
|
+
sort: modifiedData.sort || "",
|
|
206
|
+
onChange: handleChange
|
|
207
|
+
}
|
|
208
|
+
) }),
|
|
209
|
+
/* @__PURE__ */ jsx(
|
|
210
|
+
ConfirmDialog,
|
|
211
|
+
{
|
|
212
|
+
isOpen: showWarningSubmit,
|
|
213
|
+
onClose: toggleWarningSubmit,
|
|
214
|
+
onConfirm: handleConfirm,
|
|
215
|
+
variant: "success-light",
|
|
216
|
+
children: formatMessage({
|
|
217
|
+
id: getTrad("config.popUpWarning.warning.updateAllSettings"),
|
|
218
|
+
defaultMessage: "This will modify all your settings"
|
|
219
|
+
})
|
|
220
|
+
}
|
|
221
|
+
)
|
|
222
|
+
] }) }) });
|
|
223
|
+
};
|
|
224
|
+
ConfigureTheView.propTypes = {
|
|
225
|
+
config: PropTypes.shape({
|
|
226
|
+
pageSize: PropTypes.number,
|
|
227
|
+
sort: PropTypes.string
|
|
228
|
+
}).isRequired
|
|
229
|
+
};
|
|
230
|
+
export {
|
|
231
|
+
ConfigureTheView as default
|
|
232
|
+
};
|
|
233
|
+
//# sourceMappingURL=index-q-dRjRbA.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-q-dRjRbA.mjs","sources":["../../admin/src/pages/App/ConfigureTheView/components/Settings.jsx","../../admin/src/pages/App/ConfigureTheView/state/actionTypes.js","../../admin/src/pages/App/ConfigureTheView/state/actions.js","../../admin/src/pages/App/ConfigureTheView/state/init.js","../../admin/src/pages/App/ConfigureTheView/state/reducer.js","../../admin/src/pages/App/ConfigureTheView/index.jsx"],"sourcesContent":["import React from 'react';\n\nimport {\n Box,\n Grid,\n GridItem,\n SingleSelectOption,\n SingleSelect,\n Field,\n} from '@strapi/design-system';\nimport PropTypes from 'prop-types';\nimport { useIntl } from 'react-intl';\n\nimport { pageSizes, sortOptions } from '../../../../constants';\nimport getTrad from '../../../../utils/getTrad';\n\nconst Settings = ({ sort = '', pageSize = 10, onChange }) => {\n const { formatMessage } = useIntl();\n\n return (\n <Box\n background=\"neutral0\"\n hasRadius\n shadow=\"tableShadow\"\n paddingTop={6}\n paddingBottom={6}\n paddingLeft={7}\n paddingRight={7}\n >\n <Grid gap={4}>\n <GridItem s={12} col={6}>\n <Field.Root\n hint={formatMessage({\n id: getTrad('config.entries.note'),\n defaultMessage: 'Number of assets displayed by default in the Media Library',\n })}\n name=\"pageSize\"\n >\n <Field.Label>\n {formatMessage({\n id: getTrad('config.entries.title'),\n defaultMessage: 'Entries per page',\n })}\n </Field.Label>\n <SingleSelect\n onChange={(value) => onChange({ target: { name: 'pageSize', value } })}\n value={pageSize}\n >\n {pageSizes.map((pageSize) => (\n <SingleSelectOption key={pageSize} value={pageSize}>\n {pageSize}\n </SingleSelectOption>\n ))}\n </SingleSelect>\n <Field.Hint />\n </Field.Root>\n </GridItem>\n <GridItem s={12} col={6}>\n <Field.Root\n hint={formatMessage({\n id: getTrad('config.note'),\n defaultMessage: 'Note: You can override this value in the media library.',\n })}\n name=\"sort\"\n >\n <Field.Label>\n {formatMessage({\n id: getTrad('config.sort.title'),\n defaultMessage: 'Default sort order',\n })}\n </Field.Label>\n <SingleSelect\n onChange={(value) => onChange({ target: { name: 'sort', value } })}\n value={sort}\n test-sort={sort}\n data-testid=\"sort-select\"\n >\n {sortOptions.map((filter) => (\n <SingleSelectOption\n data-testid={`sort-option-${filter.value}`}\n key={filter.key}\n value={filter.value}\n >\n {formatMessage({ id: getTrad(filter.key), defaultMessage: `${filter.value}` })}\n </SingleSelectOption>\n ))}\n </SingleSelect>\n <Field.Hint />\n </Field.Root>\n </GridItem>\n </Grid>\n </Box>\n );\n};\n\nSettings.propTypes = {\n sort: PropTypes.string.isRequired,\n pageSize: PropTypes.number.isRequired,\n onChange: PropTypes.func.isRequired,\n};\n\nexport { Settings };\n","import pluginId from '../../../../pluginId';\n\nexport const ON_CHANGE = `${pluginId}/ON_CHANGE`;\nexport const SET_LOADED = `${pluginId}/SET_LOADED`;\n","import { ON_CHANGE, SET_LOADED } from './actionTypes';\n\nexport const onChange = ({ name, value }) => ({\n type: ON_CHANGE,\n keys: name,\n value,\n});\n\nexport const setLoaded = () => ({\n type: SET_LOADED,\n});\n","const initialState = {\n initialData: {},\n modifiedData: {},\n};\n\nconst init = (configData) => {\n return {\n ...initialState,\n initialData: configData,\n modifiedData: configData,\n };\n};\nexport { init, initialState };\n","import { produce } from 'immer'; // current\nimport get from 'lodash/get';\nimport set from 'lodash/set';\n\nimport { ON_CHANGE, SET_LOADED } from './actionTypes';\nimport { init, initialState } from './init';\n\nconst reducer = (state = initialState, action) =>\n // eslint-disable-next-line consistent-return\n produce(state, (draftState) => {\n switch (action.type) {\n case ON_CHANGE: {\n set(draftState, ['modifiedData', ...action.keys.split('.')], action.value);\n break;\n }\n case SET_LOADED: {\n // This action re-initialises the state using the current modifiedData.\n const reInitialise = init(get(draftState, ['modifiedData'], {}));\n draftState.initialData = reInitialise.initialData;\n draftState.modifiedData = reInitialise.modifiedData;\n break;\n }\n default:\n return draftState;\n }\n });\n\nexport default reducer;\n","import React, { useReducer, useState } from 'react';\n\nimport {\n ConfirmDialog,\n useTracking,\n useNotification,\n Page,\n Layouts,\n} from '@strapi/admin/strapi-admin';\nimport { Button, Link } from '@strapi/design-system';\nimport { ArrowLeft, Check } from '@strapi/icons';\nimport isEqual from 'lodash/isEqual';\nimport PropTypes from 'prop-types';\nimport { useIntl } from 'react-intl';\nimport { NavLink } from 'react-router-dom';\n\nimport { useConfig } from '../../../hooks/useConfig';\nimport pluginID from '../../../pluginId';\nimport getTrad from '../../../utils/getTrad';\n\nimport { Settings } from './components/Settings';\nimport { onChange, setLoaded } from './state/actions';\nimport { init, initialState } from './state/init';\nimport reducer from './state/reducer';\n\nconst ConfigureTheView = ({ config }) => {\n const { trackUsage } = useTracking();\n const { formatMessage } = useIntl();\n const { toggleNotification } = useNotification();\n const { mutateConfig } = useConfig();\n const { isLoading: isSubmittingForm } = mutateConfig;\n\n const [showWarningSubmit, setWarningSubmit] = useState(false);\n const toggleWarningSubmit = () => setWarningSubmit((prevState) => !prevState);\n\n const [reducerState, dispatch] = useReducer(reducer, initialState, () => init(config));\n const { initialData, modifiedData } = reducerState;\n\n const handleSubmit = (e) => {\n e.preventDefault();\n toggleWarningSubmit();\n };\n\n const handleConfirm = async () => {\n trackUsage('willEditMediaLibraryConfig');\n await mutateConfig.mutateAsync(modifiedData);\n toggleWarningSubmit();\n dispatch(setLoaded());\n toggleNotification({\n type: 'success',\n message: formatMessage({\n id: 'notification.form.success.fields',\n defaultMessage: 'Changes saved',\n }),\n });\n };\n\n const handleChange = ({ target: { name, value } }) => {\n dispatch(onChange({ name, value }));\n };\n\n return (\n <Layouts.Root>\n <Page.Main aria-busy={isSubmittingForm}>\n <form onSubmit={handleSubmit}>\n <Layouts.Header\n navigationAction={\n <Link\n tag={NavLink}\n startIcon={<ArrowLeft />}\n to={`/plugins/${pluginID}`}\n id=\"go-back\"\n >\n {formatMessage({ id: getTrad('config.back'), defaultMessage: 'Back' })}\n </Link>\n }\n primaryAction={\n <Button\n size=\"S\"\n startIcon={<Check />}\n disabled={isEqual(modifiedData, initialData)}\n type=\"submit\"\n >\n {formatMessage({ id: 'global.save', defaultMessage: 'Save' })}\n </Button>\n }\n subtitle={formatMessage({\n id: getTrad('config.subtitle'),\n defaultMessage: 'Define the view settings of the media library.',\n })}\n title={formatMessage({\n id: getTrad('config.title'),\n defaultMessage: 'Configure the view - Media Library',\n })}\n />\n\n <Layouts.Content>\n <Settings\n data-testid=\"settings\"\n pageSize={modifiedData.pageSize || ''}\n sort={modifiedData.sort || ''}\n onChange={handleChange}\n />\n </Layouts.Content>\n\n <ConfirmDialog\n isOpen={showWarningSubmit}\n onClose={toggleWarningSubmit}\n onConfirm={handleConfirm}\n variant=\"success-light\"\n >\n {formatMessage({\n id: getTrad('config.popUpWarning.warning.updateAllSettings'),\n defaultMessage: 'This will modify all your settings',\n })}\n </ConfirmDialog>\n </form>\n </Page.Main>\n </Layouts.Root>\n );\n};\n\nConfigureTheView.propTypes = {\n config: PropTypes.shape({\n pageSize: PropTypes.number,\n sort: PropTypes.string,\n }).isRequired,\n};\n\nexport default ConfigureTheView;\n"],"names":["onChange","pageSize","pluginID"],"mappings":"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"}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
const it = {
|
|
2
|
+
"button.next": "Prossimo",
|
|
3
|
+
"checkControl.crop-duplicate": "Copia file prima del ritaglio",
|
|
4
|
+
"checkControl.crop-original": "Ritaglia il file originale",
|
|
5
|
+
"control-card.add": "Aggiungi",
|
|
6
|
+
"control-card.cancel": "Annulla",
|
|
7
|
+
"control-card.copy-link": "Copia link",
|
|
8
|
+
"control-card.crop": "Ritaglia",
|
|
9
|
+
"control-card.download": "Download",
|
|
10
|
+
"control-card.edit": "Modifica",
|
|
11
|
+
"control-card.replace-media": "Rimpiazza Media",
|
|
12
|
+
"control-card.save": "Salva",
|
|
13
|
+
"filter.add": "Aggiungi filtro",
|
|
14
|
+
"form.button.replace-media": "Rimpiazza media",
|
|
15
|
+
"form.input.decription.file-alt": "Questo testo viene mostrato quando la risorsa non può essere visualizzata.",
|
|
16
|
+
"form.input.label.file-alt": "Testo alternativo",
|
|
17
|
+
"form.input.label.file-caption": "Didascalia",
|
|
18
|
+
"form.input.label.file-name": "Nome file",
|
|
19
|
+
"form.upload-url.error.url.invalid": "Un URL non è valido",
|
|
20
|
+
"form.upload-url.error.url.invalids": "{number} URL non sono validi",
|
|
21
|
+
"header.actions.upload-assets": "Carica risorse",
|
|
22
|
+
"header.content.assets": "{numberFolders, plural, one {1 folder} other {# folders}} - {numberAssets, plural, one {1 risorsa} other {# risorse}}",
|
|
23
|
+
"input.button.label": "Sfoglia file",
|
|
24
|
+
"input.label-bold": "Trascina & rilascia",
|
|
25
|
+
"input.label-normal": "per caricare oppure",
|
|
26
|
+
"input.placeholder": "Clicca per selezionare una risorsa o rilascia un file in quest'area",
|
|
27
|
+
"input.url.description": "Separa i tuoi URL con un ritorno a capo.",
|
|
28
|
+
"input.url.label": "URL",
|
|
29
|
+
"list.assets-empty.subtitle": "Aggiungi uno alla lista.",
|
|
30
|
+
"list.assets-empty.title": "Ancora nessuna risorsa",
|
|
31
|
+
"list.assets-empty.title-withSearch": "Nessuna risorsa con i filtri selezionati",
|
|
32
|
+
"list.assets.type-not-allowed": "Questo tipo di file non è consentito.",
|
|
33
|
+
"modal.file-details.date": "Data",
|
|
34
|
+
"modal.file-details.dimensions": "Dimensioni",
|
|
35
|
+
"modal.file-details.extension": "Estensione",
|
|
36
|
+
"modal.file-details.size": "Dimensione",
|
|
37
|
+
"modal.header.browse": "Carica risorsa",
|
|
38
|
+
"modal.header.file-detail": "Dettagli",
|
|
39
|
+
"modal.header.pending-assets": "Risorse rimanenti",
|
|
40
|
+
"modal.header.select-files": "File selezionati",
|
|
41
|
+
"modal.nav.browse": "sfoglia",
|
|
42
|
+
"modal.nav.computer": "dal computer",
|
|
43
|
+
"modal.nav.selected": "selezionato",
|
|
44
|
+
"modal.nav.url": "da url",
|
|
45
|
+
"modal.selected-list.sub-header-subtitle": "Trascina & rilascia per riordinare le risorse nel campo",
|
|
46
|
+
"modal.upload-list.sub-header-subtitle": "Gestisci le risorse prima di aggiungerle alla Libreria Media",
|
|
47
|
+
"modal.upload-list.sub-header.button": "Aggiungi più risorse",
|
|
48
|
+
"plugin.description.long": "Gestione di file Media.",
|
|
49
|
+
"plugin.description.short": "Gestione di file Media.",
|
|
50
|
+
"plugin.name": "Libreria Media",
|
|
51
|
+
"search.placeholder": "Ricerca risorse...",
|
|
52
|
+
"settings.form.autoOrientation.description": "Ruota automaticamente l'immagine secondo il tag EXIF di orientamento",
|
|
53
|
+
"settings.form.autoOrientation.label": "Abilita rotazione automatica",
|
|
54
|
+
"settings.form.responsiveDimensions.description": "Genera automaticamente formati multipli (large, medium, small) delle risorse caricate",
|
|
55
|
+
"settings.form.responsiveDimensions.label": "Abilita caricamenti responsive-friendly",
|
|
56
|
+
"settings.form.sizeOptimization.label": "Abilita ottimizzazioni di qualità (senza perdita di qualità)",
|
|
57
|
+
"settings.form.videoPreview.description": "Genera una anteprima del video di 6 secondi (GIF)",
|
|
58
|
+
"settings.form.videoPreview.label": "Anteprima",
|
|
59
|
+
"settings.header.label": "Libreria Media - Impostazioni",
|
|
60
|
+
"settings.section.image.label": "IMMAGINE",
|
|
61
|
+
"settings.section.video.label": "VIDEO",
|
|
62
|
+
"settings.sub-header.label": "Configura le impostazioni della Libreria Media",
|
|
63
|
+
"sort.created_at_asc": "Upload più vecchi",
|
|
64
|
+
"sort.created_at_desc": "Upload recenti",
|
|
65
|
+
"sort.label": "Ordina per",
|
|
66
|
+
"sort.name_asc": "Ordine alfabetico (da A a Z)",
|
|
67
|
+
"sort.name_desc": "Ordine alfabetico inverso (da Z ad A)",
|
|
68
|
+
"sort.updated_at_asc": "Aggiornamenti più vecchi",
|
|
69
|
+
"sort.updated_at_desc": "Aggiornamenti recenti",
|
|
70
|
+
"window.confirm.close-modal.file": "Sei sicuro? I tuoi cambiamenti verranno perduti.",
|
|
71
|
+
"window.confirm.close-modal.files": "Sei sicuro? Ci sono dei file che non sono stati ancora caricati."
|
|
72
|
+
};
|
|
73
|
+
export {
|
|
74
|
+
it as default
|
|
75
|
+
};
|
|
76
|
+
//# sourceMappingURL=it-B7rmoZNx.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"it-B7rmoZNx.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|