@strapi/i18n 0.0.0-experimental.9df68962083938acba06546a7901c68a63266aec → 0.0.0-experimental.9f812af47f0e9db3d5531382c836c2ac0776afdf
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/LICENSE +18 -3
- package/dist/_chunks/{SettingsPage-B5sTcP82.mjs → SettingsPage-B6QDUmu9.mjs} +8 -8
- package/dist/_chunks/SettingsPage-B6QDUmu9.mjs.map +1 -0
- package/dist/_chunks/{SettingsPage-DT1sxWa2.js → SettingsPage-BsHtr3lV.js} +9 -10
- package/dist/_chunks/SettingsPage-BsHtr3lV.js.map +1 -0
- package/dist/_chunks/{en-BsOU9o5z.js → en-BKBz3tro.js} +10 -3
- package/dist/_chunks/en-BKBz3tro.js.map +1 -0
- package/dist/_chunks/{en-CM6Pjfyv.mjs → en-DlXfy6Gy.mjs} +10 -3
- package/dist/_chunks/en-DlXfy6Gy.mjs.map +1 -0
- package/dist/_chunks/{index-jMrzaEb9.js → index-3XgwXL6T.js} +444 -207
- package/dist/_chunks/index-3XgwXL6T.js.map +1 -0
- package/dist/_chunks/{index-DsNqyQKx.mjs → index-iEQ79W05.mjs} +439 -201
- package/dist/_chunks/index-iEQ79W05.mjs.map +1 -0
- package/dist/admin/index.js +1 -1
- package/dist/admin/index.mjs +1 -1
- package/dist/admin/src/components/BulkLocaleActionModal.d.ts +2 -1
- package/dist/admin/src/components/CMHeaderActions.d.ts +29 -3
- package/dist/admin/src/components/CreateLocale.d.ts +6 -6
- package/dist/admin/src/components/LocaleListCell.d.ts +4 -4
- package/dist/admin/src/utils/clean.d.ts +4 -0
- package/dist/admin/src/utils/schemas.d.ts +1 -0
- package/dist/server/index.js +418 -478
- package/dist/server/index.js.map +1 -1
- package/dist/server/index.mjs +419 -478
- package/dist/server/index.mjs.map +1 -1
- package/dist/server/src/bootstrap.d.ts +1 -4
- package/dist/server/src/bootstrap.d.ts.map +1 -1
- package/dist/server/src/index.d.ts +21 -13
- package/dist/server/src/index.d.ts.map +1 -1
- package/dist/server/src/register.d.ts.map +1 -1
- package/dist/server/src/services/index.d.ts +20 -10
- package/dist/server/src/services/index.d.ts.map +1 -1
- package/dist/server/src/services/permissions/actions.d.ts +14 -2
- package/dist/server/src/services/permissions/actions.d.ts.map +1 -1
- package/dist/server/src/services/permissions.d.ts +14 -2
- package/dist/server/src/services/permissions.d.ts.map +1 -1
- package/dist/server/src/services/sanitize/index.d.ts +11 -0
- package/dist/server/src/services/sanitize/index.d.ts.map +1 -0
- package/dist/server/src/utils/index.d.ts +2 -2
- package/dist/server/src/utils/index.d.ts.map +1 -1
- package/package.json +13 -13
- package/dist/_chunks/SettingsPage-B5sTcP82.mjs.map +0 -1
- package/dist/_chunks/SettingsPage-DT1sxWa2.js.map +0 -1
- package/dist/_chunks/en-BsOU9o5z.js.map +0 -1
- package/dist/_chunks/en-CM6Pjfyv.mjs.map +0 -1
- package/dist/_chunks/index-DsNqyQKx.mjs.map +0 -1
- package/dist/_chunks/index-jMrzaEb9.js.map +0 -1
- package/dist/admin/src/components/Initializer.d.ts +0 -5
- package/dist/server/src/migrations/content-type/disable/index.d.ts +0 -3
- package/dist/server/src/migrations/content-type/disable/index.d.ts.map +0 -1
- package/dist/server/src/migrations/content-type/enable/index.d.ts +0 -3
- package/dist/server/src/migrations/content-type/enable/index.d.ts.map +0 -1
- package/dist/server/src/services/entity-service-decorator.d.ts +0 -29
- package/dist/server/src/services/entity-service-decorator.d.ts.map +0 -1
- package/strapi-server.js +0 -3
@@ -1,24 +1,32 @@
|
|
1
1
|
import get from "lodash/get";
|
2
2
|
import * as yup from "yup";
|
3
|
-
import { jsxs, jsx } from "react/jsx-runtime";
|
3
|
+
import { jsxs, jsx, Fragment } from "react/jsx-runtime";
|
4
4
|
import * as React from "react";
|
5
|
-
import { Typography, Dialog, Field, Checkbox, Flex, Button
|
6
|
-
import { WarningCircle, Pencil, CrossCircle, CheckCircle, ArrowsCounterClockwise, Trash, ListPlus, Earth, EarthStriked, CaretDown } from "@strapi/icons";
|
5
|
+
import { Typography, Dialog, Field, Checkbox, Flex, Button, Modal, Box, Status, IconButton, Tooltip, SingleSelect, SingleSelectOption, VisuallyHidden, useCollator, Popover } from "@strapi/design-system";
|
6
|
+
import { WarningCircle, Pencil, CrossCircle, CheckCircle, ArrowsCounterClockwise, Trash, Plus, Download, ListPlus, Cross, Earth, EarthStriked, CaretDown } from "@strapi/icons";
|
7
7
|
import { useIntl } from "react-intl";
|
8
8
|
import { styled } from "styled-components";
|
9
|
-
import {
|
9
|
+
import { skipToken } from "@reduxjs/toolkit/query";
|
10
|
+
import { useAuth, adminApi, useTable, Table, useQueryParams, useForm, useNotification, useAPIErrorHandler } from "@strapi/admin/strapi-admin";
|
10
11
|
import { unstable_useDocument, unstable_useDocumentActions, buildValidParams } from "@strapi/content-manager/strapi-admin";
|
11
12
|
import { useParams, Link, useNavigate, matchPath } from "react-router-dom";
|
12
13
|
import * as qs from "qs";
|
13
14
|
import { stringify } from "qs";
|
14
15
|
import omit from "lodash/omit";
|
15
|
-
const __variableDynamicImportRuntimeHelper = (glob, path) => {
|
16
|
+
const __variableDynamicImportRuntimeHelper = (glob, path, segs) => {
|
16
17
|
const v = glob[path];
|
17
18
|
if (v) {
|
18
19
|
return typeof v === "function" ? v() : Promise.resolve(v);
|
19
20
|
}
|
20
21
|
return new Promise((_, reject) => {
|
21
|
-
(typeof queueMicrotask === "function" ? queueMicrotask : setTimeout)(
|
22
|
+
(typeof queueMicrotask === "function" ? queueMicrotask : setTimeout)(
|
23
|
+
reject.bind(
|
24
|
+
null,
|
25
|
+
new Error(
|
26
|
+
"Unknown variable dynamic import: " + path + (path.split("/").length !== segs ? ". Note that variables only represent file names one level deep." : "")
|
27
|
+
)
|
28
|
+
)
|
29
|
+
);
|
22
30
|
});
|
23
31
|
};
|
24
32
|
const pluginId = "i18n";
|
@@ -77,11 +85,11 @@ const CheckboxConfirmation = ({
|
|
77
85
|
}) }) })
|
78
86
|
] }) }),
|
79
87
|
/* @__PURE__ */ jsxs(Dialog.Footer, { children: [
|
80
|
-
/* @__PURE__ */ jsx(Dialog.Cancel, { children: /* @__PURE__ */ jsx(Button
|
88
|
+
/* @__PURE__ */ jsx(Dialog.Cancel, { children: /* @__PURE__ */ jsx(Button, { variant: "tertiary", children: formatMessage({
|
81
89
|
id: "components.popUpWarning.button.cancel",
|
82
90
|
defaultMessage: "No, cancel"
|
83
91
|
}) }) }),
|
84
|
-
/* @__PURE__ */ jsx(Dialog.Action, { children: /* @__PURE__ */ jsx(Button
|
92
|
+
/* @__PURE__ */ jsx(Dialog.Action, { children: /* @__PURE__ */ jsx(Button, { variant: "danger-light", onClick: handleConfirm, children: formatMessage({
|
85
93
|
id: getTranslation("CheckboxConfirmation.Modal.button-confirm"),
|
86
94
|
defaultMessage: "Yes, disable"
|
87
95
|
}) }) })
|
@@ -136,7 +144,7 @@ const useI18n = () => {
|
|
136
144
|
model: params.slug
|
137
145
|
},
|
138
146
|
{
|
139
|
-
skip:
|
147
|
+
skip: true
|
140
148
|
}
|
141
149
|
);
|
142
150
|
if (doesPluginOptionsHaveI18nLocalized(schema?.pluginOptions)) {
|
@@ -216,10 +224,94 @@ const relationsApi = i18nApi.injectEndpoints({
|
|
216
224
|
})
|
217
225
|
});
|
218
226
|
const { useGetManyDraftRelationCountQuery } = relationsApi;
|
227
|
+
const cleanData = (data, schema, components) => {
|
228
|
+
const cleanedData = removeFields(data, [
|
229
|
+
"createdAt",
|
230
|
+
"createdBy",
|
231
|
+
"updatedAt",
|
232
|
+
"updatedBy",
|
233
|
+
"id",
|
234
|
+
"documentId",
|
235
|
+
"publishedAt",
|
236
|
+
"strapi_stage",
|
237
|
+
"strapi_assignee",
|
238
|
+
"locale",
|
239
|
+
"status"
|
240
|
+
]);
|
241
|
+
const cleanedDataWithoutPasswordAndRelation = recursiveRemoveFieldTypes(
|
242
|
+
cleanedData,
|
243
|
+
schema,
|
244
|
+
components,
|
245
|
+
["relation", "password"]
|
246
|
+
);
|
247
|
+
return cleanedDataWithoutPasswordAndRelation;
|
248
|
+
};
|
249
|
+
const removeFields = (data, fields) => {
|
250
|
+
return Object.keys(data).reduce((acc, current) => {
|
251
|
+
if (fields.includes(current)) {
|
252
|
+
return acc;
|
253
|
+
}
|
254
|
+
acc[current] = data[current];
|
255
|
+
return acc;
|
256
|
+
}, {});
|
257
|
+
};
|
258
|
+
const recursiveRemoveFieldTypes = (data, schema, components, fields) => {
|
259
|
+
return Object.keys(data).reduce((acc, current) => {
|
260
|
+
const attribute = schema.attributes[current] ?? { type: void 0 };
|
261
|
+
if (fields.includes(attribute.type)) {
|
262
|
+
return acc;
|
263
|
+
}
|
264
|
+
if (attribute.type === "dynamiczone") {
|
265
|
+
acc[current] = data[current].map((componentValue, index2) => {
|
266
|
+
const { id: _, ...rest } = recursiveRemoveFieldTypes(
|
267
|
+
componentValue,
|
268
|
+
components[componentValue.__component],
|
269
|
+
components,
|
270
|
+
fields
|
271
|
+
);
|
272
|
+
return {
|
273
|
+
...rest,
|
274
|
+
__temp_key__: index2 + 1
|
275
|
+
};
|
276
|
+
});
|
277
|
+
} else if (attribute.type === "component") {
|
278
|
+
const { repeatable, component } = attribute;
|
279
|
+
if (repeatable) {
|
280
|
+
acc[current] = (data[current] ?? []).map((compoData, index2) => {
|
281
|
+
const { id: _, ...rest } = recursiveRemoveFieldTypes(
|
282
|
+
compoData,
|
283
|
+
components[component],
|
284
|
+
components,
|
285
|
+
fields
|
286
|
+
);
|
287
|
+
return {
|
288
|
+
...rest,
|
289
|
+
__temp_key__: index2 + 1
|
290
|
+
};
|
291
|
+
});
|
292
|
+
} else {
|
293
|
+
const { id: _, ...rest } = recursiveRemoveFieldTypes(
|
294
|
+
data[current] ?? {},
|
295
|
+
components[component],
|
296
|
+
components,
|
297
|
+
fields
|
298
|
+
);
|
299
|
+
acc[current] = rest;
|
300
|
+
}
|
301
|
+
} else {
|
302
|
+
acc[current] = data[current];
|
303
|
+
}
|
304
|
+
return acc;
|
305
|
+
}, {});
|
306
|
+
};
|
219
307
|
const isErrorMessageDescriptor = (object) => {
|
220
308
|
return typeof object === "object" && object !== null && "id" in object && "defaultMessage" in object;
|
221
309
|
};
|
222
|
-
const EntryValidationText = ({
|
310
|
+
const EntryValidationText = ({
|
311
|
+
status = "draft",
|
312
|
+
validationErrors,
|
313
|
+
action
|
314
|
+
}) => {
|
223
315
|
const { formatMessage } = useIntl();
|
224
316
|
const getErrorStr = (key, value) => {
|
225
317
|
if (typeof value === "string") {
|
@@ -253,30 +345,63 @@ const EntryValidationText = ({ status = "draft", validationErrors }) => {
|
|
253
345
|
) })
|
254
346
|
] });
|
255
347
|
}
|
256
|
-
|
257
|
-
|
258
|
-
|
259
|
-
|
260
|
-
|
261
|
-
|
262
|
-
|
263
|
-
|
264
|
-
|
265
|
-
|
266
|
-
|
267
|
-
|
268
|
-
|
269
|
-
|
270
|
-
|
271
|
-
|
272
|
-
|
273
|
-
|
348
|
+
const getStatusMessage = () => {
|
349
|
+
if (action === "bulk-publish") {
|
350
|
+
if (status === "published") {
|
351
|
+
return {
|
352
|
+
icon: /* @__PURE__ */ jsx(CheckCircle, { fill: "success600" }),
|
353
|
+
text: formatMessage({
|
354
|
+
id: "content-manager.bulk-publish.already-published",
|
355
|
+
defaultMessage: "Already Published"
|
356
|
+
}),
|
357
|
+
textColor: "success600",
|
358
|
+
fontWeight: "bold"
|
359
|
+
};
|
360
|
+
} else if (status === "modified") {
|
361
|
+
return {
|
362
|
+
icon: /* @__PURE__ */ jsx(ArrowsCounterClockwise, { fill: "alternative600" }),
|
363
|
+
text: formatMessage({
|
364
|
+
id: "app.utils.ready-to-publish-changes",
|
365
|
+
defaultMessage: "Ready to publish changes"
|
366
|
+
})
|
367
|
+
};
|
368
|
+
} else {
|
369
|
+
return {
|
370
|
+
icon: /* @__PURE__ */ jsx(CheckCircle, { fill: "success600" }),
|
371
|
+
text: formatMessage({
|
372
|
+
id: "app.utils.ready-to-publish",
|
373
|
+
defaultMessage: "Ready to publish"
|
374
|
+
})
|
375
|
+
};
|
376
|
+
}
|
377
|
+
} else {
|
378
|
+
if (status === "draft") {
|
379
|
+
return {
|
380
|
+
icon: /* @__PURE__ */ jsx(CheckCircle, { fill: "success600" }),
|
381
|
+
text: formatMessage({
|
382
|
+
id: "content-manager.bulk-unpublish.already-unpublished",
|
383
|
+
defaultMessage: "Already Unpublished"
|
384
|
+
}),
|
385
|
+
textColor: "success600",
|
386
|
+
fontWeight: "bold"
|
387
|
+
};
|
388
|
+
} else {
|
389
|
+
return {
|
390
|
+
icon: /* @__PURE__ */ jsx(CheckCircle, { fill: "success600" }),
|
391
|
+
text: formatMessage({
|
392
|
+
id: "app.utils.ready-to-unpublish-changes",
|
393
|
+
defaultMessage: "Ready to unpublish"
|
394
|
+
}),
|
395
|
+
textColor: "success600",
|
396
|
+
fontWeight: "bold"
|
397
|
+
};
|
398
|
+
}
|
399
|
+
}
|
400
|
+
};
|
401
|
+
const { icon, text, textColor = "success600", fontWeight = "normal" } = getStatusMessage();
|
274
402
|
return /* @__PURE__ */ jsxs(Flex, { gap: 2, children: [
|
275
|
-
|
276
|
-
/* @__PURE__ */ jsx(Typography, { children:
|
277
|
-
id: "app.utils.ready-to-publish",
|
278
|
-
defaultMessage: "Ready to publish"
|
279
|
-
}) })
|
403
|
+
icon,
|
404
|
+
/* @__PURE__ */ jsx(Typography, { textColor, fontWeight, children: text })
|
280
405
|
] });
|
281
406
|
};
|
282
407
|
const BoldChunk = (chunks) => /* @__PURE__ */ jsx(Typography, { fontWeight: "bold", children: chunks });
|
@@ -284,7 +409,8 @@ const BulkLocaleActionModal = ({
|
|
284
409
|
headers,
|
285
410
|
rows,
|
286
411
|
localesMetadata,
|
287
|
-
validationErrors = {}
|
412
|
+
validationErrors = {},
|
413
|
+
action
|
288
414
|
}) => {
|
289
415
|
const { formatMessage } = useIntl();
|
290
416
|
const selectedRows = useTable(
|
@@ -297,27 +423,29 @@ const BulkLocaleActionModal = ({
|
|
297
423
|
return acc;
|
298
424
|
}, {});
|
299
425
|
const localesWithErrors = Object.keys(validationErrors);
|
300
|
-
const
|
426
|
+
const publishedCount = selectedRows.filter(
|
301
427
|
({ locale }) => currentStatusByLocale[locale] === "published"
|
302
428
|
).length;
|
303
|
-
const
|
429
|
+
const draftCount = selectedRows.filter(
|
304
430
|
({ locale }) => (currentStatusByLocale[locale] === "draft" || currentStatusByLocale[locale] === "modified") && !localesWithErrors.includes(locale)
|
305
431
|
).length;
|
306
432
|
const withErrorsCount = localesWithErrors.length;
|
433
|
+
const messageId = action === "bulk-publish" ? "content-manager.containers.list.selectedEntriesModal.selectedCount.publish" : "content-manager.containers.list.selectedEntriesModal.selectedCount.unpublish";
|
434
|
+
const defaultMessage = action === "bulk-publish" ? "<b>{publishedCount}</b> {publishedCount, plural, =0 {entries} one {entry} other {entries}} already published. <b>{draftCount}</b> {draftCount, plural, =0 {entries} one {entry} other {entries}} ready to publish. <b>{withErrorsCount}</b> {withErrorsCount, plural, =0 {entries} one {entry} other {entries}} waiting for action." : "<b>{draftCount}</b> {draftCount, plural, =0 {entries} one {entry} other {entries}} already unpublished. <b>{publishedCount}</b> {publishedCount, plural, =0 {entries} one {entry} other {entries}} ready to unpublish.";
|
307
435
|
return formatMessage(
|
308
436
|
{
|
309
|
-
id:
|
310
|
-
defaultMessage
|
437
|
+
id: messageId,
|
438
|
+
defaultMessage
|
311
439
|
},
|
312
440
|
{
|
313
441
|
withErrorsCount,
|
314
|
-
|
315
|
-
|
442
|
+
draftCount,
|
443
|
+
publishedCount,
|
316
444
|
b: BoldChunk
|
317
445
|
}
|
318
446
|
);
|
319
447
|
};
|
320
|
-
return /* @__PURE__ */ jsxs(
|
448
|
+
return /* @__PURE__ */ jsxs(Modal.Body, { children: [
|
321
449
|
/* @__PURE__ */ jsx(Typography, { children: getFormattedCountMessage() }),
|
322
450
|
/* @__PURE__ */ jsx(Box, { marginTop: 5, children: /* @__PURE__ */ jsxs(Table.Content, { children: [
|
323
451
|
/* @__PURE__ */ jsxs(Table.Head, { children: [
|
@@ -338,13 +466,12 @@ const BulkLocaleActionModal = ({
|
|
338
466
|
paddingRight: "6px",
|
339
467
|
paddingTop: "2px",
|
340
468
|
paddingBottom: "2px",
|
341
|
-
showBullet: false,
|
342
469
|
size: "S",
|
343
470
|
variant: statusVariant,
|
344
471
|
children: /* @__PURE__ */ jsx(Typography, { tag: "span", variant: "pi", fontWeight: "bold", children: capitalize(status) })
|
345
472
|
}
|
346
473
|
) }) }),
|
347
|
-
/* @__PURE__ */ jsx(Table.Cell, { children: /* @__PURE__ */ jsx(EntryValidationText, { validationErrors: error, status }) }),
|
474
|
+
/* @__PURE__ */ jsx(Table.Cell, { children: /* @__PURE__ */ jsx(EntryValidationText, { validationErrors: error, status, action }) }),
|
348
475
|
/* @__PURE__ */ jsx(Table.Cell, { children: /* @__PURE__ */ jsx(
|
349
476
|
IconButton,
|
350
477
|
{
|
@@ -361,7 +488,7 @@ const BulkLocaleActionModal = ({
|
|
361
488
|
name: locale
|
362
489
|
}
|
363
490
|
),
|
364
|
-
|
491
|
+
variant: "ghost",
|
365
492
|
children: /* @__PURE__ */ jsx(Pencil, {})
|
366
493
|
}
|
367
494
|
) })
|
@@ -370,6 +497,47 @@ const BulkLocaleActionModal = ({
|
|
370
497
|
] }) })
|
371
498
|
] });
|
372
499
|
};
|
500
|
+
const statusVariants = {
|
501
|
+
draft: "secondary",
|
502
|
+
published: "success",
|
503
|
+
modified: "alternative"
|
504
|
+
};
|
505
|
+
const LocaleOption = ({
|
506
|
+
isDraftAndPublishEnabled,
|
507
|
+
locale,
|
508
|
+
status,
|
509
|
+
entryExists
|
510
|
+
}) => {
|
511
|
+
const { formatMessage } = useIntl();
|
512
|
+
if (!entryExists) {
|
513
|
+
return formatMessage(
|
514
|
+
{
|
515
|
+
id: getTranslation("CMEditViewLocalePicker.locale.create"),
|
516
|
+
defaultMessage: "Create <bold>{locale}</bold> locale"
|
517
|
+
},
|
518
|
+
{
|
519
|
+
bold: (locale2) => /* @__PURE__ */ jsx("b", { children: locale2 }),
|
520
|
+
locale: locale.name
|
521
|
+
}
|
522
|
+
);
|
523
|
+
}
|
524
|
+
return /* @__PURE__ */ jsxs(Flex, { width: "100%", gap: 1, justifyContent: "space-between", children: [
|
525
|
+
/* @__PURE__ */ jsx(Typography, { children: locale.name }),
|
526
|
+
isDraftAndPublishEnabled ? /* @__PURE__ */ jsx(
|
527
|
+
Status,
|
528
|
+
{
|
529
|
+
display: "flex",
|
530
|
+
paddingLeft: "6px",
|
531
|
+
paddingRight: "6px",
|
532
|
+
paddingTop: "2px",
|
533
|
+
paddingBottom: "2px",
|
534
|
+
size: "S",
|
535
|
+
variant: statusVariants[status],
|
536
|
+
children: /* @__PURE__ */ jsx(Typography, { tag: "span", variant: "pi", fontWeight: "bold", children: capitalize(status) })
|
537
|
+
}
|
538
|
+
) : null
|
539
|
+
] });
|
540
|
+
};
|
373
541
|
const LocalePickerAction = ({
|
374
542
|
document,
|
375
543
|
meta,
|
@@ -381,7 +549,13 @@ const LocalePickerAction = ({
|
|
381
549
|
const [{ query }, setQuery] = useQueryParams();
|
382
550
|
const { hasI18n, canCreate, canRead } = useI18n();
|
383
551
|
const { data: locales = [] } = useGetLocalesQuery();
|
384
|
-
const
|
552
|
+
const currentDesiredLocale = query.plugins?.i18n?.locale;
|
553
|
+
const { schema } = unstable_useDocument({
|
554
|
+
model,
|
555
|
+
collectionType,
|
556
|
+
documentId,
|
557
|
+
params: { locale: currentDesiredLocale }
|
558
|
+
});
|
385
559
|
const handleSelect = React.useCallback(
|
386
560
|
(value) => {
|
387
561
|
setQuery({
|
@@ -399,53 +573,50 @@ const LocalePickerAction = ({
|
|
399
573
|
if (!Array.isArray(locales) || !hasI18n) {
|
400
574
|
return;
|
401
575
|
}
|
402
|
-
const currentDesiredLocale = query.plugins?.i18n?.locale;
|
403
576
|
const doesLocaleExist = locales.find((loc) => loc.code === currentDesiredLocale);
|
404
577
|
const defaultLocale = locales.find((locale) => locale.isDefault);
|
405
578
|
if (!doesLocaleExist && defaultLocale?.code) {
|
406
579
|
handleSelect(defaultLocale.code);
|
407
580
|
}
|
408
|
-
}, [handleSelect, hasI18n, locales,
|
581
|
+
}, [handleSelect, hasI18n, locales, currentDesiredLocale]);
|
582
|
+
const currentLocale = Array.isArray(locales) ? locales.find((locale) => locale.code === currentDesiredLocale) : void 0;
|
583
|
+
const allCurrentLocales = [
|
584
|
+
{ status: getDocumentStatus(document, meta), locale: currentLocale?.code },
|
585
|
+
...document?.localizations ?? []
|
586
|
+
];
|
409
587
|
if (!hasI18n || !Array.isArray(locales) || locales.length === 0) {
|
410
588
|
return null;
|
411
589
|
}
|
412
|
-
const
|
413
|
-
|
414
|
-
|
415
|
-
...meta?.availableLocales ?? []
|
416
|
-
];
|
590
|
+
const displayedLocales = locales.filter((locale) => {
|
591
|
+
return canRead.includes(locale.code);
|
592
|
+
});
|
417
593
|
return {
|
418
594
|
label: formatMessage({
|
419
595
|
id: getTranslation("Settings.locales.modal.locales.label"),
|
420
596
|
defaultMessage: "Locales"
|
421
597
|
}),
|
422
|
-
options:
|
598
|
+
options: displayedLocales.map((locale) => {
|
599
|
+
const entryWithLocaleExists = allCurrentLocales.some((doc) => doc.locale === locale.code);
|
423
600
|
const currentLocaleDoc = allCurrentLocales.find(
|
424
601
|
(doc) => "locale" in doc ? doc.locale === locale.code : false
|
425
602
|
);
|
426
|
-
const
|
427
|
-
const permissionsToCheck = currentLocaleDoc ? canCreate : canRead;
|
428
|
-
const statusVariant = status === "draft" ? "primary" : status === "published" ? "success" : "alternative";
|
603
|
+
const permissionsToCheck = currentLocaleDoc ? canRead : canCreate;
|
429
604
|
return {
|
430
605
|
disabled: !permissionsToCheck.includes(locale.code),
|
431
606
|
value: locale.code,
|
432
|
-
label:
|
433
|
-
|
434
|
-
Status,
|
607
|
+
label: /* @__PURE__ */ jsx(
|
608
|
+
LocaleOption,
|
435
609
|
{
|
436
|
-
|
437
|
-
|
438
|
-
|
439
|
-
|
440
|
-
paddingBottom: "2px",
|
441
|
-
showBullet: false,
|
442
|
-
size: "S",
|
443
|
-
variant: statusVariant,
|
444
|
-
children: /* @__PURE__ */ jsx(Typography, { tag: "span", variant: "pi", fontWeight: "bold", children: capitalize(status) })
|
610
|
+
isDraftAndPublishEnabled: !!schema?.options?.draftAndPublish,
|
611
|
+
locale,
|
612
|
+
status: currentLocaleDoc?.status,
|
613
|
+
entryExists: entryWithLocaleExists
|
445
614
|
}
|
446
|
-
)
|
615
|
+
),
|
616
|
+
startIcon: !entryWithLocaleExists ? /* @__PURE__ */ jsx(Plus, {}) : null
|
447
617
|
};
|
448
618
|
}),
|
619
|
+
customizeContent: () => currentLocale?.name,
|
449
620
|
onSelect: handleSelect,
|
450
621
|
value: currentLocale
|
451
622
|
};
|
@@ -461,6 +632,99 @@ const getDocumentStatus = (document, meta) => {
|
|
461
632
|
}
|
462
633
|
return docStatus;
|
463
634
|
};
|
635
|
+
const FillFromAnotherLocaleAction = ({
|
636
|
+
documentId,
|
637
|
+
meta,
|
638
|
+
model,
|
639
|
+
collectionType
|
640
|
+
}) => {
|
641
|
+
const { formatMessage } = useIntl();
|
642
|
+
const [{ query }] = useQueryParams();
|
643
|
+
const { hasI18n } = useI18n();
|
644
|
+
const currentDesiredLocale = query.plugins?.i18n?.locale;
|
645
|
+
const [localeSelected, setLocaleSelected] = React.useState(null);
|
646
|
+
const setValues = useForm("FillFromAnotherLocale", (state) => state.setValues);
|
647
|
+
const { getDocument } = unstable_useDocumentActions();
|
648
|
+
const { schema, components } = unstable_useDocument({
|
649
|
+
model,
|
650
|
+
documentId,
|
651
|
+
collectionType,
|
652
|
+
params: { locale: currentDesiredLocale }
|
653
|
+
});
|
654
|
+
const { data: locales = [] } = useGetLocalesQuery();
|
655
|
+
const availableLocales = Array.isArray(locales) ? locales.filter((locale) => meta?.availableLocales.some((l) => l.locale === locale.code)) : [];
|
656
|
+
const fillFromLocale = (onClose) => async () => {
|
657
|
+
const response = await getDocument({
|
658
|
+
collectionType,
|
659
|
+
model,
|
660
|
+
documentId,
|
661
|
+
params: { locale: localeSelected }
|
662
|
+
});
|
663
|
+
if (!response || !schema) {
|
664
|
+
return;
|
665
|
+
}
|
666
|
+
const { data } = response;
|
667
|
+
const cleanedData = cleanData(data, schema, components);
|
668
|
+
setValues(cleanedData);
|
669
|
+
onClose();
|
670
|
+
};
|
671
|
+
if (!hasI18n) {
|
672
|
+
return null;
|
673
|
+
}
|
674
|
+
return {
|
675
|
+
type: "icon",
|
676
|
+
icon: /* @__PURE__ */ jsx(Download, {}),
|
677
|
+
disabled: availableLocales.length === 0,
|
678
|
+
label: formatMessage({
|
679
|
+
id: getTranslation("CMEditViewCopyLocale.copy-text"),
|
680
|
+
defaultMessage: "Fill in from another locale"
|
681
|
+
}),
|
682
|
+
dialog: {
|
683
|
+
type: "dialog",
|
684
|
+
title: formatMessage({
|
685
|
+
id: getTranslation("CMEditViewCopyLocale.dialog.title"),
|
686
|
+
defaultMessage: "Confirmation"
|
687
|
+
}),
|
688
|
+
content: ({ onClose }) => /* @__PURE__ */ jsxs(Fragment, { children: [
|
689
|
+
/* @__PURE__ */ jsx(Dialog.Body, { children: /* @__PURE__ */ jsxs(Flex, { direction: "column", gap: 3, children: [
|
690
|
+
/* @__PURE__ */ jsx(WarningCircle, { width: "24px", height: "24px", fill: "danger600" }),
|
691
|
+
/* @__PURE__ */ jsx(Typography, { textAlign: "center", children: formatMessage({
|
692
|
+
id: getTranslation("CMEditViewCopyLocale.dialog.body"),
|
693
|
+
defaultMessage: "Your current content will be erased and filled by the content of the selected locale:"
|
694
|
+
}) }),
|
695
|
+
/* @__PURE__ */ jsxs(Field.Root, { width: "100%", children: [
|
696
|
+
/* @__PURE__ */ jsx(Field.Label, { children: formatMessage({
|
697
|
+
id: getTranslation("CMEditViewCopyLocale.dialog.field.label"),
|
698
|
+
defaultMessage: "Locale"
|
699
|
+
}) }),
|
700
|
+
/* @__PURE__ */ jsx(
|
701
|
+
SingleSelect,
|
702
|
+
{
|
703
|
+
value: localeSelected,
|
704
|
+
placeholder: formatMessage({
|
705
|
+
id: getTranslation("CMEditViewCopyLocale.dialog.field.placeholder"),
|
706
|
+
defaultMessage: "Select one locale..."
|
707
|
+
}),
|
708
|
+
onChange: (value) => setLocaleSelected(value),
|
709
|
+
children: availableLocales.map((locale) => /* @__PURE__ */ jsx(SingleSelectOption, { value: locale.code, children: locale.name }, locale.code))
|
710
|
+
}
|
711
|
+
)
|
712
|
+
] })
|
713
|
+
] }) }),
|
714
|
+
/* @__PURE__ */ jsx(Dialog.Footer, { children: /* @__PURE__ */ jsxs(Flex, { gap: 2, width: "100%", children: [
|
715
|
+
/* @__PURE__ */ jsx(Button, { flex: "auto", variant: "tertiary", onClick: onClose, children: formatMessage({
|
716
|
+
id: getTranslation("CMEditViewCopyLocale.cancel-text"),
|
717
|
+
defaultMessage: "No, cancel"
|
718
|
+
}) }),
|
719
|
+
/* @__PURE__ */ jsx(Button, { flex: "auto", variant: "success", onClick: fillFromLocale(onClose), children: formatMessage({
|
720
|
+
id: getTranslation("CMEditViewCopyLocale.submit-text"),
|
721
|
+
defaultMessage: "Yes, fill in"
|
722
|
+
}) })
|
723
|
+
] }) })
|
724
|
+
] })
|
725
|
+
}
|
726
|
+
};
|
727
|
+
};
|
464
728
|
const DeleteLocaleAction = ({
|
465
729
|
document,
|
466
730
|
documentId,
|
@@ -472,16 +736,23 @@ const DeleteLocaleAction = ({
|
|
472
736
|
const { toggleNotification } = useNotification();
|
473
737
|
const { delete: deleteAction } = unstable_useDocumentActions();
|
474
738
|
const { hasI18n, canDelete } = useI18n();
|
739
|
+
const [{ query }] = useQueryParams();
|
740
|
+
const { data: locales = [] } = useGetLocalesQuery();
|
741
|
+
const currentDesiredLocale = query.plugins?.i18n?.locale;
|
742
|
+
const locale = !("error" in locales) && locales.find((loc) => loc.code === currentDesiredLocale);
|
475
743
|
if (!hasI18n) {
|
476
744
|
return null;
|
477
745
|
}
|
478
746
|
return {
|
479
747
|
disabled: document?.locale && !canDelete.includes(document.locale) || !document || !document.id,
|
480
748
|
position: ["header", "table-row"],
|
481
|
-
label: formatMessage(
|
482
|
-
|
483
|
-
|
484
|
-
|
749
|
+
label: formatMessage(
|
750
|
+
{
|
751
|
+
id: getTranslation("actions.delete.label"),
|
752
|
+
defaultMessage: "Delete entry ({locale})"
|
753
|
+
},
|
754
|
+
{ locale: locale && locale.name }
|
755
|
+
),
|
485
756
|
icon: /* @__PURE__ */ jsx(StyledTrash, {}),
|
486
757
|
variant: "danger",
|
487
758
|
dialog: {
|
@@ -498,7 +769,12 @@ const DeleteLocaleAction = ({
|
|
498
769
|
}) })
|
499
770
|
] }),
|
500
771
|
onConfirm: async () => {
|
501
|
-
|
772
|
+
const unableToDelete = (
|
773
|
+
// We are unable to delete a collection type without a document ID
|
774
|
+
// & unable to delete generally if there is no document locale
|
775
|
+
collectionType !== "single-types" && !documentId || !document?.locale
|
776
|
+
);
|
777
|
+
if (unableToDelete) {
|
502
778
|
console.error(
|
503
779
|
"You're trying to delete a document without an id or locale, this is likely a bug with Strapi. Please open an issue."
|
504
780
|
);
|
@@ -524,37 +800,39 @@ const DeleteLocaleAction = ({
|
|
524
800
|
}
|
525
801
|
};
|
526
802
|
};
|
527
|
-
const
|
528
|
-
document
|
803
|
+
const BulkLocaleAction = ({
|
804
|
+
document,
|
529
805
|
documentId,
|
530
806
|
model,
|
531
|
-
collectionType
|
807
|
+
collectionType,
|
808
|
+
action
|
532
809
|
}) => {
|
533
|
-
const
|
810
|
+
const locale = document?.locale ?? null;
|
534
811
|
const [{ query }] = useQueryParams();
|
535
812
|
const params = React.useMemo(() => buildValidParams(query), [query]);
|
536
|
-
const
|
813
|
+
const isOnPublishedTab = query.status === "published";
|
537
814
|
const { formatMessage } = useIntl();
|
538
815
|
const { hasI18n, canPublish } = useI18n();
|
539
816
|
const { toggleNotification } = useNotification();
|
540
817
|
const { _unstableFormatAPIError: formatAPIError } = useAPIErrorHandler();
|
541
818
|
const [selectedRows, setSelectedRows] = React.useState([]);
|
542
819
|
const [isDraftRelationConfirmationOpen, setIsDraftRelationConfirmationOpen] = React.useState(false);
|
543
|
-
const { publishMany: publishManyAction } = unstable_useDocumentActions();
|
544
|
-
const {
|
545
|
-
|
546
|
-
|
547
|
-
|
548
|
-
|
549
|
-
|
550
|
-
|
551
|
-
|
552
|
-
|
553
|
-
|
554
|
-
|
820
|
+
const { publishMany: publishManyAction, unpublishMany: unpublishManyAction } = unstable_useDocumentActions();
|
821
|
+
const { schema, validate } = unstable_useDocument(
|
822
|
+
{
|
823
|
+
model,
|
824
|
+
collectionType,
|
825
|
+
documentId,
|
826
|
+
params: {
|
827
|
+
locale
|
828
|
+
}
|
829
|
+
},
|
830
|
+
{
|
831
|
+
// No need to fetch the document, the data is already available in the `document` prop
|
832
|
+
skip: true
|
555
833
|
}
|
556
|
-
|
557
|
-
const { data: localesMetadata = [] } = useGetLocalesQuery();
|
834
|
+
);
|
835
|
+
const { data: localesMetadata = [] } = useGetLocalesQuery(hasI18n ? void 0 : skipToken);
|
558
836
|
const headers = [
|
559
837
|
{
|
560
838
|
label: formatMessage({
|
@@ -579,18 +857,19 @@ const BulkLocalePublishAction = ({
|
|
579
857
|
}
|
580
858
|
];
|
581
859
|
const [rows, validationErrors] = React.useMemo(() => {
|
582
|
-
if (!document
|
860
|
+
if (!document) {
|
583
861
|
return [[], {}];
|
584
862
|
}
|
585
|
-
const
|
586
|
-
|
587
|
-
|
863
|
+
const localizations = document.localizations ?? [];
|
864
|
+
const locales = localizations.map((doc) => {
|
865
|
+
const { locale: locale2, status } = doc;
|
866
|
+
return { locale: locale2, status };
|
588
867
|
});
|
589
|
-
|
868
|
+
locales.unshift({
|
590
869
|
locale: document.locale,
|
591
870
|
status: document.status
|
592
871
|
});
|
593
|
-
const allDocuments = [document, ...
|
872
|
+
const allDocuments = [document, ...localizations];
|
594
873
|
const errors = allDocuments.reduce((errs, document2) => {
|
595
874
|
if (!document2) {
|
596
875
|
return errs;
|
@@ -601,14 +880,21 @@ const BulkLocalePublishAction = ({
|
|
601
880
|
}
|
602
881
|
return errs;
|
603
882
|
}, {});
|
604
|
-
return [
|
605
|
-
}, [document,
|
606
|
-
const
|
607
|
-
|
883
|
+
return [locales, errors];
|
884
|
+
}, [document, validate]);
|
885
|
+
const isBulkPublish = action === "bulk-publish";
|
886
|
+
const localesForAction = selectedRows.reduce((acc, selectedRow) => {
|
887
|
+
const isValidLocale = (
|
888
|
+
// Validation errors are irrelevant if we are trying to unpublish
|
889
|
+
!isBulkPublish || !Object.keys(validationErrors).includes(selectedRow.locale)
|
890
|
+
);
|
891
|
+
const shouldAddLocale = isBulkPublish ? selectedRow.status !== "published" && isValidLocale : selectedRow.status !== "draft" && isValidLocale;
|
892
|
+
if (shouldAddLocale) {
|
608
893
|
acc.push(selectedRow.locale);
|
609
894
|
}
|
610
895
|
return acc;
|
611
896
|
}, []);
|
897
|
+
const enableDraftRelationsCount = false;
|
612
898
|
const {
|
613
899
|
data: draftRelationsCount = 0,
|
614
900
|
isLoading: isDraftRelationsLoading,
|
@@ -617,10 +903,10 @@ const BulkLocalePublishAction = ({
|
|
617
903
|
{
|
618
904
|
model,
|
619
905
|
documentIds: [documentId],
|
620
|
-
locale:
|
906
|
+
locale: localesForAction
|
621
907
|
},
|
622
908
|
{
|
623
|
-
skip: !
|
909
|
+
skip: !enableDraftRelationsCount
|
624
910
|
}
|
625
911
|
);
|
626
912
|
React.useEffect(() => {
|
@@ -646,7 +932,18 @@ const BulkLocalePublishAction = ({
|
|
646
932
|
documentIds: [documentId],
|
647
933
|
params: {
|
648
934
|
...params,
|
649
|
-
locale:
|
935
|
+
locale: localesForAction
|
936
|
+
}
|
937
|
+
});
|
938
|
+
setSelectedRows([]);
|
939
|
+
};
|
940
|
+
const unpublish = async () => {
|
941
|
+
await unpublishManyAction({
|
942
|
+
model,
|
943
|
+
documentIds: [documentId],
|
944
|
+
params: {
|
945
|
+
...params,
|
946
|
+
locale: localesForAction
|
650
947
|
}
|
651
948
|
});
|
652
949
|
setSelectedRows([]);
|
@@ -654,14 +951,12 @@ const BulkLocalePublishAction = ({
|
|
654
951
|
const handleAction = async () => {
|
655
952
|
if (draftRelationsCount > 0) {
|
656
953
|
setIsDraftRelationConfirmationOpen(true);
|
657
|
-
} else {
|
954
|
+
} else if (isBulkPublish) {
|
658
955
|
await publish();
|
956
|
+
} else {
|
957
|
+
await unpublish();
|
659
958
|
}
|
660
959
|
};
|
661
|
-
const isUnpublish = document?.status === "published";
|
662
|
-
if (isUnpublish) {
|
663
|
-
console.warn(["I18N"], "Bulk locale unpublish modal not implemented");
|
664
|
-
}
|
665
960
|
if (isDraftRelationConfirmationOpen) {
|
666
961
|
return {
|
667
962
|
label: formatMessage({
|
@@ -696,20 +991,21 @@ const BulkLocalePublishAction = ({
|
|
696
991
|
}
|
697
992
|
};
|
698
993
|
}
|
994
|
+
const hasPermission = selectedRows.map(({ locale: locale2 }) => locale2).every((locale2) => canPublish.includes(locale2));
|
699
995
|
return {
|
700
996
|
label: formatMessage({
|
701
|
-
id: getTranslation("
|
702
|
-
defaultMessage: "Publish Multiple Locales
|
997
|
+
id: getTranslation(`CMEditViewBulkLocale.${isBulkPublish ? "publish" : "unpublish"}-title`),
|
998
|
+
defaultMessage: `${isBulkPublish ? "Publish" : "Unpublish"} Multiple Locales`
|
703
999
|
}),
|
704
|
-
|
705
|
-
|
1000
|
+
variant: isBulkPublish ? "secondary" : "danger",
|
1001
|
+
icon: isBulkPublish ? /* @__PURE__ */ jsx(ListPlus, {}) : /* @__PURE__ */ jsx(Cross, {}),
|
1002
|
+
disabled: isOnPublishedTab || canPublish.length === 0,
|
706
1003
|
position: ["panel"],
|
707
|
-
variant: "secondary",
|
708
1004
|
dialog: {
|
709
1005
|
type: "modal",
|
710
1006
|
title: formatMessage({
|
711
|
-
id: getTranslation("
|
712
|
-
defaultMessage: "Publish Multiple Locales
|
1007
|
+
id: getTranslation(`CMEditViewBulkLocale.${isBulkPublish ? "publish" : "unpublish"}-title`),
|
1008
|
+
defaultMessage: `${isBulkPublish ? "Publish" : "Unpublish"} Multiple Locales`
|
713
1009
|
}),
|
714
1010
|
content: () => {
|
715
1011
|
return /* @__PURE__ */ jsx(
|
@@ -728,28 +1024,35 @@ const BulkLocalePublishAction = ({
|
|
728
1024
|
validationErrors,
|
729
1025
|
headers,
|
730
1026
|
rows,
|
731
|
-
localesMetadata
|
1027
|
+
localesMetadata,
|
1028
|
+
action: action ?? "bulk-publish"
|
732
1029
|
}
|
733
1030
|
)
|
734
1031
|
}
|
735
1032
|
);
|
736
1033
|
},
|
737
|
-
footer: () => /* @__PURE__ */ jsx(
|
738
|
-
Button
|
1034
|
+
footer: () => /* @__PURE__ */ jsx(Modal.Footer, { justifyContent: "flex-end", children: /* @__PURE__ */ jsx(
|
1035
|
+
Button,
|
739
1036
|
{
|
740
1037
|
loading: isDraftRelationsLoading,
|
741
|
-
disabled:
|
1038
|
+
disabled: !hasPermission || localesForAction.length === 0,
|
742
1039
|
variant: "default",
|
743
1040
|
onClick: handleAction,
|
744
1041
|
children: formatMessage({
|
745
|
-
id: "app.utils.publish",
|
746
|
-
defaultMessage: "Publish"
|
1042
|
+
id: isBulkPublish ? "app.utils.publish" : "app.utils.unpublish",
|
1043
|
+
defaultMessage: isBulkPublish ? "Publish" : "Unpublish"
|
747
1044
|
})
|
748
1045
|
}
|
749
1046
|
) })
|
750
1047
|
}
|
751
1048
|
};
|
752
1049
|
};
|
1050
|
+
const BulkLocalePublishAction = (props) => {
|
1051
|
+
return BulkLocaleAction({ action: "bulk-publish", ...props });
|
1052
|
+
};
|
1053
|
+
const BulkLocaleUnpublishAction = (props) => {
|
1054
|
+
return BulkLocaleAction({ action: "bulk-unpublish", ...props });
|
1055
|
+
};
|
753
1056
|
const StyledTrash = styled(Trash)`
|
754
1057
|
path {
|
755
1058
|
fill: currentColor;
|
@@ -806,13 +1109,6 @@ const UnpublishModalAdditionalInfo = () => {
|
|
806
1109
|
}
|
807
1110
|
) });
|
808
1111
|
};
|
809
|
-
const Initializer = ({ setPlugin }) => {
|
810
|
-
const setPluginRef = React.useRef(setPlugin);
|
811
|
-
React.useEffect(() => {
|
812
|
-
setPluginRef.current(pluginId);
|
813
|
-
}, []);
|
814
|
-
return null;
|
815
|
-
};
|
816
1112
|
const LocalePicker = () => {
|
817
1113
|
const { formatMessage } = useIntl();
|
818
1114
|
const [{ query }, setQuery] = useQueryParams();
|
@@ -938,29 +1234,16 @@ const Span = styled(Flex)`
|
|
938
1234
|
}
|
939
1235
|
}
|
940
1236
|
`;
|
941
|
-
const LocaleListCell = ({
|
942
|
-
documentId,
|
943
|
-
locale: currentLocale,
|
944
|
-
collectionType,
|
945
|
-
model
|
946
|
-
}) => {
|
947
|
-
const { meta, isLoading } = unstable_useDocument({
|
948
|
-
documentId,
|
949
|
-
collectionType,
|
950
|
-
model,
|
951
|
-
params: {
|
952
|
-
locale: currentLocale
|
953
|
-
}
|
954
|
-
});
|
1237
|
+
const LocaleListCell = ({ locale: currentLocale, localizations }) => {
|
955
1238
|
const { locale: language } = useIntl();
|
956
1239
|
const { data: locales = [] } = useGetLocalesQuery();
|
957
1240
|
const formatter = useCollator(language, {
|
958
1241
|
sensitivity: "base"
|
959
1242
|
});
|
960
|
-
if (!Array.isArray(locales) ||
|
1243
|
+
if (!Array.isArray(locales) || !localizations) {
|
961
1244
|
return null;
|
962
1245
|
}
|
963
|
-
const availableLocales =
|
1246
|
+
const availableLocales = localizations.map((loc) => loc.locale);
|
964
1247
|
const localesForDocument = locales.reduce((acc, locale) => {
|
965
1248
|
const createdLocale = [currentLocale, ...availableLocales].find((loc) => {
|
966
1249
|
return loc === locale.code;
|
@@ -976,54 +1259,13 @@ const LocaleListCell = ({
|
|
976
1259
|
return locale.name;
|
977
1260
|
}).toSorted((a, b) => formatter.compare(a, b));
|
978
1261
|
return /* @__PURE__ */ jsxs(Popover.Root, { children: [
|
979
|
-
/* @__PURE__ */ jsx(Popover.Trigger, { children: /* @__PURE__ */ jsx(Button, { type: "button", onClick: (e) => e.stopPropagation(), children: /* @__PURE__ */ jsxs(
|
980
|
-
|
981
|
-
{
|
982
|
-
|
983
|
-
alignItems: "center",
|
984
|
-
justifyContent: "center",
|
985
|
-
height: "3.2rem",
|
986
|
-
width: "3.2rem",
|
987
|
-
children: [
|
988
|
-
/* @__PURE__ */ jsx(Typography, { textColor: "neutral800", ellipsis: true, children: localesForDocument.join(", ") }),
|
989
|
-
/* @__PURE__ */ jsx(Flex, { children: /* @__PURE__ */ jsx(CaretDown, {}) })
|
990
|
-
]
|
991
|
-
}
|
992
|
-
) }) }),
|
1262
|
+
/* @__PURE__ */ jsx(Popover.Trigger, { children: /* @__PURE__ */ jsx(Button, { variant: "ghost", type: "button", onClick: (e) => e.stopPropagation(), children: /* @__PURE__ */ jsxs(Flex, { minWidth: "100%", alignItems: "center", justifyContent: "center", fontWeight: "regular", children: [
|
1263
|
+
/* @__PURE__ */ jsx(Typography, { textColor: "neutral800", ellipsis: true, marginRight: 2, children: localesForDocument.join(", ") }),
|
1264
|
+
/* @__PURE__ */ jsx(Flex, { children: /* @__PURE__ */ jsx(CaretDown, { width: "1.2rem", height: "1.2rem" }) })
|
1265
|
+
] }) }) }),
|
993
1266
|
/* @__PURE__ */ jsx(Popover.Content, { sideOffset: 16, children: /* @__PURE__ */ jsx("ul", { children: localesForDocument.map((name) => /* @__PURE__ */ jsx(Box, { padding: 3, tag: "li", children: /* @__PURE__ */ jsx(Typography, { children: name }) }, name)) }) })
|
994
1267
|
] });
|
995
1268
|
};
|
996
|
-
const Button = styled.button`
|
997
|
-
width: 100%;
|
998
|
-
|
999
|
-
svg {
|
1000
|
-
> g,
|
1001
|
-
path {
|
1002
|
-
fill: ${({ theme }) => theme.colors.neutral500};
|
1003
|
-
}
|
1004
|
-
}
|
1005
|
-
&:hover {
|
1006
|
-
svg {
|
1007
|
-
> g,
|
1008
|
-
path {
|
1009
|
-
fill: ${({ theme }) => theme.colors.neutral600};
|
1010
|
-
}
|
1011
|
-
}
|
1012
|
-
}
|
1013
|
-
&:active {
|
1014
|
-
svg {
|
1015
|
-
> g,
|
1016
|
-
path {
|
1017
|
-
fill: ${({ theme }) => theme.colors.neutral400};
|
1018
|
-
}
|
1019
|
-
}
|
1020
|
-
}
|
1021
|
-
`;
|
1022
|
-
const ActionWrapper = styled(Flex)`
|
1023
|
-
svg {
|
1024
|
-
height: 0.4rem;
|
1025
|
-
}
|
1026
|
-
`;
|
1027
1269
|
const addColumnToTableHook = ({ displayedHeaders, layout }) => {
|
1028
1270
|
const { options } = layout;
|
1029
1271
|
const isFieldLocalized = doesPluginOptionsHaveI18nLocalized(options) ? options.i18n.localized : false;
|
@@ -1149,9 +1391,6 @@ const localeMiddleware = (ctx) => (next) => (permissions) => {
|
|
1149
1391
|
return next(revisedPermissions);
|
1150
1392
|
};
|
1151
1393
|
const prefixPluginTranslations = (trad, pluginId2) => {
|
1152
|
-
if (!pluginId2) {
|
1153
|
-
throw new TypeError("pluginId can't be empty");
|
1154
|
-
}
|
1155
1394
|
return Object.keys(trad).reduce((acc, current) => {
|
1156
1395
|
acc[`${pluginId2}.${current}`] = trad[current];
|
1157
1396
|
return acc;
|
@@ -1204,8 +1443,6 @@ const index = {
|
|
1204
1443
|
app.addRBACMiddleware([localeMiddleware]);
|
1205
1444
|
app.registerPlugin({
|
1206
1445
|
id: pluginId,
|
1207
|
-
initializer: Initializer,
|
1208
|
-
isReady: false,
|
1209
1446
|
name: pluginId
|
1210
1447
|
});
|
1211
1448
|
},
|
@@ -1223,11 +1460,11 @@ const index = {
|
|
1223
1460
|
},
|
1224
1461
|
id: "internationalization",
|
1225
1462
|
to: "internationalization",
|
1226
|
-
Component: () => import("./SettingsPage-
|
1463
|
+
Component: () => import("./SettingsPage-B6QDUmu9.mjs").then((mod) => ({ default: mod.ProtectedSettingsPage })),
|
1227
1464
|
permissions: PERMISSIONS.accessMain
|
1228
1465
|
});
|
1229
1466
|
const contentManager = app.getPlugin("content-manager");
|
1230
|
-
contentManager.apis.addDocumentHeaderAction([LocalePickerAction]);
|
1467
|
+
contentManager.apis.addDocumentHeaderAction([LocalePickerAction, FillFromAnotherLocaleAction]);
|
1231
1468
|
contentManager.apis.addDocumentAction((actions) => {
|
1232
1469
|
const indexOfDeleteAction = actions.findIndex((action) => action.type === "delete");
|
1233
1470
|
actions.splice(indexOfDeleteAction, 0, DeleteLocaleAction);
|
@@ -1235,6 +1472,7 @@ const index = {
|
|
1235
1472
|
});
|
1236
1473
|
contentManager.apis.addDocumentAction((actions) => {
|
1237
1474
|
actions.splice(2, 0, BulkLocalePublishAction);
|
1475
|
+
actions.splice(5, 0, BulkLocaleUnpublishAction);
|
1238
1476
|
return actions;
|
1239
1477
|
});
|
1240
1478
|
contentManager.injectComponent("listView", "actions", {
|
@@ -1340,7 +1578,7 @@ const index = {
|
|
1340
1578
|
async registerTrads({ locales }) {
|
1341
1579
|
const importedTrads = await Promise.all(
|
1342
1580
|
locales.map((locale) => {
|
1343
|
-
return __variableDynamicImportRuntimeHelper(/* @__PURE__ */ Object.assign({ "./translations/de.json": () => import("./de-9eCAqqrB.mjs"), "./translations/dk.json": () => import("./dk-2qBjxt-P.mjs"), "./translations/en.json": () => import("./en-
|
1581
|
+
return __variableDynamicImportRuntimeHelper(/* @__PURE__ */ Object.assign({ "./translations/de.json": () => import("./de-9eCAqqrB.mjs"), "./translations/dk.json": () => import("./dk-2qBjxt-P.mjs"), "./translations/en.json": () => import("./en-DlXfy6Gy.mjs"), "./translations/es.json": () => import("./es-DlmMVaBG.mjs"), "./translations/fr.json": () => import("./fr-3S6ke71d.mjs"), "./translations/ko.json": () => import("./ko-qTjQ8IMw.mjs"), "./translations/pl.json": () => import("./pl-B67TSHqT.mjs"), "./translations/ru.json": () => import("./ru-hagMa57T.mjs"), "./translations/tr.json": () => import("./tr-Dw_jmkG-.mjs"), "./translations/zh-Hans.json": () => import("./zh-Hans-Dyc-aR-h.mjs"), "./translations/zh.json": () => import("./zh-57YM4amO.mjs") }), `./translations/${locale}.json`, 3).then(({ default: data }) => {
|
1344
1582
|
return {
|
1345
1583
|
data: prefixPluginTranslations(data, pluginId),
|
1346
1584
|
locale
|
@@ -1366,4 +1604,4 @@ export {
|
|
1366
1604
|
index as i,
|
1367
1605
|
useCreateLocaleMutation as u
|
1368
1606
|
};
|
1369
|
-
//# sourceMappingURL=index-
|
1607
|
+
//# sourceMappingURL=index-iEQ79W05.mjs.map
|