@strapi/content-releases 0.0.0-experimental.f2351bcfa3965c60f063a492da51faa2c636eee8 → 0.0.0-experimental.f28dba7c374eae9c02b95b4b77aba4c3ad41a841

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