@strapi/upload 5.8.1 → 5.10.0
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/dist/admin/chunks/App-BJY37n6T.js +993 -0
- package/dist/admin/chunks/App-BJY37n6T.js.map +1 -0
- package/dist/admin/chunks/App-DcpAXZuK.mjs +972 -0
- package/dist/admin/chunks/App-DcpAXZuK.mjs.map +1 -0
- package/dist/admin/chunks/ConfigureTheView-Bwf5I3Vq.mjs +276 -0
- package/dist/admin/chunks/ConfigureTheView-Bwf5I3Vq.mjs.map +1 -0
- package/dist/admin/chunks/ConfigureTheView-CnUk2xYx.js +297 -0
- package/dist/admin/chunks/ConfigureTheView-CnUk2xYx.js.map +1 -0
- package/dist/admin/chunks/SettingsPage-7DUsHuJU.js +354 -0
- package/dist/admin/chunks/SettingsPage-7DUsHuJU.js.map +1 -0
- package/dist/admin/chunks/SettingsPage-DJe31MUj.mjs +332 -0
- package/dist/admin/chunks/SettingsPage-DJe31MUj.mjs.map +1 -0
- package/dist/admin/chunks/ca-Bi4qskZD.mjs +120 -0
- package/dist/{_chunks/es-CuWi2pOn.mjs.map → admin/chunks/ca-Bi4qskZD.mjs.map} +1 -1
- package/dist/admin/chunks/ca-pCOhKIn8.js +122 -0
- package/dist/{_chunks/es-DWFtw_h4.js.map → admin/chunks/ca-pCOhKIn8.js.map} +1 -1
- package/dist/admin/chunks/de-BlbX8Dl_.mjs +106 -0
- package/dist/{_chunks/pl-Cj8jChOO.mjs.map → admin/chunks/de-BlbX8Dl_.mjs.map} +1 -1
- package/dist/admin/chunks/de-DUjKLmOP.js +108 -0
- package/dist/{_chunks/de-uGb_Pkq7.js.map → admin/chunks/de-DUjKLmOP.js.map} +1 -1
- package/dist/admin/chunks/dk-C2ydE6A7.mjs +102 -0
- package/dist/{_chunks/ko-vJl9kPpn.mjs.map → admin/chunks/dk-C2ydE6A7.mjs.map} +1 -1
- package/dist/admin/chunks/dk-DSsspA0e.js +104 -0
- package/dist/{_chunks/dk-Cd8oFO-O.js.map → admin/chunks/dk-DSsspA0e.js.map} +1 -1
- package/dist/admin/chunks/en-Bw_Cb2IV.mjs +143 -0
- package/dist/{_chunks/en-oDx2Gnre.mjs.map → admin/chunks/en-Bw_Cb2IV.mjs.map} +1 -1
- package/dist/admin/chunks/en-UjETkewz.js +145 -0
- package/dist/{_chunks/en-BcOqhiNe.js.map → admin/chunks/en-UjETkewz.js.map} +1 -1
- package/dist/admin/chunks/es-CiEgbw0k.mjs +119 -0
- package/dist/{_chunks/ca-B2_I-q1t.mjs.map → admin/chunks/es-CiEgbw0k.mjs.map} +1 -1
- package/dist/admin/chunks/es-qAL8YcZz.js +121 -0
- package/dist/{_chunks/ca-BUpuZx8N.js.map → admin/chunks/es-qAL8YcZz.js.map} +1 -1
- package/dist/admin/chunks/fr-BL0Uyj6j.js +145 -0
- package/dist/admin/chunks/fr-BL0Uyj6j.js.map +1 -0
- package/dist/admin/chunks/fr-CwRt2FJu.mjs +143 -0
- package/dist/admin/chunks/fr-CwRt2FJu.mjs.map +1 -0
- package/dist/admin/chunks/he-BAmhVpfZ.js +77 -0
- package/dist/admin/chunks/he-BAmhVpfZ.js.map +1 -0
- package/dist/admin/chunks/he-DdpYNQdt.mjs +75 -0
- package/dist/admin/chunks/he-DdpYNQdt.mjs.map +1 -0
- package/dist/admin/chunks/index-DAhjYc5x.mjs +7350 -0
- package/dist/admin/chunks/index-DAhjYc5x.mjs.map +1 -0
- package/dist/admin/chunks/index-jZnIE90w.js +7407 -0
- package/dist/admin/chunks/index-jZnIE90w.js.map +1 -0
- package/dist/admin/chunks/it-Be4kgSNB.mjs +75 -0
- package/dist/admin/chunks/it-Be4kgSNB.mjs.map +1 -0
- package/dist/admin/chunks/it-_NQZYepl.js +77 -0
- package/dist/admin/chunks/it-_NQZYepl.js.map +1 -0
- package/dist/admin/chunks/ja-B75QiyXf.js +77 -0
- package/dist/admin/chunks/ja-B75QiyXf.js.map +1 -0
- package/dist/admin/chunks/ja-U1NhT0bU.mjs +75 -0
- package/dist/admin/chunks/ja-U1NhT0bU.mjs.map +1 -0
- package/dist/admin/chunks/ko-BOvUcJqv.js +107 -0
- package/dist/{_chunks/pl-esgZ7ltN.js.map → admin/chunks/ko-BOvUcJqv.js.map} +1 -1
- package/dist/admin/chunks/ko-BciqXefq.mjs +105 -0
- package/dist/{_chunks/de-A7mEKx6c.mjs.map → admin/chunks/ko-BciqXefq.mjs.map} +1 -1
- package/dist/admin/chunks/ms-B7Zl6Lm9.js +69 -0
- package/dist/admin/chunks/ms-B7Zl6Lm9.js.map +1 -0
- package/dist/admin/chunks/ms-D-8McNeg.mjs +67 -0
- package/dist/admin/chunks/ms-D-8McNeg.mjs.map +1 -0
- package/dist/admin/chunks/pl-DdUYocl5.mjs +104 -0
- package/dist/{_chunks/dk-BPfkJb9q.mjs.map → admin/chunks/pl-DdUYocl5.mjs.map} +1 -1
- package/dist/admin/chunks/pl-cYDYHOEf.js +106 -0
- package/dist/{_chunks/ko-Pzj-818C.js.map → admin/chunks/pl-cYDYHOEf.js.map} +1 -1
- package/dist/admin/chunks/pt-BR-D1u_azCM.js +77 -0
- package/dist/admin/chunks/pt-BR-D1u_azCM.js.map +1 -0
- package/dist/admin/chunks/pt-BR-Demjoq41.mjs +75 -0
- package/dist/admin/chunks/pt-BR-Demjoq41.mjs.map +1 -0
- package/dist/admin/chunks/pt-D8is2LpS.mjs +75 -0
- package/dist/admin/chunks/pt-D8is2LpS.mjs.map +1 -0
- package/dist/admin/chunks/pt-L2DZeTPL.js +77 -0
- package/dist/admin/chunks/pt-L2DZeTPL.js.map +1 -0
- package/dist/admin/chunks/ru-CGgHRTey.mjs +75 -0
- package/dist/admin/chunks/ru-CGgHRTey.mjs.map +1 -0
- package/dist/admin/chunks/ru-Uxbk_WWv.js +77 -0
- package/dist/admin/chunks/ru-Uxbk_WWv.js.map +1 -0
- package/dist/admin/chunks/sk-BlLP5HAX.js +123 -0
- package/dist/admin/chunks/sk-BlLP5HAX.js.map +1 -0
- package/dist/admin/chunks/sk-xtSwaPXq.mjs +121 -0
- package/dist/admin/chunks/sk-xtSwaPXq.mjs.map +1 -0
- package/dist/admin/chunks/th-BOpLVfmg.mjs +75 -0
- package/dist/admin/chunks/th-BOpLVfmg.mjs.map +1 -0
- package/dist/admin/chunks/th-DNxPLegS.js +77 -0
- package/dist/admin/chunks/th-DNxPLegS.js.map +1 -0
- package/dist/admin/chunks/tr-BmAPh-f1.mjs +121 -0
- package/dist/admin/chunks/tr-BmAPh-f1.mjs.map +1 -0
- package/dist/admin/chunks/tr-DWgXG75k.js +123 -0
- package/dist/admin/chunks/tr-DWgXG75k.js.map +1 -0
- package/dist/admin/chunks/uk-CMvuEdG-.mjs +72 -0
- package/dist/admin/chunks/uk-CMvuEdG-.mjs.map +1 -0
- package/dist/admin/chunks/uk-D1_rBLhp.js +74 -0
- package/dist/admin/chunks/uk-D1_rBLhp.js.map +1 -0
- package/dist/admin/chunks/zh-BIl0qgBy.mjs +128 -0
- package/dist/admin/chunks/zh-BIl0qgBy.mjs.map +1 -0
- package/dist/admin/chunks/zh-Hans-B1GabBRx.mjs +151 -0
- package/dist/{_chunks/zh-Hans-Cpmhg8uH.mjs.map → admin/chunks/zh-Hans-B1GabBRx.mjs.map} +1 -1
- package/dist/admin/chunks/zh-Hans-B8qxMQIl.js +153 -0
- package/dist/{_chunks/zh-Hans-k_xAc6nm.js.map → admin/chunks/zh-Hans-B8qxMQIl.js.map} +1 -1
- package/dist/admin/chunks/zh-MemsyMV6.js +130 -0
- package/dist/admin/chunks/zh-MemsyMV6.js.map +1 -0
- package/dist/admin/index.js +29 -6
- package/dist/admin/index.js.map +1 -1
- package/dist/admin/index.mjs +24 -8
- package/dist/admin/index.mjs.map +1 -1
- package/dist/admin/src/hooks/useMediaLibraryPermissions.d.ts +2 -5
- package/dist/admin/src/hooks/useRemoveAsset.d.ts +6 -64
- package/dist/server/chunks/graphql-BTbIs_EU.js +116 -0
- package/dist/server/chunks/graphql-BTbIs_EU.js.map +1 -0
- package/dist/server/chunks/graphql-CCPJbCFt.mjs +114 -0
- package/dist/server/chunks/graphql-CCPJbCFt.mjs.map +1 -0
- package/dist/server/chunks/index-BU4qzb-i.mjs +3161 -0
- package/dist/server/chunks/index-BU4qzb-i.mjs.map +1 -0
- package/dist/server/chunks/index-BkUy20d9.js +3164 -0
- package/dist/server/chunks/index-BkUy20d9.js.map +1 -0
- package/dist/server/index.js +19 -2
- package/dist/server/index.js.map +1 -1
- package/dist/server/index.mjs +14 -4
- package/dist/server/index.mjs.map +1 -1
- package/dist/server/src/controllers/validation/admin/folder-file.d.ts.map +1 -1
- package/dist/shared/contracts/configuration.d.ts +1 -1
- package/dist/shared/contracts/settings.d.ts +1 -1
- package/package.json +13 -9
- package/dist/_chunks/App-CLiPAP1k.mjs +0 -844
- package/dist/_chunks/App-CLiPAP1k.mjs.map +0 -1
- package/dist/_chunks/App-CppSIIEZ.js +0 -864
- package/dist/_chunks/App-CppSIIEZ.js.map +0 -1
- package/dist/_chunks/ConfigureTheView-BNDKMkvq.mjs +0 -230
- package/dist/_chunks/ConfigureTheView-BNDKMkvq.mjs.map +0 -1
- package/dist/_chunks/ConfigureTheView-DtkJsGUi.js +0 -252
- package/dist/_chunks/ConfigureTheView-DtkJsGUi.js.map +0 -1
- package/dist/_chunks/SettingsPage-DdN_brUU.js +0 -285
- package/dist/_chunks/SettingsPage-DdN_brUU.js.map +0 -1
- package/dist/_chunks/SettingsPage-DvttEqTz.mjs +0 -264
- package/dist/_chunks/SettingsPage-DvttEqTz.mjs.map +0 -1
- package/dist/_chunks/ca-B2_I-q1t.mjs +0 -121
- package/dist/_chunks/ca-BUpuZx8N.js +0 -121
- package/dist/_chunks/de-A7mEKx6c.mjs +0 -107
- package/dist/_chunks/de-uGb_Pkq7.js +0 -107
- package/dist/_chunks/dk-BPfkJb9q.mjs +0 -103
- package/dist/_chunks/dk-Cd8oFO-O.js +0 -103
- package/dist/_chunks/en-BcOqhiNe.js +0 -144
- package/dist/_chunks/en-oDx2Gnre.mjs +0 -144
- package/dist/_chunks/es-CuWi2pOn.mjs +0 -120
- package/dist/_chunks/es-DWFtw_h4.js +0 -120
- package/dist/_chunks/fr-BN6ndmWf.mjs +0 -144
- package/dist/_chunks/fr-BN6ndmWf.mjs.map +0 -1
- package/dist/_chunks/fr-D2bop66d.js +0 -144
- package/dist/_chunks/fr-D2bop66d.js.map +0 -1
- package/dist/_chunks/graphql-DMPTPlvx.mjs +0 -71
- package/dist/_chunks/graphql-DMPTPlvx.mjs.map +0 -1
- package/dist/_chunks/graphql-QF5Y36Qj.js +0 -71
- package/dist/_chunks/graphql-QF5Y36Qj.js.map +0 -1
- package/dist/_chunks/he-BpxHjaZg.js +0 -76
- package/dist/_chunks/he-BpxHjaZg.js.map +0 -1
- package/dist/_chunks/he-C9ZOXBB-.mjs +0 -76
- package/dist/_chunks/he-C9ZOXBB-.mjs.map +0 -1
- package/dist/_chunks/index-CHxEceRJ.mjs +0 -6119
- package/dist/_chunks/index-CHxEceRJ.mjs.map +0 -1
- package/dist/_chunks/index-D57iKFts.js +0 -2721
- package/dist/_chunks/index-D57iKFts.js.map +0 -1
- package/dist/_chunks/index-DGBFKgxl.js +0 -6144
- package/dist/_chunks/index-DGBFKgxl.js.map +0 -1
- package/dist/_chunks/index-sOlgMDiZ.mjs +0 -2711
- package/dist/_chunks/index-sOlgMDiZ.mjs.map +0 -1
- package/dist/_chunks/it-B7rmoZNx.mjs +0 -76
- package/dist/_chunks/it-B7rmoZNx.mjs.map +0 -1
- package/dist/_chunks/it-BKCWXl8t.js +0 -76
- package/dist/_chunks/it-BKCWXl8t.js.map +0 -1
- package/dist/_chunks/ja-DlaJTi_3.mjs +0 -76
- package/dist/_chunks/ja-DlaJTi_3.mjs.map +0 -1
- package/dist/_chunks/ja-ajHzIJz6.js +0 -76
- package/dist/_chunks/ja-ajHzIJz6.js.map +0 -1
- package/dist/_chunks/ko-Pzj-818C.js +0 -106
- package/dist/_chunks/ko-vJl9kPpn.mjs +0 -106
- package/dist/_chunks/ms-CqwG8v8l.mjs +0 -68
- package/dist/_chunks/ms-CqwG8v8l.mjs.map +0 -1
- package/dist/_chunks/ms-h3gjldBy.js +0 -68
- package/dist/_chunks/ms-h3gjldBy.js.map +0 -1
- package/dist/_chunks/pl-Cj8jChOO.mjs +0 -105
- package/dist/_chunks/pl-esgZ7ltN.js +0 -105
- package/dist/_chunks/pt-BR-B4LJHJIp.mjs +0 -76
- package/dist/_chunks/pt-BR-B4LJHJIp.mjs.map +0 -1
- package/dist/_chunks/pt-BR-Cazr7Z5I.js +0 -76
- package/dist/_chunks/pt-BR-Cazr7Z5I.js.map +0 -1
- package/dist/_chunks/pt-CNOOM_7x.mjs +0 -76
- package/dist/_chunks/pt-CNOOM_7x.mjs.map +0 -1
- package/dist/_chunks/pt-cbUnkHM5.js +0 -76
- package/dist/_chunks/pt-cbUnkHM5.js.map +0 -1
- package/dist/_chunks/ru-DqglvSUC.mjs +0 -76
- package/dist/_chunks/ru-DqglvSUC.mjs.map +0 -1
- package/dist/_chunks/ru-H6MzFUxp.js +0 -76
- package/dist/_chunks/ru-H6MzFUxp.js.map +0 -1
- package/dist/_chunks/sk-CZxC4dFY.js +0 -122
- package/dist/_chunks/sk-CZxC4dFY.js.map +0 -1
- package/dist/_chunks/sk-Dgpb3lnz.mjs +0 -122
- package/dist/_chunks/sk-Dgpb3lnz.mjs.map +0 -1
- package/dist/_chunks/th-C6unJZ8j.js +0 -76
- package/dist/_chunks/th-C6unJZ8j.js.map +0 -1
- package/dist/_chunks/th-DRfzuiFf.mjs +0 -76
- package/dist/_chunks/th-DRfzuiFf.mjs.map +0 -1
- package/dist/_chunks/tr--GzWXE_A.mjs +0 -122
- package/dist/_chunks/tr--GzWXE_A.mjs.map +0 -1
- package/dist/_chunks/tr-CY6AwX50.js +0 -122
- package/dist/_chunks/tr-CY6AwX50.js.map +0 -1
- package/dist/_chunks/uk-BniyNsD4.js +0 -73
- package/dist/_chunks/uk-BniyNsD4.js.map +0 -1
- package/dist/_chunks/uk-DVMT2Piq.mjs +0 -73
- package/dist/_chunks/uk-DVMT2Piq.mjs.map +0 -1
- package/dist/_chunks/zh-CsZw0IpM.js +0 -129
- package/dist/_chunks/zh-CsZw0IpM.js.map +0 -1
- package/dist/_chunks/zh-HOnih0is.mjs +0 -129
- package/dist/_chunks/zh-HOnih0is.mjs.map +0 -1
- package/dist/_chunks/zh-Hans-Cpmhg8uH.mjs +0 -152
- package/dist/_chunks/zh-Hans-k_xAc6nm.js +0 -152
|
@@ -1,252 +0,0 @@
|
|
|
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 designSystem = require("@strapi/design-system");
|
|
7
|
-
const icons = require("@strapi/icons");
|
|
8
|
-
const isEqual = require("lodash/isEqual");
|
|
9
|
-
const reactIntl = require("react-intl");
|
|
10
|
-
const reactRouterDom = require("react-router-dom");
|
|
11
|
-
const index = require("./index-DGBFKgxl.js");
|
|
12
|
-
require("byte-size");
|
|
13
|
-
require("date-fns");
|
|
14
|
-
require("qs");
|
|
15
|
-
const immer = require("immer");
|
|
16
|
-
const get = require("lodash/get");
|
|
17
|
-
const set = require("lodash/set");
|
|
18
|
-
const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
|
|
19
|
-
function _interopNamespace(e) {
|
|
20
|
-
if (e && e.__esModule) return e;
|
|
21
|
-
const n = Object.create(null, { [Symbol.toStringTag]: { value: "Module" } });
|
|
22
|
-
if (e) {
|
|
23
|
-
for (const k in e) {
|
|
24
|
-
if (k !== "default") {
|
|
25
|
-
const d = Object.getOwnPropertyDescriptor(e, k);
|
|
26
|
-
Object.defineProperty(n, k, d.get ? d : {
|
|
27
|
-
enumerable: true,
|
|
28
|
-
get: () => e[k]
|
|
29
|
-
});
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
n.default = e;
|
|
34
|
-
return Object.freeze(n);
|
|
35
|
-
}
|
|
36
|
-
const React__namespace = /* @__PURE__ */ _interopNamespace(React);
|
|
37
|
-
const isEqual__default = /* @__PURE__ */ _interopDefault(isEqual);
|
|
38
|
-
const get__default = /* @__PURE__ */ _interopDefault(get);
|
|
39
|
-
const set__default = /* @__PURE__ */ _interopDefault(set);
|
|
40
|
-
const Settings = ({ sort = "", pageSize = 10, onChange: onChange2 }) => {
|
|
41
|
-
const { formatMessage } = reactIntl.useIntl();
|
|
42
|
-
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
43
|
-
designSystem.Box,
|
|
44
|
-
{
|
|
45
|
-
background: "neutral0",
|
|
46
|
-
hasRadius: true,
|
|
47
|
-
shadow: "tableShadow",
|
|
48
|
-
paddingTop: 6,
|
|
49
|
-
paddingBottom: 6,
|
|
50
|
-
paddingLeft: 7,
|
|
51
|
-
paddingRight: 7,
|
|
52
|
-
children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Grid.Root, { gap: 4, children: [
|
|
53
|
-
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Item, { s: 12, col: 6, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsxRuntime.jsxs(
|
|
54
|
-
designSystem.Field.Root,
|
|
55
|
-
{
|
|
56
|
-
hint: formatMessage({
|
|
57
|
-
id: index.getTrad("config.entries.note"),
|
|
58
|
-
defaultMessage: "Number of assets displayed by default in the Media Library"
|
|
59
|
-
}),
|
|
60
|
-
name: "pageSize",
|
|
61
|
-
children: [
|
|
62
|
-
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: formatMessage({
|
|
63
|
-
id: index.getTrad("config.entries.title"),
|
|
64
|
-
defaultMessage: "Entries per page"
|
|
65
|
-
}) }),
|
|
66
|
-
/* @__PURE__ */ jsxRuntime.jsx(
|
|
67
|
-
designSystem.SingleSelect,
|
|
68
|
-
{
|
|
69
|
-
onChange: (value) => onChange2({ target: { name: "pageSize", value } }),
|
|
70
|
-
value: pageSize,
|
|
71
|
-
children: index.pageSizes.map((pageSize2) => /* @__PURE__ */ jsxRuntime.jsx(designSystem.SingleSelectOption, { value: pageSize2, children: pageSize2 }, pageSize2))
|
|
72
|
-
}
|
|
73
|
-
),
|
|
74
|
-
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Hint, {})
|
|
75
|
-
]
|
|
76
|
-
}
|
|
77
|
-
) }),
|
|
78
|
-
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Item, { s: 12, col: 6, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsxRuntime.jsxs(
|
|
79
|
-
designSystem.Field.Root,
|
|
80
|
-
{
|
|
81
|
-
hint: formatMessage({
|
|
82
|
-
id: index.getTrad("config.note"),
|
|
83
|
-
defaultMessage: "Note: You can override this value in the media library."
|
|
84
|
-
}),
|
|
85
|
-
name: "sort",
|
|
86
|
-
children: [
|
|
87
|
-
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: formatMessage({
|
|
88
|
-
id: index.getTrad("config.sort.title"),
|
|
89
|
-
defaultMessage: "Default sort order"
|
|
90
|
-
}) }),
|
|
91
|
-
/* @__PURE__ */ jsxRuntime.jsx(
|
|
92
|
-
designSystem.SingleSelect,
|
|
93
|
-
{
|
|
94
|
-
onChange: (value) => onChange2({ target: { name: "sort", value } }),
|
|
95
|
-
value: sort,
|
|
96
|
-
"test-sort": sort,
|
|
97
|
-
"data-testid": "sort-select",
|
|
98
|
-
children: index.sortOptions.map((filter) => /* @__PURE__ */ jsxRuntime.jsx(
|
|
99
|
-
designSystem.SingleSelectOption,
|
|
100
|
-
{
|
|
101
|
-
"data-testid": `sort-option-${filter.value}`,
|
|
102
|
-
value: filter.value,
|
|
103
|
-
children: formatMessage({ id: index.getTrad(filter.key), defaultMessage: `${filter.value}` })
|
|
104
|
-
},
|
|
105
|
-
filter.key
|
|
106
|
-
))
|
|
107
|
-
}
|
|
108
|
-
),
|
|
109
|
-
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Hint, {})
|
|
110
|
-
]
|
|
111
|
-
}
|
|
112
|
-
) })
|
|
113
|
-
] })
|
|
114
|
-
}
|
|
115
|
-
);
|
|
116
|
-
};
|
|
117
|
-
const ON_CHANGE = `${index.pluginId}/ON_CHANGE`;
|
|
118
|
-
const SET_LOADED = `${index.pluginId}/SET_LOADED`;
|
|
119
|
-
const onChange = ({
|
|
120
|
-
name,
|
|
121
|
-
value
|
|
122
|
-
}) => ({
|
|
123
|
-
type: ON_CHANGE,
|
|
124
|
-
keys: name,
|
|
125
|
-
value
|
|
126
|
-
});
|
|
127
|
-
const setLoaded = () => ({
|
|
128
|
-
type: SET_LOADED
|
|
129
|
-
});
|
|
130
|
-
const initialState = {
|
|
131
|
-
initialData: {},
|
|
132
|
-
modifiedData: {}
|
|
133
|
-
};
|
|
134
|
-
const init = (configData) => {
|
|
135
|
-
return {
|
|
136
|
-
...initialState,
|
|
137
|
-
initialData: configData,
|
|
138
|
-
modifiedData: configData
|
|
139
|
-
};
|
|
140
|
-
};
|
|
141
|
-
const reducer = (state = initialState, action = {
|
|
142
|
-
type: ""
|
|
143
|
-
}) => (
|
|
144
|
-
// eslint-disable-next-line consistent-return
|
|
145
|
-
immer.produce(state, (draftState) => {
|
|
146
|
-
switch (action.type) {
|
|
147
|
-
case ON_CHANGE: {
|
|
148
|
-
if ("keys" in action && "value" in action && action.keys) {
|
|
149
|
-
set__default.default(draftState, ["modifiedData", ...action.keys.split(".")], action.value);
|
|
150
|
-
}
|
|
151
|
-
break;
|
|
152
|
-
}
|
|
153
|
-
case SET_LOADED: {
|
|
154
|
-
const reInitialise = init(get__default.default(draftState, ["modifiedData"], {}));
|
|
155
|
-
draftState.initialData = reInitialise.initialData;
|
|
156
|
-
draftState.modifiedData = reInitialise.modifiedData;
|
|
157
|
-
break;
|
|
158
|
-
}
|
|
159
|
-
default:
|
|
160
|
-
return draftState;
|
|
161
|
-
}
|
|
162
|
-
})
|
|
163
|
-
);
|
|
164
|
-
const ConfigureTheView = ({ config }) => {
|
|
165
|
-
const { trackUsage } = strapiAdmin.useTracking();
|
|
166
|
-
const { formatMessage } = reactIntl.useIntl();
|
|
167
|
-
const { toggleNotification } = strapiAdmin.useNotification();
|
|
168
|
-
const { mutateConfig } = index.useConfig();
|
|
169
|
-
const { isLoading: isSubmittingForm } = mutateConfig;
|
|
170
|
-
const [showWarningSubmit, setWarningSubmit] = React__namespace.useState(false);
|
|
171
|
-
const toggleWarningSubmit = () => setWarningSubmit((prevState) => !prevState);
|
|
172
|
-
const [reducerState, dispatch] = React__namespace.useReducer(
|
|
173
|
-
reducer,
|
|
174
|
-
initialState,
|
|
175
|
-
() => init(config)
|
|
176
|
-
);
|
|
177
|
-
const typedDispatch = dispatch;
|
|
178
|
-
const { initialData, modifiedData } = reducerState;
|
|
179
|
-
const handleSubmit = (e) => {
|
|
180
|
-
e.preventDefault();
|
|
181
|
-
toggleWarningSubmit();
|
|
182
|
-
};
|
|
183
|
-
const handleConfirm = async () => {
|
|
184
|
-
trackUsage("willEditMediaLibraryConfig");
|
|
185
|
-
await mutateConfig.mutateAsync(modifiedData);
|
|
186
|
-
setWarningSubmit(false);
|
|
187
|
-
typedDispatch(setLoaded());
|
|
188
|
-
toggleNotification({
|
|
189
|
-
type: "success",
|
|
190
|
-
message: formatMessage({
|
|
191
|
-
id: "notification.form.success.fields",
|
|
192
|
-
defaultMessage: "Changes saved"
|
|
193
|
-
})
|
|
194
|
-
});
|
|
195
|
-
};
|
|
196
|
-
const handleChange = ({
|
|
197
|
-
target: { name, value }
|
|
198
|
-
}) => {
|
|
199
|
-
typedDispatch(onChange({ name, value }));
|
|
200
|
-
};
|
|
201
|
-
return /* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Layouts.Root, { children: /* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Page.Main, { "aria-busy": isSubmittingForm, children: /* @__PURE__ */ jsxRuntime.jsxs("form", { onSubmit: handleSubmit, children: [
|
|
202
|
-
/* @__PURE__ */ jsxRuntime.jsx(
|
|
203
|
-
strapiAdmin.Layouts.Header,
|
|
204
|
-
{
|
|
205
|
-
navigationAction: /* @__PURE__ */ jsxRuntime.jsx(
|
|
206
|
-
designSystem.Link,
|
|
207
|
-
{
|
|
208
|
-
tag: reactRouterDom.NavLink,
|
|
209
|
-
startIcon: /* @__PURE__ */ jsxRuntime.jsx(icons.ArrowLeft, {}),
|
|
210
|
-
to: `/plugins/${index.pluginId}`,
|
|
211
|
-
id: "go-back",
|
|
212
|
-
children: formatMessage({ id: index.getTrad("config.back"), defaultMessage: "Back" })
|
|
213
|
-
}
|
|
214
|
-
),
|
|
215
|
-
primaryAction: /* @__PURE__ */ jsxRuntime.jsx(
|
|
216
|
-
designSystem.Button,
|
|
217
|
-
{
|
|
218
|
-
size: "S",
|
|
219
|
-
startIcon: /* @__PURE__ */ jsxRuntime.jsx(icons.Check, {}),
|
|
220
|
-
disabled: isEqual__default.default(modifiedData, initialData),
|
|
221
|
-
type: "submit",
|
|
222
|
-
children: formatMessage({ id: "global.save", defaultMessage: "Save" })
|
|
223
|
-
}
|
|
224
|
-
),
|
|
225
|
-
subtitle: formatMessage({
|
|
226
|
-
id: index.getTrad("config.subtitle"),
|
|
227
|
-
defaultMessage: "Define the view settings of the media library."
|
|
228
|
-
}),
|
|
229
|
-
title: formatMessage({
|
|
230
|
-
id: index.getTrad("config.title"),
|
|
231
|
-
defaultMessage: "Configure the view - Media Library"
|
|
232
|
-
})
|
|
233
|
-
}
|
|
234
|
-
),
|
|
235
|
-
/* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Layouts.Content, { children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
236
|
-
Settings,
|
|
237
|
-
{
|
|
238
|
-
"data-testid": "settings",
|
|
239
|
-
pageSize: modifiedData.pageSize || "",
|
|
240
|
-
sort: modifiedData.sort || "",
|
|
241
|
-
onChange: handleChange
|
|
242
|
-
}
|
|
243
|
-
) }),
|
|
244
|
-
"x",
|
|
245
|
-
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Dialog.Root, { open: showWarningSubmit, onOpenChange: toggleWarningSubmit, children: /* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.ConfirmDialog, { onConfirm: handleConfirm, variant: "default", children: formatMessage({
|
|
246
|
-
id: index.getTrad("config.popUpWarning.warning.updateAllSettings"),
|
|
247
|
-
defaultMessage: "This will modify all your settings"
|
|
248
|
-
}) }) })
|
|
249
|
-
] }) }) });
|
|
250
|
-
};
|
|
251
|
-
exports.ConfigureTheView = ConfigureTheView;
|
|
252
|
-
//# sourceMappingURL=ConfigureTheView-DtkJsGUi.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ConfigureTheView-DtkJsGUi.js","sources":["../../admin/src/pages/App/ConfigureTheView/components/Settings.tsx","../../admin/src/pages/App/ConfigureTheView/state/actionTypes.ts","../../admin/src/pages/App/ConfigureTheView/state/actions.ts","../../admin/src/pages/App/ConfigureTheView/state/init.ts","../../admin/src/pages/App/ConfigureTheView/state/reducer.ts","../../admin/src/pages/App/ConfigureTheView/ConfigureTheView.tsx"],"sourcesContent":["import { Box, Grid, SingleSelectOption, SingleSelect, Field } from '@strapi/design-system';\nimport { useIntl } from 'react-intl';\n\nimport { pageSizes, sortOptions } from '../../../../constants';\nimport { getTrad } from '../../../../utils';\n\nimport type { Configuration } from '../../../../../../shared/contracts/configuration';\n\ninterface SettingsProps {\n sort: string;\n pageSize: string | number;\n onChange: ({\n target: { name, value },\n }: {\n target: { name: keyof Configuration; value: string | number };\n }) => void;\n}\n\nconst Settings = ({ sort = '', pageSize = 10, onChange }: SettingsProps) => {\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.Root gap={4}>\n <Grid.Item s={12} col={6} direction=\"column\" alignItems=\"stretch\">\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 </Grid.Item>\n <Grid.Item s={12} col={6} direction=\"column\" alignItems=\"stretch\">\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 </Grid.Item>\n </Grid.Root>\n </Box>\n );\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\nimport type { InitialState } from './init';\n\nexport const onChange = ({\n name,\n value,\n}: {\n name: keyof NonNullable<InitialState['initialData']>;\n value: number | string;\n}) => ({\n type: ON_CHANGE,\n keys: name,\n value,\n});\n\nexport const setLoaded = () => ({\n type: SET_LOADED,\n});\n","import type { Configuration } from '../../../../../../shared/contracts/configuration';\n\nexport type InitialState = {\n initialData: Partial<Configuration>;\n modifiedData: Partial<Configuration>;\n};\n\nconst initialState: InitialState = {\n initialData: {},\n modifiedData: {},\n};\n\nconst init = (configData: InitialState['initialData']): InitialState => {\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\nimport type { InitialState } from './init';\n\nexport interface ActionOnChange {\n type: string;\n keys?: string;\n value: string | number;\n}\n\nexport interface ActionSetLoaded {\n type: string;\n}\n\ninterface ActionInitialValue {\n type: string;\n}\n\nexport type Action = ActionSetLoaded | ActionOnChange | ActionInitialValue;\n\nexport const reducer = (\n state: InitialState = initialState,\n action: Action = {\n type: '',\n }\n) =>\n // eslint-disable-next-line consistent-return\n produce(state, (draftState) => {\n switch (action.type) {\n case ON_CHANGE: {\n if ('keys' in action && 'value' in action && action.keys) {\n set(draftState, ['modifiedData', ...action.keys.split('.')], action.value);\n }\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","// TODO: find a better naming convention for the file that was an index file before\nimport * as React from 'react';\n\nimport {\n ConfirmDialog,\n useTracking,\n useNotification,\n Page,\n Layouts,\n} from '@strapi/admin/strapi-admin';\nimport { Button, Dialog, Link } from '@strapi/design-system';\nimport { ArrowLeft, Check } from '@strapi/icons';\nimport isEqual from 'lodash/isEqual';\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';\n\nimport { Settings } from './components/Settings';\nimport { onChange, setLoaded } from './state/actions';\nimport { init, initialState } from './state/init';\nimport { reducer } from './state/reducer';\n\nimport type { InitialState } from './state/init';\nimport type { Action } from './state/reducer';\nimport type { Configuration } from '../../../../../shared/contracts/configuration';\n\ninterface ConfigureTheViewProps {\n config: Configuration;\n}\n\nexport const ConfigureTheView = ({ config }: ConfigureTheViewProps) => {\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] = React.useState(false);\n const toggleWarningSubmit = () => setWarningSubmit((prevState) => !prevState);\n\n const [reducerState, dispatch] = React.useReducer(\n reducer,\n initialState,\n (): InitialState => init(config)\n );\n const typedDispatch: React.Dispatch<Action> = dispatch;\n const { initialData, modifiedData } = reducerState;\n\n const handleSubmit = (e: React.FormEvent<HTMLFormElement>) => {\n e.preventDefault();\n toggleWarningSubmit();\n };\n\n const handleConfirm = async () => {\n trackUsage('willEditMediaLibraryConfig');\n await mutateConfig.mutateAsync(modifiedData as Configuration);\n setWarningSubmit(false);\n typedDispatch(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 = ({\n target: { name, value },\n }: {\n target: { name: keyof Configuration; value: string | number };\n }) => {\n typedDispatch(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 <Layouts.Content>\n <Settings\n data-testid=\"settings\"\n pageSize={modifiedData.pageSize || ''}\n sort={modifiedData.sort || ''}\n onChange={handleChange}\n />\n </Layouts.Content>\n x\n <Dialog.Root open={showWarningSubmit} onOpenChange={toggleWarningSubmit}>\n <ConfirmDialog onConfirm={handleConfirm} variant=\"default\">\n {formatMessage({\n id: getTrad('config.popUpWarning.warning.updateAllSettings'),\n defaultMessage: 'This will modify all your settings',\n })}\n </ConfirmDialog>\n </Dialog.Root>\n </form>\n </Page.Main>\n </Layouts.Root>\n );\n};\n"],"names":["onChange","useIntl","jsx","Box","jsxs","Grid","Field","getTrad","SingleSelect","pageSizes","pageSize","SingleSelectOption","sortOptions","pluginId","produce","set","get","useTracking","useNotification","useConfig","React","Layouts","Page","Link","NavLink","ArrowLeft","Button","Check","isEqual","Dialog","ConfirmDialog"],"mappings":"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"}
|
|
@@ -1,285 +0,0 @@
|
|
|
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 designSystem = require("@strapi/design-system");
|
|
7
|
-
const icons = require("@strapi/icons");
|
|
8
|
-
const isEqual = require("lodash/isEqual");
|
|
9
|
-
const reactIntl = require("react-intl");
|
|
10
|
-
const reactQuery = require("react-query");
|
|
11
|
-
const index = require("./index-DGBFKgxl.js");
|
|
12
|
-
require("byte-size");
|
|
13
|
-
require("date-fns");
|
|
14
|
-
require("qs");
|
|
15
|
-
const immer = require("immer");
|
|
16
|
-
const set = require("lodash/set");
|
|
17
|
-
const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
|
|
18
|
-
function _interopNamespace(e) {
|
|
19
|
-
if (e && e.__esModule) return e;
|
|
20
|
-
const n = Object.create(null, { [Symbol.toStringTag]: { value: "Module" } });
|
|
21
|
-
if (e) {
|
|
22
|
-
for (const k in e) {
|
|
23
|
-
if (k !== "default") {
|
|
24
|
-
const d = Object.getOwnPropertyDescriptor(e, k);
|
|
25
|
-
Object.defineProperty(n, k, d.get ? d : {
|
|
26
|
-
enumerable: true,
|
|
27
|
-
get: () => e[k]
|
|
28
|
-
});
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
n.default = e;
|
|
33
|
-
return Object.freeze(n);
|
|
34
|
-
}
|
|
35
|
-
const React__namespace = /* @__PURE__ */ _interopNamespace(React);
|
|
36
|
-
const isEqual__default = /* @__PURE__ */ _interopDefault(isEqual);
|
|
37
|
-
const set__default = /* @__PURE__ */ _interopDefault(set);
|
|
38
|
-
const init = (initialState2) => {
|
|
39
|
-
return initialState2;
|
|
40
|
-
};
|
|
41
|
-
const initialState = {
|
|
42
|
-
initialData: {
|
|
43
|
-
responsiveDimensions: true,
|
|
44
|
-
sizeOptimization: true,
|
|
45
|
-
autoOrientation: false,
|
|
46
|
-
videoPreview: false
|
|
47
|
-
},
|
|
48
|
-
modifiedData: {
|
|
49
|
-
responsiveDimensions: true,
|
|
50
|
-
sizeOptimization: true,
|
|
51
|
-
autoOrientation: false,
|
|
52
|
-
videoPreview: false
|
|
53
|
-
}
|
|
54
|
-
};
|
|
55
|
-
const reducer = (state, action) => immer.produce(state, (drafState) => {
|
|
56
|
-
switch (action.type) {
|
|
57
|
-
case "GET_DATA_SUCCEEDED": {
|
|
58
|
-
drafState.initialData = action.data;
|
|
59
|
-
drafState.modifiedData = action.data;
|
|
60
|
-
break;
|
|
61
|
-
}
|
|
62
|
-
case "ON_CHANGE": {
|
|
63
|
-
set__default.default(drafState, ["modifiedData", ...action.keys.split(".")], action.value);
|
|
64
|
-
break;
|
|
65
|
-
}
|
|
66
|
-
default:
|
|
67
|
-
return state;
|
|
68
|
-
}
|
|
69
|
-
});
|
|
70
|
-
const SettingsPage = () => {
|
|
71
|
-
const { formatMessage } = reactIntl.useIntl();
|
|
72
|
-
const { toggleNotification } = strapiAdmin.useNotification();
|
|
73
|
-
const { get, put } = strapiAdmin.useFetchClient();
|
|
74
|
-
const [{ initialData, modifiedData }, dispatch] = React__namespace.useReducer(reducer, initialState, init);
|
|
75
|
-
const { data, isLoading, refetch } = reactQuery.useQuery({
|
|
76
|
-
queryKey: ["upload", "settings"],
|
|
77
|
-
async queryFn() {
|
|
78
|
-
const {
|
|
79
|
-
data: { data: data2 }
|
|
80
|
-
} = await get("/upload/settings");
|
|
81
|
-
return data2;
|
|
82
|
-
}
|
|
83
|
-
});
|
|
84
|
-
React__namespace.useEffect(() => {
|
|
85
|
-
if (data) {
|
|
86
|
-
dispatch({
|
|
87
|
-
type: "GET_DATA_SUCCEEDED",
|
|
88
|
-
data
|
|
89
|
-
});
|
|
90
|
-
}
|
|
91
|
-
}, [data]);
|
|
92
|
-
const isSaveButtonDisabled = isEqual__default.default(initialData, modifiedData);
|
|
93
|
-
const { mutateAsync, isLoading: isSubmitting } = reactQuery.useMutation(
|
|
94
|
-
async (body) => {
|
|
95
|
-
const { data: data2 } = await put("/upload/settings", body);
|
|
96
|
-
return data2;
|
|
97
|
-
},
|
|
98
|
-
{
|
|
99
|
-
onSuccess() {
|
|
100
|
-
refetch();
|
|
101
|
-
toggleNotification({
|
|
102
|
-
type: "success",
|
|
103
|
-
message: formatMessage({ id: "notification.form.success.fields" })
|
|
104
|
-
});
|
|
105
|
-
},
|
|
106
|
-
onError(err) {
|
|
107
|
-
console.error(err);
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
);
|
|
111
|
-
const handleSubmit = async (e) => {
|
|
112
|
-
e.preventDefault();
|
|
113
|
-
if (isSaveButtonDisabled) {
|
|
114
|
-
return;
|
|
115
|
-
}
|
|
116
|
-
await mutateAsync(modifiedData);
|
|
117
|
-
};
|
|
118
|
-
const handleChange = ({
|
|
119
|
-
target: { name, value }
|
|
120
|
-
}) => {
|
|
121
|
-
dispatch({
|
|
122
|
-
type: "ON_CHANGE",
|
|
123
|
-
keys: name,
|
|
124
|
-
value
|
|
125
|
-
});
|
|
126
|
-
};
|
|
127
|
-
if (isLoading) {
|
|
128
|
-
return /* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Page.Loading, {});
|
|
129
|
-
}
|
|
130
|
-
return /* @__PURE__ */ jsxRuntime.jsxs(strapiAdmin.Page.Main, { tabIndex: -1, children: [
|
|
131
|
-
/* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Page.Title, { children: formatMessage({
|
|
132
|
-
id: index.getTrad("page.title"),
|
|
133
|
-
defaultMessage: "Settings - Media Libray"
|
|
134
|
-
}) }),
|
|
135
|
-
/* @__PURE__ */ jsxRuntime.jsxs("form", { onSubmit: handleSubmit, children: [
|
|
136
|
-
/* @__PURE__ */ jsxRuntime.jsx(
|
|
137
|
-
strapiAdmin.Layouts.Header,
|
|
138
|
-
{
|
|
139
|
-
title: formatMessage({
|
|
140
|
-
id: index.getTrad("settings.header.label"),
|
|
141
|
-
defaultMessage: "Media Library"
|
|
142
|
-
}),
|
|
143
|
-
primaryAction: /* @__PURE__ */ jsxRuntime.jsx(
|
|
144
|
-
designSystem.Button,
|
|
145
|
-
{
|
|
146
|
-
disabled: isSaveButtonDisabled,
|
|
147
|
-
loading: isSubmitting,
|
|
148
|
-
type: "submit",
|
|
149
|
-
startIcon: /* @__PURE__ */ jsxRuntime.jsx(icons.Check, {}),
|
|
150
|
-
size: "S",
|
|
151
|
-
children: formatMessage({
|
|
152
|
-
id: "global.save",
|
|
153
|
-
defaultMessage: "Save"
|
|
154
|
-
})
|
|
155
|
-
}
|
|
156
|
-
),
|
|
157
|
-
subtitle: formatMessage({
|
|
158
|
-
id: index.getTrad("settings.sub-header.label"),
|
|
159
|
-
defaultMessage: "Configure the settings for the Media Library"
|
|
160
|
-
})
|
|
161
|
-
}
|
|
162
|
-
),
|
|
163
|
-
/* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Layouts.Content, { children: /* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Layouts.Root, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Flex, { direction: "column", alignItems: "stretch", gap: 12, children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Box, { background: "neutral0", padding: 6, shadow: "filterShadow", hasRadius: true, children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { direction: "column", alignItems: "stretch", gap: 4, children: [
|
|
164
|
-
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Flex, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "delta", tag: "h2", children: formatMessage({
|
|
165
|
-
id: index.getTrad("settings.blockTitle"),
|
|
166
|
-
defaultMessage: "Asset management"
|
|
167
|
-
}) }) }),
|
|
168
|
-
/* @__PURE__ */ jsxRuntime.jsxs(designSystem.Grid.Root, { gap: 6, children: [
|
|
169
|
-
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Item, { col: 6, s: 12, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsxRuntime.jsxs(
|
|
170
|
-
designSystem.Field.Root,
|
|
171
|
-
{
|
|
172
|
-
hint: formatMessage({
|
|
173
|
-
id: index.getTrad("settings.form.responsiveDimensions.description"),
|
|
174
|
-
defaultMessage: "Enabling this option will generate multiple formats (small, medium and large) of the uploaded asset."
|
|
175
|
-
}),
|
|
176
|
-
name: "responsiveDimensions",
|
|
177
|
-
children: [
|
|
178
|
-
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: formatMessage({
|
|
179
|
-
id: index.getTrad("settings.form.responsiveDimensions.label"),
|
|
180
|
-
defaultMessage: "Responsive friendly upload"
|
|
181
|
-
}) }),
|
|
182
|
-
/* @__PURE__ */ jsxRuntime.jsx(
|
|
183
|
-
designSystem.Toggle,
|
|
184
|
-
{
|
|
185
|
-
checked: modifiedData?.responsiveDimensions,
|
|
186
|
-
offLabel: formatMessage({
|
|
187
|
-
id: "app.components.ToggleCheckbox.off-label",
|
|
188
|
-
defaultMessage: "Off"
|
|
189
|
-
}),
|
|
190
|
-
onLabel: formatMessage({
|
|
191
|
-
id: "app.components.ToggleCheckbox.on-label",
|
|
192
|
-
defaultMessage: "On"
|
|
193
|
-
}),
|
|
194
|
-
onChange: (e) => {
|
|
195
|
-
handleChange({
|
|
196
|
-
target: { name: "responsiveDimensions", value: e.target.checked }
|
|
197
|
-
});
|
|
198
|
-
}
|
|
199
|
-
}
|
|
200
|
-
),
|
|
201
|
-
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Hint, {})
|
|
202
|
-
]
|
|
203
|
-
}
|
|
204
|
-
) }),
|
|
205
|
-
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Item, { col: 6, s: 12, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsxRuntime.jsxs(
|
|
206
|
-
designSystem.Field.Root,
|
|
207
|
-
{
|
|
208
|
-
hint: formatMessage({
|
|
209
|
-
id: index.getTrad("settings.form.sizeOptimization.description"),
|
|
210
|
-
defaultMessage: "Enabling this option will reduce the image size and slightly reduce its quality."
|
|
211
|
-
}),
|
|
212
|
-
name: "sizeOptimization",
|
|
213
|
-
children: [
|
|
214
|
-
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: formatMessage({
|
|
215
|
-
id: index.getTrad("settings.form.sizeOptimization.label"),
|
|
216
|
-
defaultMessage: "Size optimization"
|
|
217
|
-
}) }),
|
|
218
|
-
/* @__PURE__ */ jsxRuntime.jsx(
|
|
219
|
-
designSystem.Toggle,
|
|
220
|
-
{
|
|
221
|
-
checked: modifiedData?.sizeOptimization,
|
|
222
|
-
offLabel: formatMessage({
|
|
223
|
-
id: "app.components.ToggleCheckbox.off-label",
|
|
224
|
-
defaultMessage: "Off"
|
|
225
|
-
}),
|
|
226
|
-
onLabel: formatMessage({
|
|
227
|
-
id: "app.components.ToggleCheckbox.on-label",
|
|
228
|
-
defaultMessage: "On"
|
|
229
|
-
}),
|
|
230
|
-
onChange: (e) => {
|
|
231
|
-
handleChange({
|
|
232
|
-
target: { name: "sizeOptimization", value: e.target.checked }
|
|
233
|
-
});
|
|
234
|
-
}
|
|
235
|
-
}
|
|
236
|
-
),
|
|
237
|
-
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Hint, {})
|
|
238
|
-
]
|
|
239
|
-
}
|
|
240
|
-
) }),
|
|
241
|
-
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Item, { col: 6, s: 12, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsxRuntime.jsxs(
|
|
242
|
-
designSystem.Field.Root,
|
|
243
|
-
{
|
|
244
|
-
hint: formatMessage({
|
|
245
|
-
id: index.getTrad("settings.form.autoOrientation.description"),
|
|
246
|
-
defaultMessage: "Enabling this option will automatically rotate the image according to EXIF orientation tag."
|
|
247
|
-
}),
|
|
248
|
-
name: "autoOrientation",
|
|
249
|
-
children: [
|
|
250
|
-
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: formatMessage({
|
|
251
|
-
id: index.getTrad("settings.form.autoOrientation.label"),
|
|
252
|
-
defaultMessage: "Auto orientation"
|
|
253
|
-
}) }),
|
|
254
|
-
/* @__PURE__ */ jsxRuntime.jsx(
|
|
255
|
-
designSystem.Toggle,
|
|
256
|
-
{
|
|
257
|
-
checked: modifiedData?.autoOrientation,
|
|
258
|
-
offLabel: formatMessage({
|
|
259
|
-
id: "app.components.ToggleCheckbox.off-label",
|
|
260
|
-
defaultMessage: "Off"
|
|
261
|
-
}),
|
|
262
|
-
onLabel: formatMessage({
|
|
263
|
-
id: "app.components.ToggleCheckbox.on-label",
|
|
264
|
-
defaultMessage: "On"
|
|
265
|
-
}),
|
|
266
|
-
onChange: (e) => {
|
|
267
|
-
handleChange({
|
|
268
|
-
target: { name: "autoOrientation", value: e.target.checked }
|
|
269
|
-
});
|
|
270
|
-
}
|
|
271
|
-
}
|
|
272
|
-
),
|
|
273
|
-
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Hint, {})
|
|
274
|
-
]
|
|
275
|
-
}
|
|
276
|
-
) })
|
|
277
|
-
] })
|
|
278
|
-
] }) }) }) }) })
|
|
279
|
-
] })
|
|
280
|
-
] });
|
|
281
|
-
};
|
|
282
|
-
const ProtectedSettingsPage = () => /* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Page.Protect, { permissions: index.PERMISSIONS.settings, children: /* @__PURE__ */ jsxRuntime.jsx(SettingsPage, {}) });
|
|
283
|
-
exports.ProtectedSettingsPage = ProtectedSettingsPage;
|
|
284
|
-
exports.SettingsPage = SettingsPage;
|
|
285
|
-
//# sourceMappingURL=SettingsPage-DdN_brUU.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"SettingsPage-DdN_brUU.js","sources":["../../admin/src/pages/SettingsPage/init.ts","../../admin/src/pages/SettingsPage/reducer.ts","../../admin/src/pages/SettingsPage/SettingsPage.tsx"],"sourcesContent":["import type { InitialState } from './reducer';\n\nexport const init = (initialState: InitialState) => {\n return initialState;\n};\n","import { produce } from 'immer';\nimport set from 'lodash/set';\n\nexport type InitialState = {\n initialData: {\n responsiveDimensions?: boolean;\n sizeOptimization?: boolean;\n autoOrientation?: boolean;\n videoPreview?: boolean;\n } | null;\n modifiedData: {\n responsiveDimensions?: boolean;\n sizeOptimization?: boolean;\n autoOrientation?: boolean;\n videoPreview?: boolean;\n } | null;\n};\n\ninterface ActionGetDataSucceeded {\n type: 'GET_DATA_SUCCEEDED';\n data: InitialState['initialData'];\n}\n\ninterface ActionOnChange {\n type: 'ON_CHANGE';\n keys: keyof NonNullable<InitialState['initialData']>;\n value: boolean;\n}\n\nexport type Action = ActionGetDataSucceeded | ActionOnChange;\n\nconst initialState: 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: InitialState, action: Action) =>\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 { initialState, reducer };\n","// TODO: find a better naming convention for the file that was an index file before\nimport * as React from 'react';\n\nimport { Page, useNotification, useFetchClient, Layouts } from '@strapi/admin/strapi-admin';\nimport { Box, Button, Flex, Grid, Toggle, Typography, Field } 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 { UpdateSettings } from '../../../../shared/contracts/settings';\nimport { PERMISSIONS } from '../../constants';\nimport { getTrad } from '../../utils';\n\nimport { init } from './init';\nimport { initialState, reducer } from './reducer';\n\nimport type { 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] = React.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: isSubmitting } = useMutation<\n UpdateSettings.Response['data'],\n UpdateSettings.Response['error'],\n UpdateSettings.Request['body']\n >(\n async (body) => {\n const { data } = await put('/upload/settings', body);\n\n return data;\n },\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\n const handleSubmit = async (e: React.FormEvent<HTMLFormElement>) => {\n e.preventDefault();\n\n if (isSaveButtonDisabled) {\n return;\n }\n\n await mutateAsync(modifiedData!);\n };\n\n const handleChange = ({\n target: { name, value },\n }: {\n target: { name: keyof NonNullable<InitialState['initialData']>; value: boolean };\n }) => {\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={isSubmitting}\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.Root gap={6}>\n <Grid.Item col={6} s={12} direction=\"column\" alignItems=\"stretch\">\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 </Grid.Item>\n <Grid.Item col={6} s={12} direction=\"column\" alignItems=\"stretch\">\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 </Grid.Item>\n <Grid.Item col={6} s={12} direction=\"column\" alignItems=\"stretch\">\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 </Grid.Item>\n </Grid.Root>\n </Flex>\n </Box>\n </Flex>\n </Layouts.Root>\n </Layouts.Content>\n </form>\n </Page.Main>\n );\n};\n\nexport const ProtectedSettingsPage = () => (\n <Page.Protect permissions={PERMISSIONS.settings}>\n <SettingsPage />\n </Page.Protect>\n);\n"],"names":["initialState","produce","set","useIntl","useNotification","useFetchClient","React","useQuery","data","isEqual","useMutation","jsx","Page","jsxs","getTrad","Layouts","Button","Check","Flex","Box","Typography","Grid","Field","Toggle","PERMISSIONS"],"mappings":"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"}
|