@strapi/content-releases 5.0.0-rc.2 → 5.0.0-rc.21

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 (60) hide show
  1. package/dist/_chunks/{App-CKoteEu-.js → App-BFo3ibui.js} +156 -101
  2. package/dist/_chunks/App-BFo3ibui.js.map +1 -0
  3. package/dist/_chunks/{App-CwBi9wFK.mjs → App-JwN_xBnA.mjs} +161 -106
  4. package/dist/_chunks/App-JwN_xBnA.mjs.map +1 -0
  5. package/dist/_chunks/{ReleasesSettingsPage-U9Ud3HzH.js → ReleasesSettingsPage-BanjZwEc.js} +4 -4
  6. package/dist/_chunks/ReleasesSettingsPage-BanjZwEc.js.map +1 -0
  7. package/dist/_chunks/{ReleasesSettingsPage-Be1qEgcA.mjs → ReleasesSettingsPage-CNMXGcZC.mjs} +4 -4
  8. package/dist/_chunks/ReleasesSettingsPage-CNMXGcZC.mjs.map +1 -0
  9. package/dist/_chunks/{en-1_1re1mc.js → en-CmYoEnA7.js} +3 -1
  10. package/dist/_chunks/en-CmYoEnA7.js.map +1 -0
  11. package/dist/_chunks/{en-C3sq5KNP.mjs → en-D0yVZFqf.mjs} +3 -1
  12. package/dist/_chunks/en-D0yVZFqf.mjs.map +1 -0
  13. package/dist/_chunks/{index-VB3t7pBK.mjs → index-C_e6DQb0.mjs} +254 -11
  14. package/dist/_chunks/index-C_e6DQb0.mjs.map +1 -0
  15. package/dist/_chunks/{index-JLkDg3pp.js → index-Em3KctMx.js} +251 -8
  16. package/dist/_chunks/index-Em3KctMx.js.map +1 -0
  17. package/dist/_chunks/schemas-63pFihNF.mjs +44 -0
  18. package/dist/_chunks/schemas-63pFihNF.mjs.map +1 -0
  19. package/dist/_chunks/{schemas-3o-6hwUE.js → schemas-z5zp-_Gd.js} +20 -18
  20. package/dist/_chunks/schemas-z5zp-_Gd.js.map +1 -0
  21. package/dist/admin/index.js +1 -1
  22. package/dist/admin/index.mjs +1 -1
  23. package/dist/admin/src/components/ReleaseListCell.d.ts +28 -0
  24. package/dist/admin/src/services/release.d.ts +6 -4
  25. package/dist/admin/src/validation/schemas.d.ts +4 -0
  26. package/dist/server/index.js +84 -76
  27. package/dist/server/index.js.map +1 -1
  28. package/dist/server/index.mjs +84 -76
  29. package/dist/server/index.mjs.map +1 -1
  30. package/dist/server/src/controllers/index.d.ts +2 -0
  31. package/dist/server/src/controllers/index.d.ts.map +1 -1
  32. package/dist/server/src/controllers/release-action.d.ts +1 -0
  33. package/dist/server/src/controllers/release-action.d.ts.map +1 -1
  34. package/dist/server/src/controllers/release.d.ts +1 -0
  35. package/dist/server/src/controllers/release.d.ts.map +1 -1
  36. package/dist/server/src/index.d.ts +4 -0
  37. package/dist/server/src/index.d.ts.map +1 -1
  38. package/dist/server/src/routes/release-action.d.ts.map +1 -1
  39. package/dist/server/src/routes/release.d.ts.map +1 -1
  40. package/dist/server/src/services/index.d.ts +2 -0
  41. package/dist/server/src/services/index.d.ts.map +1 -1
  42. package/dist/server/src/services/release-action.d.ts +3 -1
  43. package/dist/server/src/services/release-action.d.ts.map +1 -1
  44. package/dist/shared/contracts/release-actions.d.ts +3 -5
  45. package/dist/shared/contracts/release-actions.d.ts.map +1 -1
  46. package/dist/shared/contracts/releases.d.ts +3 -2
  47. package/dist/shared/contracts/releases.d.ts.map +1 -1
  48. package/package.json +12 -11
  49. package/dist/_chunks/App-CKoteEu-.js.map +0 -1
  50. package/dist/_chunks/App-CwBi9wFK.mjs.map +0 -1
  51. package/dist/_chunks/ReleasesSettingsPage-Be1qEgcA.mjs.map +0 -1
  52. package/dist/_chunks/ReleasesSettingsPage-U9Ud3HzH.js.map +0 -1
  53. package/dist/_chunks/en-1_1re1mc.js.map +0 -1
  54. package/dist/_chunks/en-C3sq5KNP.mjs.map +0 -1
  55. package/dist/_chunks/index-JLkDg3pp.js.map +0 -1
  56. package/dist/_chunks/index-VB3t7pBK.mjs.map +0 -1
  57. package/dist/_chunks/schemas-3o-6hwUE.js.map +0 -1
  58. package/dist/_chunks/schemas-CBVqXur2.mjs +0 -42
  59. package/dist/_chunks/schemas-CBVqXur2.mjs.map +0 -1
  60. package/strapi-server.js +0 -3
@@ -6,8 +6,8 @@ const designSystem = require("@strapi/design-system");
6
6
  const icons = require("@strapi/icons");
7
7
  const reactIntl = require("react-intl");
8
8
  const reactRedux = require("react-redux");
