@strapi/content-releases 0.0.0-experimental.fc1ac2acd58c8a5a858679956b6d102ac5ee4011 → 0.0.0-experimental.fccfa141baa6df7776ec7cb83f7fe923626ba6f5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (127) hide show
  1. package/LICENSE +17 -1
  2. package/dist/_chunks/{App-C768ulk4.js → App-BKB1esYS.js} +497 -483
  3. package/dist/_chunks/App-BKB1esYS.js.map +1 -0
  4. package/dist/_chunks/{App-0Er6xxcq.mjs → App-Cne--1Z8.mjs} +480 -464
  5. package/dist/_chunks/App-Cne--1Z8.mjs.map +1 -0
  6. package/dist/_chunks/{PurchaseContentReleases-YhAPgpG9.js → PurchaseContentReleases-Be3acS2L.js} +8 -7
  7. package/dist/_chunks/PurchaseContentReleases-Be3acS2L.js.map +1 -0
  8. package/dist/_chunks/{PurchaseContentReleases-Clm0iACO.mjs → PurchaseContentReleases-_MxP6-Dt.mjs} +9 -8
  9. package/dist/_chunks/PurchaseContentReleases-_MxP6-Dt.mjs.map +1 -0
  10. package/dist/_chunks/ReleasesSettingsPage-C1WwGWIH.mjs +178 -0
  11. package/dist/_chunks/ReleasesSettingsPage-C1WwGWIH.mjs.map +1 -0
  12. package/dist/_chunks/ReleasesSettingsPage-kuXIwpWp.js +178 -0
  13. package/dist/_chunks/ReleasesSettingsPage-kuXIwpWp.js.map +1 -0
  14. package/dist/_chunks/{en-gcJJ5htG.js → en-CmYoEnA7.js} +19 -4
  15. package/dist/_chunks/en-CmYoEnA7.js.map +1 -0
  16. package/dist/_chunks/{en-WuuhP6Bn.mjs → en-D0yVZFqf.mjs} +19 -4
  17. package/dist/_chunks/en-D0yVZFqf.mjs.map +1 -0
  18. package/dist/_chunks/index-5Odi61vw.js +1381 -0
  19. package/dist/_chunks/index-5Odi61vw.js.map +1 -0
  20. package/dist/_chunks/index-Cy7qwpaU.mjs +1362 -0
  21. package/dist/_chunks/index-Cy7qwpaU.mjs.map +1 -0
  22. package/dist/_chunks/schemas-BE1LxE9J.js +62 -0
  23. package/dist/_chunks/schemas-BE1LxE9J.js.map +1 -0
  24. package/dist/_chunks/schemas-DdA2ic2U.mjs +44 -0
  25. package/dist/_chunks/schemas-DdA2ic2U.mjs.map +1 -0
  26. package/dist/admin/index.js +1 -15
  27. package/dist/admin/index.js.map +1 -1
  28. package/dist/admin/index.mjs +2 -16
  29. package/dist/admin/index.mjs.map +1 -1
  30. package/dist/admin/src/components/ReleaseAction.d.ts +3 -0
  31. package/dist/admin/src/components/ReleaseActionMenu.d.ts +4 -4
  32. package/dist/admin/src/components/ReleaseActionModal.d.ts +24 -0
  33. package/dist/admin/src/components/ReleaseListCell.d.ts +28 -0
  34. package/dist/admin/src/components/ReleaseModal.d.ts +3 -2
  35. package/dist/admin/src/components/ReleasesPanel.d.ts +3 -0
  36. package/dist/admin/src/constants.d.ts +18 -0
  37. package/dist/admin/src/modules/hooks.d.ts +7 -0
  38. package/dist/admin/src/pages/ReleasesSettingsPage.d.ts +1 -0
  39. package/dist/admin/src/services/release.d.ts +66 -323
  40. package/dist/admin/src/utils/api.d.ts +6 -0
  41. package/dist/admin/src/utils/prefixPluginTranslations.d.ts +3 -0
  42. package/dist/admin/src/utils/time.d.ts +9 -0
  43. package/dist/admin/src/validation/schemas.d.ts +6 -0
  44. package/dist/server/index.js +1053 -646
  45. package/dist/server/index.js.map +1 -1
  46. package/dist/server/index.mjs +1054 -647
  47. package/dist/server/index.mjs.map +1 -1
  48. package/dist/server/src/bootstrap.d.ts +2 -2
  49. package/dist/server/src/bootstrap.d.ts.map +1 -1
  50. package/dist/server/src/constants.d.ts +11 -2
  51. package/dist/server/src/constants.d.ts.map +1 -1
  52. package/dist/server/src/content-types/index.d.ts +3 -5
  53. package/dist/server/src/content-types/index.d.ts.map +1 -1
  54. package/dist/server/src/content-types/release-action/index.d.ts +3 -5
  55. package/dist/server/src/content-types/release-action/index.d.ts.map +1 -1
  56. package/dist/server/src/content-types/release-action/schema.d.ts +3 -5
  57. package/dist/server/src/content-types/release-action/schema.d.ts.map +1 -1
  58. package/dist/server/src/controllers/index.d.ts +8 -1
  59. package/dist/server/src/controllers/index.d.ts.map +1 -1
  60. package/dist/server/src/controllers/release-action.d.ts +1 -0
  61. package/dist/server/src/controllers/release-action.d.ts.map +1 -1
  62. package/dist/server/src/controllers/release.d.ts +8 -1
  63. package/dist/server/src/controllers/release.d.ts.map +1 -1
  64. package/dist/server/src/controllers/settings.d.ts +11 -0
  65. package/dist/server/src/controllers/settings.d.ts.map +1 -0
  66. package/dist/server/src/controllers/validation/release-action.d.ts +13 -2
  67. package/dist/server/src/controllers/validation/release-action.d.ts.map +1 -1
  68. package/dist/server/src/controllers/validation/release.d.ts +2 -0
  69. package/dist/server/src/controllers/validation/release.d.ts.map +1 -1
  70. package/dist/server/src/controllers/validation/settings.d.ts +3 -0
  71. package/dist/server/src/controllers/validation/settings.d.ts.map +1 -0
  72. package/dist/server/src/destroy.d.ts +2 -2
  73. package/dist/server/src/destroy.d.ts.map +1 -1
  74. package/dist/server/src/index.d.ts +1518 -3241
  75. package/dist/server/src/index.d.ts.map +1 -1
  76. package/dist/server/src/middlewares/documents.d.ts +6 -0
  77. package/dist/server/src/middlewares/documents.d.ts.map +1 -0
  78. package/dist/server/src/migrations/database/5.0.0-document-id-in-actions.d.ts +9 -0
  79. package/dist/server/src/migrations/database/5.0.0-document-id-in-actions.d.ts.map +1 -0
  80. package/dist/server/src/migrations/index.d.ts +3 -0
  81. package/dist/server/src/migrations/index.d.ts.map +1 -1
  82. package/dist/server/src/register.d.ts +2 -2
  83. package/dist/server/src/register.d.ts.map +1 -1
  84. package/dist/server/src/routes/index.d.ts +16 -0
  85. package/dist/server/src/routes/index.d.ts.map +1 -1
  86. package/dist/server/src/routes/release-action.d.ts.map +1 -1
  87. package/dist/server/src/routes/release.d.ts.map +1 -1
  88. package/dist/server/src/routes/settings.d.ts +18 -0
  89. package/dist/server/src/routes/settings.d.ts.map +1 -0
  90. package/dist/server/src/services/index.d.ts +1482 -3226
  91. package/dist/server/src/services/index.d.ts.map +1 -1
  92. package/dist/server/src/services/release-action.d.ts +38 -0
  93. package/dist/server/src/services/release-action.d.ts.map +1 -0
  94. package/dist/server/src/services/release.d.ts +19 -1800
  95. package/dist/server/src/services/release.d.ts.map +1 -1
  96. package/dist/server/src/services/scheduling.d.ts +6 -6
  97. package/dist/server/src/services/scheduling.d.ts.map +1 -1
  98. package/dist/server/src/services/settings.d.ts +13 -0
  99. package/dist/server/src/services/settings.d.ts.map +1 -0
  100. package/dist/server/src/services/validation.d.ts +7 -3
  101. package/dist/server/src/services/validation.d.ts.map +1 -1
  102. package/dist/server/src/utils/index.d.ts +33 -16
  103. package/dist/server/src/utils/index.d.ts.map +1 -1
  104. package/dist/shared/contracts/release-actions.d.ts +37 -12
  105. package/dist/shared/contracts/release-actions.d.ts.map +1 -1
  106. package/dist/shared/contracts/releases.d.ts +24 -6
  107. package/dist/shared/contracts/releases.d.ts.map +1 -1
  108. package/dist/shared/contracts/settings.d.ts +39 -0
  109. package/dist/shared/contracts/settings.d.ts.map +1 -0
  110. package/dist/shared/types.d.ts +2 -2
  111. package/dist/shared/types.d.ts.map +1 -1
  112. package/package.json +29 -27
  113. package/dist/_chunks/App-0Er6xxcq.mjs.map +0 -1
  114. package/dist/_chunks/App-C768ulk4.js.map +0 -1
  115. package/dist/_chunks/PurchaseContentReleases-Clm0iACO.mjs.map +0 -1
  116. package/dist/_chunks/PurchaseContentReleases-YhAPgpG9.js.map +0 -1
  117. package/dist/_chunks/en-WuuhP6Bn.mjs.map +0 -1
  118. package/dist/_chunks/en-gcJJ5htG.js.map +0 -1
  119. package/dist/_chunks/index-BLSMpbpZ.js +0 -1028
  120. package/dist/_chunks/index-BLSMpbpZ.js.map +0 -1
  121. package/dist/_chunks/index-fJx1up7m.mjs +0 -1007
  122. package/dist/_chunks/index-fJx1up7m.mjs.map +0 -1
  123. package/dist/admin/src/components/CMReleasesContainer.d.ts +0 -1
  124. package/dist/admin/src/services/axios.d.ts +0 -29
  125. package/dist/shared/validation-schemas.d.ts +0 -2
  126. package/dist/shared/validation-schemas.d.ts.map +0 -1
  127. package/strapi-server.js +0 -3
