@strapi/content-releases 0.0.0-experimental.d23c1d5b0e45dd06ef09977f526c85468be05403 → 0.0.0-experimental.d23f1485e5669cca1cee1bf5f8168b6b8109b78f

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