9
- const index = require("./index-JLkDg3pp.js");
10
- const schemas = require("./schemas-3o-6hwUE.js");
9
+ const index = require("./index-Em3KctMx.js");
10
+ const schemas = require("./schemas-z5zp-_Gd.js");
11
11
  const useTypedSelector = reactRedux.useSelector;
12
12
  const ReleasesSettingsPage = () => {
13
13
  const { formatMessage } = reactIntl.useIntl();
@@ -116,7 +116,7 @@ const ReleasesSettingsPage = () => {
116
116
  id: "content-releases.pages.Settings.releases.preferences.title",
117
117
  defaultMessage: "Preferences"
118
118
  }) }),
119
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Root, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Item, { col: 6, s: 12, children: /* @__PURE__ */ jsxRuntime.jsx(TimezoneDropdown, {}) }) })
119
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Root, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Item, { col: 6, s: 12, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsxRuntime.jsx(TimezoneDropdown, {}) }) })
120
120
  ]
121
121
  }
122
122
  ) })
@@ -175,4 +175,4 @@ const ProtectedReleasesSettingsPage = () => {
175
175
  return /* @__PURE__ */ jsxRuntime.jsx(strapiAdmin.Page.Protect, { permissions, children: /* @__PURE__ */ jsxRuntime.jsx(ReleasesSettingsPage, {}) });
176
176
  };
177
177
  exports.ProtectedReleasesSettingsPage = ProtectedReleasesSettingsPage;
178
- //# sourceMappingURL=ReleasesSettingsPage-U9Ud3HzH.js.map
178
+ //# sourceMappingURL=ReleasesSettingsPage-BanjZwEc.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ReleasesSettingsPage-BanjZwEc.js","sources":["../../admin/src/modules/hooks.ts","../../admin/src/pages/ReleasesSettingsPage.tsx"],"sourcesContent":["import { Dispatch } from '@reduxjs/toolkit';\nimport { TypedUseSelectorHook, useDispatch, useSelector } from 'react-redux';\n\nimport type { Store } from '@strapi/admin/strapi-admin';\n\ntype RootState = ReturnType<Store['getState']>;\n\nconst useTypedDispatch: () => Dispatch = useDispatch;\nconst useTypedSelector: TypedUseSelectorHook<RootState> = useSelector;\n\nexport { useTypedSelector, useTypedDispatch };\n","import {\n Form,\n Layouts,\n Page,\n useAPIErrorHandler,\n isFetchError,\n useNotification,\n useField,\n useRBAC,\n} from '@strapi/admin/strapi-admin';\nimport {\n Button,\n Combobox,\n ComboboxOption,\n Field,\n Flex,\n Grid,\n Typography,\n} from '@strapi/design-system';\nimport { Check } from '@strapi/icons';\nimport { useIntl } from 'react-intl';\n\nimport { useTypedSelector } from '../modules/hooks';\nimport { useGetReleaseSettingsQuery, useUpdateReleaseSettingsMutation } from '../services/release';\nimport { getTimezones } from '../utils/time';\nimport { SETTINGS_SCHEMA } from '../validation/schemas';\n\nimport type { UpdateSettings } from '../../../shared/contracts/settings';\n\nconst ReleasesSettingsPage = () => {\n const { formatMessage } = useIntl();\n const { formatAPIError } = useAPIErrorHandler();\n const { toggleNotification } = useNotification();\n const { data, isLoading: isLoadingSettings } = useGetReleaseSettingsQuery();\n const [updateReleaseSettings, { isLoading: isSubmittingForm }] =\n useUpdateReleaseSettingsMutation();\n const permissions = useTypedSelector(\n (state) => state.admin_app.permissions['settings']?.['releases']\n );\n const {\n allowedActions: { canUpdate },\n } = useRBAC(permissions);\n\n const { timezoneList } = getTimezones(new Date());\n\n const handleSubmit = async (body: UpdateSettings.Request['body']) => {\n const { defaultTimezone } = body;\n const isBodyTimezoneValid = timezoneList.some((timezone) => timezone.value === defaultTimezone);\n const newBody =\n !defaultTimezone || !isBodyTimezoneValid ? { defaultTimezone: null } : { ...body };\n try {\n const response = await updateReleaseSettings(newBody);\n\n if ('data' in response) {\n toggleNotification({\n type: 'success',\n message: formatMessage({\n id: 'content-releases.pages.Settings.releases.setting.default-timezone-notification-success',\n defaultMessage: 'Default timezone updated.',\n }),\n });\n } else if (isFetchError(response.error)) {\n toggleNotification({\n type: 'danger',\n message: formatAPIError(response.error),\n });\n } else {\n toggleNotification({\n type: 'danger',\n message: formatMessage({ id: 'notification.error', defaultMessage: 'An error occurred' }),\n });\n }\n } catch (error) {\n toggleNotification({\n type: 'danger',\n message: formatMessage({ id: 'notification.error', defaultMessage: 'An error occurred' }),\n });\n }\n };\n\n if (isLoadingSettings) {\n return <Page.Loading />;\n }\n\n return (\n <Layouts.Root>\n <Page.Title>\n {formatMessage(\n { id: 'Settings.PageTitle', defaultMessage: 'Settings - {name}' },\n {\n name: 'Releases',\n }\n )}\n </Page.Title>\n <Page.Main aria-busy={isLoadingSettings} tabIndex={-1}>\n <Form\n method=\"PUT\"\n initialValues={{\n defaultTimezone: data?.data.defaultTimezone,\n }}\n onSubmit={handleSubmit}\n validationSchema={SETTINGS_SCHEMA}\n >\n {({ modified, isSubmitting }: { modified: boolean; isSubmitting: boolean }) => {\n return (\n <>\n <Layouts.Header\n primaryAction={\n canUpdate ? (\n <Button\n disabled={!modified || isSubmittingForm}\n loading={isSubmitting}\n startIcon={<Check />}\n type=\"submit\"\n >\n {formatMessage({\n id: 'global.save',\n defaultMessage: 'Save',\n })}\n </Button>\n ) : null\n }\n title={formatMessage({\n id: 'content-releases.pages.Settings.releases.title',\n defaultMessage: 'Releases',\n })}\n subtitle={formatMessage({\n id: 'content-releases.pages.Settings.releases.description',\n defaultMessage: 'Create and manage content updates',\n })}\n />\n <Layouts.Content>\n <Flex\n direction=\"column\"\n background=\"neutral0\"\n alignItems=\"stretch\"\n padding={6}\n gap={6}\n shadow=\"filterShadow\"\n hasRadius\n >\n <Typography variant=\"delta\" tag=\"h2\">\n {formatMessage({\n id: 'content-releases.pages.Settings.releases.preferences.title',\n defaultMessage: 'Preferences',\n })}\n </Typography>\n <Grid.Root>\n <Grid.Item col={6} s={12} direction=\"column\" alignItems=\"stretch\">\n <TimezoneDropdown />\n </Grid.Item>\n </Grid.Root>\n </Flex>\n </Layouts.Content>\n </>\n );\n }}\n </Form>\n </Page.Main>\n </Layouts.Root>\n );\n};\n\nconst TimezoneDropdown = () => {\n const permissions = useTypedSelector(\n (state) => state.admin_app.permissions['settings']?.['releases']\n );\n const {\n allowedActions: { canUpdate },\n } = useRBAC(permissions);\n const { formatMessage } = useIntl();\n const { timezoneList } = getTimezones(new Date());\n const field = useField('defaultTimezone');\n return (\n <Field.Root\n name=\"defaultTimezone\"\n hint={formatMessage({\n id: 'content-releases.pages.Settings.releases.timezone.hint',\n defaultMessage: 'The timezone of every release can still be changed individually. ',\n })}\n error={field.error}\n >\n <Field.Label>\n {formatMessage({\n id: 'content-releases.pages.Settings.releases.timezone.label',\n defaultMessage: 'Default timezone',\n })}\n </Field.Label>\n <Combobox\n autocomplete={{ type: 'list', filter: 'contains' }}\n onChange={(value) => field.onChange('defaultTimezone', value)}\n onTextValueChange={(value) => field.onChange('defaultTimezone', value)}\n onClear={() => field.onChange('defaultTimezone', '')}\n value={field.value}\n disabled={!canUpdate}\n >\n {timezoneList.map((timezone) => (\n <ComboboxOption key={timezone.value} value={timezone.value}>\n {timezone.value.replace(/&/, ' ')}\n </ComboboxOption>\n ))}\n </Combobox>\n <Field.Hint />\n <Field.Error />\n </Field.Root>\n );\n};\n\n/* -------------------------------------------------------------------------------------------------\n * ProtectedSettingsPage\n * -----------------------------------------------------------------------------------------------*/\n\nexport const ProtectedReleasesSettingsPage = () => {\n const permissions = useTypedSelector(\n (state) => state.admin_app.permissions['settings']?.['releases']?.read\n );\n\n return (\n <Page.Protect permissions={permissions}>\n <ReleasesSettingsPage />\n </Page.Protect>\n );\n};\n"],"names":["useSelector","useIntl","useAPIErrorHandler","useNotification","useGetReleaseSettingsQuery","useUpdateReleaseSettingsMutation","useRBAC","getTimezones","isFetchError","jsx","Page","jsxs","Layouts","Form","SETTINGS_SCHEMA","Fragment","Button","Check","Flex","Typography","Grid","useField","Field","Combobox","ComboboxOption"],"mappings":"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"}
@@ -4,8 +4,8 @@ import { Button, Flex, Typography, Grid, Field, Combobox, ComboboxOption } from
4
4
  import { Check } from "@strapi/icons";