@@ -1,1007 +0,0 @@
1
- import { getFetchClient, useNotification, useAPIErrorHandler, CheckPermissions, useQueryParams, prefixPluginTranslations } from "@strapi/helper-plugin";
2
- import { Cross, Pencil, More, Plus, EmptyDocuments, PaperPlane } from "@strapi/icons";
3
- import { jsx, jsxs } from "react/jsx-runtime";
4
- import * as React from "react";
5
- import { skipToken } from "@reduxjs/toolkit/query";
6
- import { IconButton, Flex, Icon, Typography, Field, FieldLabel, VisuallyHidden, FieldInput, Box, Button, ModalLayout, ModalHeader, ModalBody, SingleSelect, SingleSelectOption, ModalFooter, EmptyStateLayout } from "@strapi/design-system";
7
- import { Menu, Link, LinkButton } from "@strapi/design-system/v2";
8
- import { isAxiosError as isAxiosError$1 } from "axios";
9
- import { Formik, Form } from "formik";
10
- import { useIntl } from "react-intl";
11
- import { NavLink, useParams, Link as Link$1 } from "react-router-dom";
12
- import * as yup from "yup";
13
- import { createApi } from "@reduxjs/toolkit/query/react";
14
- import styled from "styled-components";
15
- import { useDispatch, useSelector } from "react-redux";
16
- const __variableDynamicImportRuntimeHelper = (glob, path) => {
17
- const v = glob[path];
18
- if (v) {
19
- return typeof v === "function" ? v() : Promise.resolve(v);
20
- }
21
- return new Promise((_, reject) => {
22
- (typeof queueMicrotask === "function" ? queueMicrotask : setTimeout)(reject.bind(null, new Error("Unknown variable dynamic import: " + path)));
23
- });
24
- };
25
- const PERMISSIONS = {
26
- main: [
27
- {
28
- action: "plugin::content-releases.read",
29
- subject: null,
30
- id: "",
31
- actionParameters: {},
32
- properties: {},
33
- conditions: []
34
- }
35
- ],
36
- create: [
37
- {
38
- action: "plugin::content-releases.create",
39
- subject: null,
40
- id: "",
41
- actionParameters: {},
42
- properties: {},
43
- conditions: []
44
- }
45
- ],
46
- update: [
47
- {
48
- action: "plugin::content-releases.update",
49
- subject: null,
50
- id: "",
51
- actionParameters: {},
52
- properties: {},
53
- conditions: []
54
- }
55
- ],
56
- delete: [
57
- {
58
- action: "plugin::content-releases.delete",
59
- subject: null,
60
- id: "",
61
- actionParameters: {},
62
- properties: {},
63
- conditions: []
64
- }
65
- ],
66
- createAction: [
67
- {
68
- action: "plugin::content-releases.create-action",
69
- subject: null,
70
- id: "",
71
- actionParameters: {},
72
- properties: {},
73
- conditions: []
74
- }
75
- ],
76
- deleteAction: [
77
- {
78
- action: "plugin::content-releases.delete-action",
79
- subject: null,
80
- id: "",
81
- actionParameters: {},
82
- properties: {},
83
- conditions: []
84
- }
85
- ],
86
- publish: [
87
- {
88
- action: "plugin::content-releases.publish",
89
- subject: null,
90
- id: "",
91
- actionParameters: {},
92
- properties: {},
93
- conditions: []
94
- }
95
- ]
96
- };
97
- const pluginId = "content-releases";
98
- const axiosBaseQuery = async ({
99
- url,
100
- method,
101
- data,
102
- config
103
- }) => {
104
- try {
105
- const { get, post, del, put } = getFetchClient();
106
- if (method === "POST") {
107
- const result2 = await post(url, data, config);
108
- return { data: result2.data };
109
- }
110
- if (method === "DELETE") {
111
- const result2 = await del(url, config);
112
- return { data: result2.data };
113
- }
114
- if (method === "PUT") {
115
- const result2 = await put(url, data, config);
116
- return { data: result2.data };
117
- }
118
- const result = await get(url, config);
119
- return { data: result.data };
120
- } catch (error) {
121
- const err = error;
122
- return {
123
- error: {
124
- status: err.response?.status,
125
- code: err.code,
126
- response: {
127
- data: err.response?.data
128
- }
129
- }
130
- };
131
- }
132
- };
133
- const isAxiosError = (err) => {
134
- return typeof err === "object" && err !== null && "response" in err && typeof err.response === "object" && err.response !== null && "data" in err.response;
135
- };
136
- const releaseApi = createApi({
137
- reducerPath: pluginId,
138
- baseQuery: axiosBaseQuery,
139
- tagTypes: ["Release", "ReleaseAction"],
140
- endpoints: (build) => {
141
- return {
142
- getReleasesForEntry: build.query({
143
- query(params) {
144
- return {
145
- url: "/content-releases",
146
- method: "GET",
147
- config: {
148
- params
149
- }
150
- };
151
- },
152
- providesTags: (result) => result ? [
153
- ...result.data.map(({ id }) => ({ type: "Release", id })),
154
- { type: "Release", id: "LIST" }
155
- ] : []
156
- }),
157
- getReleases: build.query({
158
- query({ page, pageSize, filters } = {
159
- page: 1,
160
- pageSize: 16,
161
- filters: {
162
- releasedAt: {
163
- $notNull: false
164
- }
165
- }
166
- }) {
167
- return {
168
- url: "/content-releases",
169
- method: "GET",
170
- config: {
171
- params: {
172
- page: page || 1,
173
- pageSize: pageSize || 16,
174
- filters: filters || {
175
- releasedAt: {
176
- $notNull: false
177
- }
178
- }
179
- }
180
- }
181
- };
182
- },
183
- transformResponse(response, meta, arg) {
184
- const releasedAtValue = arg?.filters?.releasedAt?.$notNull;
185
- const isActiveDoneTab = releasedAtValue === "true";
186
- const newResponse = {
187
- ...response,
188
- meta: {
189
- ...response.meta,
190
- activeTab: isActiveDoneTab ? "done" : "pending"
191
- }
192
- };
193
- return newResponse;
194
- },
195
- providesTags: (result) => result ? [
196
- ...result.data.map(({ id }) => ({ type: "Release", id })),
197
- { type: "Release", id: "LIST" }
198
- ] : [{ type: "Release", id: "LIST" }]
199
- }),
200
- getRelease: build.query({
201
- query({ id }) {
202
- return {
203
- url: `/content-releases/${id}`,
204
- method: "GET"
205
- };
206
- },
207
- providesTags: (result, error, arg) => [{ type: "Release", id: arg.id }]
208
- }),
209
- getReleaseActions: build.query({
210
- query({ releaseId, ...params }) {
211
- return {
212
- url: `/content-releases/${releaseId}/actions`,
213
- method: "GET",
214
- config: {
215
- params
216
- }
217
- };
218
- },
219
- providesTags: [{ type: "ReleaseAction", id: "LIST" }]
220
- }),
221
- createRelease: build.mutation({
222
- query(data) {
223
- return {
224
- url: "/content-releases",
225
- method: "POST",
226
- data
227
- };
228
- },
229
- invalidatesTags: [{ type: "Release", id: "LIST" }]
230
- }),
231
- updateRelease: build.mutation({
232
- query({ id, ...data }) {
233
- return {
234
- url: `/content-releases/${id}`,
235
- method: "PUT",
236
- data
237
- };
238
- },
239
- invalidatesTags: (result, error, arg) => [{ type: "Release", id: arg.id }]
240
- }),
241
- createReleaseAction: build.mutation({
242
- query({ body, params }) {
243
- return {
244
- url: `/content-releases/${params.releaseId}/actions`,
245
- method: "POST",
246
- data: body
247
- };
248
- },
249
- invalidatesTags: [
250
- { type: "Release", id: "LIST" },
251
- { type: "ReleaseAction", id: "LIST" }
252
- ]
253
- }),
254
- updateReleaseAction: build.mutation({
255
- query({ body, params }) {
256
- return {
257
- url: `/content-releases/${params.releaseId}/actions/${params.actionId}`,
258
- method: "PUT",
259
- data: body
260
- };
261
- },
262
- invalidatesTags: () => [{ type: "ReleaseAction", id: "LIST" }],
263
- async onQueryStarted({ body, params, query, actionPath }, { dispatch, queryFulfilled }) {
264
- const paramsWithoutActionId = {
265
- releaseId: params.releaseId,
266
- ...query
267
- };
268
- const patchResult = dispatch(
269
- releaseApi.util.updateQueryData("getReleaseActions", paramsWithoutActionId, (draft) => {
270
- const [key, index] = actionPath;
271
- const action = draft.data[key][index];
272
- if (action) {
273
- action.type = body.type;
274
- }
275
- })
276
- );
277
- try {
278
- await queryFulfilled;
279
- } catch {
280
- patchResult.undo();
281
- }
282
- }
283
- }),
284
- deleteReleaseAction: build.mutation({
285
- query({ params }) {
286
- return {
287
- url: `/content-releases/${params.releaseId}/actions/${params.actionId}`,
288
- method: "DELETE"
289
- };
290
- },
291
- invalidatesTags: [
292
- { type: "Release", id: "LIST" },
293
- { type: "ReleaseAction", id: "LIST" }
294
- ]
295
- }),
296
- publishRelease: build.mutation({
297
- query({ id }) {
298
- return {
299
- url: `/content-releases/${id}/publish`,
300
- method: "POST"
301
- };
302
- },
303
- invalidatesTags: (result, error, arg) => [{ type: "Release", id: arg.id }]
304
- }),
305
- deleteRelease: build.mutation({
306
- query({ id }) {
307
- return {
308
- url: `/content-releases/${id}`,
309
- method: "DELETE"
310
- };
311
- },
312
- invalidatesTags: (result, error, arg) => [{ type: "Release", id: arg.id }]
313
- })
314
- };
315
- }
316
- });
317
- const {
318
- useGetReleasesQuery,
319
- useGetReleasesForEntryQuery,
320
- useGetReleaseQuery,
321
- useGetReleaseActionsQuery,
322
- useCreateReleaseMutation,
323
- useCreateReleaseActionMutation,
324
- useUpdateReleaseMutation,
325
- useUpdateReleaseActionMutation,
326
- usePublishReleaseMutation,
327
- useDeleteReleaseActionMutation,
328
- useDeleteReleaseMutation
329
- } = releaseApi;
330
- const getTimezoneOffset = (timezone, date) => {
331
- try {
332
- const offsetPart = new Intl.DateTimeFormat("en", {
333
- timeZone: timezone,
334
- timeZoneName: "longOffset"
335
- }).formatToParts(date).find((part) => part.type === "timeZoneName");
336
- const offset = offsetPart ? offsetPart.value : "";
337
- let utcOffset = offset.replace("GMT", "UTC");
338
- if (!utcOffset.includes("+") && !utcOffset.includes("-")) {
339
- utcOffset = `${utcOffset}+00:00`;
340
- }
341
- return utcOffset;
342
- } catch (error) {
343
- return "";
344
- }
345
- };
346
- const useTypedDispatch = useDispatch;
347
- const useTypedSelector = useSelector;
348
- const StyledMenuItem = styled(Menu.Item)`
349
- &:hover {
350
- background: ${({ theme, variant = "neutral" }) => theme.colors[`${variant}100`]};
351
-
352
- svg {
353
- path {
354
- fill: ${({ theme, variant = "neutral" }) => theme.colors[`${variant}600`]};
355
- }
356
- }
357
-
358
- a {
359
- color: ${({ theme }) => theme.colors.neutral800};
360
- }
361
- }
362
-
363
- svg {
364
- path {
365
- fill: ${({ theme, variant = "neutral" }) => theme.colors[`${variant}600`]};
366
- }
367
- }
368
-
369
- a {
370
- color: ${({ theme }) => theme.colors.neutral800};
371
- }
372
-
373
- span,
374
- a {
375
- width: 100%;
376
- }
377
- `;
378
- const StyledIconButton = styled(IconButton)`
379
- /* Setting this style inline with borderColor will not apply the style */
380
- border: ${({ theme }) => `1px solid ${theme.colors.neutral200}`};
381
- `;
382
- const DeleteReleaseActionItem = ({ releaseId, actionId }) => {
383
- const { formatMessage } = useIntl();
384
- const toggleNotification = useNotification();
385
- const { formatAPIError } = useAPIErrorHandler();
386
- const [deleteReleaseAction] = useDeleteReleaseActionMutation();
387
- const handleDeleteAction = async () => {
388
- const response = await deleteReleaseAction({
389
- params: { releaseId, actionId }
390
- });
391
- if ("data" in response) {
392
- toggleNotification({
393
- type: "success",
394
- message: formatMessage({
395
- id: "content-releases.content-manager-edit-view.remove-from-release.notification.success",
396
- defaultMessage: "Entry removed from release"
397
- })
398
- });
399
- return;
400
- }
401
- if ("error" in response) {
402
- if (isAxiosError$1(response.error)) {
403
- toggleNotification({
404
- type: "warning",
405
- message: formatAPIError(response.error)
406
- });
407
- } else {
408
- toggleNotification({
409
- type: "warning",
410
- message: formatMessage({ id: "notification.error", defaultMessage: "An error occurred" })
411
- });
412
- }
413
- }
414
- };
415
- return /* @__PURE__ */ jsx(CheckPermissions, { permissions: PERMISSIONS.deleteAction, children: /* @__PURE__ */ jsx(StyledMenuItem, { variant: "danger", onSelect: handleDeleteAction, children: /* @__PURE__ */ jsxs(Flex, { gap: 2, children: [
416
- /* @__PURE__ */ jsx(Icon, { as: Cross, width: 3, height: 3 }),
417
- /* @__PURE__ */ jsx(Typography, { textColor: "danger600", variant: "omega", children: formatMessage({
418
- id: "content-releases.content-manager-edit-view.remove-from-release",
419
- defaultMessage: "Remove from release"
420
- }) })
421
- ] }) }) });
422
- };
423
- const ReleaseActionEntryLinkItem = ({
424
- contentTypeUid,
425
- entryId,
426
- locale
427
- }) => {
428
- const { formatMessage } = useIntl();
429
- const collectionTypePermissions = useTypedSelector(
430
- (state) => state.rbacProvider.collectionTypesRelatedPermissions
431
- );
432
- const updatePermissions = contentTypeUid ? collectionTypePermissions[contentTypeUid]?.["plugin::content-manager.explorer.update"] : [];
433
- const canUpdateEntryForLocale = Boolean(
434
- !locale || updatePermissions?.find(
435
- (permission) => permission.properties?.locales?.includes(locale)
436
- )
437
- );
438
- return /* @__PURE__ */ jsx(
439
- CheckPermissions,
440
- {
441
- permissions: [
442
- {
443
- action: "plugin::content-manager.explorer.update",
444
- subject: contentTypeUid
445
- }
446
- ],
447
- children: canUpdateEntryForLocale && /* @__PURE__ */ jsx(StyledMenuItem, { children: /* @__PURE__ */ jsx(
448
- Link,
449
- {
450
- as: NavLink,
451
- to: {
452
- pathname: `/content-manager/collection-types/${contentTypeUid}/${entryId}`,
453
- search: locale && `?plugins[i18n][locale]=${locale}`
454
- },
455
- startIcon: /* @__PURE__ */ jsx(Icon, { as: Pencil, width: 3, height: 3 }),
456
- children: /* @__PURE__ */ jsx(Typography, { variant: "omega", children: formatMessage({
457
- id: "content-releases.content-manager-edit-view.edit-entry",
458
- defaultMessage: "Edit entry"
459
- }) })
460
- }
461
- ) })
462
- }
463
- );
464
- };
465
- const EditReleaseItem = ({ releaseId }) => {
466
- const { formatMessage } = useIntl();
467
- return /* @__PURE__ */ jsx(StyledMenuItem, { children: /* @__PURE__ */ jsx(
468
- Link,
469
- {
470
- as: NavLink,
471
- to: `/plugins/content-releases/${releaseId}`,
472
- startIcon: /* @__PURE__ */ jsx(Icon, { as: Pencil, width: 3, height: 3 }),
473
- children: /* @__PURE__ */ jsx(Typography, { variant: "omega", children: formatMessage({
474
- id: "content-releases.content-manager-edit-view.edit-release",
475
- defaultMessage: "Edit release"
476
- }) })
477
- }
478
- ) });
479
- };
480
- const Root = ({ children, hasTriggerBorder = false }) => {
481
- const { formatMessage } = useIntl();
482
- return (
483
- // A user can access the dropdown if they have permissions to delete a release-action OR update a release
484
- /* @__PURE__ */ jsx(CheckPermissions, { permissions: [...PERMISSIONS.deleteAction, ...PERMISSIONS.update], children: /* @__PURE__ */ jsxs(Menu.Root, { children: [
485
- /* @__PURE__ */ jsx(
486
- Menu.Trigger,
487
- {
488
- as: hasTriggerBorder ? StyledIconButton : IconButton,
489
- paddingLeft: 2,
490
- paddingRight: 2,
491
- "aria-label": formatMessage({
492
- id: "content-releases.content-manager-edit-view.release-action-menu",
493
- defaultMessage: "Release action options"
494
- }),
495
- icon: /* @__PURE__ */ jsx(More, {})
496
- }
497
- ),
498
- /* @__PURE__ */ jsx(Menu.Content, { top: 1, popoverPlacement: "bottom-end", children })
499
- ] }) })
500
- );
501
- };
502
- const ReleaseActionMenu = {
503
- Root,
504
- EditReleaseItem,
505
- DeleteReleaseActionItem,
506
- ReleaseActionEntryLinkItem
507
- };
508
- const getBorderLeftRadiusValue = (actionType) => {
509
- return actionType === "publish" ? 1 : 0;
510
- };
511
- const getBorderRightRadiusValue = (actionType) => {
512
- return actionType === "publish" ? 0 : 1;
513
- };
514
- const FieldWrapper = styled(Field)`
515
- border-top-left-radius: ${({ actionType, theme }) => theme.spaces[getBorderLeftRadiusValue(actionType)]};
516
- border-bottom-left-radius: ${({ actionType, theme }) => theme.spaces[getBorderLeftRadiusValue(actionType)]};
517
- border-top-right-radius: ${({ actionType, theme }) => theme.spaces[getBorderRightRadiusValue(actionType)]};
518
- border-bottom-right-radius: ${({ actionType, theme }) => theme.spaces[getBorderRightRadiusValue(actionType)]};
519
-
520
- > label {
521
- color: inherit;
522
- padding: ${({ theme }) => `${theme.spaces[2]} ${theme.spaces[3]}`};
523
- text-align: center;
524
- vertical-align: middle;
525
- text-transform: capitalize;
526
- }
527
-
528
- &[data-checked='true'] {
529
- color: ${({ theme, actionType }) => actionType === "publish" ? theme.colors.primary700 : theme.colors.danger600};
530
- background-color: ${({ theme, actionType }) => actionType === "publish" ? theme.colors.primary100 : theme.colors.danger100};
531
- border-color: ${({ theme, actionType }) => actionType === "publish" ? theme.colors.primary700 : theme.colors.danger600};
532
- }
533
-
534
- &[data-checked='false'] {
535
- border-left: ${({ actionType }) => actionType === "unpublish" && "none"};
536
- border-right: ${({ actionType }) => actionType === "publish" && "none"};
537
- }
538
-
539
- &[data-checked='false'][data-disabled='false']:hover {
540
- color: ${({ theme }) => theme.colors.neutral700};
541
- background-color: ${({ theme }) => theme.colors.neutral100};
542
- border-color: ${({ theme }) => theme.colors.neutral200};
543
-
544
- & > label {
545
- cursor: pointer;
546
- }
547
- }
548
-
549
- &[data-disabled='true'] {
550
- color: ${({ theme }) => theme.colors.neutral600};
551
- background-color: ${({ theme }) => theme.colors.neutral150};
552
- border-color: ${({ theme }) => theme.colors.neutral300};
553
- }
554
- `;
555
- const ActionOption = ({
556
- selected,
557
- actionType,
558
- handleChange,
559
- name,
560
- disabled = false
561
- }) => {
562
- return /* @__PURE__ */ jsx(
563
- FieldWrapper,
564
- {
565
- actionType,
566
- background: "primary0",
567
- borderColor: "neutral200",
568
- color: selected === actionType ? "primary600" : "neutral600",
569
- position: "relative",
570
- cursor: "pointer",
571
- "data-checked": selected === actionType,
572
- "data-disabled": disabled && selected !== actionType,
573
- children: /* @__PURE__ */ jsxs(FieldLabel, { htmlFor: `${name}-${actionType}`, children: [
574
- /* @__PURE__ */ jsx(VisuallyHidden, { children: /* @__PURE__ */ jsx(
575
- FieldInput,
576
- {
577
- type: "radio",
578
- id: `${name}-${actionType}`,
579
- name,
580
- checked: selected === actionType,
581
- onChange: handleChange,
582
- value: actionType,
583
- disabled
584
- }
585
- ) }),
586
- actionType
587
- ] })
588
- }
589
- );
590
- };
591
- const ReleaseActionOptions = ({
592
- selected,
593
- handleChange,
594
- name,
595
- disabled = false
596
- }) => {
597
- return /* @__PURE__ */ jsxs(Flex, { children: [
598
- /* @__PURE__ */ jsx(
599
- ActionOption,
600
- {
601
- actionType: "publish",
602
- selected,
603
- handleChange,
604
- name,
605
- disabled
606
- }
607
- ),
608
- /* @__PURE__ */ jsx(
609
- ActionOption,
610
- {
611
- actionType: "unpublish",
612
- selected,
613
- handleChange,
614
- name,
615
- disabled
616
- }
617
- )
618
- ] });
619
- };
620
- const RELEASE_ACTION_FORM_SCHEMA = yup.object().shape({
621
- type: yup.string().oneOf(["publish", "unpublish"]).required(),
622
- releaseId: yup.string().required()
623
- });
624
- const INITIAL_VALUES = {
625
- type: "publish",
626
- releaseId: ""
627
- };
628
- const NoReleases = () => {
629
- const { formatMessage } = useIntl();
630
- return /* @__PURE__ */ jsx(
631
- EmptyStateLayout,
632
- {
633
- icon: /* @__PURE__ */ jsx(EmptyDocuments, { width: "10rem" }),
634
- content: formatMessage({
635
- id: "content-releases.content-manager-edit-view.add-to-release.no-releases-message",
636
- defaultMessage: "No available releases. Open the list of releases and create a new one from there."
637
- }),
638
- action: /* @__PURE__ */ jsx(
639
- LinkButton,
640
- {
641
- to: {
642
- pathname: "/plugins/content-releases"
643
- },
644
- as: Link$1,
645
- variant: "secondary",
646
- children: formatMessage({
647
- id: "content-releases.content-manager-edit-view.add-to-release.redirect-button",
648
- defaultMessage: "Open the list of releases"
649
- })
650
- }
651
- )
652
- }
653
- );
654
- };
655
- const AddActionToReleaseModal = ({
656
- handleClose,
657
- contentTypeUid,
658
- entryId
659
- }) => {
660
- const releaseHeaderId = React.useId();
661
- const { formatMessage } = useIntl();
662
- const toggleNotification = useNotification();
663
- const { formatAPIError } = useAPIErrorHandler();
664
- const [{ query }] = useQueryParams();
665
- const locale = query.plugins?.i18n?.locale;
666
- const response = useGetReleasesForEntryQuery({
667
- contentTypeUid,
668
- entryId,
669
- hasEntryAttached: false
670
- });
671
- const releases = response.data?.data;
672
- const [createReleaseAction, { isLoading }] = useCreateReleaseActionMutation();
673
- const handleSubmit = async (values) => {
674
- const releaseActionEntry = {
675
- contentType: contentTypeUid,
676
- id: entryId,
677
- locale
678
- };
679
- const response2 = await createReleaseAction({
680
- body: { type: values.type, entry: releaseActionEntry },
681
- params: { releaseId: values.releaseId }
682
- });
683
- if ("data" in response2) {
684
- toggleNotification({
685
- type: "success",
686
- message: formatMessage({
687
- id: "content-releases.content-manager-edit-view.add-to-release.notification.success",
688
- defaultMessage: "Entry added to release"
689
- })
690
- });
691
- handleClose();
692
- return;
693
- }
694
- if ("error" in response2) {
695
- if (isAxiosError$1(response2.error)) {
696
- toggleNotification({
697
- type: "warning",
698
- message: formatAPIError(response2.error)
699
- });
700
- } else {
701
- toggleNotification({
702
- type: "warning",
703
- message: formatMessage({ id: "notification.error", defaultMessage: "An error occurred" })
704
- });
705
- }
706
- }
707
- };
708
- return /* @__PURE__ */ jsxs(ModalLayout, { onClose: handleClose, labelledBy: releaseHeaderId, children: [
709
- /* @__PURE__ */ jsx(ModalHeader, { children: /* @__PURE__ */ jsx(Typography, { id: releaseHeaderId, fontWeight: "bold", textColor: "neutral800", children: formatMessage({
710
- id: "content-releases.content-manager-edit-view.add-to-release",
711
- defaultMessage: "Add to release"
712
- }) }) }),
713
- /* @__PURE__ */ jsx(
714
- Formik,
715
- {
716
- onSubmit: handleSubmit,
717
- validationSchema: RELEASE_ACTION_FORM_SCHEMA,
718
- initialValues: INITIAL_VALUES,
719
- children: ({ values, setFieldValue }) => {
720
- return /* @__PURE__ */ jsxs(Form, { children: [
721
- releases?.length === 0 ? /* @__PURE__ */ jsx(NoReleases, {}) : /* @__PURE__ */ jsx(ModalBody, { children: /* @__PURE__ */ jsxs(Flex, { direction: "column", alignItems: "stretch", gap: 2, children: [
722
- /* @__PURE__ */ jsx(Box, { paddingBottom: 6, children: /* @__PURE__ */ jsx(
723
- SingleSelect,
724
- {
725
- required: true,
726
- label: formatMessage({
727
- id: "content-releases.content-manager-edit-view.add-to-release.select-label",
728
- defaultMessage: "Select a release"
729
- }),
730
- placeholder: formatMessage({
731
- id: "content-releases.content-manager-edit-view.add-to-release.select-placeholder",
732
- defaultMessage: "Select"
733
- }),
734
- onChange: (value) => setFieldValue("releaseId", value),
735
- value: values.releaseId,
736
- children: releases?.map((release) => /* @__PURE__ */ jsx(SingleSelectOption, { value: release.id, children: release.name }, release.id))
737
- }
738
- ) }),
739
- /* @__PURE__ */ jsx(FieldLabel, { children: formatMessage({
740
- id: "content-releases.content-manager-edit-view.add-to-release.action-type-label",
741
- defaultMessage: "What do you want to do with this entry?"
742
- }) }),
743
- /* @__PURE__ */ jsx(
744
- ReleaseActionOptions,
745
- {
746
- selected: values.type,
747
- handleChange: (e) => setFieldValue("type", e.target.value),
748
- name: "type"
749
- }
750
- )
751
- ] }) }),
752
- /* @__PURE__ */ jsx(
753
- ModalFooter,
754
- {
755
- startActions: /* @__PURE__ */ jsx(Button, { onClick: handleClose, variant: "tertiary", name: "cancel", children: formatMessage({
756
- id: "content-releases.content-manager-edit-view.add-to-release.cancel-button",
757
- defaultMessage: "Cancel"
758
- }) }),
759
- endActions: (
760
- /**
761
- * TODO: Ideally we would use isValid from Formik to disable the button, however currently it always returns true
762
- * for yup.string().required(), even when the value is falsy (including empty string)
763
- */
764
- /* @__PURE__ */ jsx(Button, { type: "submit", disabled: !values.releaseId, loading: isLoading, children: formatMessage({
765
- id: "content-releases.content-manager-edit-view.add-to-release.continue-button",
766
- defaultMessage: "Continue"
767
- }) })
768
- )
769
- }
770
- )
771
- ] });
772
- }
773
- }
774
- )
775
- ] });
776
- };
777
- const CMReleasesContainer = () => {
778
- const [isModalOpen, setIsModalOpen] = React.useState(false);
779
- const { formatMessage, formatDate, formatTime } = useIntl();
780
- const { id, slug } = useParams();
781
- const isCreatingEntry = id === "create";
782
- const contentTypeUid = slug;
783
- const IsSchedulingEnabled = window.strapi.future.isEnabled("contentReleasesScheduling");
784
- const canFetch = id != null && contentTypeUid != null;
785
- const fetchParams = canFetch ? {
786
- contentTypeUid,
787
- entryId: id,
788
- hasEntryAttached: true
789
- } : skipToken;
790
- const response = useGetReleasesForEntryQuery(fetchParams);
791
- const releases = response.data?.data;
792
- if (!canFetch) {
793
- return null;
794
- }
795
- if (isCreatingEntry) {
796
- return null;
797
- }
798
- const toggleModal = () => setIsModalOpen((prev) => !prev);
799
- const getReleaseColorVariant = (actionType, shade) => {
800
- if (actionType === "unpublish") {
801
- return `secondary${shade}`;
802
- }
803
- return `success${shade}`;
804
- };
805
- return /* @__PURE__ */ jsx(CheckPermissions, { permissions: PERMISSIONS.main, children: /* @__PURE__ */ jsxs(
806
- Box,
807
- {
808
- as: "aside",
809
- "aria-label": formatMessage({
810
- id: "content-releases.plugin.name",
811
- defaultMessage: "Releases"
812
- }),
813
- background: "neutral0",
814
- borderColor: "neutral150",
815
- hasRadius: true,
816
- padding: 4,
817
- shadow: "tableShadow",
818
- children: [
819
- /* @__PURE__ */ jsxs(Flex, { direction: "column", alignItems: "stretch", gap: 3, children: [
820
- /* @__PURE__ */ jsx(Typography, { variant: "sigma", textColor: "neutral600", textTransform: "uppercase", children: formatMessage({
821
- id: "content-releases.plugin.name",
822
- defaultMessage: "Releases"
823
- }) }),
824
- releases?.map((release) => {
825
- return /* @__PURE__ */ jsxs(
826
- Flex,
827
- {
828
- direction: "column",
829
- alignItems: "start",
830
- borderWidth: "1px",
831
- borderStyle: "solid",
832
- borderColor: getReleaseColorVariant(release.action.type, "200"),
833
- overflow: "hidden",
834
- hasRadius: true,
835
- children: [
836
- /* @__PURE__ */ jsx(
837
- Box,
838
- {
839
- paddingTop: 3,
840
- paddingBottom: 3,
841
- paddingLeft: 4,
842
- paddingRight: 4,
843
- background: getReleaseColorVariant(release.action.type, "100"),
844
- width: "100%",
845
- children: /* @__PURE__ */ jsx(
846
- Typography,
847
- {
848
- fontSize: 1,
849
- variant: "pi",
850
- textColor: getReleaseColorVariant(release.action.type, "600"),
851
- children: formatMessage(
852
- {
853
- id: "content-releases.content-manager-edit-view.list-releases.title",
854
- defaultMessage: "{isPublish, select, true {Will be published in} other {Will be unpublished in}}"
855
- },
856
- { isPublish: release.action.type === "publish" }
857
- )
858
- }
859
- )
860
- }
861
- ),
862
- /* @__PURE__ */ jsxs(Flex, { padding: 4, direction: "column", gap: 2, width: "100%", alignItems: "flex-start", children: [
863
- /* @__PURE__ */ jsx(Typography, { fontSize: 2, fontWeight: "bold", variant: "omega", textColor: "neutral700", children: release.name }),
864
- IsSchedulingEnabled && release.scheduledAt && release.timezone && /* @__PURE__ */ jsx(Typography, { variant: "pi", textColor: "neutral600", children: formatMessage(
865
- {
866
- id: "content-releases.content-manager-edit-view.scheduled.date",
867
- defaultMessage: "{date} at {time} ({offset})"
868
- },
869
- {
870
- date: formatDate(new Date(release.scheduledAt), {
871
- day: "2-digit",
872
- month: "2-digit",
873
- year: "numeric",
874
- timeZone: release.timezone
875
- }),
876
- time: formatTime(new Date(release.scheduledAt), {
877
- hourCycle: "h23",
878
- timeZone: release.timezone
879
- }),
880
- offset: getTimezoneOffset(
881
- release.timezone,
882
- new Date(release.scheduledAt)
883
- )
884
- }
885
- ) }),
886
- /* @__PURE__ */ jsx(CheckPermissions, { permissions: PERMISSIONS.deleteAction, children: /* @__PURE__ */ jsxs(ReleaseActionMenu.Root, { hasTriggerBorder: true, children: [
887
- /* @__PURE__ */ jsx(ReleaseActionMenu.EditReleaseItem, { releaseId: release.id }),
888
- /* @__PURE__ */ jsx(
889
- ReleaseActionMenu.DeleteReleaseActionItem,
890
- {
891
- releaseId: release.id,
892
- actionId: release.action.id
893
- }
894
- )
895
- ] }) })
896
- ] })
897
- ]
898
- },
899
- release.id
900
- );
901
- }),
902
- /* @__PURE__ */ jsx(CheckPermissions, { permissions: PERMISSIONS.createAction, children: /* @__PURE__ */ jsx(
903
- Button,
904
- {
905
- justifyContent: "center",
906
- paddingLeft: 4,
907
- paddingRight: 4,
908
- color: "neutral700",
909
- variant: "tertiary",
910
- startIcon: /* @__PURE__ */ jsx(Plus, {}),
911
- onClick: toggleModal,
912
- children: formatMessage({
913
- id: "content-releases.content-manager-edit-view.add-to-release",
914
- defaultMessage: "Add to release"
915
- })
916
- }
917
- ) })
918
- ] }),
919
- isModalOpen && /* @__PURE__ */ jsx(
920
- AddActionToReleaseModal,
921
- {
922
- handleClose: toggleModal,
923
- contentTypeUid,
924
- entryId: id
925
- }
926
- )
927
- ]
928
- }
929
- ) });
930
- };
931
- const admin = {
932
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
933
- register(app) {
934
- if (window.strapi.features.isEnabled("cms-content-releases")) {
935
- app.addMenuLink({
936
- to: `plugins/${pluginId}`,
937
- icon: PaperPlane,
938
- intlLabel: {
939
- id: `${pluginId}.plugin.name`,
940
- defaultMessage: "Releases"
941
- },
942
- Component: () => import("./App-0Er6xxcq.mjs").then((mod) => ({ default: mod.App })),
943
- permissions: PERMISSIONS.main
944
- });
945
- app.addMiddlewares([() => releaseApi.middleware]);
946
- app.addReducers({
947
- [releaseApi.reducerPath]: releaseApi.reducer
948
- });
949
- app.injectContentManagerComponent("editView", "right-links", {
950
- name: `${pluginId}-link`,
951
- Component: CMReleasesContainer
952
- });
953
- } else if (!window.strapi.features.isEnabled("cms-content-releases") && window.strapi?.flags?.promoteEE) {
954
- app.addMenuLink({
955
- to: `/plugins/purchase-content-releases`,
956
- icon: PaperPlane,
957
- intlLabel: {
958
- id: `${pluginId}.plugin.name`,
959
- defaultMessage: "Releases"
960
- },
961
- async Component() {
962
- const { PurchaseContentReleases } = await import("./PurchaseContentReleases-Clm0iACO.mjs");
963
- return PurchaseContentReleases;
964
- },
965
- lockIcon: true
966
- });
967
- }
968
- },
969
- async registerTrads({ locales }) {
970
- const importedTrads = await Promise.all(
971
- locales.map((locale) => {
972
- return __variableDynamicImportRuntimeHelper(/* @__PURE__ */ Object.assign({ "./translations/en.json": () => import("./en-WuuhP6Bn.mjs") }), `./translations/${locale}.json`).then(({ default: data }) => {
973
- return {
974
- data: prefixPluginTranslations(data, "content-releases"),
975
- locale
976
- };
977
- }).catch(() => {
978
- return {
979
- data: {},
980
- locale
981
- };
982
- });
983
- })
984
- );
985
- return Promise.resolve(importedTrads);
986
- }
987
- };
988
- export {
989
- PERMISSIONS as P,
990
- ReleaseActionOptions as R,
991
- useCreateReleaseMutation as a,
992
- useGetReleaseQuery as b,
993
- useUpdateReleaseMutation as c,
994
- useDeleteReleaseMutation as d,
995
- usePublishReleaseMutation as e,
996
- useTypedDispatch as f,
997
- getTimezoneOffset as g,
998
- useGetReleaseActionsQuery as h,
999
- isAxiosError as i,
1000
- useUpdateReleaseActionMutation as j,
1001
- ReleaseActionMenu as k,
1002
- admin as l,
1003
- pluginId as p,
1004
- releaseApi as r,
1005
- useGetReleasesQuery as u
1006
- };
1007
- //# sourceMappingURL=index-fJx1up7m.mjs.map