@strapi/content-releases 0.0.0-next.c5f067b5650921187770124e9b6c8186e805e242 → 0.0.0-next.c72b48da735f44a3ccafb7a6dc9ba5213f3844db

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