5
5
  import { useIntl } from "react-intl";
6
6
  import { useSelector } from "react-redux";
7
- import { a as useGetReleaseSettingsQuery, l as useUpdateReleaseSettingsMutation, g as getTimezones } from "./index-VB3t7pBK.mjs";
8
- import { S as SETTINGS_SCHEMA } from "./schemas-CBVqXur2.mjs";
7
+ import { a as useGetReleaseSettingsQuery, l as useUpdateReleaseSettingsMutation, g as getTimezones } from "./index-C_e6DQb0.mjs";
8
+ import { S as SETTINGS_SCHEMA } from "./schemas-63pFihNF.mjs";
9
9
  const useTypedSelector = useSelector;
10
10
  const ReleasesSettingsPage = () => {
11
11
  const { formatMessage } = useIntl();
@@ -114,7 +114,7 @@ const ReleasesSettingsPage = () => {
114
114
  id: "content-releases.pages.Settings.releases.preferences.title",
115
115
  defaultMessage: "Preferences"
116
116
  }) }),
117
- /* @__PURE__ */ jsx(Grid.Root, { children: /* @__PURE__ */ jsx(Grid.Item, { col: 6, s: 12, children: /* @__PURE__ */ jsx(TimezoneDropdown, {}) }) })
117
+ /* @__PURE__ */ jsx(Grid.Root, { children: /* @__PURE__ */ jsx(Grid.Item, { col: 6, s: 12, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsx(TimezoneDropdown, {}) }) })
118
118
  ]
119
119
  }
