@strapi/content-manager 0.0.0-experimental.36632203b17974c18103c138ffbef53a82e448c3 → 0.0.0-experimental.382d4503a015dbc8e8850b92e67c203a76d9dfdb
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/_chunks/CardDragPreview-C0QyJgRA.js.map +1 -1
- package/dist/_chunks/CardDragPreview-DOxamsuj.mjs.map +1 -1
- package/dist/_chunks/{ComponentConfigurationPage-DhwMhiRn.mjs → ComponentConfigurationPage-D4H-v0et.mjs} +3 -3
- package/dist/_chunks/{ComponentConfigurationPage-DhwMhiRn.mjs.map → ComponentConfigurationPage-D4H-v0et.mjs.map} +1 -1
- package/dist/_chunks/{ComponentConfigurationPage-Br8hp2Xt.js → ComponentConfigurationPage-DdkVGfXC.js} +4 -5
- package/dist/_chunks/{ComponentConfigurationPage-Br8hp2Xt.js.map → ComponentConfigurationPage-DdkVGfXC.js.map} +1 -1
- package/dist/_chunks/{ComponentIcon-BXdiCGQp.js → ComponentIcon-CRbtQEUV.js} +2 -3
- package/dist/_chunks/{ComponentIcon-BXdiCGQp.js.map → ComponentIcon-CRbtQEUV.js.map} +1 -1
- package/dist/_chunks/ComponentIcon-u4bIXTFY.mjs.map +1 -1
- package/dist/_chunks/{EditConfigurationPage-CWao3CZ3.mjs → EditConfigurationPage-D1nvB7Br.mjs} +3 -3
- package/dist/_chunks/{EditConfigurationPage-CWao3CZ3.mjs.map → EditConfigurationPage-D1nvB7Br.mjs.map} +1 -1
- package/dist/_chunks/{EditConfigurationPage-BG7rpPjL.js → EditConfigurationPage-LYEvR4fW.js} +4 -5
- package/dist/_chunks/{EditConfigurationPage-BG7rpPjL.js.map → EditConfigurationPage-LYEvR4fW.js.map} +1 -1
- package/dist/_chunks/{EditViewPage-hiwZg61J.mjs → EditViewPage-Bcnff6Vd.mjs} +19 -58
- package/dist/_chunks/EditViewPage-Bcnff6Vd.mjs.map +1 -0
- package/dist/_chunks/{EditViewPage-BUtpHsMz.js → EditViewPage-DqelJ9UK.js} +22 -62
- package/dist/_chunks/EditViewPage-DqelJ9UK.js.map +1 -0
- package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs.map +1 -1
- package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js.map +1 -1
- package/dist/_chunks/{Form-v5pkY-X_.js → Form-CnHfBeiB.js} +5 -6
- package/dist/_chunks/{Form-v5pkY-X_.js.map → Form-CnHfBeiB.js.map} +1 -1
- package/dist/_chunks/{Form-DwJovCha.mjs → Form-CzPCJi3B.mjs} +3 -3
- package/dist/_chunks/{Form-DwJovCha.mjs.map → Form-CzPCJi3B.mjs.map} +1 -1
- package/dist/_chunks/{History-B9uJsxZl.mjs → History-CcmSn3Mj.mjs} +37 -60
- package/dist/_chunks/History-CcmSn3Mj.mjs.map +1 -0
- package/dist/_chunks/{History-40apIShV.js → History-zArjENzj.js} +48 -72
- package/dist/_chunks/History-zArjENzj.js.map +1 -0
- package/dist/_chunks/{Field-DEdug-Ll.js → Input-CDHKQd7o.js} +1294 -1271
- package/dist/_chunks/Input-CDHKQd7o.js.map +1 -0
- package/dist/_chunks/{Field-BQQLwyUs.mjs → Input-aV8SSoTa.mjs} +1333 -1310
- package/dist/_chunks/Input-aV8SSoTa.mjs.map +1 -0
- package/dist/_chunks/{ListConfigurationPage-CA4oi4Hj.mjs → ListConfigurationPage-BPvzENJJ.mjs} +6 -5
- package/dist/_chunks/ListConfigurationPage-BPvzENJJ.mjs.map +1 -0
- package/dist/_chunks/{ListConfigurationPage-DAGbWDIL.js → ListConfigurationPage-ByZAO_9H.js} +6 -6
- package/dist/_chunks/ListConfigurationPage-ByZAO_9H.js.map +1 -0
- package/dist/_chunks/{ListViewPage-CjaHQ2_V.js → ListViewPage-BVKBeQAA.js} +74 -60
- package/dist/_chunks/ListViewPage-BVKBeQAA.js.map +1 -0
- package/dist/_chunks/{ListViewPage-Ca8F1NL-.mjs → ListViewPage-HljQVnFH.mjs} +68 -53
- package/dist/_chunks/ListViewPage-HljQVnFH.mjs.map +1 -0
- package/dist/_chunks/{NoContentTypePage-CGxqLI8j.js → NoContentTypePage-BV5zfDxr.js} +2 -2
- package/dist/_chunks/{NoContentTypePage-CGxqLI8j.js.map → NoContentTypePage-BV5zfDxr.js.map} +1 -1
- package/dist/_chunks/{NoContentTypePage-CwfnU-aN.mjs → NoContentTypePage-BfHaSM-K.mjs} +2 -2
- package/dist/_chunks/{NoContentTypePage-CwfnU-aN.mjs.map → NoContentTypePage-BfHaSM-K.mjs.map} +1 -1
- package/dist/_chunks/{NoPermissionsPage-iPk2lFR6.mjs → NoPermissionsPage-D6ze2nQL.mjs} +2 -2
- package/dist/_chunks/{NoPermissionsPage-iPk2lFR6.mjs.map → NoPermissionsPage-D6ze2nQL.mjs.map} +1 -1
- package/dist/_chunks/{NoPermissionsPage-CY3_QduF.js → NoPermissionsPage-vdNpc6jb.js} +2 -2
- package/dist/_chunks/{NoPermissionsPage-CY3_QduF.js.map → NoPermissionsPage-vdNpc6jb.js.map} +1 -1
- package/dist/_chunks/{Preview-V8XOfrQf.js → Preview-DEHdENT1.js} +95 -76
- package/dist/_chunks/Preview-DEHdENT1.js.map +1 -0
- package/dist/_chunks/{Preview-DRJhcaIO.mjs → Preview-vfWOtPG5.mjs} +97 -77
- package/dist/_chunks/Preview-vfWOtPG5.mjs.map +1 -0
- package/dist/_chunks/{Relations-DGWa9W2j.mjs → Relations-B7_hbF0w.mjs} +9 -10
- package/dist/_chunks/Relations-B7_hbF0w.mjs.map +1 -0
- package/dist/_chunks/{Relations-CGerEwji.js → Relations-DcoOBejP.js} +10 -12
- package/dist/_chunks/Relations-DcoOBejP.js.map +1 -0
- package/dist/_chunks/{en-CHOp_xJv.js → en-BR48D_RH.js} +13 -3
- package/dist/_chunks/{en-CHOp_xJv.js.map → en-BR48D_RH.js.map} +1 -1
- package/dist/_chunks/{en-D_BMf0hT.mjs → en-D65uIF6Y.mjs} +13 -3
- package/dist/_chunks/{en-D_BMf0hT.mjs.map → en-D65uIF6Y.mjs.map} +1 -1
- package/dist/_chunks/{fr-B2Kyv8Z9.js → fr-C43IbhA_.js} +4 -1
- package/dist/_chunks/{fr-B2Kyv8Z9.js.map → fr-C43IbhA_.js.map} +1 -1
- package/dist/_chunks/{fr--pg5jUbt.mjs → fr-DBseuRuB.mjs} +4 -1
- package/dist/_chunks/{fr--pg5jUbt.mjs.map → fr-DBseuRuB.mjs.map} +1 -1
- package/dist/_chunks/hooks-BAaaKPS_.js.map +1 -1
- package/dist/_chunks/{index-tN1hpOMN.js → index-CxLSGwnk.js} +541 -248
- package/dist/_chunks/index-CxLSGwnk.js.map +1 -0
- package/dist/_chunks/{index-V8MWkDSd.mjs → index-EH8ZtHd5.mjs} +559 -265
- package/dist/_chunks/index-EH8ZtHd5.mjs.map +1 -0
- package/dist/_chunks/{layout-Bue_C6ui.mjs → layout-CxDMdJ13.mjs} +4 -4
- package/dist/_chunks/{layout-Bue_C6ui.mjs.map → layout-CxDMdJ13.mjs.map} +1 -1
- package/dist/_chunks/{layout-BzX903CL.js → layout-DSeUTfMv.js} +5 -6
- package/dist/_chunks/{layout-BzX903CL.js.map → layout-DSeUTfMv.js.map} +1 -1
- package/dist/_chunks/objects-BcXOv6_9.js.map +1 -1
- package/dist/_chunks/objects-D6yBsdmx.mjs.map +1 -1
- package/dist/_chunks/{relations-C8eyDiIO.mjs → relations-B8_Uu38Q.mjs} +17 -3
- package/dist/_chunks/relations-B8_Uu38Q.mjs.map +1 -0
- package/dist/_chunks/{relations-C4HcWYYJ.js → relations-S5nNKdN3.js} +16 -2
- package/dist/_chunks/relations-S5nNKdN3.js.map +1 -0
- package/dist/_chunks/{useDragAndDrop-J0TUUbR6.js → useDragAndDrop-BMtgCYzL.js} +5 -9
- package/dist/_chunks/{useDragAndDrop-J0TUUbR6.js.map → useDragAndDrop-BMtgCYzL.js.map} +1 -1
- package/dist/_chunks/{useDragAndDrop-DdHgKsqq.mjs → useDragAndDrop-DJ6jqvZN.mjs} +4 -7
- package/dist/_chunks/{useDragAndDrop-DdHgKsqq.mjs.map → useDragAndDrop-DJ6jqvZN.mjs.map} +1 -1
- package/dist/_chunks/{useDebounce-CtcjDB3L.js → usePrev-B9w_-eYc.js} +1 -14
- package/dist/_chunks/usePrev-B9w_-eYc.js.map +1 -0
- package/dist/_chunks/usePrev-DH6iah0A.mjs +16 -0
- package/dist/_chunks/usePrev-DH6iah0A.mjs.map +1 -0
- package/dist/admin/index.js +2 -1
- package/dist/admin/index.js.map +1 -1
- package/dist/admin/index.mjs +6 -5
- package/dist/admin/src/content-manager.d.ts +3 -2
- package/dist/admin/src/exports.d.ts +1 -0
- package/dist/admin/src/history/services/historyVersion.d.ts +1 -1
- package/dist/admin/src/hooks/useDocument.d.ts +19 -2
- package/dist/admin/src/pages/EditView/components/DocumentActions.d.ts +1 -1
- package/dist/admin/src/pages/EditView/components/DocumentStatus.d.ts +3 -3
- package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/Code.d.ts +7 -0
- package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/Blocks/utils/prismLanguages.d.ts +49 -0
- package/dist/admin/src/pages/EditView/components/FormInputs/BlocksInput/utils/constants.d.ts +1 -0
- package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.d.ts +4 -1
- package/dist/admin/src/pages/EditView/components/FormInputs/DynamicZone/Field.d.ts +4 -1
- package/dist/admin/src/pages/EditView/components/FormLayout.d.ts +27 -0
- package/dist/admin/src/pages/EditView/utils/data.d.ts +1 -0
- package/dist/admin/src/preview/components/PreviewContent.d.ts +2 -0
- package/dist/admin/src/preview/pages/Preview.d.ts +1 -1
- package/dist/admin/src/preview/services/preview.d.ts +1 -1
- package/dist/admin/src/router.d.ts +1 -1
- package/dist/admin/src/services/api.d.ts +1 -1
- package/dist/admin/src/services/components.d.ts +2 -2
- package/dist/admin/src/services/contentTypes.d.ts +3 -3
- package/dist/admin/src/services/documents.d.ts +16 -19
- package/dist/admin/src/services/init.d.ts +1 -1
- package/dist/admin/src/services/relations.d.ts +2 -2
- package/dist/admin/src/services/uid.d.ts +3 -3
- package/dist/server/index.js +230 -187
- package/dist/server/index.js.map +1 -1
- package/dist/server/index.mjs +231 -187
- package/dist/server/index.mjs.map +1 -1
- package/dist/server/src/controllers/utils/metadata.d.ts +1 -0
- package/dist/server/src/controllers/utils/metadata.d.ts.map +1 -1
- package/dist/server/src/history/controllers/history-version.d.ts +1 -1
- package/dist/server/src/history/controllers/history-version.d.ts.map +1 -1
- package/dist/server/src/history/services/history.d.ts +3 -3
- package/dist/server/src/history/services/history.d.ts.map +1 -1
- package/dist/server/src/history/services/utils.d.ts +6 -10
- package/dist/server/src/history/services/utils.d.ts.map +1 -1
- package/dist/server/src/index.d.ts +3 -2
- package/dist/server/src/index.d.ts.map +1 -1
- package/dist/server/src/preview/controllers/validation/preview.d.ts.map +1 -1
- package/dist/server/src/preview/index.d.ts.map +1 -1
- package/dist/server/src/preview/services/index.d.ts +1 -0
- package/dist/server/src/preview/services/index.d.ts.map +1 -1
- package/dist/server/src/preview/services/preview-config.d.ts +2 -0
- package/dist/server/src/preview/services/preview-config.d.ts.map +1 -1
- package/dist/server/src/preview/utils.d.ts +1 -0
- package/dist/server/src/preview/utils.d.ts.map +1 -1
- package/dist/server/src/register.d.ts.map +1 -1
- package/dist/server/src/services/document-manager.d.ts.map +1 -1
- package/dist/server/src/services/document-metadata.d.ts +4 -2
- package/dist/server/src/services/document-metadata.d.ts.map +1 -1
- package/dist/server/src/services/index.d.ts +3 -2
- package/dist/server/src/services/index.d.ts.map +1 -1
- package/dist/server/src/services/utils/configuration/index.d.ts +2 -2
- package/dist/server/src/services/utils/configuration/layouts.d.ts +2 -2
- package/dist/server/src/services/utils/populate.d.ts +2 -2
- package/dist/server/src/services/utils/populate.d.ts.map +1 -1
- package/package.json +12 -11
- package/dist/_chunks/EditViewPage-BUtpHsMz.js.map +0 -1
- package/dist/_chunks/EditViewPage-hiwZg61J.mjs.map +0 -1
- package/dist/_chunks/Field-BQQLwyUs.mjs.map +0 -1
- package/dist/_chunks/Field-DEdug-Ll.js.map +0 -1
- package/dist/_chunks/History-40apIShV.js.map +0 -1
- package/dist/_chunks/History-B9uJsxZl.mjs.map +0 -1
- package/dist/_chunks/ListConfigurationPage-CA4oi4Hj.mjs.map +0 -1
- package/dist/_chunks/ListConfigurationPage-DAGbWDIL.js.map +0 -1
- package/dist/_chunks/ListViewPage-Ca8F1NL-.mjs.map +0 -1
- package/dist/_chunks/ListViewPage-CjaHQ2_V.js.map +0 -1
- package/dist/_chunks/Preview-DRJhcaIO.mjs.map +0 -1
- package/dist/_chunks/Preview-V8XOfrQf.js.map +0 -1
- package/dist/_chunks/Relations-CGerEwji.js.map +0 -1
- package/dist/_chunks/Relations-DGWa9W2j.mjs.map +0 -1
- package/dist/_chunks/index-V8MWkDSd.mjs.map +0 -1
- package/dist/_chunks/index-tN1hpOMN.js.map +0 -1
- package/dist/_chunks/relations-C4HcWYYJ.js.map +0 -1
- package/dist/_chunks/relations-C8eyDiIO.mjs.map +0 -1
- package/dist/_chunks/useDebounce-CtcjDB3L.js.map +0 -1
- package/dist/_chunks/useDebounce-DmuSJIF3.mjs +0 -29
- package/dist/_chunks/useDebounce-DmuSJIF3.mjs.map +0 -1
- package/dist/admin/src/preview/constants.d.ts +0 -1
- package/dist/server/src/preview/constants.d.ts +0 -2
- package/dist/server/src/preview/constants.d.ts.map +0 -1
@@ -1,26 +1,34 @@
|
|
1
|
-
import { More, Cross, WarningCircle, ListPlus, Pencil, Trash, Check,
|
1
|
+
import { More, Cross, WarningCircle, ListPlus, Pencil, Trash, Check, CheckCircle, ArrowsCounterClockwise, CrossCircle, ChevronRight, Duplicate, ClockCounterClockwise, Feather } from "@strapi/icons";
|
2
2
|
import { jsx, Fragment, jsxs } from "react/jsx-runtime";
|
3
3
|
import { useStrapiApp, createContext, useQueryParams, useAuth, useRBAC, Page, adminApi, translatedErrors, useNotification, useAPIErrorHandler, getYupValidationErrors, useForm, useTracking, useGuidedTour, BackButton, DescriptionComponentRenderer, useTable, Table } from "@strapi/admin/strapi-admin";
|
4
4
|
import * as React from "react";
|
5
5
|
import { lazy } from "react";
|
6
|
-
import {
|
6
|
+
import { Menu, Button, VisuallyHidden, Flex, Dialog, Modal, Typography, Radio, Status, Box, SingleSelect, SingleSelectOption, IconButton, RawTable, Loader, Tbody, Tr, Td, Tooltip, LinkButton } from "@strapi/design-system";
|
7
7
|
import mapValues from "lodash/fp/mapValues";
|
8
8
|
import { useIntl } from "react-intl";
|
9
9
|
import { useParams, useNavigate, Navigate, useMatch, useLocation, Link, NavLink } from "react-router-dom";
|
10
|
+
import { styled } from "styled-components";
|
10
11
|
import * as yup from "yup";
|
11
12
|
import { ValidationError } from "yup";
|
13
|
+
import { generateNKeysBetween } from "fractional-indexing";
|
12
14
|
import pipe from "lodash/fp/pipe";
|
13
|
-
import { intervalToDuration, isPast } from "date-fns";
|
14
|
-
import { styled } from "styled-components";
|
15
15
|
import { stringify } from "qs";
|
16
|
+
import { intervalToDuration, isPast } from "date-fns";
|
16
17
|
import { createSlice, combineReducers } from "@reduxjs/toolkit";
|
17
|
-
const __variableDynamicImportRuntimeHelper = (glob, path) => {
|
18
|
+
const __variableDynamicImportRuntimeHelper = (glob, path, segs) => {
|
18
19
|
const v = glob[path];
|
19
20
|
if (v) {
|
20
21
|
return typeof v === "function" ? v() : Promise.resolve(v);
|
21
22
|
}
|
22
23
|
return new Promise((_, reject) => {
|
23
|
-
(typeof queueMicrotask === "function" ? queueMicrotask : setTimeout)(
|
24
|
+
(typeof queueMicrotask === "function" ? queueMicrotask : setTimeout)(
|
25
|
+
reject.bind(
|
26
|
+
null,
|
27
|
+
new Error(
|
28
|
+
"Unknown variable dynamic import: " + path + (path.split("/").length !== segs ? ". Note that variables only represent file names one level deep." : "")
|
29
|
+
)
|
30
|
+
)
|
31
|
+
);
|
24
32
|
});
|
25
33
|
};
|
26
34
|
const PLUGIN_ID = "content-manager";
|
@@ -159,6 +167,113 @@ const extractAndDedupeFields = (permissions = []) => permissions.flatMap((permis
|
|
159
167
|
(field, index2, arr) => arr.indexOf(field) === index2 && typeof field === "string"
|
160
168
|
);
|
161
169
|
const removeNumericalStrings = (arr) => arr.filter((item) => isNaN(Number(item)));
|
170
|
+
const BLOCK_LIST_ATTRIBUTE_KEYS = ["__component", "__temp_key__"];
|
171
|
+
const traverseData = (predicate, transform) => (schema, components = {}) => (data = {}) => {
|
172
|
+
const traverse = (datum, attributes) => {
|
173
|
+
return Object.entries(datum).reduce((acc, [key, value]) => {
|
174
|
+
const attribute = attributes[key];
|
175
|
+
if (BLOCK_LIST_ATTRIBUTE_KEYS.includes(key) || value === null || value === void 0) {
|
176
|
+
acc[key] = value;
|
177
|
+
return acc;
|
178
|
+
}
|
179
|
+
if (attribute.type === "component") {
|
180
|
+
if (attribute.repeatable) {
|
181
|
+
const componentValue = predicate(attribute, value) ? transform(value, attribute) : value;
|
182
|
+
acc[key] = componentValue.map(
|
183
|
+
(componentData) => traverse(componentData, components[attribute.component]?.attributes ?? {})
|
184
|
+
);
|
185
|
+
} else {
|
186
|
+
const componentValue = predicate(attribute, value) ? transform(value, attribute) : value;
|
187
|
+
acc[key] = traverse(componentValue, components[attribute.component]?.attributes ?? {});
|
188
|
+
}
|
189
|
+
} else if (attribute.type === "dynamiczone") {
|
190
|
+
const dynamicZoneValue = predicate(attribute, value) ? transform(value, attribute) : value;
|
191
|
+
acc[key] = dynamicZoneValue.map(
|
192
|
+
(componentData) => traverse(componentData, components[componentData.__component]?.attributes ?? {})
|
193
|
+
);
|
194
|
+
} else if (predicate(attribute, value)) {
|
195
|
+
acc[key] = transform(value, attribute);
|
196
|
+
} else {
|
197
|
+
acc[key] = value;
|
198
|
+
}
|
199
|
+
return acc;
|
200
|
+
}, {});
|
201
|
+
};
|
202
|
+
return traverse(data, schema.attributes);
|
203
|
+
};
|
204
|
+
const removeProhibitedFields = (prohibitedFields) => traverseData(
|
205
|
+
(attribute) => prohibitedFields.includes(attribute.type),
|
206
|
+
() => ""
|
207
|
+
);
|
208
|
+
const prepareRelations = traverseData(
|
209
|
+
(attribute) => attribute.type === "relation",
|
210
|
+
() => ({
|
211
|
+
connect: [],
|
212
|
+
disconnect: []
|
213
|
+
})
|
214
|
+
);
|
215
|
+
const prepareTempKeys = traverseData(
|
216
|
+
(attribute) => attribute.type === "component" && attribute.repeatable || attribute.type === "dynamiczone",
|
217
|
+
(data) => {
|
218
|
+
if (Array.isArray(data) && data.length > 0) {
|
219
|
+
const keys = generateNKeysBetween(void 0, void 0, data.length);
|
220
|
+
return data.map((datum, index2) => ({
|
221
|
+
...datum,
|
222
|
+
__temp_key__: keys[index2]
|
223
|
+
}));
|
224
|
+
}
|
225
|
+
return data;
|
226
|
+
}
|
227
|
+
);
|
228
|
+
const removeFieldsThatDontExistOnSchema = (schema) => (data) => {
|
229
|
+
const schemaKeys = Object.keys(schema.attributes);
|
230
|
+
const dataKeys = Object.keys(data);
|
231
|
+
const keysToRemove = dataKeys.filter((key) => !schemaKeys.includes(key));
|
232
|
+
const revisedData = [...keysToRemove, ...DOCUMENT_META_FIELDS].reduce((acc, key) => {
|
233
|
+
delete acc[key];
|
234
|
+
return acc;
|
235
|
+
}, structuredClone(data));
|
236
|
+
return revisedData;
|
237
|
+
};
|
238
|
+
const removeNullValues = (data) => {
|
239
|
+
return Object.entries(data).reduce((acc, [key, value]) => {
|
240
|
+
if (value === null) {
|
241
|
+
return acc;
|
242
|
+
}
|
243
|
+
acc[key] = value;
|
244
|
+
return acc;
|
245
|
+
}, {});
|
246
|
+
};
|
247
|
+
const transformDocument = (schema, components = {}) => (document) => {
|
248
|
+
const transformations = pipe(
|
249
|
+
removeFieldsThatDontExistOnSchema(schema),
|
250
|
+
removeProhibitedFields(["password"])(schema, components),
|
251
|
+
removeNullValues,
|
252
|
+
prepareRelations(schema, components),
|
253
|
+
prepareTempKeys(schema, components)
|
254
|
+
);
|
255
|
+
return transformations(document);
|
256
|
+
};
|
257
|
+
const createDefaultForm = (contentType, components = {}) => {
|
258
|
+
const traverseSchema = (attributes) => {
|
259
|
+
return Object.entries(attributes).reduce((acc, [key, attribute]) => {
|
260
|
+
if ("default" in attribute) {
|
261
|
+
acc[key] = attribute.default;
|
262
|
+
} else if (attribute.type === "component" && attribute.required) {
|
263
|
+
const defaultComponentForm = traverseSchema(components[attribute.component].attributes);
|
264
|
+
if (attribute.repeatable) {
|
265
|
+
acc[key] = attribute.min ? [...Array(attribute.min).fill(defaultComponentForm)] : [];
|
266
|
+
} else {
|
267
|
+
acc[key] = defaultComponentForm;
|
268
|
+
}
|
269
|
+
} else if (attribute.type === "dynamiczone" && attribute.required) {
|
270
|
+
acc[key] = [];
|
271
|
+
}
|
272
|
+
return acc;
|
273
|
+
}, {});
|
274
|
+
};
|
275
|
+
return traverseSchema(contentType.attributes);
|
276
|
+
};
|
162
277
|
const contentManagerApi = adminApi.enhanceEndpoints({
|
163
278
|
addTagTypes: [
|
164
279
|
"ComponentConfiguration",
|
@@ -168,7 +283,8 @@ const contentManagerApi = adminApi.enhanceEndpoints({
|
|
168
283
|
"InitialData",
|
169
284
|
"HistoryVersion",
|
170
285
|
"Relations",
|
171
|
-
"UidAvailability"
|
286
|
+
"UidAvailability",
|
287
|
+
"RecentDocumentList"
|
172
288
|
]
|
173
289
|
});
|
174
290
|
const documentApi = contentManagerApi.injectEndpoints({
|
@@ -186,7 +302,7 @@ const documentApi = contentManagerApi.injectEndpoints({
|
|
186
302
|
if (error) {
|
187
303
|
return [];
|
188
304
|
}
|
189
|
-
return [{ type: "Document", id: `${model}_LIST` }];
|
305
|
+
return [{ type: "Document", id: `${model}_LIST` }, "RecentDocumentList"];
|
190
306
|
}
|
191
307
|
}),
|
192
308
|
cloneDocument: builder.mutation({
|
@@ -200,7 +316,8 @@ const documentApi = contentManagerApi.injectEndpoints({
|
|
200
316
|
}),
|
201
317
|
invalidatesTags: (_result, _error, { model }) => [
|
202
318
|
{ type: "Document", id: `${model}_LIST` },
|
203
|
-
{ type: "UidAvailability", id: model }
|
319
|
+
{ type: "UidAvailability", id: model },
|
320
|
+
"RecentDocumentList"
|
204
321
|
]
|
205
322
|
}),
|
206
323
|
/**
|
@@ -219,8 +336,21 @@ const documentApi = contentManagerApi.injectEndpoints({
|
|
219
336
|
invalidatesTags: (result, _error, { model }) => [
|
220
337
|
{ type: "Document", id: `${model}_LIST` },
|
221
338
|
"Relations",
|
222
|
-
{ type: "UidAvailability", id: model }
|
223
|
-
|
339
|
+
{ type: "UidAvailability", id: model },
|
340
|
+
"RecentDocumentList"
|
341
|
+
],
|
342
|
+
transformResponse: (response, meta, arg) => {
|
343
|
+
if (!("data" in response) && arg.model === "plugin::users-permissions.user") {
|
344
|
+
return {
|
345
|
+
data: response,
|
346
|
+
meta: {
|
347
|
+
availableStatus: [],
|
348
|
+
availableLocales: []
|
349
|
+
}
|
350
|
+
};
|
351
|
+
}
|
352
|
+
return response;
|
353
|
+
}
|
224
354
|
}),
|
225
355
|
deleteDocument: builder.mutation({
|
226
356
|
query: ({ collectionType, model, documentId, params }) => ({
|
@@ -231,7 +361,8 @@ const documentApi = contentManagerApi.injectEndpoints({
|
|
231
361
|
}
|
232
362
|
}),
|
233
363
|
invalidatesTags: (_result, _error, { collectionType, model }) => [
|
234
|
-
{ type: "Document", id: collectionType !== SINGLE_TYPES ? `${model}_LIST` : model }
|
364
|
+
{ type: "Document", id: collectionType !== SINGLE_TYPES ? `${model}_LIST` : model },
|
365
|
+
"RecentDocumentList"
|
235
366
|
]
|
236
367
|
}),
|
237
368
|
deleteManyDocuments: builder.mutation({
|
@@ -243,7 +374,10 @@ const documentApi = contentManagerApi.injectEndpoints({
|
|
243
374
|
params
|
244
375
|
}
|
245
376
|
}),
|
246
|
-
invalidatesTags: (_res, _error, { model }) => [
|
377
|
+
invalidatesTags: (_res, _error, { model }) => [
|
378
|
+
{ type: "Document", id: `${model}_LIST` },
|
379
|
+
"RecentDocumentList"
|
380
|
+
]
|
247
381
|
}),
|
248
382
|
discardDocument: builder.mutation({
|
249
383
|
query: ({ collectionType, model, documentId, params }) => ({
|
@@ -261,7 +395,8 @@ const documentApi = contentManagerApi.injectEndpoints({
|
|
261
395
|
},
|
262
396
|
{ type: "Document", id: `${model}_LIST` },
|
263
397
|
"Relations",
|
264
|
-
{ type: "UidAvailability", id: model }
|
398
|
+
{ type: "UidAvailability", id: model },
|
399
|
+
"RecentDocumentList"
|
265
400
|
];
|
266
401
|
}
|
267
402
|
}),
|
@@ -274,7 +409,7 @@ const documentApi = contentManagerApi.injectEndpoints({
|
|
274
409
|
url: `/content-manager/collection-types/${model}`,
|
275
410
|
method: "GET",
|
276
411
|
config: {
|
277
|
-
params
|
412
|
+
params: stringify(params, { encode: true })
|
278
413
|
}
|
279
414
|
}),
|
280
415
|
providesTags: (result, _error, arg) => {
|
@@ -356,7 +491,8 @@ const documentApi = contentManagerApi.injectEndpoints({
|
|
356
491
|
id: collectionType !== SINGLE_TYPES ? `${model}_${documentId}` : model
|
357
492
|
},
|
358
493
|
{ type: "Document", id: `${model}_LIST` },
|
359
|
-
"Relations"
|
494
|
+
"Relations",
|
495
|
+
"RecentDocumentList"
|
360
496
|
];
|
361
497
|
}
|
362
498
|
}),
|
@@ -387,7 +523,9 @@ const documentApi = contentManagerApi.injectEndpoints({
|
|
387
523
|
id: collectionType !== SINGLE_TYPES ? `${model}_${documentId}` : model
|
388
524
|
},
|
389
525
|
"Relations",
|
390
|
-
{ type: "UidAvailability", id: model }
|
526
|
+
{ type: "UidAvailability", id: model },
|
527
|
+
"RecentDocumentList",
|
528
|
+
"RecentDocumentList"
|
391
529
|
];
|
392
530
|
},
|
393
531
|
async onQueryStarted({ data, ...patch }, { dispatch, queryFulfilled }) {
|
@@ -417,7 +555,8 @@ const documentApi = contentManagerApi.injectEndpoints({
|
|
417
555
|
{
|
418
556
|
type: "Document",
|
419
557
|
id: collectionType !== SINGLE_TYPES ? `${model}_${documentId}` : model
|
420
|
-
}
|
558
|
+
},
|
559
|
+
"RecentDocumentList"
|
421
560
|
];
|
422
561
|
}
|
423
562
|
}),
|
@@ -430,7 +569,10 @@ const documentApi = contentManagerApi.injectEndpoints({
|
|
430
569
|
params
|
431
570
|
}
|
432
571
|
}),
|
433
|
-
invalidatesTags: (_res, _error, { model, documentIds }) =>
|
572
|
+
invalidatesTags: (_res, _error, { model, documentIds }) => [
|
573
|
+
...documentIds.map((id) => ({ type: "Document", id: `${model}_${id}` })),
|
574
|
+
"RecentDocumentList"
|
575
|
+
]
|
434
576
|
})
|
435
577
|
})
|
436
578
|
});
|
@@ -453,8 +595,7 @@ const {
|
|
453
595
|
useUnpublishManyDocumentsMutation
|
454
596
|
} = documentApi;
|
455
597
|
const buildValidParams = (query) => {
|
456
|
-
if (!query)
|
457
|
-
return query;
|
598
|
+
if (!query) return query;
|
458
599
|
const { plugins: _, ...validQueryParams } = {
|
459
600
|
...query,
|
460
601
|
...Object.values(query?.plugins ?? {}).reduce(
|
@@ -462,9 +603,6 @@ const buildValidParams = (query) => {
|
|
462
603
|
{}
|
463
604
|
)
|
464
605
|
};
|
465
|
-
if ("_q" in validQueryParams) {
|
466
|
-
validQueryParams._q = encodeURIComponent(validQueryParams._q);
|
467
|
-
}
|
468
606
|
return validQueryParams;
|
469
607
|
};
|
470
608
|
const isBaseQueryError = (error) => {
|
@@ -1105,6 +1243,7 @@ const convertListLayoutToFieldLayouts = (columns, attributes = {}, metadatas, co
|
|
1105
1243
|
const useDocument = (args, opts) => {
|
1106
1244
|
const { toggleNotification } = useNotification();
|
1107
1245
|
const { _unstableFormatAPIError: formatAPIError } = useAPIErrorHandler();
|
1246
|
+
const { formatMessage } = useIntl();
|
1108
1247
|
const {
|
1109
1248
|
currentData: data,
|
1110
1249
|
isLoading: isLoadingDocument,
|
@@ -1114,12 +1253,27 @@ const useDocument = (args, opts) => {
|
|
1114
1253
|
...opts,
|
1115
1254
|
skip: !args.documentId && args.collectionType !== SINGLE_TYPES || opts?.skip
|
1116
1255
|
});
|
1256
|
+
const document = data?.data;
|
1257
|
+
const meta = data?.meta;
|
1117
1258
|
const {
|
1118
1259
|
components,
|
1119
1260
|
schema,
|
1120
1261
|
schemas,
|
1121
1262
|
isLoading: isLoadingSchema
|
1122
1263
|
} = useContentTypeSchema(args.model);
|
1264
|
+
const isSingleType = schema?.kind === "singleType";
|
1265
|
+
const getTitle = (mainField) => {
|
1266
|
+
if (mainField !== "id" && document?.[mainField]) {
|
1267
|
+
return document[mainField];
|
1268
|
+
}
|
1269
|
+
if (isSingleType && schema?.info.displayName) {
|
1270
|
+
return schema.info.displayName;
|
1271
|
+
}
|
1272
|
+
return formatMessage({
|
1273
|
+
id: "content-manager.containers.untitled",
|
1274
|
+
defaultMessage: "Untitled"
|
1275
|
+
});
|
1276
|
+
};
|
1123
1277
|
React.useEffect(() => {
|
1124
1278
|
if (error) {
|
1125
1279
|
toggleNotification({
|
@@ -1135,14 +1289,14 @@ const useDocument = (args, opts) => {
|
|
1135
1289
|
return createYupSchema(schema.attributes, components);
|
1136
1290
|
}, [schema, components]);
|
1137
1291
|
const validate = React.useCallback(
|
1138
|
-
(
|
1292
|
+
(document2) => {
|
1139
1293
|
if (!validationSchema) {
|
1140
1294
|
throw new Error(
|
1141
1295
|
"There is no validation schema generated, this is likely due to the schema not being loaded yet."
|
1142
1296
|
);
|
1143
1297
|
}
|
1144
1298
|
try {
|
1145
|
-
validationSchema.validateSync(
|
1299
|
+
validationSchema.validateSync(document2, { abortEarly: false, strict: true });
|
1146
1300
|
return null;
|
1147
1301
|
} catch (error2) {
|
1148
1302
|
if (error2 instanceof ValidationError) {
|
@@ -1153,17 +1307,29 @@ const useDocument = (args, opts) => {
|
|
1153
1307
|
},
|
1154
1308
|
[validationSchema]
|
1155
1309
|
);
|
1310
|
+
const getInitialFormValues = React.useCallback(
|
1311
|
+
(isCreatingDocument = false) => {
|
1312
|
+
if (!document && !isCreatingDocument && !isSingleType || !schema) {
|
1313
|
+
return void 0;
|
1314
|
+
}
|
1315
|
+
const form = document?.id ? document : createDefaultForm(schema, components);
|
1316
|
+
return transformDocument(schema, components)(form);
|
1317
|
+
},
|
1318
|
+
[document, isSingleType, schema, components]
|
1319
|
+
);
|
1156
1320
|
const isLoading = isLoadingDocument || isFetchingDocument || isLoadingSchema;
|
1157
1321
|
const hasError = !!error;
|
1158
1322
|
return {
|
1159
1323
|
components,
|
1160
|
-
document
|
1161
|
-
meta
|
1324
|
+
document,
|
1325
|
+
meta,
|
1162
1326
|
isLoading,
|
1163
1327
|
hasError,
|
1164
1328
|
schema,
|
1165
1329
|
schemas,
|
1166
|
-
validate
|
1330
|
+
validate,
|
1331
|
+
getTitle,
|
1332
|
+
getInitialFormValues
|
1167
1333
|
};
|
1168
1334
|
};
|
1169
1335
|
const useDoc = () => {
|
@@ -1664,7 +1830,7 @@ const useDocumentActions = () => {
|
|
1664
1830
|
};
|
1665
1831
|
};
|
1666
1832
|
const ProtectedHistoryPage = React.lazy(
|
1667
|
-
() => import("./History-
|
1833
|
+
() => import("./History-CcmSn3Mj.mjs").then((mod) => ({ default: mod.ProtectedHistoryPage }))
|
1668
1834
|
);
|
1669
1835
|
const routes$2 = [
|
1670
1836
|
{
|
@@ -1677,7 +1843,7 @@ const routes$2 = [
|
|
1677
1843
|
}
|
1678
1844
|
];
|
1679
1845
|
const ProtectedPreviewPage = React.lazy(
|
1680
|
-
() => import("./Preview-
|
1846
|
+
() => import("./Preview-vfWOtPG5.mjs").then((mod) => ({ default: mod.ProtectedPreviewPage }))
|
1681
1847
|
);
|
1682
1848
|
const routes$1 = [
|
1683
1849
|
{
|
@@ -1690,31 +1856,31 @@ const routes$1 = [
|
|
1690
1856
|
}
|
1691
1857
|
];
|
1692
1858
|
const ProtectedEditViewPage = lazy(
|
1693
|
-
() => import("./EditViewPage-
|
1859
|
+
() => import("./EditViewPage-Bcnff6Vd.mjs").then((mod) => ({ default: mod.ProtectedEditViewPage }))
|
1694
1860
|
);
|
1695
1861
|
const ProtectedListViewPage = lazy(
|
1696
|
-
() => import("./ListViewPage-
|
1862
|
+
() => import("./ListViewPage-HljQVnFH.mjs").then((mod) => ({ default: mod.ProtectedListViewPage }))
|
1697
1863
|
);
|
1698
1864
|
const ProtectedListConfiguration = lazy(
|
1699
|
-
() => import("./ListConfigurationPage-
|
1865
|
+
() => import("./ListConfigurationPage-BPvzENJJ.mjs").then((mod) => ({
|
1700
1866
|
default: mod.ProtectedListConfiguration
|
1701
1867
|
}))
|
1702
1868
|
);
|
1703
1869
|
const ProtectedEditConfigurationPage = lazy(
|
1704
|
-
() => import("./EditConfigurationPage-
|
1870
|
+
() => import("./EditConfigurationPage-D1nvB7Br.mjs").then((mod) => ({
|
1705
1871
|
default: mod.ProtectedEditConfigurationPage
|
1706
1872
|
}))
|
1707
1873
|
);
|
1708
1874
|
const ProtectedComponentConfigurationPage = lazy(
|
1709
|
-
() => import("./ComponentConfigurationPage-
|
1875
|
+
() => import("./ComponentConfigurationPage-D4H-v0et.mjs").then((mod) => ({
|
1710
1876
|
default: mod.ProtectedComponentConfigurationPage
|
1711
1877
|
}))
|
1712
1878
|
);
|
1713
1879
|
const NoPermissions = lazy(
|
1714
|
-
() => import("./NoPermissionsPage-
|
1880
|
+
() => import("./NoPermissionsPage-D6ze2nQL.mjs").then((mod) => ({ default: mod.NoPermissions }))
|
1715
1881
|
);
|
1716
1882
|
const NoContentType = lazy(
|
1717
|
-
() => import("./NoContentTypePage-
|
1883
|
+
() => import("./NoContentTypePage-BfHaSM-K.mjs").then((mod) => ({ default: mod.NoContentType }))
|
1718
1884
|
);
|
1719
1885
|
const CollectionTypePages = () => {
|
1720
1886
|
const { collectionType } = useParams();
|
@@ -1726,7 +1892,7 @@ const CollectionTypePages = () => {
|
|
1726
1892
|
const CLONE_RELATIVE_PATH = ":collectionType/:slug/clone/:origin";
|
1727
1893
|
const CLONE_PATH = `/content-manager/${CLONE_RELATIVE_PATH}`;
|
1728
1894
|
const LIST_RELATIVE_PATH = ":collectionType/:slug";
|
1729
|
-
const LIST_PATH = `/content-manager
|
1895
|
+
const LIST_PATH = `/content-manager/collection-types/:slug`;
|
1730
1896
|
const routes = [
|
1731
1897
|
{
|
1732
1898
|
path: LIST_RELATIVE_PATH,
|
@@ -1859,6 +2025,11 @@ const DocumentActionButton = (action) => {
|
|
1859
2025
|
) : null
|
1860
2026
|
] });
|
1861
2027
|
};
|
2028
|
+
const MenuItem = styled(Menu.Item)`
|
2029
|
+
&:hover {
|
2030
|
+
background: ${({ theme, isVariantDanger, isDisabled }) => isVariantDanger && !isDisabled ? theme.colors.danger100 : "neutral"};
|
2031
|
+
}
|
2032
|
+
`;
|
1862
2033
|
const DocumentActionsMenu = ({
|
1863
2034
|
actions: actions2,
|
1864
2035
|
children,
|
@@ -1917,48 +2088,32 @@ const DocumentActionsMenu = ({
|
|
1917
2088
|
/* @__PURE__ */ jsxs(Menu.Content, { maxHeight: void 0, popoverPlacement: "bottom-end", children: [
|
1918
2089
|
actions2.map((action) => {
|
1919
2090
|
return /* @__PURE__ */ jsx(
|
1920
|
-
|
2091
|
+
MenuItem,
|
1921
2092
|
{
|
1922
2093
|
disabled: action.disabled,
|
1923
2094
|
onSelect: handleClick(action),
|
1924
2095
|
display: "block",
|
1925
|
-
|
1926
|
-
|
1927
|
-
|
1928
|
-
|
1929
|
-
|
1930
|
-
|
1931
|
-
|
1932
|
-
|
1933
|
-
|
1934
|
-
|
1935
|
-
|
1936
|
-
|
1937
|
-
|
1938
|
-
|
1939
|
-
|
1940
|
-
|
1941
|
-
|
1942
|
-
|
1943
|
-
|
1944
|
-
|
1945
|
-
|
1946
|
-
Flex,
|
1947
|
-
{
|
1948
|
-
alignItems: "center",
|
1949
|
-
background: "alternative100",
|
1950
|
-
borderStyle: "solid",
|
1951
|
-
borderColor: "alternative200",
|
1952
|
-
borderWidth: "1px",
|
1953
|
-
height: 5,
|
1954
|
-
paddingLeft: 2,
|
1955
|
-
paddingRight: 2,
|
1956
|
-
hasRadius: true,
|
1957
|
-
color: "alternative600",
|
1958
|
-
children: /* @__PURE__ */ jsx(Typography, { variant: "sigma", fontWeight: "bold", lineHeight: 1, children: formatMessage({ id: "global.new", defaultMessage: "New" }) })
|
1959
|
-
}
|
1960
|
-
)
|
1961
|
-
] })
|
2096
|
+
isVariantDanger: action.variant === "danger",
|
2097
|
+
isDisabled: action.disabled,
|
2098
|
+
children: /* @__PURE__ */ jsx(Flex, { justifyContent: "space-between", gap: 4, children: /* @__PURE__ */ jsxs(
|
2099
|
+
Flex,
|
2100
|
+
{
|
2101
|
+
color: !action.disabled ? convertActionVariantToColor(action.variant) : "inherit",
|
2102
|
+
gap: 2,
|
2103
|
+
tag: "span",
|
2104
|
+
children: [
|
2105
|
+
/* @__PURE__ */ jsx(
|
2106
|
+
Flex,
|
2107
|
+
{
|
2108
|
+
tag: "span",
|
2109
|
+
color: !action.disabled ? convertActionVariantToIconColor(action.variant) : "inherit",
|
2110
|
+
children: action.icon
|
2111
|
+
}
|
2112
|
+
),
|
2113
|
+
action.label
|
2114
|
+
]
|
2115
|
+
}
|
2116
|
+
) })
|
1962
2117
|
},
|
1963
2118
|
action.id
|
1964
2119
|
);
|
@@ -2095,6 +2250,7 @@ const PublishAction$1 = ({
|
|
2095
2250
|
const { _unstableFormatValidationErrors: formatValidationErrors } = useAPIErrorHandler();
|
2096
2251
|
const isListView = useMatch(LIST_PATH) !== null;
|
2097
2252
|
const isCloning = useMatch(CLONE_PATH) !== null;
|
2253
|
+
const { id } = useParams();
|
2098
2254
|
const { formatMessage } = useIntl();
|
2099
2255
|
const canPublish = useDocumentRBAC("PublishAction", ({ canPublish: canPublish2 }) => canPublish2);
|
2100
2256
|
const { publish } = useDocumentActions();
|
@@ -2197,10 +2353,12 @@ const PublishAction$1 = ({
|
|
2197
2353
|
transformData(formValues)
|
2198
2354
|
);
|
2199
2355
|
if ("data" in res && collectionType !== SINGLE_TYPES) {
|
2200
|
-
|
2201
|
-
|
2202
|
-
|
2203
|
-
|
2356
|
+
if (id === "create") {
|
2357
|
+
navigate({
|
2358
|
+
pathname: `../${collectionType}/${model}/${res.data.documentId}`,
|
2359
|
+
search: rawQuery
|
2360
|
+
});
|
2361
|
+
}
|
2204
2362
|
} else if ("error" in res && isBaseQueryError(res.error) && res.error.name === "ValidationError") {
|
2205
2363
|
setErrors(formatValidationErrors(res.error));
|
2206
2364
|
}
|
@@ -2253,6 +2411,7 @@ const PublishAction$1 = ({
|
|
2253
2411
|
};
|
2254
2412
|
};
|
2255
2413
|
PublishAction$1.type = "publish";
|
2414
|
+
PublishAction$1.position = "panel";
|
2256
2415
|
const UpdateAction = ({
|
2257
2416
|
activeTab,
|
2258
2417
|
documentId,
|
@@ -2275,96 +2434,134 @@ const UpdateAction = ({
|
|
2275
2434
|
const validate = useForm("UpdateAction", (state) => state.validate);
|
2276
2435
|
const setErrors = useForm("UpdateAction", (state) => state.setErrors);
|
2277
2436
|
const resetForm = useForm("PublishAction", ({ resetForm: resetForm2 }) => resetForm2);
|
2278
|
-
|
2279
|
-
|
2280
|
-
|
2281
|
-
|
2282
|
-
|
2283
|
-
|
2284
|
-
|
2285
|
-
|
2286
|
-
|
2287
|
-
|
2288
|
-
|
2289
|
-
|
2290
|
-
|
2291
|
-
|
2292
|
-
|
2293
|
-
|
2294
|
-
status: "draft"
|
2437
|
+
const handleUpdate = React.useCallback(async () => {
|
2438
|
+
setSubmitting(true);
|
2439
|
+
try {
|
2440
|
+
if (!modified) {
|
2441
|
+
return;
|
2442
|
+
}
|
2443
|
+
const { errors } = await validate(true, {
|
2444
|
+
status: "draft"
|
2445
|
+
});
|
2446
|
+
if (errors) {
|
2447
|
+
toggleNotification({
|
2448
|
+
type: "danger",
|
2449
|
+
message: formatMessage({
|
2450
|
+
id: "content-manager.validation.error",
|
2451
|
+
defaultMessage: "There are validation errors in your document. Please fix them before saving."
|
2452
|
+
})
|
2295
2453
|
});
|
2296
|
-
|
2297
|
-
|
2298
|
-
|
2299
|
-
|
2300
|
-
|
2301
|
-
|
2302
|
-
|
2303
|
-
|
2304
|
-
|
2305
|
-
|
2306
|
-
|
2307
|
-
|
2308
|
-
|
2309
|
-
model,
|
2310
|
-
documentId: cloneMatch.params.origin,
|
2311
|
-
params
|
2312
|
-
},
|
2313
|
-
transformData(document)
|
2314
|
-
);
|
2315
|
-
if ("data" in res) {
|
2316
|
-
navigate(
|
2317
|
-
{
|
2318
|
-
pathname: `../${res.data.documentId}`,
|
2319
|
-
search: rawQuery
|
2320
|
-
},
|
2321
|
-
{ relative: "path" }
|
2322
|
-
);
|
2323
|
-
} else if ("error" in res && isBaseQueryError(res.error) && res.error.name === "ValidationError") {
|
2324
|
-
setErrors(formatValidationErrors(res.error));
|
2325
|
-
}
|
2326
|
-
} else if (documentId || collectionType === SINGLE_TYPES) {
|
2327
|
-
const res = await update(
|
2454
|
+
return;
|
2455
|
+
}
|
2456
|
+
if (isCloning) {
|
2457
|
+
const res = await clone(
|
2458
|
+
{
|
2459
|
+
model,
|
2460
|
+
documentId: cloneMatch.params.origin,
|
2461
|
+
params
|
2462
|
+
},
|
2463
|
+
transformData(document)
|
2464
|
+
);
|
2465
|
+
if ("data" in res) {
|
2466
|
+
navigate(
|
2328
2467
|
{
|
2329
|
-
|
2330
|
-
|
2331
|
-
documentId,
|
2332
|
-
params
|
2468
|
+
pathname: `../${res.data.documentId}`,
|
2469
|
+
search: rawQuery
|
2333
2470
|
},
|
2334
|
-
|
2471
|
+
{ relative: "path" }
|
2335
2472
|
);
|
2336
|
-
|
2337
|
-
|
2338
|
-
|
2339
|
-
|
2340
|
-
|
2473
|
+
} else if ("error" in res && isBaseQueryError(res.error) && res.error.name === "ValidationError") {
|
2474
|
+
setErrors(formatValidationErrors(res.error));
|
2475
|
+
}
|
2476
|
+
} else if (documentId || collectionType === SINGLE_TYPES) {
|
2477
|
+
const res = await update(
|
2478
|
+
{
|
2479
|
+
collectionType,
|
2480
|
+
model,
|
2481
|
+
documentId,
|
2482
|
+
params
|
2483
|
+
},
|
2484
|
+
transformData(document)
|
2485
|
+
);
|
2486
|
+
if ("error" in res && isBaseQueryError(res.error) && res.error.name === "ValidationError") {
|
2487
|
+
setErrors(formatValidationErrors(res.error));
|
2341
2488
|
} else {
|
2342
|
-
|
2489
|
+
resetForm();
|
2490
|
+
}
|
2491
|
+
} else {
|
2492
|
+
const res = await create(
|
2493
|
+
{
|
2494
|
+
model,
|
2495
|
+
params
|
2496
|
+
},
|
2497
|
+
transformData(document)
|
2498
|
+
);
|
2499
|
+
if ("data" in res && collectionType !== SINGLE_TYPES) {
|
2500
|
+
navigate(
|
2343
2501
|
{
|
2344
|
-
|
2345
|
-
|
2502
|
+
pathname: `../${res.data.documentId}`,
|
2503
|
+
search: rawQuery
|
2346
2504
|
},
|
2347
|
-
|
2505
|
+
{ replace: true, relative: "path" }
|
2348
2506
|
);
|
2349
|
-
|
2350
|
-
|
2351
|
-
{
|
2352
|
-
pathname: `../${res.data.documentId}`,
|
2353
|
-
search: rawQuery
|
2354
|
-
},
|
2355
|
-
{ replace: true, relative: "path" }
|
2356
|
-
);
|
2357
|
-
} else if ("error" in res && isBaseQueryError(res.error) && res.error.name === "ValidationError") {
|
2358
|
-
setErrors(formatValidationErrors(res.error));
|
2359
|
-
}
|
2507
|
+
} else if ("error" in res && isBaseQueryError(res.error) && res.error.name === "ValidationError") {
|
2508
|
+
setErrors(formatValidationErrors(res.error));
|
2360
2509
|
}
|
2361
|
-
} finally {
|
2362
|
-
setSubmitting(false);
|
2363
2510
|
}
|
2511
|
+
} finally {
|
2512
|
+
setSubmitting(false);
|
2364
2513
|
}
|
2514
|
+
}, [
|
2515
|
+
clone,
|
2516
|
+
cloneMatch?.params.origin,
|
2517
|
+
collectionType,
|
2518
|
+
create,
|
2519
|
+
document,
|
2520
|
+
documentId,
|
2521
|
+
formatMessage,
|
2522
|
+
formatValidationErrors,
|
2523
|
+
isCloning,
|
2524
|
+
model,
|
2525
|
+
modified,
|
2526
|
+
navigate,
|
2527
|
+
params,
|
2528
|
+
rawQuery,
|
2529
|
+
resetForm,
|
2530
|
+
setErrors,
|
2531
|
+
setSubmitting,
|
2532
|
+
toggleNotification,
|
2533
|
+
update,
|
2534
|
+
validate
|
2535
|
+
]);
|
2536
|
+
React.useEffect(() => {
|
2537
|
+
const handleKeyDown = (e) => {
|
2538
|
+
if (e.key === "Enter" && (e.metaKey || e.ctrlKey)) {
|
2539
|
+
e.preventDefault();
|
2540
|
+
handleUpdate();
|
2541
|
+
}
|
2542
|
+
};
|
2543
|
+
window.addEventListener("keydown", handleKeyDown);
|
2544
|
+
return () => {
|
2545
|
+
window.removeEventListener("keydown", handleKeyDown);
|
2546
|
+
};
|
2547
|
+
}, [handleUpdate]);
|
2548
|
+
return {
|
2549
|
+
/**
|
2550
|
+
* Disabled when:
|
2551
|
+
* - the form is submitting
|
2552
|
+
* - the document is not modified & we're not cloning (you can save a clone entity straight away)
|
2553
|
+
* - the active tab is the published tab
|
2554
|
+
*/
|
2555
|
+
disabled: isSubmitting || !modified && !isCloning || activeTab === "published",
|
2556
|
+
label: formatMessage({
|
2557
|
+
id: "global.save",
|
2558
|
+
defaultMessage: "Save"
|
2559
|
+
}),
|
2560
|
+
onClick: handleUpdate
|
2365
2561
|
};
|
2366
2562
|
};
|
2367
2563
|
UpdateAction.type = "update";
|
2564
|
+
UpdateAction.position = "panel";
|
2368
2565
|
const UNPUBLISH_DRAFT_OPTIONS = {
|
2369
2566
|
KEEP: "keep",
|
2370
2567
|
DISCARD: "discard"
|
@@ -2487,6 +2684,7 @@ const UnpublishAction$1 = ({
|
|
2487
2684
|
};
|
2488
2685
|
};
|
2489
2686
|
UnpublishAction$1.type = "unpublish";
|
2687
|
+
UnpublishAction$1.position = "panel";
|
2490
2688
|
const DiscardAction = ({
|
2491
2689
|
activeTab,
|
2492
2690
|
documentId,
|
@@ -2537,6 +2735,7 @@ const DiscardAction = ({
|
|
2537
2735
|
};
|
2538
2736
|
};
|
2539
2737
|
DiscardAction.type = "discard";
|
2738
|
+
DiscardAction.position = "panel";
|
2540
2739
|
const DEFAULT_ACTIONS = [PublishAction$1, UpdateAction, UnpublishAction$1, DiscardAction];
|
2541
2740
|
const intervals = ["years", "months", "days", "hours", "minutes", "seconds"];
|
2542
2741
|
const RelativeTime = React.forwardRef(
|
@@ -2549,7 +2748,7 @@ const RelativeTime = React.forwardRef(
|
|
2549
2748
|
});
|
2550
2749
|
const unit = intervals.find((intervalUnit) => {
|
2551
2750
|
return interval[intervalUnit] > 0 && Object.keys(interval).includes(intervalUnit);
|
2552
|
-
});
|
2751
|
+
}) ?? "seconds";
|
2553
2752
|
const relativeTime = isPast(timestamp) ? -interval[unit] : interval[unit];
|
2554
2753
|
const customInterval = customIntervals.find(
|
2555
2754
|
(custom) => interval[custom.unit] < custom.threshold
|
@@ -2583,10 +2782,10 @@ const getDisplayName = ({
|
|
2583
2782
|
return email ?? "";
|
2584
2783
|
};
|
2585
2784
|
const capitalise = (str) => str.charAt(0).toUpperCase() + str.slice(1);
|
2586
|
-
const DocumentStatus = ({ status = "draft", ...restProps }) => {
|
2785
|
+
const DocumentStatus = ({ status = "draft", size = "S", ...restProps }) => {
|
2587
2786
|
const statusVariant = status === "draft" ? "secondary" : status === "published" ? "success" : "alternative";
|
2588
2787
|
const { formatMessage } = useIntl();
|
2589
|
-
return /* @__PURE__ */ jsx(Status, { ...restProps,
|
2788
|
+
return /* @__PURE__ */ jsx(Status, { ...restProps, size, variant: statusVariant, children: /* @__PURE__ */ jsx(Typography, { tag: "span", variant: "omega", fontWeight: "bold", children: formatMessage({
|
2590
2789
|
id: `content-manager.containers.List.${status}`,
|
2591
2790
|
defaultMessage: capitalise(status)
|
2592
2791
|
}) }) });
|
@@ -2594,12 +2793,18 @@ const DocumentStatus = ({ status = "draft", ...restProps }) => {
|
|
2594
2793
|
const Header = ({ isCreating, status, title: documentTitle = "Untitled" }) => {
|
2595
2794
|
const { formatMessage } = useIntl();
|
2596
2795
|
const isCloning = useMatch(CLONE_PATH) !== null;
|
2796
|
+
const params = useParams();
|
2597
2797
|
const title = isCreating ? formatMessage({
|
2598
2798
|
id: "content-manager.containers.edit.title.new",
|
2599
2799
|
defaultMessage: "Create an entry"
|
2600
2800
|
}) : documentTitle;
|
2601
2801
|
return /* @__PURE__ */ jsxs(Flex, { direction: "column", alignItems: "flex-start", paddingTop: 6, paddingBottom: 4, gap: 2, children: [
|
2602
|
-
/* @__PURE__ */ jsx(
|
2802
|
+
/* @__PURE__ */ jsx(
|
2803
|
+
BackButton,
|
2804
|
+
{
|
2805
|
+
fallback: params.collectionType === SINGLE_TYPES ? void 0 : `../${COLLECTION_TYPES}/${params.slug}`
|
2806
|
+
}
|
2807
|
+
),
|
2603
2808
|
/* @__PURE__ */ jsxs(Flex, { width: "100%", justifyContent: "space-between", gap: "80px", alignItems: "flex-start", children: [
|
2604
2809
|
/* @__PURE__ */ jsx(Typography, { variant: "alpha", tag: "h1", children: title }),
|
2605
2810
|
/* @__PURE__ */ jsx(HeaderToolbar, {})
|
@@ -2650,7 +2855,7 @@ const HeaderToolbar = () => {
|
|
2650
2855
|
meta: isCloning ? void 0 : meta,
|
2651
2856
|
collectionType
|
2652
2857
|
},
|
2653
|
-
descriptions: plugins["content-manager"].apis.getDocumentActions(),
|
2858
|
+
descriptions: plugins["content-manager"].apis.getDocumentActions("header"),
|
2654
2859
|
children: (actions2) => {
|
2655
2860
|
const headerActions = actions2.filter((action) => {
|
2656
2861
|
const positions = Array.isArray(action.position) ? action.position : [action.position];
|
@@ -2858,6 +3063,7 @@ const ConfigureTheViewAction = ({ collectionType, model }) => {
|
|
2858
3063
|
};
|
2859
3064
|
};
|
2860
3065
|
ConfigureTheViewAction.type = "configure-the-view";
|
3066
|
+
ConfigureTheViewAction.position = "header";
|
2861
3067
|
const EditTheModelAction = ({ model }) => {
|
2862
3068
|
const navigate = useNavigate();
|
2863
3069
|
const { formatMessage } = useIntl();
|
@@ -2874,6 +3080,7 @@ const EditTheModelAction = ({ model }) => {
|
|
2874
3080
|
};
|
2875
3081
|
};
|
2876
3082
|
EditTheModelAction.type = "edit-the-model";
|
3083
|
+
EditTheModelAction.position = "header";
|
2877
3084
|
const DeleteAction$1 = ({ documentId, model, collectionType, document }) => {
|
2878
3085
|
const navigate = useNavigate();
|
2879
3086
|
const { formatMessage } = useIntl();
|
@@ -2947,6 +3154,7 @@ const DeleteAction$1 = ({ documentId, model, collectionType, document }) => {
|
|
2947
3154
|
};
|
2948
3155
|
};
|
2949
3156
|
DeleteAction$1.type = "delete";
|
3157
|
+
DeleteAction$1.position = ["header", "table-row"];
|
2950
3158
|
const DEFAULT_HEADER_ACTIONS = [EditTheModelAction, ConfigureTheViewAction, DeleteAction$1];
|
2951
3159
|
const Panels = () => {
|
2952
3160
|
const isCloning = useMatch(CLONE_PATH) !== null;
|
@@ -3009,7 +3217,7 @@ const ActionsPanelContent = () => {
|
|
3009
3217
|
DescriptionComponentRenderer,
|
3010
3218
|
{
|
3011
3219
|
props,
|
3012
|
-
descriptions: plugins["content-manager"].apis.getDocumentActions(),
|
3220
|
+
descriptions: plugins["content-manager"].apis.getDocumentActions("panel"),
|
3013
3221
|
children: (actions2) => /* @__PURE__ */ jsx(DocumentActions, { actions: actions2 })
|
3014
3222
|
}
|
3015
3223
|
),
|
@@ -3067,7 +3275,7 @@ const ConfirmBulkActionDialog = ({
|
|
3067
3275
|
] })
|
3068
3276
|
] }) });
|
3069
3277
|
};
|
3070
|
-
const BoldChunk
|
3278
|
+
const BoldChunk = (chunks) => /* @__PURE__ */ jsx(Typography, { fontWeight: "bold", children: chunks });
|
3071
3279
|
const ConfirmDialogPublishAll = ({
|
3072
3280
|
isOpen,
|
3073
3281
|
onToggleDialog,
|
@@ -3116,7 +3324,7 @@ const ConfirmDialogPublishAll = ({
|
|
3116
3324
|
defaultMessage: "<b>{count} {count, plural, one { relation } other { relations } } out of {entities} { entities, plural, one { entry } other { entries } } {count, plural, one { is } other { are } }</b> not published yet and might lead to unexpected behavior. "
|
3117
3325
|
},
|
3118
3326
|
{
|
3119
|
-
b: BoldChunk
|
3327
|
+
b: BoldChunk,
|
3120
3328
|
count: countDraftRelations,
|
3121
3329
|
entities: selectedEntries.length
|
3122
3330
|
}
|
@@ -3155,6 +3363,16 @@ const ConfirmDialogPublishAll = ({
|
|
3155
3363
|
const TypographyMaxWidth = styled(Typography)`
|
3156
3364
|
max-width: 300px;
|
3157
3365
|
`;
|
3366
|
+
const TableComponent = styled(RawTable)`
|
3367
|
+
width: 100%;
|
3368
|
+
table-layout: fixed;
|
3369
|
+
td:first-child {
|
3370
|
+
border-right: 1px solid ${({ theme }) => theme.colors.neutral150};
|
3371
|
+
}
|
3372
|
+
td:first-of-type {
|
3373
|
+
padding: ${({ theme }) => theme.spaces[4]};
|
3374
|
+
}
|
3375
|
+
`;
|
3158
3376
|
const formatErrorMessages = (errors, parentKey, formatMessage) => {
|
3159
3377
|
const messages = [];
|
3160
3378
|
Object.entries(errors).forEach(([key, value]) => {
|
@@ -3259,7 +3477,7 @@ const SelectedEntriesTableContent = ({
|
|
3259
3477
|
)
|
3260
3478
|
] }),
|
3261
3479
|
/* @__PURE__ */ jsx(Table.Loading, {}),
|
3262
|
-
/* @__PURE__ */ jsx(Table.Body, { children: rowsToDisplay.map((row
|
3480
|
+
/* @__PURE__ */ jsx(Table.Body, { children: rowsToDisplay.map((row) => /* @__PURE__ */ jsxs(Table.Row, { children: [
|
3263
3481
|
/* @__PURE__ */ jsx(Table.CheckboxCell, { id: row.id }),
|
3264
3482
|
/* @__PURE__ */ jsx(Table.Cell, { children: /* @__PURE__ */ jsx(Typography, { children: row.id }) }),
|
3265
3483
|
shouldDisplayMainField && /* @__PURE__ */ jsx(Table.Cell, { children: /* @__PURE__ */ jsx(Typography, { children: row[mainField] }) }),
|
@@ -3286,18 +3504,10 @@ const SelectedEntriesTableContent = ({
|
|
3286
3504
|
search: row.locale && `?plugins[i18n][locale]=${row.locale}`
|
3287
3505
|
},
|
3288
3506
|
state: { from: pathname },
|
3289
|
-
label: formatMessage(
|
3290
|
-
|
3291
|
-
|
3292
|
-
|
3293
|
-
{
|
3294
|
-
id: "content-manager.components.ListViewHelperPluginTable.row-line",
|
3295
|
-
defaultMessage: "item line {number}"
|
3296
|
-
},
|
3297
|
-
{ number: index2 + 1 }
|
3298
|
-
)
|
3299
|
-
}
|
3300
|
-
),
|
3507
|
+
label: formatMessage({
|
3508
|
+
id: "content-manager.bulk-publish.edit",
|
3509
|
+
defaultMessage: "Edit"
|
3510
|
+
}),
|
3301
3511
|
target: "_blank",
|
3302
3512
|
marginLeft: "auto",
|
3303
3513
|
variant: "ghost",
|
@@ -3307,7 +3517,73 @@ const SelectedEntriesTableContent = ({
|
|
3307
3517
|
] }, row.id)) })
|
3308
3518
|
] });
|
3309
3519
|
};
|
3310
|
-
const
|
3520
|
+
const PublicationStatusSummary = ({ count, icon, message }) => {
|
3521
|
+
return /* @__PURE__ */ jsxs(Flex, { justifyContent: "space-between", flex: 1, gap: 3, children: [
|
3522
|
+
/* @__PURE__ */ jsxs(Flex, { gap: 2, children: [
|
3523
|
+
icon,
|
3524
|
+
/* @__PURE__ */ jsx(Typography, { children: message })
|
3525
|
+
] }),
|
3526
|
+
/* @__PURE__ */ jsx(Typography, { fontWeight: "bold", children: count })
|
3527
|
+
] });
|
3528
|
+
};
|
3529
|
+
const PublicationStatusGrid = ({
|
3530
|
+
entriesReadyToPublishCount,
|
3531
|
+
entriesPublishedCount,
|
3532
|
+
entriesModifiedCount,
|
3533
|
+
entriesWithErrorsCount
|
3534
|
+
}) => {
|
3535
|
+
const { formatMessage } = useIntl();
|
3536
|
+
return /* @__PURE__ */ jsx(Box, { hasRadius: true, borderColor: "neutral150", children: /* @__PURE__ */ jsx(TableComponent, { colCount: 2, rowCount: 2, children: /* @__PURE__ */ jsxs(Tbody, { children: [
|
3537
|
+
/* @__PURE__ */ jsxs(Tr, { children: [
|
3538
|
+
/* @__PURE__ */ jsx(Td, { children: /* @__PURE__ */ jsx(
|
3539
|
+
PublicationStatusSummary,
|
3540
|
+
{
|
3541
|
+
count: entriesReadyToPublishCount,
|
3542
|
+
icon: /* @__PURE__ */ jsx(CheckCircle, { fill: "success600" }),
|
3543
|
+
message: formatMessage({
|
3544
|
+
id: "app.utils.ready-to-publish",
|
3545
|
+
defaultMessage: "Ready to publish"
|
3546
|
+
})
|
3547
|
+
}
|
3548
|
+
) }),
|
3549
|
+
/* @__PURE__ */ jsx(Td, { children: /* @__PURE__ */ jsx(
|
3550
|
+
PublicationStatusSummary,
|
3551
|
+
{
|
3552
|
+
count: entriesPublishedCount,
|
3553
|
+
icon: /* @__PURE__ */ jsx(CheckCircle, { fill: "success600" }),
|
3554
|
+
message: formatMessage({
|
3555
|
+
id: "app.utils.already-published",
|
3556
|
+
defaultMessage: "Already published"
|
3557
|
+
})
|
3558
|
+
}
|
3559
|
+
) })
|
3560
|
+
] }),
|
3561
|
+
/* @__PURE__ */ jsxs(Tr, { children: [
|
3562
|
+
/* @__PURE__ */ jsx(Td, { children: /* @__PURE__ */ jsx(
|
3563
|
+
PublicationStatusSummary,
|
3564
|
+
{
|
3565
|
+
count: entriesModifiedCount,
|
3566
|
+
icon: /* @__PURE__ */ jsx(ArrowsCounterClockwise, { fill: "alternative600" }),
|
3567
|
+
message: formatMessage({
|
3568
|
+
id: "content-manager.bulk-publish.modified",
|
3569
|
+
defaultMessage: "Ready to publish changes"
|
3570
|
+
})
|
3571
|
+
}
|
3572
|
+
) }),
|
3573
|
+
/* @__PURE__ */ jsx(Td, { children: /* @__PURE__ */ jsx(
|
3574
|
+
PublicationStatusSummary,
|
3575
|
+
{
|
3576
|
+
count: entriesWithErrorsCount,
|
3577
|
+
icon: /* @__PURE__ */ jsx(CrossCircle, { fill: "danger600" }),
|
3578
|
+
message: formatMessage({
|
3579
|
+
id: "content-manager.bulk-publish.waiting-for-action",
|
3580
|
+
defaultMessage: "Waiting for action"
|
3581
|
+
})
|
3582
|
+
}
|
3583
|
+
) })
|
3584
|
+
] })
|
3585
|
+
] }) }) });
|
3586
|
+
};
|
3311
3587
|
const SelectedEntriesModalContent = ({
|
3312
3588
|
listViewSelectedEntries,
|
3313
3589
|
toggleModal,
|
@@ -3366,7 +3642,6 @@ const SelectedEntriesModalContent = ({
|
|
3366
3642
|
validationErrors: {}
|
3367
3643
|
};
|
3368
3644
|
}, [components, data, schema]);
|
3369
|
-
const [publishedCount, setPublishedCount] = React.useState(0);
|
3370
3645
|
const [isDialogOpen, setIsDialogOpen] = React.useState(false);
|
3371
3646
|
const { publishMany: bulkPublishAction } = useDocumentActions();
|
3372
3647
|
const [, { isLoading: isSubmittingForm }] = usePublishManyDocumentsMutation();
|
@@ -3378,53 +3653,36 @@ const SelectedEntriesModalContent = ({
|
|
3378
3653
|
const selectedEntriesWithErrorsCount = selectedEntries.filter(
|
3379
3654
|
({ documentId }) => validationErrors[documentId]
|
3380
3655
|
).length;
|
3381
|
-
const
|
3656
|
+
const selectedEntriesPublishedCount = selectedEntries.filter(
|
3382
3657
|
({ status }) => status === "published"
|
3383
3658
|
).length;
|
3384
|
-
const
|
3659
|
+
const selectedEntriesModifiedCount = selectedEntries.filter(
|
3660
|
+
({ status, documentId }) => status === "modified" && !validationErrors[documentId]
|
3661
|
+
).length;
|
3662
|
+
const selectedEntriesWithNoErrorsCount = selectedEntries.length - selectedEntriesWithErrorsCount - selectedEntriesPublishedCount;
|
3385
3663
|
const toggleDialog = () => setIsDialogOpen((prev) => !prev);
|
3386
3664
|
const handleConfirmBulkPublish = async () => {
|
3387
3665
|
toggleDialog();
|
3388
3666
|
const res = await bulkPublishAction({ model, documentIds: entriesToPublish, params });
|
3389
3667
|
if (!("error" in res)) {
|
3390
|
-
setPublishedCount(res.count);
|
3391
3668
|
const unpublishedEntries = rows.filter((row) => {
|
3392
3669
|
return !entriesToPublish.includes(row.documentId);
|
3393
3670
|
});
|
3394
3671
|
setListViewSelectedDocuments(unpublishedEntries);
|
3395
3672
|
}
|
3396
3673
|
};
|
3397
|
-
const getFormattedCountMessage = () => {
|
3398
|
-
if (publishedCount) {
|
3399
|
-
return formatMessage(
|
3400
|
-
{
|
3401
|
-
id: getTranslation("containers.list.selectedEntriesModal.publishedCount"),
|
3402
|
-
defaultMessage: "<b>{publishedCount}</b> {publishedCount, plural, =0 {entries} one {entry} other {entries}} published. <b>{withErrorsCount}</b> {withErrorsCount, plural, =0 {entries} one {entry} other {entries}} waiting for action."
|
3403
|
-
},
|
3404
|
-
{
|
3405
|
-
publishedCount,
|
3406
|
-
withErrorsCount: selectedEntriesWithErrorsCount,
|
3407
|
-
b: BoldChunk
|
3408
|
-
}
|
3409
|
-
);
|
3410
|
-
}
|
3411
|
-
return formatMessage(
|
3412
|
-
{
|
3413
|
-
id: getTranslation("containers.list.selectedEntriesModal.selectedCount"),
|
3414
|
-
defaultMessage: "<b>{alreadyPublishedCount}</b> {alreadyPublishedCount, plural, =0 {entries} one {entry} other {entries}} already published. <b>{readyToPublishCount}</b> {readyToPublishCount, plural, =0 {entries} one {entry} other {entries}} ready to publish. <b>{withErrorsCount}</b> {withErrorsCount, plural, =0 {entries} one {entry} other {entries}} waiting for action."
|
3415
|
-
},
|
3416
|
-
{
|
3417
|
-
readyToPublishCount: selectedEntriesWithNoErrorsCount,
|
3418
|
-
withErrorsCount: selectedEntriesWithErrorsCount,
|
3419
|
-
alreadyPublishedCount: selectedEntriesPublished,
|
3420
|
-
b: BoldChunk
|
3421
|
-
}
|
3422
|
-
);
|
3423
|
-
};
|
3424
3674
|
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
3425
3675
|
/* @__PURE__ */ jsxs(Modal.Body, { children: [
|
3426
|
-
/* @__PURE__ */ jsx(
|
3427
|
-
|
3676
|
+
/* @__PURE__ */ jsx(
|
3677
|
+
PublicationStatusGrid,
|
3678
|
+
{
|
3679
|
+
entriesReadyToPublishCount: selectedEntriesWithNoErrorsCount - selectedEntriesModifiedCount,
|
3680
|
+
entriesPublishedCount: selectedEntriesPublishedCount,
|
3681
|
+
entriesModifiedCount: selectedEntriesModifiedCount,
|
3682
|
+
entriesWithErrorsCount: selectedEntriesWithErrorsCount
|
3683
|
+
}
|
3684
|
+
),
|
3685
|
+
/* @__PURE__ */ jsx(Box, { marginTop: 7, children: /* @__PURE__ */ jsx(
|
3428
3686
|
SelectedEntriesTableContent,
|
3429
3687
|
{
|
3430
3688
|
isPublishing: isSubmittingForm,
|
@@ -3445,7 +3703,7 @@ const SelectedEntriesModalContent = ({
|
|
3445
3703
|
Button,
|
3446
3704
|
{
|
3447
3705
|
onClick: toggleDialog,
|
3448
|
-
disabled: selectedEntries.length === 0 || selectedEntries.length === selectedEntriesWithErrorsCount ||
|
3706
|
+
disabled: selectedEntries.length === 0 || selectedEntries.length === selectedEntriesWithErrorsCount || selectedEntriesPublishedCount === selectedEntries.length || isLoading,
|
3449
3707
|
loading: isSubmittingForm,
|
3450
3708
|
children: formatMessage({ id: "app.utils.publish", defaultMessage: "Publish" })
|
3451
3709
|
}
|
@@ -3471,8 +3729,7 @@ const PublishAction = ({ documents, model }) => {
|
|
3471
3729
|
const refetchList = () => {
|
3472
3730
|
contentManagerApi.util.invalidateTags([{ type: "Document", id: `${model}_LIST` }]);
|
3473
3731
|
};
|
3474
|
-
if (!showPublishButton)
|
3475
|
-
return null;
|
3732
|
+
if (!showPublishButton) return null;
|
3476
3733
|
return {
|
3477
3734
|
actionType: "publish",
|
3478
3735
|
variant: "tertiary",
|
@@ -3540,8 +3797,7 @@ const DeleteAction = ({ documents, model }) => {
|
|
3540
3797
|
selectRow([]);
|
3541
3798
|
}
|
3542
3799
|
};
|
3543
|
-
if (!hasDeletePermission)
|
3544
|
-
return null;
|
3800
|
+
if (!hasDeletePermission) return null;
|
3545
3801
|
return {
|
3546
3802
|
variant: "danger-light",
|
3547
3803
|
label: formatMessage({ id: "global.delete", defaultMessage: "Delete" }),
|
@@ -3590,8 +3846,7 @@ const UnpublishAction = ({ documents, model }) => {
|
|
3590
3846
|
}
|
3591
3847
|
};
|
3592
3848
|
const showUnpublishButton = hasDraftAndPublishEnabled && hasPublishPermission && documents.some((entry) => entry.status === "published" || entry.status === "modified");
|
3593
|
-
if (!showUnpublishButton)
|
3594
|
-
return null;
|
3849
|
+
if (!showUnpublishButton) return null;
|
3595
3850
|
return {
|
3596
3851
|
variant: "tertiary",
|
3597
3852
|
label: formatMessage({ id: "app.utils.unpublish", defaultMessage: "Unpublish" }),
|
@@ -3696,7 +3951,7 @@ const TableActions = ({ document }) => {
|
|
3696
3951
|
DescriptionComponentRenderer,
|
3697
3952
|
{
|
3698
3953
|
props,
|
3699
|
-
descriptions: plugins["content-manager"].apis.getDocumentActions().filter((action) => action.name !== "PublishAction"),
|
3954
|
+
descriptions: plugins["content-manager"].apis.getDocumentActions("table-row").filter((action) => action.name !== "PublishAction"),
|
3700
3955
|
children: (actions2) => {
|
3701
3956
|
const tableRowActions = actions2.filter((action) => {
|
3702
3957
|
const positions = Array.isArray(action.position) ? action.position : [action.position];
|
@@ -3755,6 +4010,7 @@ const EditAction = ({ documentId }) => {
|
|
3755
4010
|
};
|
3756
4011
|
};
|
3757
4012
|
EditAction.type = "edit";
|
4013
|
+
EditAction.position = "table-row";
|
3758
4014
|
const StyledPencil = styled(Pencil)`
|
3759
4015
|
path {
|
3760
4016
|
fill: currentColor;
|
@@ -3831,6 +4087,7 @@ const CloneAction = ({ model, documentId }) => {
|
|
3831
4087
|
};
|
3832
4088
|
};
|
3833
4089
|
CloneAction.type = "clone";
|
4090
|
+
CloneAction.position = "table-row";
|
3834
4091
|
const StyledDuplicate = styled(Duplicate)`
|
3835
4092
|
path {
|
3836
4093
|
fill: currentColor;
|
@@ -3917,7 +4174,14 @@ class ContentManagerPlugin {
|
|
3917
4174
|
addDocumentHeaderAction: this.addDocumentHeaderAction.bind(this),
|
3918
4175
|
addEditViewSidePanel: this.addEditViewSidePanel.bind(this),
|
3919
4176
|
getBulkActions: () => this.bulkActions,
|
3920
|
-
getDocumentActions: () =>
|
4177
|
+
getDocumentActions: (position) => {
|
4178
|
+
if (position) {
|
4179
|
+
return this.documentActions.filter(
|
4180
|
+
(action) => action.position == void 0 || [action.position].flat().includes(position)
|
4181
|
+
);
|
4182
|
+
}
|
4183
|
+
return this.documentActions;
|
4184
|
+
},
|
3921
4185
|
getEditViewSidePanels: () => this.editViewSidePanels,
|
3922
4186
|
getHeaderActions: () => this.headerActions
|
3923
4187
|
}
|
@@ -3927,10 +4191,8 @@ class ContentManagerPlugin {
|
|
3927
4191
|
const getPrintableType = (value) => {
|
3928
4192
|
const nativeType = typeof value;
|
3929
4193
|
if (nativeType === "object") {
|
3930
|
-
if (value === null)
|
3931
|
-
|
3932
|
-
if (Array.isArray(value))
|
3933
|
-
return "array";
|
4194
|
+
if (value === null) return "null";
|
4195
|
+
if (Array.isArray(value)) return "array";
|
3934
4196
|
if (value instanceof Object && value.constructor.name !== "Object") {
|
3935
4197
|
return value.constructor.name;
|
3936
4198
|
}
|
@@ -3941,17 +4203,27 @@ const HistoryAction = ({ model, document }) => {
|
|
3941
4203
|
const { formatMessage } = useIntl();
|
3942
4204
|
const [{ query }] = useQueryParams();
|
3943
4205
|
const navigate = useNavigate();
|
4206
|
+
const { trackUsage } = useTracking();
|
4207
|
+
const { pathname } = useLocation();
|
3944
4208
|
const pluginsQueryParams = stringify({ plugins: query.plugins }, { encode: false });
|
3945
4209
|
if (!window.strapi.features.isEnabled("cms-content-history")) {
|
3946
4210
|
return null;
|
3947
4211
|
}
|
4212
|
+
const handleOnClick = () => {
|
4213
|
+
const destination = { pathname: "history", search: pluginsQueryParams };
|
4214
|
+
trackUsage("willNavigate", {
|
4215
|
+
from: pathname,
|
4216
|
+
to: `${pathname}/${destination.pathname}`
|
4217
|
+
});
|
4218
|
+
navigate(destination);
|
4219
|
+
};
|
3948
4220
|
return {
|
3949
4221
|
icon: /* @__PURE__ */ jsx(ClockCounterClockwise, {}),
|
3950
4222
|
label: formatMessage({
|
3951
4223
|
id: "content-manager.history.document-action",
|
3952
4224
|
defaultMessage: "Content History"
|
3953
4225
|
}),
|
3954
|
-
onClick:
|
4226
|
+
onClick: handleOnClick,
|
3955
4227
|
disabled: (
|
3956
4228
|
/**
|
3957
4229
|
* The user is creating a new document.
|
@@ -3973,6 +4245,7 @@ const HistoryAction = ({ model, document }) => {
|
|
3973
4245
|
};
|
3974
4246
|
};
|
3975
4247
|
HistoryAction.type = "history";
|
4248
|
+
HistoryAction.position = "header";
|
3976
4249
|
const historyAdmin = {
|
3977
4250
|
bootstrap(app) {
|
3978
4251
|
const { addDocumentAction } = app.getPlugin("content-manager").apis;
|
@@ -4035,10 +4308,18 @@ const previewApi = contentManagerApi.injectEndpoints({
|
|
4035
4308
|
})
|
4036
4309
|
});
|
4037
4310
|
const { useGetPreviewUrlQuery } = previewApi;
|
4311
|
+
const ConditionalTooltip = ({ isShown, label, children }) => {
|
4312
|
+
if (isShown) {
|
4313
|
+
return /* @__PURE__ */ jsx(Tooltip, { label, children });
|
4314
|
+
}
|
4315
|
+
return children;
|
4316
|
+
};
|
4038
4317
|
const PreviewSidePanel = ({ model, documentId, document }) => {
|
4039
4318
|
const { formatMessage } = useIntl();
|
4040
4319
|
const { trackUsage } = useTracking();
|
4320
|
+
const { pathname } = useLocation();
|
4041
4321
|
const [{ query }] = useQueryParams();
|
4322
|
+
const isModified = useForm("PreviewSidePanel", (state) => state.modified);
|
4042
4323
|
const { data, error } = useGetPreviewUrlQuery({
|
4043
4324
|
params: {
|
4044
4325
|
contentType: model
|
@@ -4052,33 +4333,43 @@ const PreviewSidePanel = ({ model, documentId, document }) => {
|
|
4052
4333
|
if (!data?.data?.url || error) {
|
4053
4334
|
return null;
|
4054
4335
|
}
|
4055
|
-
const
|
4056
|
-
|
4336
|
+
const trackNavigation = () => {
|
4337
|
+
const destinationPathname = pathname.replace(/\/$/, "") + "/preview";
|
4338
|
+
trackUsage("willNavigate", { from: pathname, to: destinationPathname });
|
4057
4339
|
};
|
4058
4340
|
return {
|
4059
4341
|
title: formatMessage({ id: "content-manager.preview.panel.title", defaultMessage: "Preview" }),
|
4060
|
-
content: /* @__PURE__ */ jsx(
|
4061
|
-
|
4342
|
+
content: /* @__PURE__ */ jsx(
|
4343
|
+
ConditionalTooltip,
|
4062
4344
|
{
|
4063
|
-
|
4064
|
-
|
4065
|
-
|
4066
|
-
|
4067
|
-
|
4068
|
-
children:
|
4069
|
-
|
4070
|
-
|
4071
|
-
|
4345
|
+
label: formatMessage({
|
4346
|
+
id: "content-manager.preview.panel.button-disabled-tooltip",
|
4347
|
+
defaultMessage: "Please save to open the preview"
|
4348
|
+
}),
|
4349
|
+
isShown: isModified,
|
4350
|
+
children: /* @__PURE__ */ jsx(Box, { cursor: "not-allowed", width: "100%", children: /* @__PURE__ */ jsx(
|
4351
|
+
Button,
|
4352
|
+
{
|
4353
|
+
variant: "tertiary",
|
4354
|
+
tag: Link,
|
4355
|
+
to: { pathname: "preview", search: stringify(query, { encode: false }) },
|
4356
|
+
onClick: trackNavigation,
|
4357
|
+
width: "100%",
|
4358
|
+
disabled: isModified,
|
4359
|
+
pointerEvents: isModified ? "none" : void 0,
|
4360
|
+
tabIndex: isModified ? -1 : void 0,
|
4361
|
+
children: formatMessage({
|
4362
|
+
id: "content-manager.preview.panel.button",
|
4363
|
+
defaultMessage: "Open preview"
|
4364
|
+
})
|
4365
|
+
}
|
4366
|
+
) })
|
4072
4367
|
}
|
4073
|
-
)
|
4368
|
+
)
|
4074
4369
|
};
|
4075
4370
|
};
|
4076
|
-
const FEATURE_ID = "preview";
|
4077
4371
|
const previewAdmin = {
|
4078
4372
|
bootstrap(app) {
|
4079
|
-
if (!window.strapi.future.isEnabled(FEATURE_ID)) {
|
4080
|
-
return;
|
4081
|
-
}
|
4082
4373
|
const contentManagerPluginApis = app.getPlugin("content-manager").apis;
|
4083
4374
|
contentManagerPluginApis.addEditViewSidePanel([PreviewSidePanel]);
|
4084
4375
|
}
|
@@ -4102,7 +4393,7 @@ const index = {
|
|
4102
4393
|
app.router.addRoute({
|
4103
4394
|
path: "content-manager/*",
|
4104
4395
|
lazy: async () => {
|
4105
|
-
const { Layout } = await import("./layout-
|
4396
|
+
const { Layout } = await import("./layout-CxDMdJ13.mjs");
|
4106
4397
|
return {
|
4107
4398
|
Component: Layout
|
4108
4399
|
};
|
@@ -4122,7 +4413,7 @@ const index = {
|
|
4122
4413
|
async registerTrads({ locales }) {
|
4123
4414
|
const importedTrads = await Promise.all(
|
4124
4415
|
locales.map((locale) => {
|
4125
|
-
return __variableDynamicImportRuntimeHelper(/* @__PURE__ */ Object.assign({ "./translations/ar.json": () => import("./ar-CCEVvqGG.mjs"), "./translations/ca.json": () => import("./ca-5U32ON2v.mjs"), "./translations/cs.json": () => import("./cs-CM2aBUar.mjs"), "./translations/de.json": () => import("./de-C72KDNOl.mjs"), "./translations/en.json": () => import("./en-
|
4416
|
+
return __variableDynamicImportRuntimeHelper(/* @__PURE__ */ Object.assign({ "./translations/ar.json": () => import("./ar-CCEVvqGG.mjs"), "./translations/ca.json": () => import("./ca-5U32ON2v.mjs"), "./translations/cs.json": () => import("./cs-CM2aBUar.mjs"), "./translations/de.json": () => import("./de-C72KDNOl.mjs"), "./translations/en.json": () => import("./en-D65uIF6Y.mjs"), "./translations/es.json": () => import("./es-D34tqjMw.mjs"), "./translations/eu.json": () => import("./eu-CdALomew.mjs"), "./translations/fr.json": () => import("./fr-DBseuRuB.mjs"), "./translations/gu.json": () => import("./gu-CNpaMDpH.mjs"), "./translations/hi.json": () => import("./hi-Dwvd04m3.mjs"), "./translations/hu.json": () => import("./hu-CeYvaaO0.mjs"), "./translations/id.json": () => import("./id-BtwA9WJT.mjs"), "./translations/it.json": () => import("./it-BrVPqaf1.mjs"), "./translations/ja.json": () => import("./ja-BHqhDq4V.mjs"), "./translations/ko.json": () => import("./ko-HVQRlfUI.mjs"), "./translations/ml.json": () => import("./ml-BihZwQit.mjs"), "./translations/ms.json": () => import("./ms-m_WjyWx7.mjs"), "./translations/nl.json": () => import("./nl-D4R9gHx5.mjs"), "./translations/pl.json": () => import("./pl-sbx9mSt_.mjs"), "./translations/pt-BR.json": () => import("./pt-BR-C71iDxnh.mjs"), "./translations/pt.json": () => import("./pt-BsaFvS8-.mjs"), "./translations/ru.json": () => import("./ru-BE6A4Exp.mjs"), "./translations/sa.json": () => import("./sa-Dag0k-Z8.mjs"), "./translations/sk.json": () => import("./sk-BFg-R8qJ.mjs"), "./translations/sv.json": () => import("./sv-CUnfWGsh.mjs"), "./translations/th.json": () => import("./th-BqbI8lIT.mjs"), "./translations/tr.json": () => import("./tr-CgeK3wJM.mjs"), "./translations/uk.json": () => import("./uk-CR-zDhAY.mjs"), "./translations/vi.json": () => import("./vi-DUXIk_fw.mjs"), "./translations/zh-Hans.json": () => import("./zh-Hans-BPQcRIyH.mjs"), "./translations/zh.json": () => import("./zh-BWZspA60.mjs") }), `./translations/${locale}.json`, 3).then(({ default: data }) => {
|
4126
4417
|
return {
|
4127
4418
|
data: prefixPluginTranslations(data, PLUGIN_ID),
|
4128
4419
|
locale
|
@@ -4139,24 +4430,27 @@ const index = {
|
|
4139
4430
|
}
|
4140
4431
|
};
|
4141
4432
|
export {
|
4142
|
-
|
4433
|
+
useUpdateContentTypeConfigurationMutation as A,
|
4143
4434
|
BulkActionsRenderer as B,
|
4144
4435
|
COLLECTION_TYPES as C,
|
4145
4436
|
DocumentStatus as D,
|
4146
|
-
|
4147
|
-
|
4148
|
-
|
4437
|
+
ATTRIBUTE_TYPES_THAT_CANNOT_BE_MAIN_FIELD as E,
|
4438
|
+
extractContentTypeComponents as F,
|
4439
|
+
DEFAULT_SETTINGS as G,
|
4149
4440
|
HOOKS as H,
|
4150
4441
|
InjectionZone as I,
|
4151
|
-
|
4152
|
-
|
4153
|
-
|
4154
|
-
|
4155
|
-
|
4442
|
+
convertEditLayoutToFieldLayouts as J,
|
4443
|
+
removeFieldsThatDontExistOnSchema as K,
|
4444
|
+
prepareTempKeys as L,
|
4445
|
+
useDocument as M,
|
4446
|
+
useGetPreviewUrlQuery as N,
|
4447
|
+
index as O,
|
4156
4448
|
Panels as P,
|
4449
|
+
useContentManagerContext as Q,
|
4157
4450
|
RelativeTime as R,
|
4158
4451
|
SINGLE_TYPES as S,
|
4159
4452
|
TableActions as T,
|
4453
|
+
useDocumentActions as U,
|
4160
4454
|
useGetInitialDataQuery as a,
|
4161
4455
|
useGetAllContentTypeSettingsQuery as b,
|
4162
4456
|
useDoc as c,
|
@@ -4169,19 +4463,19 @@ export {
|
|
4169
4463
|
Header as j,
|
4170
4464
|
PERMISSIONS as k,
|
4171
4465
|
DocumentRBAC as l,
|
4172
|
-
|
4173
|
-
|
4174
|
-
|
4466
|
+
useDocLayout as m,
|
4467
|
+
createDefaultForm as n,
|
4468
|
+
CLONE_PATH as o,
|
4175
4469
|
useGetContentTypeConfigurationQuery as p,
|
4176
4470
|
CREATOR_FIELDS as q,
|
4177
4471
|
getMainField as r,
|
4178
4472
|
setInitialData as s,
|
4179
|
-
|
4473
|
+
transformDocument as t,
|
4180
4474
|
useContentTypeSchema as u,
|
4181
|
-
|
4182
|
-
|
4183
|
-
|
4184
|
-
|
4185
|
-
|
4475
|
+
getDisplayName as v,
|
4476
|
+
checkIfAttributeIsDisplayable as w,
|
4477
|
+
useGetAllDocumentsQuery as x,
|
4478
|
+
convertListLayoutToFieldLayouts as y,
|
4479
|
+
capitalise as z
|
4186
4480
|
};
|
4187
|
-
//# sourceMappingURL=index-
|
4481
|
+
//# sourceMappingURL=index-EH8ZtHd5.mjs.map
|