@strapi/content-releases 0.0.0-experimental.c592deb623aed3f74ef7fdacfad9757ed59d34f7 → 0.0.0-experimental.c95cecbc9ed31c3bd68eff1ae5fa4b64f2a5020e

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 (140) hide show
  1. package/dist/_chunks/App-dLXY5ei3.js +1353 -0
  2. package/dist/_chunks/App-dLXY5ei3.js.map +1 -0
  3. package/dist/_chunks/{App-Db0aPjrG.mjs → App-jrh58sXY.mjs} +558 -602
  4. package/dist/_chunks/App-jrh58sXY.mjs.map +1 -0
  5. package/dist/_chunks/{PurchaseContentReleases-_MxP6-Dt.mjs → PurchaseContentReleases-3tRbmbY3.mjs} +7 -8
  6. package/dist/_chunks/PurchaseContentReleases-3tRbmbY3.mjs.map +1 -0
  7. package/dist/_chunks/{PurchaseContentReleases-Be3acS2L.js → PurchaseContentReleases-bpIYXOfu.js} +6 -7
  8. package/dist/_chunks/PurchaseContentReleases-bpIYXOfu.js.map +1 -0
  9. package/dist/_chunks/{en-CmYoEnA7.js → en-HrREghh3.js} +2 -9
  10. package/dist/_chunks/en-HrREghh3.js.map +1 -0
  11. package/dist/_chunks/{en-D0yVZFqf.mjs → en-ltT1TlKQ.mjs} +2 -9
  12. package/dist/_chunks/en-ltT1TlKQ.mjs.map +1 -0
  13. package/dist/_chunks/index-CVO0Rqdm.js +1336 -0
  14. package/dist/_chunks/index-CVO0Rqdm.js.map +1 -0
  15. package/dist/_chunks/index-PiOGBETy.mjs +1315 -0
  16. package/dist/_chunks/index-PiOGBETy.mjs.map +1 -0
  17. package/dist/admin/index.js +15 -1
  18. package/dist/admin/index.js.map +1 -1
  19. package/dist/admin/index.mjs +16 -2
  20. package/dist/admin/index.mjs.map +1 -1
  21. package/dist/server/index.js +639 -826
  22. package/dist/server/index.js.map +1 -1
  23. package/dist/server/index.mjs +639 -827
  24. package/dist/server/index.mjs.map +1 -1
  25. package/package.json +38 -32
  26. package/strapi-server.js +3 -0
  27. package/dist/_chunks/App-Db0aPjrG.mjs.map +0 -1
  28. package/dist/_chunks/App-xHZkNTlJ.js +0 -1395
  29. package/dist/_chunks/App-xHZkNTlJ.js.map +0 -1
  30. package/dist/_chunks/PurchaseContentReleases-Be3acS2L.js.map +0 -1
  31. package/dist/_chunks/PurchaseContentReleases-_MxP6-Dt.mjs.map +0 -1
  32. package/dist/_chunks/ReleasesSettingsPage-C3rlM6Kf.mjs +0 -178
  33. package/dist/_chunks/ReleasesSettingsPage-C3rlM6Kf.mjs.map +0 -1
  34. package/dist/_chunks/ReleasesSettingsPage-DxEYftwd.js +0 -178
  35. package/dist/_chunks/ReleasesSettingsPage-DxEYftwd.js.map +0 -1
  36. package/dist/_chunks/en-CmYoEnA7.js.map +0 -1
  37. package/dist/_chunks/en-D0yVZFqf.mjs.map +0 -1
  38. package/dist/_chunks/index-CulHY6KM.js +0 -1377
  39. package/dist/_chunks/index-CulHY6KM.js.map +0 -1
  40. package/dist/_chunks/index-Dj_bL2s7.mjs +0 -1358
  41. package/dist/_chunks/index-Dj_bL2s7.mjs.map +0 -1
  42. package/dist/_chunks/schemas-63pFihNF.mjs +0 -44
  43. package/dist/_chunks/schemas-63pFihNF.mjs.map +0 -1
  44. package/dist/_chunks/schemas-z5zp-_Gd.js +0 -62
  45. package/dist/_chunks/schemas-z5zp-_Gd.js.map +0 -1
  46. package/dist/admin/src/components/RelativeTime.d.ts +0 -28
  47. package/dist/admin/src/components/ReleaseAction.d.ts +0 -3
  48. package/dist/admin/src/components/ReleaseActionMenu.d.ts +0 -26
  49. package/dist/admin/src/components/ReleaseActionModal.d.ts +0 -24
  50. package/dist/admin/src/components/ReleaseActionOptions.d.ts +0 -9
  51. package/dist/admin/src/components/ReleaseListCell.d.ts +0 -28
  52. package/dist/admin/src/components/ReleaseModal.d.ts +0 -17
  53. package/dist/admin/src/components/ReleasesPanel.d.ts +0 -3
  54. package/dist/admin/src/constants.d.ts +0 -76
  55. package/dist/admin/src/index.d.ts +0 -3
  56. package/dist/admin/src/modules/hooks.d.ts +0 -7
  57. package/dist/admin/src/pages/App.d.ts +0 -1
  58. package/dist/admin/src/pages/PurchaseContentReleases.d.ts +0 -2
  59. package/dist/admin/src/pages/ReleaseDetailsPage.d.ts +0 -2
  60. package/dist/admin/src/pages/ReleasesPage.d.ts +0 -8
  61. package/dist/admin/src/pages/ReleasesSettingsPage.d.ts +0 -1
  62. package/dist/admin/src/pages/tests/mockReleaseDetailsPageData.d.ts +0 -181
  63. package/dist/admin/src/pages/tests/mockReleasesPageData.d.ts +0 -39
  64. package/dist/admin/src/pluginId.d.ts +0 -1
  65. package/dist/admin/src/services/release.d.ts +0 -112
  66. package/dist/admin/src/store/hooks.d.ts +0 -7
  67. package/dist/admin/src/utils/api.d.ts +0 -6
  68. package/dist/admin/src/utils/prefixPluginTranslations.d.ts +0 -3
  69. package/dist/admin/src/utils/time.d.ts +0 -10
  70. package/dist/admin/src/validation/schemas.d.ts +0 -6
  71. package/dist/server/src/bootstrap.d.ts +0 -5
  72. package/dist/server/src/bootstrap.d.ts.map +0 -1
  73. package/dist/server/src/constants.d.ts +0 -21
  74. package/dist/server/src/constants.d.ts.map +0 -1
  75. package/dist/server/src/content-types/index.d.ts +0 -97
  76. package/dist/server/src/content-types/index.d.ts.map +0 -1
  77. package/dist/server/src/content-types/release/index.d.ts +0 -48
  78. package/dist/server/src/content-types/release/index.d.ts.map +0 -1
  79. package/dist/server/src/content-types/release/schema.d.ts +0 -47
  80. package/dist/server/src/content-types/release/schema.d.ts.map +0 -1
  81. package/dist/server/src/content-types/release-action/index.d.ts +0 -48
  82. package/dist/server/src/content-types/release-action/index.d.ts.map +0 -1
  83. package/dist/server/src/content-types/release-action/schema.d.ts +0 -47
  84. package/dist/server/src/content-types/release-action/schema.d.ts.map +0 -1
  85. package/dist/server/src/controllers/index.d.ts +0 -25
  86. package/dist/server/src/controllers/index.d.ts.map +0 -1
  87. package/dist/server/src/controllers/release-action.d.ts +0 -10
  88. package/dist/server/src/controllers/release-action.d.ts.map +0 -1
  89. package/dist/server/src/controllers/release.d.ts +0 -18
  90. package/dist/server/src/controllers/release.d.ts.map +0 -1
  91. package/dist/server/src/controllers/settings.d.ts +0 -11
  92. package/dist/server/src/controllers/settings.d.ts.map +0 -1
  93. package/dist/server/src/controllers/validation/release-action.d.ts +0 -14
  94. package/dist/server/src/controllers/validation/release-action.d.ts.map +0 -1
  95. package/dist/server/src/controllers/validation/release.d.ts +0 -4
  96. package/dist/server/src/controllers/validation/release.d.ts.map +0 -1
  97. package/dist/server/src/controllers/validation/settings.d.ts +0 -3
  98. package/dist/server/src/controllers/validation/settings.d.ts.map +0 -1
  99. package/dist/server/src/destroy.d.ts +0 -5
  100. package/dist/server/src/destroy.d.ts.map +0 -1
  101. package/dist/server/src/index.d.ts +0 -2115
  102. package/dist/server/src/index.d.ts.map +0 -1
  103. package/dist/server/src/middlewares/documents.d.ts +0 -6
  104. package/dist/server/src/middlewares/documents.d.ts.map +0 -1
  105. package/dist/server/src/migrations/database/5.0.0-document-id-in-actions.d.ts +0 -9
  106. package/dist/server/src/migrations/database/5.0.0-document-id-in-actions.d.ts.map +0 -1
  107. package/dist/server/src/migrations/index.d.ts +0 -13
  108. package/dist/server/src/migrations/index.d.ts.map +0 -1
  109. package/dist/server/src/register.d.ts +0 -5
  110. package/dist/server/src/register.d.ts.map +0 -1
  111. package/dist/server/src/routes/index.d.ts +0 -51
  112. package/dist/server/src/routes/index.d.ts.map +0 -1
  113. package/dist/server/src/routes/release-action.d.ts +0 -18
  114. package/dist/server/src/routes/release-action.d.ts.map +0 -1
  115. package/dist/server/src/routes/release.d.ts +0 -18
  116. package/dist/server/src/routes/release.d.ts.map +0 -1
  117. package/dist/server/src/routes/settings.d.ts +0 -18
  118. package/dist/server/src/routes/settings.d.ts.map +0 -1
  119. package/dist/server/src/services/index.d.ts +0 -1828
  120. package/dist/server/src/services/index.d.ts.map +0 -1
  121. package/dist/server/src/services/release-action.d.ts +0 -38
  122. package/dist/server/src/services/release-action.d.ts.map +0 -1
  123. package/dist/server/src/services/release.d.ts +0 -31
  124. package/dist/server/src/services/release.d.ts.map +0 -1
  125. package/dist/server/src/services/scheduling.d.ts +0 -18
  126. package/dist/server/src/services/scheduling.d.ts.map +0 -1
  127. package/dist/server/src/services/settings.d.ts +0 -13
  128. package/dist/server/src/services/settings.d.ts.map +0 -1
  129. package/dist/server/src/services/validation.d.ts +0 -18
  130. package/dist/server/src/services/validation.d.ts.map +0 -1
  131. package/dist/server/src/utils/index.d.ts +0 -35
  132. package/dist/server/src/utils/index.d.ts.map +0 -1
  133. package/dist/shared/contracts/release-actions.d.ts +0 -130
  134. package/dist/shared/contracts/release-actions.d.ts.map +0 -1
  135. package/dist/shared/contracts/releases.d.ts +0 -184
  136. package/dist/shared/contracts/releases.d.ts.map +0 -1
  137. package/dist/shared/contracts/settings.d.ts +0 -39
  138. package/dist/shared/contracts/settings.d.ts.map +0 -1
  139. package/dist/shared/types.d.ts +0 -24
  140. package/dist/shared/types.d.ts.map +0 -1