120
120
  ) })
@@ -175,4 +175,4 @@ const ProtectedReleasesSettingsPage = () => {
175
175
  export {
176
176
  ProtectedReleasesSettingsPage
177
177
  };
178
- //# sourceMappingURL=ReleasesSettingsPage-Be1qEgcA.mjs.map
178
+ //# sourceMappingURL=ReleasesSettingsPage-CNMXGcZC.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ReleasesSettingsPage-CNMXGcZC.mjs","sources":["../../admin/src/modules/hooks.ts","../../admin/src/pages/ReleasesSettingsPage.tsx"],"sourcesContent":["import { Dispatch } from '@reduxjs/toolkit';\nimport { TypedUseSelectorHook, useDispatch, useSelector } from 'react-redux';\n\nimport type { Store } from '@strapi/admin/strapi-admin';\n\ntype RootState = ReturnType<Store['getState']>;\n\nconst useTypedDispatch: () => Dispatch = useDispatch;\nconst useTypedSelector: TypedUseSelectorHook<RootState> = useSelector;\n\nexport { useTypedSelector, useTypedDispatch };\n","import {\n Form,\n Layouts,\n Page,\n useAPIErrorHandler,\n isFetchError,\n useNotification,\n useField,\n useRBAC,\n} from '@strapi/admin/strapi-admin';\nimport {\n Button,\n Combobox,\n ComboboxOption,\n Field,\n Flex,\n Grid,\n Typography,\n} from '@strapi/design-system';\nimport { Check } from '@strapi/icons';\nimport { useIntl } from 'react-intl';\n\nimport { useTypedSelector } from '../modules/hooks';\nimport { useGetReleaseSettingsQuery, useUpdateReleaseSettingsMutation } from '../services/release';\nimport { getTimezones } from '../utils/time';\nimport { SETTINGS_SCHEMA } from '../validation/schemas';\n\nimport type { UpdateSettings } from '../../../shared/contracts/settings';\n\nconst ReleasesSettingsPage = () => {\n const { formatMessage } = useIntl();\n const { formatAPIError } = useAPIErrorHandler();\n const { toggleNotification } = useNotification();\n const { data, isLoading: isLoadingSettings } = useGetReleaseSettingsQuery();\n const [updateReleaseSettings, { isLoading: isSubmittingForm }] =\n useUpdateReleaseSettingsMutation();\n const permissions = useTypedSelector(\n (state) => state.admin_app.permissions['settings']?.['releases']\n );\n const {\n allowedActions: { canUpdate },\n } = useRBAC(permissions);\n\n const { timezoneList } = getTimezones(new Date());\n\n const handleSubmit = async (body: UpdateSettings.Request['body']) => {\n const { defaultTimezone } = body;\n const isBodyTimezoneValid = timezoneList.some((timezone) => timezone.value === defaultTimezone);\n const newBody =\n !defaultTimezone || !isBodyTimezoneValid ? { defaultTimezone: null } : { ...body };\n try {\n const response = await updateReleaseSettings(newBody);\n\n if ('data' in response) {\n toggleNotification({\n type: 'success',\n message: formatMessage({\n id: 'content-releases.pages.Settings.releases.setting.default-timezone-notification-success',\n defaultMessage: 'Default timezone updated.',\n }),\n });\n } else if (isFetchError(response.error)) {\n toggleNotification({\n type: 'danger',\n message: formatAPIError(response.error),\n });\n } else {\n toggleNotification({\n type: 'danger',\n message: formatMessage({ id: 'notification.error', defaultMessage: 'An error occurred' }),\n });\n }\n } catch (error) {\n toggleNotification({\n type: 'danger',\n message: formatMessage({ id: 'notification.error', defaultMessage: 'An error occurred' }),\n });\n }\n };\n\n if (isLoadingSettings) {\n return <Page.Loading />;\n }\n\n return (\n <Layouts.Root>\n <Page.Title>\n {formatMessage(\n { id: 'Settings.PageTitle', defaultMessage: 'Settings - {name}' },\n {\n name: 'Releases',\n }\n )}\n </Page.Title>\n <Page.Main aria-busy={isLoadingSettings} tabIndex={-1}>\n <Form\n method=\"PUT\"\n initialValues={{\n defaultTimezone: data?.data.defaultTimezone,\n }}\n onSubmit={handleSubmit}\n validationSchema={SETTINGS_SCHEMA}\n >\n {({ modified, isSubmitting }: { modified: boolean; isSubmitting: boolean }) => {\n return (\n <>\n <Layouts.Header\n primaryAction={\n canUpdate ? (\n <Button\n disabled={!modified || isSubmittingForm}\n loading={isSubmitting}\n startIcon={<Check />}\n type=\"submit\"\n >\n {formatMessage({\n id: 'global.save',\n defaultMessage: 'Save',\n })}\n </Button>\n ) : null\n }\n title={formatMessage({\n id: 'content-releases.pages.Settings.releases.title',\n defaultMessage: 'Releases',\n })}\n subtitle={formatMessage({\n id: 'content-releases.pages.Settings.releases.description',\n defaultMessage: 'Create and manage content updates',\n })}\n />\n <Layouts.Content>\n <Flex\n direction=\"column\"\n background=\"neutral0\"\n alignItems=\"stretch\"\n padding={6}\n gap={6}\n shadow=\"filterShadow\"\n hasRadius\n >\n <Typography variant=\"delta\" tag=\"h2\">\n {formatMessage({\n id: 'content-releases.pages.Settings.releases.preferences.title',\n defaultMessage: 'Preferences',\n })}\n </Typography>\n <Grid.Root>\n <Grid.Item col={6} s={12} direction=\"column\" alignItems=\"stretch\">\n <TimezoneDropdown />\n </Grid.Item>\n </Grid.Root>\n </Flex>\n </Layouts.Content>\n </>\n );\n }}\n </Form>\n </Page.Main>\n </Layouts.Root>\n );\n};\n\nconst TimezoneDropdown = () => {\n const permissions = useTypedSelector(\n (state) => state.admin_app.permissions['settings']?.['releases']\n );\n const {\n allowedActions: { canUpdate },\n } = useRBAC(permissions);\n const { formatMessage } = useIntl();\n const { timezoneList } = getTimezones(new Date());\n const field = useField('defaultTimezone');\n return (\n <Field.Root\n name=\"defaultTimezone\"\n hint={formatMessage({\n id: 'content-releases.pages.Settings.releases.timezone.hint',\n defaultMessage: 'The timezone of every release can still be changed individually. ',\n })}\n error={field.error}\n >\n <Field.Label>\n {formatMessage({\n id: 'content-releases.pages.Settings.releases.timezone.label',\n defaultMessage: 'Default timezone',\n })}\n </Field.Label>\n <Combobox\n autocomplete={{ type: 'list', filter: 'contains' }}\n onChange={(value) => field.onChange('defaultTimezone', value)}\n onTextValueChange={(value) => field.onChange('defaultTimezone', value)}\n onClear={() => field.onChange('defaultTimezone', '')}\n value={field.value}\n disabled={!canUpdate}\n >\n {timezoneList.map((timezone) => (\n <ComboboxOption key={timezone.value} value={timezone.value}>\n {timezone.value.replace(/&/, ' ')}\n </ComboboxOption>\n ))}\n </Combobox>\n <Field.Hint />\n <Field.Error />\n </Field.Root>\n );\n};\n\n/* -------------------------------------------------------------------------------------------------\n * ProtectedSettingsPage\n * -----------------------------------------------------------------------------------------------*/\n\nexport const ProtectedReleasesSettingsPage = () => {\n const permissions = useTypedSelector(\n (state) => state.admin_app.permissions['settings']?.['releases']?.read\n );\n\n return (\n <Page.Protect permissions={permissions}>\n <ReleasesSettingsPage />\n </Page.Protect>\n );\n};\n"],"names":[],"mappings":"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"}
@@ -17,6 +17,7 @@ const en = {
17
17
  "content-releases.content-manager-edit-view.edit-entry": "Edit entry",
18
18
  "content-manager-edit-view.remove-from-release.notification.success": "Entry removed from release",
19
19
  "content-manager-edit-view.release-action-menu": "Release action options",
20
+ "content-manager.list-view.releases.header": "To be released in",
20
21
  "content-manager-list-view.add-to-release": "Add to release",
21
22
  "content-manager-list-view.add-to-release.cancel-button": "Cancel",
22
23
  "content-manager-list-view.add-to-release.continue-button": "Continue",
@@ -53,6 +54,7 @@ const en = {
53
54
  "modal.form.input.label.timezone": "Timezone",
54
55
  "modal.form.input.clearLabel": "Clear",
55
56
  "modal.form.button.submit": "{isCreatingRelease, select, true {Continue} other {Save}}",
57
+ "modal.form.time.has-passed": "Selected time has already passed.",
56
58
  "pages.Details.header-subtitle": "{number, plural, =0 {No entries} one {# entry} other {# entries}}",
57
59
  "pages.Releases.tab-group.label": "Releases list",
58
60
  "pages.Releases.tab.pending": "Pending ({count})",
@@ -88,4 +90,4 @@ const en = {
88
90
  "pages.Settings.releases.setting.default-timezone-notification-success": "Default timezone updated."
89
91
  };
90
92
  exports.default = en;
91
- //# sourceMappingURL=en-1_1re1mc.js.map
93
+ //# sourceMappingURL=en-CmYoEnA7.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"en-CmYoEnA7.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -15,6 +15,7 @@ const en = {
15
15
  "content-releases.content-manager-edit-view.edit-entry": "Edit entry",
16
16
  "content-manager-edit-view.remove-from-release.notification.success": "Entry removed from release",
17
17
  "content-manager-edit-view.release-action-menu": "Release action options",
18
+ "content-manager.list-view.releases.header": "To be released in",
18
19
  "content-manager-list-view.add-to-release": "Add to release",
19
20
  "content-manager-list-view.add-to-release.cancel-button": "Cancel",
20
21
  "content-manager-list-view.add-to-release.continue-button": "Continue",
@@ -51,6 +52,7 @@ const en = {
51
52
  "modal.form.input.label.timezone": "Timezone",
52
53
  "modal.form.input.clearLabel": "Clear",
53
54
  "modal.form.button.submit": "{isCreatingRelease, select, true {Continue} other {Save}}",
55
+ "modal.form.time.has-passed": "Selected time has already passed.",
54
56
  "pages.Details.header-subtitle": "{number, plural, =0 {No entries} one {# entry} other {# entries}}",
55
57
  "pages.Releases.tab-group.label": "Releases list",
56
58
  "pages.Releases.tab.pending": "Pending ({count})",
@@ -88,4 +90,4 @@ const en = {
88
90
  export {
89
91
  en as default
90
92
  };
91
- //# sourceMappingURL=en-C3sq5KNP.mjs.map
93
+ //# sourceMappingURL=en-D0yVZFqf.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"en-D0yVZFqf.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,11 +1,11 @@
1
- import { PaperPlane, Cross, Pencil, More } from "@strapi/icons";
1
+ import { PaperPlane, CaretDown, Cross, Pencil, More } from "@strapi/icons";
2
2
  import { jsxs, jsx } from "react/jsx-runtime";
3
- import { adminApi, useRBAC, useNotification, useAPIErrorHandler, useQueryParams, isFetchError, useAuth } from "@strapi/admin/strapi-admin";
3
+ import { adminApi, useRBAC, useNotification, useAPIErrorHandler, useQueryParams, isFetchError, useTable, useAuth } from "@strapi/admin/strapi-admin";
4
+ import { Field, Flex, VisuallyHidden, Modal, Button, EmptyStateLayout, LinkButton, Box, SingleSelect, SingleSelectOption, Popover, Typography, Link as Link$1, Menu, AccessibleIcon } from "@strapi/design-system";
5
+ import { useFormik, Formik, Form } from "formik";
6
+ import { useIntl } from "react-intl";
4
7
  import { unstable_useDocumentLayout } from "@strapi/content-manager/strapi-admin";
5
- import { Field, Flex, VisuallyHidden, Modal, Button, Box, SingleSelect, SingleSelectOption, EmptyStateLayout, LinkButton, Menu, Typography, AccessibleIcon } from "@strapi/design-system";
6
8
  import { EmptyDocuments } from "@strapi/icons/symbols";
7
- import { useFormik } from "formik";
8
- import { useIntl } from "react-intl";
9
9
  import { Link, NavLink } from "react-router-dom";
10
10
  import * as yup from "yup";
11
11
  import { styled } from "styled-components";
@@ -352,7 +352,7 @@ const releaseApi = adminApi.enhanceEndpoints({
352
352
  data
353
353
  };
354
354
  },
355
- invalidatesTags: (result, error, arg) => [{ type: "ReleaseSettings" }]
355
+ invalidatesTags: [{ type: "ReleaseSettings" }]
356
356
  })
357
357
  };
358
358
  }
@@ -693,6 +693,236 @@ const ReleaseActionModalForm = ({
693
693
  }
694
694
  };
695
695
  };
