@strapi/content-releases 0.0.0-next.6d59515520a3850456f256fb0e4c54b75054ddf4 → 0.0.0-next.7051057497777a23c7418e675330d2fb69c89fec

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