@@ -1,1358 +0,0 @@
1
- import { PaperPlane, CaretDown, Cross, Pencil, More } from "@strapi/icons";
2
- import { jsxs, jsx } from "react/jsx-runtime";
3
- import { adminApi, useRBAC, useNotification, useAPIErrorHandler, useQueryParams, isFetchError, useTable, useAuth } from "@strapi/admin/strapi-admin";
4
- import { Field, Flex, VisuallyHidden, Modal, Button, EmptyStateLayout, LinkButton, Box, SingleSelect, SingleSelectOption, Popover, Typography, Link as Link$1, Menu, AccessibleIcon } from "@strapi/design-system";
5
- import { useFormik, Formik, Form } from "formik";
6
- import { useIntl } from "react-intl";
7
- import { unstable_useDocumentLayout } from "@strapi/content-manager/strapi-admin";
8
- import { EmptyDocuments } from "@strapi/icons/symbols";
9
- import { Link, NavLink } from "react-router-dom";
10
- import * as yup from "yup";
11
- import { styled } from "styled-components";
12
- import * as React from "react";
13
- const __variableDynamicImportRuntimeHelper = (glob, path) => {
14
- const v = glob[path];
15
- if (v) {
16
- return typeof v === "function" ? v() : Promise.resolve(v);
17
- }
18
- return new Promise((_, reject) => {
19
- (typeof queueMicrotask === "function" ? queueMicrotask : setTimeout)(reject.bind(null, new Error("Unknown variable dynamic import: " + path)));
20
- });
21
- };
22
- const PERMISSIONS = {
23
- main: [
24
- {
25
- action: "plugin::content-releases.read",
26
- subject: null,
27
- id: "",
28
- actionParameters: {},
29
- properties: {},
30
- conditions: []
31
- }
32
- ],
33
- create: [
34
- {
35
- action: "plugin::content-releases.create",
36
- subject: null,
37
- id: "",
38
- actionParameters: {},
39
- properties: {},
40
- conditions: []
41
- }
42
- ],
43
- update: [
44
- {
45
- action: "plugin::content-releases.update",
46
- subject: null,
47
- id: "",
48
- actionParameters: {},
49
- properties: {},
50
- conditions: []
51
- }
52
- ],
53
- delete: [
54
- {
55
- action: "plugin::content-releases.delete",
56
- subject: null,
57
- id: "",
58
- actionParameters: {},
59
- properties: {},
60
- conditions: []
61
- }
62
- ],
63
- createAction: [
64
- {
65
- action: "plugin::content-releases.create-action",
66
- subject: null,
67
- id: "",
68
- actionParameters: {},
69
- properties: {},
70
- conditions: []
71
- }
72
- ],
73
- deleteAction: [
74
- {
75
- action: "plugin::content-releases.delete-action",
76
- subject: null,
77
- id: "",
78
- actionParameters: {},
79
- properties: {},
80
- conditions: []
81
- }
82
- ],
83
- publish: [
84
- {
85
- action: "plugin::content-releases.publish",
86
- subject: null,
87
- id: "",
88
- actionParameters: {},
89
- properties: {},
90
- conditions: []
91
- }
92
- ]
93
- };
94
- const extendInvalidatesTags = (endpoint, extraTags) => {
95
- if (!endpoint) {
96
- return;
97
- }
98
- const originalInvalidatesTags = endpoint.invalidatesTags;
99
- const newInvalidatesTags = (result, err, args, meta) => {
100
- const originalTags = typeof originalInvalidatesTags === "function" ? originalInvalidatesTags(result, err, args, meta) : originalInvalidatesTags;
101
- return [...originalTags ?? [], ...extraTags];
102
- };
103
- Object.assign(endpoint, { invalidatesTags: newInvalidatesTags });
104
- };
105
- const releaseApi = adminApi.enhanceEndpoints({
106
- addTagTypes: ["Release", "ReleaseAction", "EntriesInRelease", "ReleaseSettings"],
107
- endpoints: {
108
- updateDocument(endpoint) {
109
- extendInvalidatesTags(endpoint, [
110
- { type: "Release", id: "LIST" },
111
- { type: "ReleaseAction", id: "LIST" }
112
- ]);
113
- },
114
- deleteDocument(endpoint) {
115
- extendInvalidatesTags(endpoint, [
116
- { type: "Release", id: "LIST" },
117
- { type: "ReleaseAction", id: "LIST" }
118
- ]);
119
- },
120
- deleteManyDocuments(endpoint) {
121
- extendInvalidatesTags(endpoint, [
122
- { type: "Release", id: "LIST" },
123
- { type: "ReleaseAction", id: "LIST" }
124
- ]);
125
- },
126
- discardDocument(endpoint) {
127
- extendInvalidatesTags(endpoint, [
128
- { type: "Release", id: "LIST" },
129
- { type: "ReleaseAction", id: "LIST" }
130
- ]);
131
- }
132
- }
133
- }).injectEndpoints({
134
- endpoints: (build) => {
135
- return {
136
- getReleasesForEntry: build.query({
137
- query(params) {
138
- return {
139
- url: "/content-releases/getByDocumentAttached",
140
- method: "GET",
141
- config: {
142
- params
143
- }
144
- };
145
- },
146
- providesTags: (result) => result ? [
147
- ...result.data.map(({ id }) => ({ type: "Release", id })),
148
- { type: "Release", id: "LIST" }
149
- ] : []
150
- }),
151
- getReleases: build.query({
152
- query({ page, pageSize, filters } = {
153
- page: 1,
154
- pageSize: 16,
155
- filters: {
156
- releasedAt: {
157
- $notNull: false
158
- }
159
- }
160
- }) {
161
- return {
162
- url: "/content-releases",
163
- method: "GET",
164
- config: {
165
- params: {
166
- page: page || 1,
167
- pageSize: pageSize || 16,
168
- filters: filters || {
169
- releasedAt: {
170
- $notNull: false
171
- }
172
- }
173
- }
174
- }
175
- };
176
- },
177
- transformResponse(response, meta, arg) {
178
- const releasedAtValue = arg?.filters?.releasedAt?.$notNull;
179
- const isActiveDoneTab = releasedAtValue === "true";
180
- const newResponse = {
181
- ...response,
182
- meta: {
183
- ...response.meta,
184
- activeTab: isActiveDoneTab ? "done" : "pending"
185
- }
186
- };
187
- return newResponse;
188
- },
189
- providesTags: (result) => result ? [
190
- ...result.data.map(({ id }) => ({ type: "Release", id })),
191
- { type: "Release", id: "LIST" }
192
- ] : [{ type: "Release", id: "LIST" }]
193
- }),
194
- getRelease: build.query({
195
- query({ id }) {
196
- return {
197
- url: `/content-releases/${id}`,
198
- method: "GET"
199
- };
200
- },
201
- providesTags: (result, error, arg) => [
202
- { type: "Release", id: "LIST" },
203
- { type: "Release", id: arg.id }
204
- ]
205
- }),
206
- getReleaseActions: build.query({
207
- query({ releaseId, ...params }) {
208
- return {
209
- url: `/content-releases/${releaseId}/actions`,
210
- method: "GET",
211
- config: {
212
- params
213
- }
214
- };
215
- },
216
- providesTags: [{ type: "ReleaseAction", id: "LIST" }]
217
- }),
218
- createRelease: build.mutation({
219
- query(data) {
220
- return {
221
- url: "/content-releases",
222
- method: "POST",
223
- data
224
- };
225
- },
226
- invalidatesTags: [{ type: "Release", id: "LIST" }]
227
- }),
228
- updateRelease: build.mutation({
229
- query({ id, ...data }) {
230
- return {
231
- url: `/content-releases/${id}`,
232
- method: "PUT",
233
- data
234
- };
235
- },
236
- invalidatesTags: (result, error, arg) => [{ type: "Release", id: arg.id }]
237
- }),
238
- createReleaseAction: build.mutation({
239
- query({ body, params }) {
240
- return {
241
- url: `/content-releases/${params.releaseId}/actions`,
242
- method: "POST",
243
- data: body
244
- };
245
- },
246
- invalidatesTags: [
247
- { type: "Release", id: "LIST" },
248
- { type: "ReleaseAction", id: "LIST" }
249
- ]
250
- }),
251
- createManyReleaseActions: build.mutation({
252
- query({ body, params }) {
253
- return {
254
- url: `/content-releases/${params.releaseId}/actions/bulk`,
255
- method: "POST",
256
- data: body
257
- };
258
- },
259
- invalidatesTags: [
260
- { type: "Release", id: "LIST" },
261
- { type: "ReleaseAction", id: "LIST" },
262
- { type: "EntriesInRelease" }
263
- ]
264
- }),
265
- updateReleaseAction: build.mutation({
266
- query({ body, params }) {
267
- return {
268
- url: `/content-releases/${params.releaseId}/actions/${params.actionId}`,
269
- method: "PUT",
270
- data: body
271
- };
272
- },
273
- invalidatesTags: () => [{ type: "ReleaseAction", id: "LIST" }],
274
- async onQueryStarted({ body, params, query, actionPath }, { dispatch, queryFulfilled }) {
275
- const paramsWithoutActionId = {
276
- releaseId: params.releaseId,
277
- ...query
278
- };
279
- const patchResult = dispatch(
280
- releaseApi.util.updateQueryData(
281
- "getReleaseActions",
282
- paramsWithoutActionId,
283
- (draft) => {
284
- const [key, index] = actionPath;
285
- const action = draft.data[key][index];
286
- if (action) {
287
- action.type = body.type;
288
- }
289
- }
290
- )
291
- );
292
- try {
293
- await queryFulfilled;
294
- } catch {
295
- patchResult.undo();
296
- }
297
- }
298
- }),
299
- deleteReleaseAction: build.mutation({
300
- query({ params }) {
301
- return {
302
- url: `/content-releases/${params.releaseId}/actions/${params.actionId}`,
303
- method: "DELETE"
304
- };
305
- },
306
- invalidatesTags: (result, error, arg) => [
307
- { type: "Release", id: "LIST" },
308
- { type: "Release", id: arg.params.releaseId },
309
- { type: "ReleaseAction", id: "LIST" },
310
- { type: "EntriesInRelease" }
311
- ]
312
- }),
313
- publishRelease: build.mutation({
314
- query({ id }) {
315
- return {
316
- url: `/content-releases/${id}/publish`,
317
- method: "POST"
318
- };
319
- },
320
- invalidatesTags: (result, error, arg) => [{ type: "Release", id: arg.id }]
321
- }),
322
- deleteRelease: build.mutation({
323
- query({ id }) {
324
- return {
325
- url: `/content-releases/${id}`,
326
- method: "DELETE"
327
- };
328
- },
329
- invalidatesTags: () => [{ type: "Release", id: "LIST" }, { type: "EntriesInRelease" }]
330
- }),
331
- getMappedEntriesInReleases: build.query({
332
- query(params) {
333
- return {
334
- url: "/content-releases/mapEntriesToReleases",
335
- method: "GET",
336
- config: {
337
- params
338
- }
339
- };
340
- },
341
- transformResponse(response) {
342
- return response.data;
343
- },
344
- providesTags: [{ type: "EntriesInRelease" }]
345
- }),
346
- getReleaseSettings: build.query({
347
- query: () => "/content-releases/settings",
348
- providesTags: [{ type: "ReleaseSettings" }]
349
- }),
350
- updateReleaseSettings: build.mutation({
351
- query(data) {
352
- return {
353
- url: "/content-releases/settings",
354
- method: "PUT",
355
- data
356
- };
357
- },
358
- invalidatesTags: [{ type: "ReleaseSettings" }]
359
- })
360
- };
361
- }
362
- });
363
- const {
364
- useGetReleasesQuery,
365
- useGetReleasesForEntryQuery,
366
- useGetReleaseQuery,
367
- useGetReleaseActionsQuery,
368
- useCreateReleaseMutation,
369
- useCreateReleaseActionMutation,
370
- useCreateManyReleaseActionsMutation,
371
- useUpdateReleaseMutation,
372
- useUpdateReleaseActionMutation,
373
- usePublishReleaseMutation,
374
- useDeleteReleaseActionMutation,
375
- useDeleteReleaseMutation,
376
- useGetMappedEntriesInReleasesQuery,
377
- useGetReleaseSettingsQuery,
378
- useUpdateReleaseSettingsMutation
379
- } = releaseApi;
380
- const getBorderLeftRadiusValue = (actionType) => {
381
- return actionType === "publish" ? 1 : 0;
382
- };
383
- const getBorderRightRadiusValue = (actionType) => {
384
- return actionType === "publish" ? 0 : 1;
385
- };
386
- const FieldWrapper = styled(Field.Root)`
387
- border-top-left-radius: ${({ $actionType, theme }) => theme.spaces[getBorderLeftRadiusValue($actionType)]};
388
- border-bottom-left-radius: ${({ $actionType, theme }) => theme.spaces[getBorderLeftRadiusValue($actionType)]};
389
- border-top-right-radius: ${({ $actionType, theme }) => theme.spaces[getBorderRightRadiusValue($actionType)]};
390
- border-bottom-right-radius: ${({ $actionType, theme }) => theme.spaces[getBorderRightRadiusValue($actionType)]};
391
-
392
- > label {
393
- color: inherit;
394
- padding: ${({ theme }) => `${theme.spaces[2]} ${theme.spaces[3]}`};
395
- text-align: center;
396
- vertical-align: middle;
397
- text-transform: capitalize;
398
- }
399
-
400
- &[data-checked='true'] {
401
- color: ${({ theme, $actionType }) => $actionType === "publish" ? theme.colors.primary700 : theme.colors.danger600};
402
- background-color: ${({ theme, $actionType }) => $actionType === "publish" ? theme.colors.primary100 : theme.colors.danger100};
403
- border-color: ${({ theme, $actionType }) => $actionType === "publish" ? theme.colors.primary700 : theme.colors.danger600};
404
- }
405
-
406
- &[data-checked='false'] {
407
- border-left: ${({ $actionType }) => $actionType === "unpublish" && "none"};
408
- border-right: ${({ $actionType }) => $actionType === "publish" && "none"};
409
- }
410
-
411
- &[data-checked='false'][data-disabled='false']:hover {
412
- color: ${({ theme }) => theme.colors.neutral700};
413
- background-color: ${({ theme }) => theme.colors.neutral100};
414
- border-color: ${({ theme }) => theme.colors.neutral200};
415
-
416
- & > label {
417
- cursor: pointer;
418
- }
419
- }
420
-
421
- &[data-disabled='true'] {
422
- color: ${({ theme }) => theme.colors.neutral600};
423
- background-color: ${({ theme }) => theme.colors.neutral150};
424
- border-color: ${({ theme }) => theme.colors.neutral300};
425
- }
426
- `;
427
- const ActionOption = ({
428
- selected,
429
- actionType,
430
- handleChange,
431
- name,
432
- disabled = false
433
- }) => {
434
- return /* @__PURE__ */ jsx(
435
- FieldWrapper,
436
- {
437
- $actionType: actionType,
438
- background: "primary0",
439
- borderColor: "neutral200",
440
- color: selected === actionType ? "primary600" : "neutral600",
441
- position: "relative",
442
- cursor: "pointer",
443
- "data-checked": selected === actionType,
444
- "data-disabled": disabled && selected !== actionType,
445
- children: /* @__PURE__ */ jsxs(Field.Label, { children: [
446
- /* @__PURE__ */ jsx(VisuallyHidden, { children: /* @__PURE__ */ jsx(
447
- Field.Input,
448
- {
449
- type: "radio",
450
- name,
451
- checked: selected === actionType,
452
- onChange: handleChange,
453
- value: actionType,
454
- disabled
455
- }
456
- ) }),
457
- actionType
458
- ] })
459
- }
460
- );
461
- };
462
- const ReleaseActionOptions = ({
463
- selected,
464
- handleChange,
465
- name,
466
- disabled = false
467
- }) => {
468
- return /* @__PURE__ */ jsxs(Flex, { children: [
469
- /* @__PURE__ */ jsx(
470
- ActionOption,
471
- {
472
- actionType: "publish",
473
- selected,
474
- handleChange,
475
- name,
476
- disabled
477
- }
478
- ),
479
- /* @__PURE__ */ jsx(
480
- ActionOption,
481
- {
482
- actionType: "unpublish",
483
- selected,
484
- handleChange,
485
- name,
486
- disabled
487
- }
488
- )
489
- ] });
490
- };
491
- const RELEASE_ACTION_FORM_SCHEMA = yup.object().shape({
492
- type: yup.string().oneOf(["publish", "unpublish"]).required(),
493
- releaseId: yup.string().required()
494
- });
495
- const INITIAL_VALUES = {
496
- type: "publish",
497
- releaseId: ""
498
- };
499
- const NoReleases = () => {
500
- const { formatMessage } = useIntl();
501
- return /* @__PURE__ */ jsx(
502
- EmptyStateLayout,
503
- {
504
- icon: /* @__PURE__ */ jsx(EmptyDocuments, { width: "16rem" }),
505
- content: formatMessage({
506
- id: "content-releases.content-manager-edit-view.add-to-release.no-releases-message",
507
- defaultMessage: "No available releases. Open the list of releases and create a new one from there."
508
- }),
509
- action: /* @__PURE__ */ jsx(
510
- LinkButton,
511
- {
512
- to: {
513
- pathname: "/plugins/content-releases"
514
- },
515
- tag: Link,
516
- variant: "secondary",
517
- children: formatMessage({
518
- id: "content-releases.content-manager-edit-view.add-to-release.redirect-button",
519
- defaultMessage: "Open the list of releases"
520
- })
521
- }
522
- ),
523
- shadow: "none"
524
- }
525
- );
526
- };
527
- const AddActionToReleaseModal = ({
528
- contentType,
529
- documentId,
530
- onInputChange,
531
- values
532
- }) => {
533
- const { formatMessage } = useIntl();
534
- const [{ query }] = useQueryParams();
535
- const locale = query.plugins?.i18n?.locale;
536
- const response = useGetReleasesForEntryQuery({
537
- contentType,
538
- entryDocumentId: documentId,
539
- hasEntryAttached: false,
540
- locale
541
- });
542
- const releases = response.data?.data;
543
- if (releases?.length === 0) {
544
- return /* @__PURE__ */ jsx(NoReleases, {});
545
- }
546
- return /* @__PURE__ */ jsxs(Flex, { direction: "column", alignItems: "stretch", gap: 2, children: [
547
- /* @__PURE__ */ jsx(Box, { paddingBottom: 6, children: /* @__PURE__ */ jsxs(Field.Root, { required: true, children: [
548
- /* @__PURE__ */ jsx(Field.Label, { children: formatMessage({
549
- id: "content-releases.content-manager-edit-view.add-to-release.select-label",
550
- defaultMessage: "Select a release"
551
- }) }),
552
- /* @__PURE__ */ jsx(
553
- SingleSelect,
554
- {
555
- required: true,
556
- placeholder: formatMessage({
557
- id: "content-releases.content-manager-edit-view.add-to-release.select-placeholder",
558
- defaultMessage: "Select"
559
- }),
560
- name: "releaseId",
561
- onChange: (value) => onInputChange("releaseId", value),
562
- value: values.releaseId,
563
- children: releases?.map((release) => /* @__PURE__ */ jsx(SingleSelectOption, { value: release.id, children: release.name }, release.id))
564
- }
565
- )
566
- ] }) }),
567
- /* @__PURE__ */ jsx(Field.Label, { children: formatMessage({
568
- id: "content-releases.content-manager-edit-view.add-to-release.action-type-label",
569
- defaultMessage: "What do you want to do with this entry?"
570
- }) }),
571
- /* @__PURE__ */ jsx(
572
- ReleaseActionOptions,
573
- {
574
- selected: values.type,
575
- handleChange: (e) => onInputChange("type", e.target.value),
576
- name: "type"
577
- }
578
- )
579
- ] });
580
- };
581
- const ReleaseActionModalForm = ({
582
- documentId,
583
- document,
584
- model,
585
- collectionType
586
- }) => {
587
- const { formatMessage } = useIntl();
588
- const { allowedActions } = useRBAC(PERMISSIONS);
589
- const { canCreateAction } = allowedActions;
590
- const [createReleaseAction, { isLoading }] = useCreateReleaseActionMutation();
591
- const { toggleNotification } = useNotification();
592
- const { formatAPIError } = useAPIErrorHandler();
593
- const [{ query }] = useQueryParams();
594
- const locale = query.plugins?.i18n?.locale;
595
- const handleSubmit = async (e, onClose) => {
596
- try {
597
- await formik.handleSubmit(e);
598
- onClose();
599
- } catch (error) {
600
- if (isFetchError(error)) {
601
- toggleNotification({
602
- type: "danger",
603
- message: formatAPIError(error)
604
- });
605
- } else {
606
- toggleNotification({
607
- type: "danger",
608
- message: formatMessage({
609
- id: "notification.error",
610
- defaultMessage: "An error occurred"
611
- })
612
- });
613
- }
614
- }
615
- };
616
- const formik = useFormik({
617
- initialValues: INITIAL_VALUES,
618
- validationSchema: RELEASE_ACTION_FORM_SCHEMA,
619
- onSubmit: async (values) => {
620
- if (collectionType === "collection-types" && !documentId) {
621
- throw new Error("Document id is required");
622
- }
623
- const response = await createReleaseAction({
624
- body: {
625
- type: values.type,
626
- contentType: model,
627
- entryDocumentId: documentId,
628
- locale
629
- },
630
- params: { releaseId: values.releaseId }
631
- });
632
- if ("data" in response) {
633
- toggleNotification({
634
- type: "success",
635
- message: formatMessage({
636
- id: "content-releases.content-manager-edit-view.add-to-release.notification.success",
637
- defaultMessage: "Entry added to release"
638
- })
639
- });
640
- return;
641
- }
642
- if ("error" in response) {
643
- throw response.error;
644
- }
645
- }
646
- });
647
- const {
648
- edit: { options }
649
- } = unstable_useDocumentLayout(model);
650
- if (!window.strapi.isEE || !options?.draftAndPublish || !canCreateAction) {
651
- return null;
652
- }
653
- if (collectionType === "collection-types" && (!documentId || documentId === "create")) {
654
- return null;
655
- }
656
- return {
657
- label: formatMessage({
658
- id: "content-releases.content-manager-edit-view.add-to-release",
659
- defaultMessage: "Add to release"
660
- }),
661
- icon: /* @__PURE__ */ jsx(PaperPlane, {}),
662
- // Entry is creating so we don't want to allow adding it to a release
663
- disabled: !document,
664
- position: ["panel", "table-row"],
665
- dialog: {
666
- type: "modal",
667
- title: formatMessage({
668
- id: "content-releases.content-manager-edit-view.add-to-release",
669
- defaultMessage: "Add to release"
670
- }),
671
- content: /* @__PURE__ */ jsx(
672
- AddActionToReleaseModal,
673
- {
674
- contentType: model,
675
- documentId,
676
- onInputChange: formik.setFieldValue,
677
- values: formik.values
678
- }
679
- ),
680
- footer: ({ onClose }) => /* @__PURE__ */ jsxs(Modal.Footer, { children: [
681
- /* @__PURE__ */ jsx(Button, { onClick: onClose, variant: "tertiary", name: "cancel", children: formatMessage({
682
- id: "content-releases.content-manager-edit-view.add-to-release.cancel-button",
683
- defaultMessage: "Cancel"
684
- }) }),
685
- /* @__PURE__ */ jsx(
686
- Button,
687
- {
688
- type: "submit",
689
- onClick: (e) => handleSubmit(e, onClose),
690
- disabled: !formik.values.releaseId,
691
- loading: isLoading,
692
- children: formatMessage({
693
- id: "content-releases.content-manager-edit-view.add-to-release.continue-button",
694
- defaultMessage: "Continue"
695
- })
696
- }
697
- )
698
- ] })
699
- }
700
- };
701
- };
702
- const getContentPermissions = (subject) => {
703
- const permissions = {
704
- publish: [
705
- {
706
- action: "plugin::content-manager.explorer.publish",
707
- subject,
708
- id: "",
709
- actionParameters: {},
710
- properties: {},
711
- conditions: []
712
- }
713
- ]
714
- };
715
- return permissions;
716
- };
717
- const ReleaseAction = ({ documents, model }) => {
718
- const { formatMessage } = useIntl();
719
- const { toggleNotification } = useNotification();
720
- const { formatAPIError } = useAPIErrorHandler();
721
- const [{ query }] = useQueryParams();
722
- const contentPermissions = getContentPermissions(model);
723
- const {
724
- allowedActions: { canPublish }
725
- } = useRBAC(contentPermissions);
726
- const {
727
- allowedActions: { canCreate }
728
- } = useRBAC(PERMISSIONS);
729
- const response = useGetReleasesQuery();
730
- const releases = response.data?.data;
731
- const [createManyReleaseActions, { isLoading }] = useCreateManyReleaseActionsMutation();
732
- const documentIds = documents.map((doc) => doc.documentId);
733
- const handleSubmit = async (values) => {
734
- const locale = query.plugins?.i18n?.locale;
735
- const releaseActionEntries = documentIds.map(
736
- (entryDocumentId) => ({
737
- type: values.type,
738
- contentType: model,
739
- entryDocumentId,
740
- locale
741
- })
742
- );
743
- const response2 = await createManyReleaseActions({
744
- body: releaseActionEntries,
745
- params: { releaseId: values.releaseId }
746
- });
747
- if ("data" in response2) {
748
- const notificationMessage = formatMessage(
749
- {
750
- id: "content-releases.content-manager-list-view.add-to-release.notification.success.message",
751
- defaultMessage: "{entriesAlreadyInRelease} out of {totalEntries} entries were already in the release."
752
- },
753
- {
754
- entriesAlreadyInRelease: response2.data.meta.entriesAlreadyInRelease,
755
- totalEntries: response2.data.meta.totalEntries
756
- }
757
- );
758
- const notification = {
759
- type: "success",
760
- title: formatMessage(
761
- {
762
- id: "content-releases.content-manager-list-view.add-to-release.notification.success.title",
763
- defaultMessage: "Successfully added to release."
764
- },
765
- {
766
- entriesAlreadyInRelease: response2.data.meta.entriesAlreadyInRelease,
767
- totalEntries: response2.data.meta.totalEntries
768
- }
769
- ),
770
- message: response2.data.meta.entriesAlreadyInRelease ? notificationMessage : ""
771
- };
772
- toggleNotification(notification);
773
- return true;
774
- }
775
- if ("error" in response2) {
776
- if (isFetchError(response2.error)) {
777
- toggleNotification({
778
- type: "warning",
779
- message: formatAPIError(response2.error)
780
- });
781
- } else {
782
- toggleNotification({
783
- type: "warning",
784
- message: formatMessage({ id: "notification.error", defaultMessage: "An error occurred" })
785
- });
786
- }
787
- }
788
- };
789
- if (!canCreate || !canPublish)
790
- return null;
791
- return {
792
- actionType: "release",
793
- variant: "tertiary",
794
- label: formatMessage({
795
- id: "content-manager-list-view.add-to-release",
796
- defaultMessage: "Add to Release"
797
- }),
798
- dialog: {
799
- type: "modal",
800
- title: formatMessage({
801
- id: "content-manager-list-view.add-to-release",
802
- defaultMessage: "Add to Release"
803
- }),
804
- content: ({ onClose }) => {
805
- return /* @__PURE__ */ jsx(
806
- Formik,
807
- {
808
- onSubmit: async (values) => {
809
- const data = await handleSubmit(values);
810
- if (data) {
811
- return onClose();
812
- }
813
- },
814
- validationSchema: RELEASE_ACTION_FORM_SCHEMA,
815
- initialValues: INITIAL_VALUES,
816
- children: ({ values, setFieldValue }) => /* @__PURE__ */ jsxs(Form, { children: [
817
- releases?.length === 0 ? /* @__PURE__ */ jsx(NoReleases, {}) : /* @__PURE__ */ jsx(Modal.Body, { children: /* @__PURE__ */ jsxs(Flex, { direction: "column", alignItems: "stretch", gap: 2, children: [
818
- /* @__PURE__ */ jsx(Box, { paddingBottom: 6, children: /* @__PURE__ */ jsxs(Field.Root, { required: true, children: [
819
- /* @__PURE__ */ jsx(Field.Label, { children: formatMessage({
820
- id: "content-releases.content-manager-list-view.add-to-release.select-label",
821
- defaultMessage: "Select a release"
822
- }) }),
823
- /* @__PURE__ */ jsx(
824
- SingleSelect,
825
- {
826
- placeholder: formatMessage({
827
- id: "content-releases.content-manager-list-view.add-to-release.select-placeholder",
828
- defaultMessage: "Select"
829
- }),
830
- onChange: (value) => setFieldValue("releaseId", value),
831
- value: values.releaseId,
832
- children: releases?.map((release) => /* @__PURE__ */ jsx(SingleSelectOption, { value: release.id, children: release.name }, release.id))
833
- }
834
- )
835
- ] }) }),
836
- /* @__PURE__ */ jsx(Field.Label, { children: formatMessage({
837
- id: "content-releases.content-manager-list-view.add-to-release.action-type-label",
838
- defaultMessage: "What do you want to do with these entries?"
839
- }) }),
840
- /* @__PURE__ */ jsx(
841
- ReleaseActionOptions,
842
- {
843
- selected: values.type,
844
- handleChange: (e) => setFieldValue("type", e.target.value),
845
- name: "type"
846
- }
847
- )
848
- ] }) }),
849
- /* @__PURE__ */ jsxs(Modal.Footer, { children: [
850
- /* @__PURE__ */ jsx(Button, { onClick: onClose, variant: "tertiary", name: "cancel", children: formatMessage({
851
- id: "content-releases.content-manager-list-view.add-to-release.cancel-button",
852
- defaultMessage: "Cancel"
853
- }) }),
854
- /* @__PURE__ */ jsx(Button, { type: "submit", disabled: !values.releaseId, loading: isLoading, children: formatMessage({
855
- id: "content-releases.content-manager-list-view.add-to-release.continue-button",
856
- defaultMessage: "Continue"
857
- }) })
858
- ] })
859
- ] })
860
- }
861
- );
862
- }
863
- }
864
- };
865
- };
866
- const useReleasesList = (contentTypeUid, documentId) => {
867
- const listViewData = useTable("ListView", (state) => state.rows);
868
- const documentIds = listViewData.map((entry) => entry.documentId);
869
- const [{ query }] = useQueryParams();
870
- const locale = query?.plugins?.i18n?.locale || void 0;
871
- const response = useGetMappedEntriesInReleasesQuery(
872
- { contentTypeUid, documentIds, locale },
873
- { skip: !documentIds || !contentTypeUid || documentIds.length === 0 }
874
- );
875
- const mappedEntriesInReleases = response.data || {};
876
- return mappedEntriesInReleases?.[documentId] || [];
877
- };
878
- const addColumnToTableHook = ({ displayedHeaders, layout }) => {
879
- const { options } = layout;
880
- if (!options?.draftAndPublish) {
881
- return { displayedHeaders, layout };
882
- }
883
- return {
884
- displayedHeaders: [
885
- ...displayedHeaders,
886
- {
887
- searchable: false,
888
- sortable: false,
889
- name: "releases",
890
- label: {
891
- id: "content-releases.content-manager.list-view.releases.header",
892
- defaultMessage: "To be released in"
893
- },
894
- cellFormatter: (props, _, { model }) => /* @__PURE__ */ jsx(ReleaseListCell, { ...props, model })
895
- }
896
- ],
897
- layout
898
- };
899
- };
900
- const ReleaseListCell = ({ documentId, model }) => {
901
- const releases = useReleasesList(model, documentId);
902
- const { formatMessage } = useIntl();
903
- return /* @__PURE__ */ jsxs(Popover.Root, { children: [
904
- /* @__PURE__ */ jsx(Popover.Trigger, { children: /* @__PURE__ */ jsx(
905
- Button,
906
- {
907
- variant: "ghost",
908
- onClick: (e) => e.stopPropagation(),
909
- endIcon: releases.length > 0 ? /* @__PURE__ */ jsx(CaretDown, { width: "1.2rem", height: "1.2rem" }) : null,
910
- children: /* @__PURE__ */ jsx(
911
- Typography,
912
- {
913
- style: { maxWidth: "252px", cursor: "pointer" },
914
- textColor: "neutral800",
915
- fontWeight: "regular",
916
- children: releases.length > 0 ? formatMessage(
917
- {
918
- id: "content-releases.content-manager.list-view.releases-number",
919
- defaultMessage: "{number} {number, plural, one {release} other {releases}}"
920
- },
921
- {
922
- number: releases.length
923
- }
924
- ) : "-"
925
- }
926
- )
927
- }
928
- ) }),
929
- /* @__PURE__ */ jsx(Popover.Content, { children: /* @__PURE__ */ jsx("ul", { children: releases.map(({ id, name }) => /* @__PURE__ */ jsx(Box, { padding: 3, tag: "li", children: /* @__PURE__ */ jsx(Link$1, { href: `/admin/plugins/content-releases/${id}`, isExternal: false, children: name }) }, id)) }) })
930
- ] });
931
- };
932
- const getTimezoneOffset = (timezone, date) => {
933
- try {
934
- const offsetPart = new Intl.DateTimeFormat("en", {
935
- timeZone: timezone,
936
- timeZoneName: "longOffset"
937
- }).formatToParts(date).find((part) => part.type === "timeZoneName");
938
- const offset = offsetPart ? offsetPart.value : "";
939
- let utcOffset = offset.replace("GMT", "UTC");
940
- if (!utcOffset.includes("+") && !utcOffset.includes("-")) {
941
- utcOffset = `${utcOffset}+00:00`;
942
- }
943
- return utcOffset;
944
- } catch (error) {
945
- return "";
946
- }
947
- };
948
- const getTimezones = (selectedDate) => {
949
- const timezoneList = Intl.supportedValuesOf("timeZone").map((timezone) => {
950
- const utcOffset = getTimezoneOffset(timezone, selectedDate);
951
- return { offset: utcOffset, value: `${utcOffset}&${timezone}` };
952
- });
953
- const systemTimezone = timezoneList.find(
954
- (timezone) => timezone.value.split("&")[1] === Intl.DateTimeFormat().resolvedOptions().timeZone
955
- );
956
- return { timezoneList, systemTimezone };
957
- };
958
- const StyledMenuItem = styled(Menu.Item)`
959
- &:hover {
960
- background: ${({ theme, $variant = "neutral" }) => theme.colors[`${$variant}100`]};
961
-
962
- svg {
963
- fill: ${({ theme, $variant = "neutral" }) => theme.colors[`${$variant}600`]};
964
- }
965
-
966
- a {
967
- color: ${({ theme }) => theme.colors.neutral800};
968
- }
969
- }
970
-
971
- svg {
972
- color: ${({ theme, $variant = "neutral" }) => theme.colors[`${$variant}500`]};
973
- }
974
-
975
- span {
976
- color: ${({ theme, $variant = "neutral" }) => theme.colors[`${$variant}800`]};
977
- }
978
-
979
- span,
980
- a {
981
- width: 100%;
982
- }
983
- `;
984
- const DeleteReleaseActionItem = ({ releaseId, actionId }) => {
985
- const { formatMessage } = useIntl();
986
- const { toggleNotification } = useNotification();
987
- const { formatAPIError } = useAPIErrorHandler();
988
- const [deleteReleaseAction] = useDeleteReleaseActionMutation();
989
- const {
990
- allowedActions: { canDeleteAction }
991
- } = useRBAC(PERMISSIONS);
992
- const handleDeleteAction = async () => {
993
- const response = await deleteReleaseAction({
994
- params: { releaseId, actionId }
995
- });
996
- if ("data" in response) {
997
- toggleNotification({
998
- type: "success",
999
- message: formatMessage({
1000
- id: "content-releases.content-manager-edit-view.remove-from-release.notification.success",
1001
- defaultMessage: "Entry removed from release"
1002
- })
1003
- });
1004
- return;
1005
- }
1006
- if ("error" in response) {
1007
- if (isFetchError(response.error)) {
1008
- toggleNotification({
1009
- type: "danger",
1010
- message: formatAPIError(response.error)
1011
- });
1012
- } else {
1013
- toggleNotification({
1014
- type: "danger",
1015
- message: formatMessage({ id: "notification.error", defaultMessage: "An error occurred" })
1016
- });
1017
- }
1018
- }
1019
- };
1020
- if (!canDeleteAction) {
1021
- return null;
1022
- }
1023
- return /* @__PURE__ */ jsx(StyledMenuItem, { $variant: "danger", onSelect: handleDeleteAction, children: /* @__PURE__ */ jsxs(Flex, { gap: 2, children: [
1024
- /* @__PURE__ */ jsx(Cross, { width: "1.6rem", height: "1.6rem" }),
1025
- /* @__PURE__ */ jsx(Typography, { textColor: "danger600", variant: "omega", children: formatMessage({
1026
- id: "content-releases.content-manager-edit-view.remove-from-release",
1027
- defaultMessage: "Remove from release"
1028
- }) })
1029
- ] }) });
1030
- };
1031
- const ReleaseActionEntryLinkItem = ({
1032
- contentTypeUid,
1033
- documentId,
1034
- locale
1035
- }) => {
1036
- const { formatMessage } = useIntl();
1037
- const userPermissions = useAuth("ReleaseActionEntryLinkItem", (state) => state.permissions);
1038
- const canUpdateEntryForLocale = React.useMemo(() => {
1039
- const updatePermissions = userPermissions.find(
1040
- (permission) => permission.subject === contentTypeUid && permission.action === "plugin::content-manager.explorer.update"
1041
- );
1042
- if (!updatePermissions) {
1043
- return false;
1044
- }
1045
- return Boolean(!locale || updatePermissions.properties?.locales?.includes(locale));
1046
- }, [contentTypeUid, locale, userPermissions]);
1047
- const {
1048
- allowedActions: { canUpdate: canUpdateContentType }
1049
- } = useRBAC({
1050
- updateContentType: [
1051
- {
1052
- action: "plugin::content-manager.explorer.update",
1053
- subject: contentTypeUid
1054
- }
1055
- ]
1056
- });
1057
- if (!canUpdateContentType || !canUpdateEntryForLocale) {
1058
- return null;
1059
- }
1060
- return /* @__PURE__ */ jsx(
1061
- StyledMenuItem,
1062
- {
1063
- tag: NavLink,
1064
- isLink: true,
1065
- to: {
1066
- pathname: `/content-manager/collection-types/${contentTypeUid}/${documentId}`,
1067
- search: locale && `?plugins[i18n][locale]=${locale}`
1068
- },
1069
- children: /* @__PURE__ */ jsxs(Flex, { gap: 2, children: [
1070
- /* @__PURE__ */ jsx(Pencil, { width: "1.6rem", height: "1.6rem" }),
1071
- /* @__PURE__ */ jsx(Typography, { variant: "omega", children: formatMessage({
1072
- id: "content-releases.content-manager-edit-view.edit-entry",
1073
- defaultMessage: "Edit entry"
1074
- }) })
1075
- ] })
1076
- }
1077
- );
1078
- };
1079
- const EditReleaseItem = ({ releaseId }) => {
1080
- const { formatMessage } = useIntl();
1081
- return (
1082
- /* @ts-expect-error inference isn't working in DS */
1083
- /* @__PURE__ */ jsx(StyledMenuItem, { tag: NavLink, isLink: true, to: `/plugins/content-releases/${releaseId}`, children: /* @__PURE__ */ jsxs(Flex, { gap: 2, children: [
1084
- /* @__PURE__ */ jsx(Pencil, { width: "1.6rem", height: "1.6rem" }),
1085
- /* @__PURE__ */ jsx(Typography, { textColor: "neutral800", variant: "omega", children: formatMessage({
1086
- id: "content-releases.content-manager-edit-view.edit-release",
1087
- defaultMessage: "Edit release"
1088
- }) })
1089
- ] }) })
1090
- );
1091
- };
1092
- const Root = ({ children }) => {
1093
- const { formatMessage } = useIntl();
1094
- const { allowedActions } = useRBAC(PERMISSIONS);
1095
- return (
1096
- // A user can access the dropdown if they have permissions to delete a release-action OR update a release
1097
- allowedActions.canDeleteAction || allowedActions.canUpdate ? /* @__PURE__ */ jsxs(Menu.Root, { children: [
1098
- /* @__PURE__ */ jsx(StyledMoreButton, { variant: "tertiary", endIcon: null, paddingLeft: "7px", paddingRight: "7px", children: /* @__PURE__ */ jsx(
1099
- AccessibleIcon,
1100
- {
1101
- label: formatMessage({
1102
- id: "content-releases.content-manager-edit-view.release-action-menu",
1103
- defaultMessage: "Release action options"
1104
- }),
1105
- children: /* @__PURE__ */ jsx(More, {})
1106
- }
1107
- ) }),
1108
- /* @__PURE__ */ jsx(Menu.Content, { top: 1, popoverPlacement: "bottom-end", children })
1109
- ] }) : null
1110
- );
1111
- };
1112
- const StyledMoreButton = styled(Menu.Trigger)`
1113
- & > span {
1114
- display: flex;
1115
- }
1116
- `;
1117
- const ReleaseActionMenu = {
1118
- Root,
1119
- EditReleaseItem,
1120
- DeleteReleaseActionItem,
1121
- ReleaseActionEntryLinkItem
1122
- };
1123
- const Panel = ({
1124
- model,
1125
- document,
1126
- documentId,
1127
- collectionType
1128
- }) => {
1129
- const [{ query }] = useQueryParams();
1130
- const locale = query.plugins?.i18n?.locale;
1131
- const {
1132
- edit: { options }
1133
- } = unstable_useDocumentLayout(model);
1134
- const { formatMessage, formatDate, formatTime } = useIntl();
1135
- const { allowedActions } = useRBAC(PERMISSIONS);
1136
- const { canRead, canDeleteAction } = allowedActions;
1137
- const response = useGetReleasesForEntryQuery(
1138
- {
1139
- contentType: model,
1140
- entryDocumentId: documentId,
1141
- locale,
1142
- hasEntryAttached: true
1143
- },
1144
- {
1145
- skip: !document
1146
- }
1147
- );
1148
- const releases = response.data?.data;
1149
- const getReleaseColorVariant = (actionType, shade) => {
1150
- if (actionType === "unpublish") {
1151
- return `secondary${shade}`;
1152
- }
1153
- return `success${shade}`;
1154
- };
1155
- if (!window.strapi.isEE || !options?.draftAndPublish || !canRead) {
1156
- return null;
1157
- }
1158
- if (collectionType === "collection-types" && (!documentId || documentId === "create")) {
1159
- return null;
1160
- }
1161
- if (!releases || releases.length === 0) {
1162
- return null;
1163
- }
1164
- return {
1165
- title: formatMessage({
1166
- id: "content-releases.plugin.name",
1167
- defaultMessage: "Releases"
1168
- }),
1169
- content: /* @__PURE__ */ jsx(Flex, { direction: "column", alignItems: "stretch", gap: 3, width: "100%", children: releases?.map((release) => /* @__PURE__ */ jsxs(
1170
- Flex,
1171
- {
1172
- direction: "column",
1173
- alignItems: "start",
1174
- borderWidth: "1px",
1175
- borderStyle: "solid",
1176
- borderColor: getReleaseColorVariant(release.actions[0].type, "200"),
1177
- overflow: "hidden",
1178
- hasRadius: true,
1179
- children: [
1180
- /* @__PURE__ */ jsx(
1181
- Box,
1182
- {
1183
- paddingTop: 3,
1184
- paddingBottom: 3,
1185
- paddingLeft: 4,
1186
- paddingRight: 4,
1187
- background: getReleaseColorVariant(release.actions[0].type, "100"),
1188
- width: "100%",
1189
- children: /* @__PURE__ */ jsx(
1190
- Typography,
1191
- {
1192
- fontSize: 1,
1193
- variant: "pi",
1194
- textColor: getReleaseColorVariant(release.actions[0].type, "600"),
1195
- children: formatMessage(
1196
- {
1197
- id: "content-releases.content-manager-edit-view.list-releases.title",
1198
- defaultMessage: "{isPublish, select, true {Will be published in} other {Will be unpublished in}}"
1199
- },
1200
- { isPublish: release.actions[0].type === "publish" }
1201
- )
1202
- }
1203
- )
1204
- }
1205
- ),
1206
- /* @__PURE__ */ jsxs(Flex, { padding: 4, direction: "column", gap: 2, width: "100%", alignItems: "flex-start", children: [
1207
- /* @__PURE__ */ jsx(Typography, { fontSize: 2, fontWeight: "bold", variant: "omega", textColor: "neutral700", children: release.name }),
1208
- release.scheduledAt && release.timezone && /* @__PURE__ */ jsx(Typography, { variant: "pi", textColor: "neutral600", children: formatMessage(
1209
- {
1210
- id: "content-releases.content-manager-edit-view.scheduled.date",
1211
- defaultMessage: "{date} at {time} ({offset})"
1212
- },
1213
- {
1214
- date: formatDate(new Date(release.scheduledAt), {
1215
- day: "2-digit",
1216
- month: "2-digit",
1217
- year: "numeric",
1218
- timeZone: release.timezone
1219
- }),
1220
- time: formatTime(new Date(release.scheduledAt), {
1221
- hourCycle: "h23",
1222
- timeZone: release.timezone
1223
- }),
1224
- offset: getTimezoneOffset(release.timezone, new Date(release.scheduledAt))
1225
- }
1226
- ) }),
1227
- canDeleteAction ? /* @__PURE__ */ jsxs(ReleaseActionMenu.Root, { hasTriggerBorder: true, children: [
1228
- /* @__PURE__ */ jsx(ReleaseActionMenu.EditReleaseItem, { releaseId: release.id }),
1229
- /* @__PURE__ */ jsx(
1230
- ReleaseActionMenu.DeleteReleaseActionItem,
1231
- {
1232
- releaseId: release.id,
1233
- actionId: release.actions[0].id
1234
- }
1235
- )
1236
- ] }) : null
1237
- ] })
1238
- ]
1239
- },
1240
- release.id
1241
- )) })
1242
- };
1243
- };
1244
- const pluginId = "content-releases";
1245
- const prefixPluginTranslations = (trad, pluginId2) => {
1246
- if (!pluginId2) {
1247
- throw new TypeError("pluginId can't be empty");
1248
- }
1249
- return Object.keys(trad).reduce((acc, current) => {
1250
- acc[`${pluginId2}.${current}`] = trad[current];
1251
- return acc;
1252
- }, {});
1253
- };
1254
- const admin = {
1255
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
1256
- register(app) {
1257
- app.createHook("ContentReleases/pages/ReleaseDetails/add-locale-in-releases");
1258
- if (window.strapi.features.isEnabled("cms-content-releases")) {
1259
- app.addMenuLink({
1260
- to: `plugins/${pluginId}`,
1261
- icon: PaperPlane,
1262
- intlLabel: {
1263
- id: `${pluginId}.plugin.name`,
1264
- defaultMessage: "Releases"
1265
- },
1266
- Component: () => import("./App-Db0aPjrG.mjs").then((mod) => ({ default: mod.App })),
1267
- permissions: PERMISSIONS.main,
1268
- position: 2
1269
- });
1270
- const contentManagerPluginApis = app.getPlugin("content-manager").apis;
1271
- if ("addEditViewSidePanel" in contentManagerPluginApis && typeof contentManagerPluginApis.addEditViewSidePanel === "function") {
1272
- contentManagerPluginApis.addEditViewSidePanel([Panel]);
1273
- }
1274
- if ("addDocumentAction" in contentManagerPluginApis && typeof contentManagerPluginApis.addDocumentAction === "function") {
1275
- contentManagerPluginApis.addDocumentAction((actions) => {
1276
- const indexOfDeleteAction = actions.findIndex((action) => action.type === "unpublish");
1277
- actions.splice(indexOfDeleteAction, 0, ReleaseActionModalForm);
1278
- return actions;
1279
- });
1280
- }
1281
- app.addSettingsLink("global", {
1282
- id: pluginId,
1283
- to: "releases",
1284
- intlLabel: {
1285
- id: `${pluginId}.plugin.name`,
1286
- defaultMessage: "Releases"
1287
- },
1288
- permissions: [],
1289
- async Component() {
1290
- const { ProtectedReleasesSettingsPage } = await import("./ReleasesSettingsPage-C3rlM6Kf.mjs");
1291
- return { default: ProtectedReleasesSettingsPage };
1292
- }
1293
- });
1294
- if ("addBulkAction" in contentManagerPluginApis && typeof contentManagerPluginApis.addBulkAction === "function") {
1295
- contentManagerPluginApis.addBulkAction((actions) => {
1296
- const deleteActionIndex = actions.findIndex((action) => action.type === "delete");
1297
- actions.splice(deleteActionIndex, 0, ReleaseAction);
1298
- return actions;
1299
- });
1300
- }
1301
- app.registerHook("Admin/CM/pages/ListView/inject-column-in-table", addColumnToTableHook);
1302
- } else if (!window.strapi.features.isEnabled("cms-content-releases") && window.strapi?.flags?.promoteEE) {
1303
- app.addSettingsLink("global", {
1304
- id: pluginId,
1305
- to: "/plugins/purchase-content-releases",
1306
- intlLabel: {
1307
- id: `${pluginId}.plugin.name`,
1308
- defaultMessage: "Releases"
1309
- },
1310
- permissions: [],
1311
- async Component() {
1312
- const { PurchaseContentReleases } = await import("./PurchaseContentReleases-_MxP6-Dt.mjs");
1313
- return { default: PurchaseContentReleases };
1314
- },
1315
- licenseOnly: true
1316
- });
1317
- }
1318
- },
1319
- async registerTrads({ locales }) {
1320
- const importedTrads = await Promise.all(
1321
- locales.map((locale) => {
1322
- return __variableDynamicImportRuntimeHelper(/* @__PURE__ */ Object.assign({ "./translations/en.json": () => import("./en-D0yVZFqf.mjs") }), `./translations/${locale}.json`).then(({ default: data }) => {
1323
- return {
1324
- data: prefixPluginTranslations(data, "content-releases"),
1325
- locale
1326
- };
1327
- }).catch(() => {
1328
- return {
1329
- data: {},
1330
- locale
1331
- };
1332
- });
1333
- })
1334
- );
1335
- return Promise.resolve(importedTrads);
1336
- }
1337
- };
1338
- export {
1339
- PERMISSIONS as P,
1340
- ReleaseActionOptions as R,
1341
- useGetReleaseSettingsQuery as a,
1342
- useCreateReleaseMutation as b,
1343
- useGetReleaseQuery as c,
1344
- useUpdateReleaseMutation as d,
1345
- useDeleteReleaseMutation as e,
1346
- usePublishReleaseMutation as f,
1347
- getTimezones as g,
1348
- getTimezoneOffset as h,
1349
- useGetReleaseActionsQuery as i,
1350
- useUpdateReleaseActionMutation as j,
1351
- ReleaseActionMenu as k,
1352
- useUpdateReleaseSettingsMutation as l,
1353
- admin as m,
1354
- pluginId as p,
1355
- releaseApi as r,
1356
- useGetReleasesQuery as u
1357
- };
1358
- //# sourceMappingURL=index-Dj_bL2s7.mjs.map