696
+ const getContentPermissions = (subject) => {
697
+ const permissions = {
698
+ publish: [
699
+ {
700
+ action: "plugin::content-manager.explorer.publish",
701
+ subject,
702
+ id: "",
703
+ actionParameters: {},
704
+ properties: {},
705
+ conditions: []
706
+ }
707
+ ]
708
+ };
709
+ return permissions;
710
+ };
711
+ const ReleaseAction = ({ documents, model }) => {
712
+ const { formatMessage } = useIntl();
713
+ const { toggleNotification } = useNotification();
714
+ const { formatAPIError } = useAPIErrorHandler();
715
+ const [{ query }] = useQueryParams();
716
+ const contentPermissions = getContentPermissions(model);
717
+ const {
718
+ allowedActions: { canPublish }
719
+ } = useRBAC(contentPermissions);
720
+ const {
721
+ allowedActions: { canCreate }
722
+ } = useRBAC(PERMISSIONS);
723
+ const response = useGetReleasesQuery();
724
+ const releases = response.data?.data;
725
+ const [createManyReleaseActions, { isLoading }] = useCreateManyReleaseActionsMutation();
726
+ const documentIds = documents.map((doc) => doc.documentId);
727
+ const handleSubmit = async (values) => {
728
+ const locale = query.plugins?.i18n?.locale;
729
+ const releaseActionEntries = documentIds.map(
730
+ (entryDocumentId) => ({
731
+ type: values.type,
732
+ contentType: model,
733
+ entryDocumentId,
734
+ locale
735
+ })
736
+ );
737
+ const response2 = await createManyReleaseActions({
738
+ body: releaseActionEntries,
739
+ params: { releaseId: values.releaseId }
740
+ });
741
+ if ("data" in response2) {
742
+ const notificationMessage = formatMessage(
743
+ {
744
+ id: "content-releases.content-manager-list-view.add-to-release.notification.success.message",
745
+ defaultMessage: "{entriesAlreadyInRelease} out of {totalEntries} entries were already in the release."
746
+ },
747
+ {
748
+ entriesAlreadyInRelease: response2.data.meta.entriesAlreadyInRelease,
749
+ totalEntries: response2.data.meta.totalEntries
750
+ }
751
+ );
752
+ const notification = {
753
+ type: "success",
754
+ title: formatMessage(
755
+ {
756
+ id: "content-releases.content-manager-list-view.add-to-release.notification.success.title",
757
+ defaultMessage: "Successfully added to release."
758
+ },
759
+ {
760
+ entriesAlreadyInRelease: response2.data.meta.entriesAlreadyInRelease,
761
+ totalEntries: response2.data.meta.totalEntries
762
+ }
763
+ ),
764
+ message: response2.data.meta.entriesAlreadyInRelease ? notificationMessage : ""
765
+ };
766
+ toggleNotification(notification);
767
+ return true;
768
+ }
769
+ if ("error" in response2) {
770
+ if (isFetchError(response2.error)) {
771
+ toggleNotification({
772
+ type: "warning",
773
+ message: formatAPIError(response2.error)
774
+ });
775
+ } else {
776
+ toggleNotification({
777
+ type: "warning",
778
+ message: formatMessage({ id: "notification.error", defaultMessage: "An error occurred" })
779
+ });
780
+ }
781
+ }
782
+ };
783
+ if (!canCreate || !canPublish)
784
+ return null;
785
+ return {
786
+ actionType: "release",
787
+ variant: "tertiary",
788
+ label: formatMessage({
789
+ id: "content-manager-list-view.add-to-release",
790
+ defaultMessage: "Add to Release"
791
+ }),
792
+ dialog: {
793
+ type: "modal",
794
+ title: formatMessage({
795
+ id: "content-manager-list-view.add-to-release",
796
+ defaultMessage: "Add to Release"
797
+ }),
798
+ content: ({ onClose }) => {
799
+ return /* @__PURE__ */ jsx(
800
+ Formik,
801
+ {
802
+ onSubmit: async (values) => {
803
+ const data = await handleSubmit(values);
804
+ if (data) {
805
+ return onClose();
806
+ }
807
+ },
808
+ validationSchema: RELEASE_ACTION_FORM_SCHEMA,
809
+ initialValues: INITIAL_VALUES,
810
+ children: ({ values, setFieldValue }) => /* @__PURE__ */ jsxs(Form, { children: [
811
+ releases?.length === 0 ? /* @__PURE__ */ jsx(NoReleases, {}) : /* @__PURE__ */ jsx(Modal.Body, { children: /* @__PURE__ */ jsxs(Flex, { direction: "column", alignItems: "stretch", gap: 2, children: [
812
+ /* @__PURE__ */ jsx(Box, { paddingBottom: 6, children: /* @__PURE__ */ jsxs(Field.Root, { required: true, children: [
813
+ /* @__PURE__ */ jsx(Field.Label, { children: formatMessage({
814
+ id: "content-releases.content-manager-list-view.add-to-release.select-label",
815
+ defaultMessage: "Select a release"
816
+ }) }),
817
+ /* @__PURE__ */ jsx(
818
+ SingleSelect,
819
+ {
820
+ placeholder: formatMessage({
821
+ id: "content-releases.content-manager-list-view.add-to-release.select-placeholder",
822
+ defaultMessage: "Select"
823
+ }),
824
+ onChange: (value) => setFieldValue("releaseId", value),
825
+ value: values.releaseId,
826
+ children: releases?.map((release) => /* @__PURE__ */ jsx(SingleSelectOption, { value: release.id, children: release.name }, release.id))
827
+ }
828
+ )
829
+ ] }) }),
830
+ /* @__PURE__ */ jsx(Field.Label, { children: formatMessage({
831
+ id: "content-releases.content-manager-list-view.add-to-release.action-type-label",
832
+ defaultMessage: "What do you want to do with these entries?"
833
+ }) }),
834
+ /* @__PURE__ */ jsx(
835
+ ReleaseActionOptions,
836
+ {
837
+ selected: values.type,
838
+ handleChange: (e) => setFieldValue("type", e.target.value),
839
+ name: "type"
840
+ }
841
+ )
842
+ ] }) }),
843
+ /* @__PURE__ */ jsxs(Modal.Footer, { children: [
844
+ /* @__PURE__ */ jsx(Button, { onClick: onClose, variant: "tertiary", name: "cancel", children: formatMessage({
845
+ id: "content-releases.content-manager-list-view.add-to-release.cancel-button",
846
+ defaultMessage: "Cancel"
847
+ }) }),
848
+ /* @__PURE__ */ jsx(Button, { type: "submit", disabled: !values.releaseId, loading: isLoading, children: formatMessage({
849
+ id: "content-releases.content-manager-list-view.add-to-release.continue-button",
850
+ defaultMessage: "Continue"
851
+ }) })
852
+ ] })
853
+ ] })
854
+ }
855
+ );
856
+ }
857
+ }
858
+ };
859
+ };
860
+ const useReleasesList = (contentTypeUid, documentId) => {
861
+ const listViewData = useTable("ListView", (state) => state.rows);
862
+ const documentIds = listViewData.map((entry) => entry.documentId);
863
+ const [{ query }] = useQueryParams();
864
+ const locale = query?.plugins?.i18n?.locale || void 0;
865
+ const response = useGetMappedEntriesInReleasesQuery(
866
+ { contentTypeUid, documentIds, locale },
867
+ { skip: !documentIds || !contentTypeUid || documentIds.length === 0 }
868
+ );
869
+ const mappedEntriesInReleases = response.data || {};
870
+ return mappedEntriesInReleases?.[documentId] || [];
871
+ };
872
+ const addColumnToTableHook = ({ displayedHeaders, layout }) => {
873
+ const { options } = layout;
874
+ if (!options?.draftAndPublish) {
875
+ return { displayedHeaders, layout };
876
+ }
877
+ return {
878
+ displayedHeaders: [
879
+ ...displayedHeaders,
880
+ {
881
+ searchable: false,
882
+ sortable: false,
883
+ name: "releases",
884
+ label: {
885
+ id: "content-releases.content-manager.list-view.releases.header",
886
+ defaultMessage: "To be released in"
887
+ },
888
+ cellFormatter: (props, _, { model }) => /* @__PURE__ */ jsx(ReleaseListCell, { ...props, model })
889
+ }
890
+ ],
891
+ layout
892
+ };
893
+ };
894
+ const ReleaseListCell = ({ documentId, model }) => {
895
+ const releases = useReleasesList(model, documentId);
896
+ const { formatMessage } = useIntl();
897
+ return /* @__PURE__ */ jsxs(Popover.Root, { children: [
898
+ /* @__PURE__ */ jsx(Popover.Trigger, { children: /* @__PURE__ */ jsx(
899
+ Button,
900
+ {
901
+ variant: "ghost",
902
+ onClick: (e) => e.stopPropagation(),
903
+ endIcon: releases.length > 0 ? /* @__PURE__ */ jsx(CaretDown, { width: "1.2rem", height: "1.2rem" }) : null,
904
+ children: /* @__PURE__ */ jsx(
905
+ Typography,
906
+ {
907
+ style: { maxWidth: "252px", cursor: "pointer" },
908
+ textColor: "neutral800",
909
+ fontWeight: "regular",
910
+ children: releases.length > 0 ? formatMessage(
911
+ {
912
+ id: "content-releases.content-manager.list-view.releases-number",
913
+ defaultMessage: "{number} {number, plural, one {release} other {releases}}"
914
+ },
915
+ {
916
+ number: releases.length
917
+ }
918
+ ) : "-"
919
+ }
920
+ )
921
+ }
922
+ ) }),
923
+ /* @__PURE__ */ jsx(Popover.Content, { children: /* @__PURE__ */ jsx("ul", { children: releases.map(({ id, name }) => /* @__PURE__ */ jsx(Box, { padding: 3, tag: "li", children: /* @__PURE__ */ jsx(Link$1, { href: `/admin/plugins/content-releases/${id}`, isExternal: false, children: name }) }, id)) }) })
924
+ ] });
925
+ };
696
926
  const getTimezoneOffset = (timezone, date) => {
697
927
  try {
698
928
  const offsetPart = new Intl.DateTimeFormat("en", {
@@ -859,7 +1089,7 @@ const Root = ({ children }) => {
859
1089
  return (
860
1090
  // A user can access the dropdown if they have permissions to delete a release-action OR update a release
861
1091
  allowedActions.canDeleteAction || allowedActions.canUpdate ? /* @__PURE__ */ jsxs(Menu.Root, { children: [
862
- /* @__PURE__ */ jsx(Menu.Trigger, { variant: "tertiary", endIcon: null, paddingLeft: 2, paddingRight: 2, children: /* @__PURE__ */ jsx(
1092
+ /* @__PURE__ */ jsx(StyledMoreButton, { variant: "tertiary", endIcon: null, paddingLeft: "7px", paddingRight: "7px", children: /* @__PURE__ */ jsx(
863
1093
  AccessibleIcon,
864
1094
  {
865
1095
  label: formatMessage({
@@ -873,6 +1103,11 @@ const Root = ({ children }) => {
873
1103
  ] }) : null
874
1104
  );
875
1105
  };
1106
+ const StyledMoreButton = styled(Menu.Trigger)`
1107
+ & > span {
1108
+ display: flex;
1109
+ }
1110
+ `;
876
1111
  const ReleaseActionMenu = {
877
1112
  Root,
878
1113
  EditReleaseItem,
@@ -1012,7 +1247,7 @@ const admin = {
1012
1247
  id: `${pluginId}.plugin.name`,
1013
1248
  defaultMessage: "Releases"
1014
1249
  },
1015
- Component: () => import("./App-CwBi9wFK.mjs").then((mod) => ({ default: mod.App })),
1250
+ Component: () => import("./App-JwN_xBnA.mjs").then((mod) => ({ default: mod.App })),
1016
1251
  permissions: PERMISSIONS.main,
1017
1252
  position: 2
1018
1253
  });
@@ -1036,10 +1271,18 @@ const admin = {
1036
1271
  },
1037
1272
  permissions: [],
1038
1273
  async Component() {
1039
- const { ProtectedReleasesSettingsPage } = await import("./ReleasesSettingsPage-Be1qEgcA.mjs");
1274
+ const { ProtectedReleasesSettingsPage } = await import("./ReleasesSettingsPage-CNMXGcZC.mjs");
1040
1275
  return { default: ProtectedReleasesSettingsPage };
1041
1276
  }
1042
1277
  });
1278
+ if ("addBulkAction" in contentManagerPluginApis && typeof contentManagerPluginApis.addBulkAction === "function") {
1279
+ contentManagerPluginApis.addBulkAction((actions) => {
1280
+ const deleteActionIndex = actions.findIndex((action) => action.type === "delete");
1281
+ actions.splice(deleteActionIndex, 0, ReleaseAction);
1282
+ return actions;
1283
+ });
1284
+ }
1285
+ app.registerHook("Admin/CM/pages/ListView/inject-column-in-table", addColumnToTableHook);
1043
1286
  } else if (!window.strapi.features.isEnabled("cms-content-releases") && window.strapi?.flags?.promoteEE) {
1044
1287
  app.addSettingsLink("global", {
1045
1288
  id: pluginId,
@@ -1060,7 +1303,7 @@ const admin = {
1060
1303
  async registerTrads({ locales }) {
1061
1304
  const importedTrads = await Promise.all(
1062
1305
  locales.map((locale) => {
1063
- return __variableDynamicImportRuntimeHelper(/* @__PURE__ */ Object.assign({ "./translations/en.json": () => import("./en-C3sq5KNP.mjs") }), `./translations/${locale}.json`).then(({ default: data }) => {
1306
+ return __variableDynamicImportRuntimeHelper(/* @__PURE__ */ Object.assign({ "./translations/en.json": () => import("./en-D0yVZFqf.mjs") }), `./translations/${locale}.json`).then(({ default: data }) => {
1064
1307
  return {
1065
1308
  data: prefixPluginTranslations(data, "content-releases"),
1066
1309
  locale
@@ -1096,4 +1339,4 @@ export {
1096
1339
  releaseApi as r,
1097
1340
  useGetReleasesQuery as u
1098
1341
  };
1099
- //# sourceMappingURL=index-VB3t7pBK.mjs.map
1342
+ //# sourceMappingURL=index-C_e6DQb0.mjs.map