@strapi/content-releases 0.0.0-next.fc231041206e6f3999b094160cfa05db2892ad54 → 0.0.0-next.fc9d26d995624dc886b29f563e1de655d47e6609

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