@strapi/content-releases 0.0.0-next.8d576f41729640e32a4a0cfcb258b6288e6631f6 → 0.0.0-next.8f0cdd4f9e4697ffed86c783465297fe532713f8
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.
- package/dist/admin/components/ReleaseActionMenu.js +25 -74
- package/dist/admin/components/ReleaseActionMenu.js.map +1 -1
- package/dist/admin/components/ReleaseActionMenu.mjs +26 -75
- package/dist/admin/components/ReleaseActionMenu.mjs.map +1 -1
- package/dist/admin/index.js +1 -0
- package/dist/admin/index.js.map +1 -1
- package/dist/admin/index.mjs +1 -0
- package/dist/admin/index.mjs.map +1 -1
- package/dist/admin/pages/ReleaseDetailsPage.js +11 -60
- package/dist/admin/pages/ReleaseDetailsPage.js.map +1 -1
- package/dist/admin/pages/ReleaseDetailsPage.mjs +13 -62
- package/dist/admin/pages/ReleaseDetailsPage.mjs.map +1 -1
- package/dist/server/destroy.js +2 -2
- package/dist/server/destroy.js.map +1 -1
- package/dist/server/destroy.mjs +2 -2
- package/dist/server/destroy.mjs.map +1 -1
- package/dist/server/services/scheduling.js +16 -12
- package/dist/server/services/scheduling.js.map +1 -1
- package/dist/server/services/scheduling.mjs +16 -12
- package/dist/server/services/scheduling.mjs.map +1 -1
- package/dist/server/src/destroy.d.ts.map +1 -1
- package/dist/server/src/index.d.ts +4 -4
- package/dist/server/src/services/index.d.ts +4 -4
- package/dist/server/src/services/scheduling.d.ts +4 -5
- package/dist/server/src/services/scheduling.d.ts.map +1 -1
- package/package.json +9 -10
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ReleaseDetailsPage.mjs","sources":["../../../admin/src/pages/ReleaseDetailsPage.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport {\n Page,\n Pagination,\n Table,\n BackButton,\n ConfirmDialog,\n useTracking,\n useAPIErrorHandler,\n useNotification,\n useQueryParams,\n useRBAC,\n isFetchError,\n useStrapiApp,\n Layouts,\n} from '@strapi/admin/strapi-admin';\nimport {\n Button,\n Flex,\n Main,\n Tr,\n Td,\n Typography,\n Badge,\n SingleSelect,\n SingleSelectOption,\n EmptyStateLayout,\n LinkButton,\n Dialog,\n SimpleMenu,\n MenuItem,\n} from '@strapi/design-system';\nimport { More, Pencil, Trash } from '@strapi/icons';\nimport { EmptyDocuments } from '@strapi/icons/symbols';\nimport format from 'date-fns/format';\nimport { utcToZonedTime } from 'date-fns-tz';\nimport { useIntl } from 'react-intl';\nimport { useParams, useNavigate, Link as ReactRouterLink, Navigate } from 'react-router-dom';\nimport { styled } from 'styled-components';\n\nimport { EntryValidationPopover } from '../components/EntryValidationPopover';\nimport { RelativeTime } from '../components/RelativeTime';\nimport { ReleaseActionMenu } from '../components/ReleaseActionMenu';\nimport { ReleaseActionOptions } from '../components/ReleaseActionOptions';\nimport { ReleaseModal, FormValues } from '../components/ReleaseModal';\nimport { PERMISSIONS } from '../constants';\nimport {\n GetReleaseActionsQueryParams,\n useGetReleaseActionsQuery,\n useGetReleaseQuery,\n useGetReleaseSettingsQuery,\n useUpdateReleaseMutation,\n useUpdateReleaseActionMutation,\n usePublishReleaseMutation,\n useDeleteReleaseMutation,\n releaseApi,\n} from '../services/release';\nimport { useTypedDispatch } from '../store/hooks';\nimport { isBaseQueryError } from '../utils/api';\nimport { getTimezoneOffset } from '../utils/time';\n\nimport { getBadgeProps } from './ReleasesPage';\n\nimport type {\n ReleaseAction,\n ReleaseActionGroupBy,\n} from '../../../shared/contracts/release-actions';\n\n/* -------------------------------------------------------------------------------------------------\n * ReleaseDetailsLayout\n * -----------------------------------------------------------------------------------------------*/\nconst ReleaseInfoWrapper = styled(Flex)`\n align-self: stretch;\n border-bottom-right-radius: ${({ theme }) => theme.borderRadius};\n border-bottom-left-radius: ${({ theme }) => theme.borderRadius};\n border-top: 1px solid ${({ theme }) => theme.colors.neutral150};\n`;\n\nconst StyledMenuItem = styled(MenuItem)<{\n disabled?: boolean;\n $variant?: 'neutral' | 'danger';\n}>`\n svg path {\n fill: ${({ theme, disabled }) => disabled && theme.colors.neutral500};\n }\n span {\n color: ${({ theme, disabled }) => disabled && theme.colors.neutral500};\n }\n\n &:hover {\n background: ${({ theme, $variant = 'neutral' }) => theme.colors[`${$variant}100`]};\n }\n`;\n\nconst PencilIcon = styled(Pencil)`\n width: ${({ theme }) => theme.spaces[4]};\n height: ${({ theme }) => theme.spaces[4]};\n path {\n fill: ${({ theme }) => theme.colors.neutral600};\n }\n`;\n\nconst TrashIcon = styled(Trash)`\n width: ${({ theme }) => theme.spaces[4]};\n height: ${({ theme }) => theme.spaces[4]};\n path {\n fill: ${({ theme }) => theme.colors.danger600};\n }\n`;\n\ninterface ReleaseDetailsLayoutProps {\n toggleEditReleaseModal: () => void;\n toggleWarningSubmit: () => void;\n children: React.ReactNode;\n}\n\nconst ReleaseDetailsLayout = ({\n toggleEditReleaseModal,\n toggleWarningSubmit,\n children,\n}: ReleaseDetailsLayoutProps) => {\n const { formatMessage, formatDate, formatTime } = useIntl();\n const { releaseId } = useParams<{ releaseId: string }>();\n const {\n data,\n isLoading: isLoadingDetails,\n error,\n } = useGetReleaseQuery(\n { id: releaseId! },\n {\n skip: !releaseId,\n }\n );\n const [publishRelease, { isLoading: isPublishing }] = usePublishReleaseMutation();\n const { toggleNotification } = useNotification();\n const { formatAPIError } = useAPIErrorHandler();\n const { allowedActions } = useRBAC(PERMISSIONS);\n const { canUpdate, canDelete, canPublish } = allowedActions;\n const dispatch = useTypedDispatch();\n const { trackUsage } = useTracking();\n\n const release = data?.data;\n\n const handlePublishRelease = (id: string) => async () => {\n const response = await publishRelease({ id });\n\n if ('data' in response) {\n // When the response returns an object with 'data', handle success\n toggleNotification({\n type: 'success',\n message: formatMessage({\n id: 'content-releases.pages.ReleaseDetails.publish-notification-success',\n defaultMessage: 'Release was published successfully.',\n }),\n });\n\n const { totalEntries, totalPublishedEntries, totalUnpublishedEntries } = response.data.meta;\n\n trackUsage('didPublishRelease', {\n totalEntries,\n totalPublishedEntries,\n totalUnpublishedEntries,\n });\n } else if (isFetchError(response.error)) {\n // When the response returns an object with 'error', handle fetch error\n toggleNotification({\n type: 'danger',\n message: formatAPIError(response.error),\n });\n } else {\n // Otherwise, the response returns an object with 'error', handle a generic error\n toggleNotification({\n type: 'danger',\n message: formatMessage({ id: 'notification.error', defaultMessage: 'An error occurred' }),\n });\n }\n };\n\n const handleRefresh = () => {\n dispatch(\n releaseApi.util.invalidateTags([\n { type: 'ReleaseAction', id: 'LIST' },\n { type: 'Release', id: releaseId },\n ])\n );\n };\n\n const getCreatedByUser = () => {\n if (!release?.createdBy) {\n return null;\n }\n\n // Favor the username\n if (release.createdBy.username) {\n return release.createdBy.username;\n }\n\n // Firstname may not exist if created with SSO\n if (release.createdBy.firstname) {\n return `${release.createdBy.firstname} ${release.createdBy.lastname || ''}`.trim();\n }\n\n // All users must have at least an email\n return release.createdBy.email;\n };\n\n if (isLoadingDetails) {\n return <Page.Loading />;\n }\n\n if ((isBaseQueryError(error) && 'code' in error) || !release) {\n return (\n <Navigate\n to=\"..\"\n state={{\n errors: [\n {\n // @ts-expect-error – TODO: fix this weird error flow\n code: error?.code,\n },\n ],\n }}\n />\n );\n }\n\n const totalEntries = release.actions.meta.count || 0;\n const hasCreatedByUser = Boolean(getCreatedByUser());\n\n const isScheduled = release.scheduledAt && release.timezone;\n const numberOfEntriesText = formatMessage(\n {\n id: 'content-releases.pages.Details.header-subtitle',\n defaultMessage: '{number, plural, =0 {No entries} one {# entry} other {# entries}}',\n },\n { number: totalEntries }\n );\n const scheduledText = isScheduled\n ? formatMessage(\n {\n id: 'content-releases.pages.ReleaseDetails.header-subtitle.scheduled',\n defaultMessage: 'Scheduled for {date} at {time} ({offset})',\n },\n {\n date: formatDate(new Date(release.scheduledAt!), {\n weekday: 'long',\n day: 'numeric',\n month: 'long',\n year: 'numeric',\n timeZone: release.timezone!,\n }),\n time: formatTime(new Date(release.scheduledAt!), {\n timeZone: release.timezone!,\n hourCycle: 'h23',\n }),\n offset: getTimezoneOffset(release.timezone!, new Date(release.scheduledAt!)),\n }\n )\n : '';\n\n return (\n <Main aria-busy={isLoadingDetails}>\n <Layouts.Header\n title={release.name}\n subtitle={\n <Flex gap={2} lineHeight={6}>\n <Typography textColor=\"neutral600\" variant=\"epsilon\">\n {numberOfEntriesText + (isScheduled ? ` - ${scheduledText}` : '')}\n </Typography>\n <Badge {...getBadgeProps(release.status)}>{release.status}</Badge>\n </Flex>\n }\n navigationAction={<BackButton fallback=\"..\" />}\n primaryAction={\n !release.releasedAt && (\n <Flex gap={2}>\n <SimpleMenuButton\n label={<More />}\n variant=\"tertiary\"\n endIcon={null}\n paddingLeft=\"7px\"\n paddingRight=\"7px\"\n aria-label={formatMessage({\n id: 'content-releases.header.actions.open-release-actions',\n defaultMessage: 'Release edit and delete menu',\n })}\n popoverPlacement=\"bottom-end\"\n >\n <StyledMenuItem disabled={!canUpdate} onSelect={toggleEditReleaseModal}>\n <Flex alignItems=\"center\" gap={2} hasRadius width=\"100%\">\n <PencilIcon />\n <Typography ellipsis>\n {formatMessage({\n id: 'content-releases.header.actions.edit',\n defaultMessage: 'Edit',\n })}\n </Typography>\n </Flex>\n </StyledMenuItem>\n <StyledMenuItem\n disabled={!canDelete}\n onSelect={toggleWarningSubmit}\n $variant=\"danger\"\n >\n <Flex alignItems=\"center\" gap={2} hasRadius width=\"100%\">\n <TrashIcon />\n <Typography ellipsis textColor=\"danger600\">\n {formatMessage({\n id: 'content-releases.header.actions.delete',\n defaultMessage: 'Delete',\n })}\n </Typography>\n </Flex>\n </StyledMenuItem>\n <ReleaseInfoWrapper\n direction=\"column\"\n justifyContent=\"center\"\n alignItems=\"flex-start\"\n gap={1}\n padding={4}\n >\n <Typography variant=\"pi\" fontWeight=\"bold\">\n {formatMessage({\n id: 'content-releases.header.actions.created',\n defaultMessage: 'Created',\n })}\n </Typography>\n <Typography variant=\"pi\" color=\"neutral300\">\n <RelativeTime timestamp={new Date(release.createdAt)} />\n {formatMessage(\n {\n id: 'content-releases.header.actions.created.description',\n defaultMessage:\n '{hasCreatedByUser, select, true { by {createdBy}} other { by deleted user}}',\n },\n { createdBy: getCreatedByUser(), hasCreatedByUser }\n )}\n </Typography>\n </ReleaseInfoWrapper>\n </SimpleMenuButton>\n <Button size=\"S\" variant=\"tertiary\" onClick={handleRefresh}>\n {formatMessage({\n id: 'content-releases.header.actions.refresh',\n defaultMessage: 'Refresh',\n })}\n </Button>\n {canPublish ? (\n <Button\n size=\"S\"\n variant=\"default\"\n onClick={handlePublishRelease(release.id.toString())}\n loading={isPublishing}\n disabled={release.actions.meta.count === 0}\n >\n {formatMessage({\n id: 'content-releases.header.actions.publish',\n defaultMessage: 'Publish',\n })}\n </Button>\n ) : null}\n </Flex>\n )\n }\n />\n {children}\n </Main>\n );\n};\n\nconst SimpleMenuButton = styled(SimpleMenu)`\n & > span {\n display: flex;\n }\n`;\n\n/* -------------------------------------------------------------------------------------------------\n * ReleaseDetailsBody\n * -----------------------------------------------------------------------------------------------*/\nconst GROUP_BY_OPTIONS = ['contentType', 'locale', 'action'] as const;\nconst GROUP_BY_OPTIONS_NO_LOCALE = ['contentType', 'action'] as const;\nconst getGroupByOptionLabel = (value: (typeof GROUP_BY_OPTIONS)[number]) => {\n if (value === 'locale') {\n return {\n id: 'content-releases.pages.ReleaseDetails.groupBy.option.locales',\n defaultMessage: 'Locales',\n };\n }\n\n if (value === 'action') {\n return {\n id: 'content-releases.pages.ReleaseDetails.groupBy.option.actions',\n defaultMessage: 'Actions',\n };\n }\n\n return {\n id: 'content-releases.pages.ReleaseDetails.groupBy.option.content-type',\n defaultMessage: 'Content-Types',\n };\n};\n\ninterface ReleaseDetailsBodyProps {\n releaseId: string;\n}\n\nconst ReleaseDetailsBody = ({ releaseId }: ReleaseDetailsBodyProps) => {\n const { formatMessage } = useIntl();\n const [{ query }, setQuery] = useQueryParams<GetReleaseActionsQueryParams>();\n const { toggleNotification } = useNotification();\n const { formatAPIError } = useAPIErrorHandler();\n const {\n data: releaseData,\n isLoading: isReleaseLoading,\n error: releaseError,\n } = useGetReleaseQuery({ id: releaseId });\n const {\n allowedActions: { canUpdate },\n } = useRBAC(PERMISSIONS);\n const runHookWaterfall = useStrapiApp('ReleaseDetailsPage', (state) => state.runHookWaterfall);\n\n // TODO: Migrated displayedHeader to v5\n const { displayedHeaders, hasI18nEnabled }: { displayedHeaders: any; hasI18nEnabled: boolean } =\n runHookWaterfall('ContentReleases/pages/ReleaseDetails/add-locale-in-releases', {\n displayedHeaders: [\n {\n label: {\n id: 'content-releases.page.ReleaseDetails.table.header.label.name',\n defaultMessage: 'name',\n },\n name: 'name',\n },\n ],\n hasI18nEnabled: false,\n });\n\n const release = releaseData?.data;\n const selectedGroupBy = query?.groupBy || 'contentType';\n\n const {\n isLoading,\n isFetching,\n isError,\n data,\n error: releaseActionsError,\n } = useGetReleaseActionsQuery({\n ...query,\n releaseId,\n });\n\n const [updateReleaseAction] = useUpdateReleaseActionMutation();\n\n const handleChangeType = async (\n e: React.ChangeEvent<HTMLInputElement>,\n actionId: ReleaseAction['id'],\n actionPath: [string, number]\n ) => {\n const response = await updateReleaseAction({\n params: {\n releaseId,\n actionId,\n },\n body: {\n type: e.target.value as ReleaseAction['type'],\n },\n query, // We are passing the query params to make optimistic updates\n actionPath, // We are passing the action path to found the position in the cache of the action for optimistic updates\n });\n\n if ('error' in response) {\n if (isFetchError(response.error)) {\n // When the response returns an object with 'error', handle fetch error\n toggleNotification({\n type: 'danger',\n message: formatAPIError(response.error),\n });\n } else {\n // Otherwise, the response returns an object with 'error', handle a generic error\n toggleNotification({\n type: 'danger',\n message: formatMessage({ id: 'notification.error', defaultMessage: 'An error occurred' }),\n });\n }\n }\n };\n\n if (isLoading || isReleaseLoading) {\n return <Page.Loading />;\n }\n\n const releaseActions = data?.data;\n const releaseMeta = data?.meta;\n const contentTypes = releaseMeta?.contentTypes || {};\n const components = releaseMeta?.components || {};\n\n if (isBaseQueryError(releaseError) || !release) {\n const errorsArray = [];\n if (releaseError && 'code' in releaseError) {\n errorsArray.push({\n code: releaseError.code,\n });\n }\n if (releaseActionsError && 'code' in releaseActionsError) {\n errorsArray.push({\n code: releaseActionsError.code,\n });\n }\n return (\n <Navigate\n to=\"..\"\n state={{\n errors: errorsArray,\n }}\n />\n );\n }\n\n if (isError || !releaseActions) {\n return <Page.Error />;\n }\n\n if (Object.keys(releaseActions).length === 0) {\n return (\n <Layouts.Content>\n <EmptyStateLayout\n action={\n <LinkButton\n tag={ReactRouterLink}\n to={{\n pathname: '/content-manager',\n }}\n style={{ textDecoration: 'none' }}\n variant=\"secondary\"\n >\n {formatMessage({\n id: 'content-releases.page.Details.button.openContentManager',\n defaultMessage: 'Open the Content Manager',\n })}\n </LinkButton>\n }\n icon={<EmptyDocuments width=\"16rem\" />}\n content={formatMessage({\n id: 'content-releases.pages.Details.tab.emptyEntries',\n defaultMessage:\n 'This release is empty. Open the Content Manager, select an entry and add it to the release.',\n })}\n />\n </Layouts.Content>\n );\n }\n\n const groupByLabel = formatMessage({\n id: 'content-releases.pages.ReleaseDetails.groupBy.aria-label',\n defaultMessage: 'Group by',\n });\n const headers = [\n ...displayedHeaders,\n {\n label: {\n id: 'content-releases.page.ReleaseDetails.table.header.label.content-type',\n defaultMessage: 'content-type',\n },\n name: 'content-type',\n },\n {\n label: {\n id: 'content-releases.page.ReleaseDetails.table.header.label.action',\n defaultMessage: 'action',\n },\n name: 'action',\n },\n ...(!release.releasedAt\n ? [\n {\n label: {\n id: 'content-releases.page.ReleaseDetails.table.header.label.status',\n defaultMessage: 'status',\n },\n name: 'status',\n },\n ]\n : []),\n ];\n\n const options = hasI18nEnabled ? GROUP_BY_OPTIONS : GROUP_BY_OPTIONS_NO_LOCALE;\n\n return (\n <Layouts.Content>\n <Flex gap={8} direction=\"column\" alignItems=\"stretch\">\n <Flex>\n <SingleSelect\n placeholder={groupByLabel}\n aria-label={groupByLabel}\n customizeContent={(value) =>\n formatMessage(\n {\n id: `content-releases.pages.ReleaseDetails.groupBy.label`,\n defaultMessage: `Group by {groupBy}`,\n },\n {\n groupBy: value,\n }\n )\n }\n value={formatMessage(getGroupByOptionLabel(selectedGroupBy))}\n onChange={(value) => setQuery({ groupBy: value as ReleaseActionGroupBy })}\n >\n {options.map((option) => (\n <SingleSelectOption key={option} value={option}>\n {formatMessage(getGroupByOptionLabel(option))}\n </SingleSelectOption>\n ))}\n </SingleSelect>\n </Flex>\n {Object.keys(releaseActions).map((key) => (\n <Flex key={`releases-group-${key}`} gap={4} direction=\"column\" alignItems=\"stretch\">\n <Flex role=\"separator\" aria-label={key}>\n <Badge>{key}</Badge>\n </Flex>\n <Table.Root\n rows={releaseActions[key].map((item) => ({\n ...item,\n id: Number(item.entry.id),\n }))}\n headers={headers}\n isLoading={isLoading || isFetching}\n >\n <Table.Content>\n <Table.Head>\n {headers.map(({ label, name }) => (\n <Table.HeaderCell key={name} label={formatMessage(label)} name={name} />\n ))}\n </Table.Head>\n <Table.Loading />\n <Table.Body>\n {releaseActions[key].map(\n ({ id, contentType, locale, type, entry, status }, actionIndex) => (\n <Tr key={id}>\n <Td width=\"25%\" maxWidth=\"200px\">\n <Typography ellipsis>{`${\n contentType.mainFieldValue || entry.id\n }`}</Typography>\n </Td>\n {hasI18nEnabled && (\n <Td width=\"10%\">\n <Typography>{`${locale?.name ? locale.name : '-'}`}</Typography>\n </Td>\n )}\n\n <Td width=\"10%\">\n <Typography>{contentType.displayName || ''}</Typography>\n </Td>\n <Td width=\"20%\">\n {release.releasedAt ? (\n <Typography>\n {formatMessage(\n {\n id: 'content-releases.page.ReleaseDetails.table.action-published',\n defaultMessage:\n 'This entry was <b>{isPublish, select, true {published} other {unpublished}}</b>.',\n },\n {\n isPublish: type === 'publish',\n b: (children: React.ReactNode) => (\n <Typography fontWeight=\"bold\">{children}</Typography>\n ),\n }\n )}\n </Typography>\n ) : (\n <ReleaseActionOptions\n selected={type}\n handleChange={(e) => handleChangeType(e, id, [key, actionIndex])}\n name={`release-action-${id}-type`}\n disabled={!canUpdate}\n />\n )}\n </Td>\n {!release.releasedAt && (\n <>\n <Td width=\"20%\" minWidth=\"200px\">\n <EntryValidationPopover\n action={type}\n schema={contentTypes?.[contentType.uid]}\n entry={entry}\n status={status}\n />\n </Td>\n <Td>\n <Flex justifyContent=\"flex-end\">\n <ReleaseActionMenu.Root>\n <ReleaseActionMenu.ReleaseActionEntryLinkItem\n contentTypeUid={contentType.uid}\n documentId={entry.documentId}\n locale={locale?.code}\n />\n <ReleaseActionMenu.DeleteReleaseActionItem\n releaseId={release.id}\n actionId={id}\n />\n </ReleaseActionMenu.Root>\n </Flex>\n </Td>\n </>\n )}\n </Tr>\n )\n )}\n </Table.Body>\n </Table.Content>\n </Table.Root>\n </Flex>\n ))}\n <Pagination.Root\n {...releaseMeta?.pagination}\n defaultPageSize={releaseMeta?.pagination?.pageSize}\n >\n <Pagination.PageSize />\n <Pagination.Links />\n </Pagination.Root>\n </Flex>\n </Layouts.Content>\n );\n};\n\n/* -------------------------------------------------------------------------------------------------\n * ReleaseDetailsPage\n * -----------------------------------------------------------------------------------------------*/\nconst ReleaseDetailsPage = () => {\n const { formatMessage } = useIntl();\n const { releaseId } = useParams<{ releaseId: string }>();\n const { toggleNotification } = useNotification();\n const { formatAPIError } = useAPIErrorHandler();\n const navigate = useNavigate();\n const [releaseModalShown, setReleaseModalShown] = React.useState(false);\n const [showWarningSubmit, setWarningSubmit] = React.useState(false);\n\n const {\n isLoading: isLoadingDetails,\n data,\n isSuccess: isSuccessDetails,\n } = useGetReleaseQuery(\n { id: releaseId! },\n {\n skip: !releaseId,\n }\n );\n const { data: dataTimezone, isLoading: isLoadingTimezone } = useGetReleaseSettingsQuery();\n const [updateRelease, { isLoading: isSubmittingForm }] = useUpdateReleaseMutation();\n const [deleteRelease] = useDeleteReleaseMutation();\n\n const toggleEditReleaseModal = () => {\n setReleaseModalShown((prev) => !prev);\n };\n\n const getTimezoneValue = () => {\n if (releaseData?.timezone) {\n return releaseData.timezone;\n } else {\n if (dataTimezone?.data.defaultTimezone) {\n return dataTimezone.data.defaultTimezone;\n }\n return null;\n }\n };\n\n const toggleWarningSubmit = () => setWarningSubmit((prevState) => !prevState);\n\n if (isLoadingDetails || isLoadingTimezone) {\n return (\n <ReleaseDetailsLayout\n toggleEditReleaseModal={toggleEditReleaseModal}\n toggleWarningSubmit={toggleWarningSubmit}\n >\n <Page.Loading />\n </ReleaseDetailsLayout>\n );\n }\n\n if (!releaseId) {\n return <Navigate to=\"..\" />;\n }\n\n const releaseData = (isSuccessDetails && data?.data) || null;\n\n const title = releaseData?.name || '';\n const timezone = getTimezoneValue();\n const scheduledAt =\n releaseData?.scheduledAt && timezone ? utcToZonedTime(releaseData.scheduledAt, timezone) : null;\n // Just get the date and time to display without considering updated timezone time\n const date = scheduledAt ? format(scheduledAt, 'yyyy-MM-dd') : undefined;\n const time = scheduledAt ? format(scheduledAt, 'HH:mm') : '';\n\n const handleEditRelease = async (values: FormValues) => {\n const response = await updateRelease({\n id: releaseId,\n name: values.name,\n scheduledAt: values.scheduledAt,\n timezone: values.timezone,\n });\n\n if ('data' in response) {\n // When the response returns an object with 'data', handle success\n toggleNotification({\n type: 'success',\n message: formatMessage({\n id: 'content-releases.modal.release-updated-notification-success',\n defaultMessage: 'Release updated.',\n }),\n });\n toggleEditReleaseModal();\n } else if (isFetchError(response.error)) {\n // When the response returns an object with 'error', handle fetch error\n toggleNotification({\n type: 'danger',\n message: formatAPIError(response.error),\n });\n } else {\n // Otherwise, the response returns an object with 'error', handle a generic error\n toggleNotification({\n type: 'danger',\n message: formatMessage({ id: 'notification.error', defaultMessage: 'An error occurred' }),\n });\n }\n };\n\n const handleDeleteRelease = async () => {\n const response = await deleteRelease({\n id: releaseId,\n });\n\n if ('data' in response) {\n navigate('..');\n } else if (isFetchError(response.error)) {\n // When the response returns an object with 'error', handle fetch error\n toggleNotification({\n type: 'danger',\n message: formatAPIError(response.error),\n });\n } else {\n // Otherwise, the response returns an object with 'error', handle a generic error\n toggleNotification({\n type: 'danger',\n message: formatMessage({ id: 'notification.error', defaultMessage: 'An error occurred' }),\n });\n }\n };\n\n return (\n <ReleaseDetailsLayout\n toggleEditReleaseModal={toggleEditReleaseModal}\n toggleWarningSubmit={toggleWarningSubmit}\n >\n <ReleaseDetailsBody releaseId={releaseId} />\n <ReleaseModal\n open={releaseModalShown}\n handleClose={toggleEditReleaseModal}\n handleSubmit={handleEditRelease}\n isLoading={isLoadingDetails || isSubmittingForm}\n initialValues={{\n name: title || '',\n scheduledAt,\n date,\n time,\n isScheduled: Boolean(scheduledAt),\n timezone,\n }}\n />\n <Dialog.Root open={showWarningSubmit} onOpenChange={toggleWarningSubmit}>\n <ConfirmDialog onConfirm={handleDeleteRelease}>\n {formatMessage({\n id: 'content-releases.dialog.confirmation-message',\n defaultMessage: 'Are you sure you want to delete this release?',\n })}\n </ConfirmDialog>\n </Dialog.Root>\n </ReleaseDetailsLayout>\n );\n};\n\nexport { ReleaseDetailsPage };\n"],"names":["ReleaseInfoWrapper","styled","Flex","theme","borderRadius","colors","neutral150","StyledMenuItem","MenuItem","disabled","neutral500","$variant","PencilIcon","Pencil","spaces","neutral600","TrashIcon","Trash","danger600","ReleaseDetailsLayout","toggleEditReleaseModal","toggleWarningSubmit","children","formatMessage","formatDate","formatTime","useIntl","releaseId","useParams","data","isLoading","isLoadingDetails","error","useGetReleaseQuery","id","skip","publishRelease","isPublishing","usePublishReleaseMutation","toggleNotification","useNotification","formatAPIError","useAPIErrorHandler","allowedActions","useRBAC","PERMISSIONS","canUpdate","canDelete","canPublish","dispatch","useTypedDispatch","trackUsage","useTracking","release","handlePublishRelease","response","type","message","defaultMessage","totalEntries","totalPublishedEntries","totalUnpublishedEntries","meta","isFetchError","handleRefresh","releaseApi","util","invalidateTags","getCreatedByUser","createdBy","username","firstname","lastname","trim","email","_jsx","Page","Loading","Navigate","to","state","errors","code","actions","count","hasCreatedByUser","Boolean","isScheduled","scheduledAt","timezone","numberOfEntriesText","number","scheduledText","date","Date","weekday","day","month","year","timeZone","time","hourCycle","offset","getTimezoneOffset","_jsxs","Main","aria-busy","Layouts","Header","title","name","subtitle","gap","lineHeight","Typography","textColor","variant","Badge","getBadgeProps","status","navigationAction","BackButton","fallback","primaryAction","releasedAt","SimpleMenuButton","label","More","endIcon","paddingLeft","paddingRight","aria-label","popoverPlacement","onSelect","alignItems","hasRadius","width","ellipsis","direction","justifyContent","padding","fontWeight","color","RelativeTime","timestamp","createdAt","Button","size","onClick","toString","loading","SimpleMenu","GROUP_BY_OPTIONS","GROUP_BY_OPTIONS_NO_LOCALE","getGroupByOptionLabel","value","ReleaseDetailsBody","query","setQuery","useQueryParams","releaseData","isReleaseLoading","releaseError","runHookWaterfall","useStrapiApp","displayedHeaders","hasI18nEnabled","selectedGroupBy","groupBy","isFetching","isError","releaseActionsError","useGetReleaseActionsQuery","updateReleaseAction","useUpdateReleaseActionMutation","handleChangeType","e","actionId","actionPath","params","body","target","releaseActions","releaseMeta","contentTypes","components","isBaseQueryError","errorsArray","push","Error","Object","keys","length","Content","EmptyStateLayout","action","LinkButton","tag","ReactRouterLink","pathname","style","textDecoration","icon","EmptyDocuments","content","groupByLabel","headers","options","SingleSelect","placeholder","customizeContent","onChange","map","option","SingleSelectOption","key","role","Table","Root","rows","item","Number","entry","Head","HeaderCell","Body","contentType","locale","actionIndex","Tr","Td","maxWidth","mainFieldValue","displayName","isPublish","b","ReleaseActionOptions","selected","handleChange","_Fragment","minWidth","EntryValidationPopover","schema","uid","ReleaseActionMenu","ReleaseActionEntryLinkItem","contentTypeUid","documentId","DeleteReleaseActionItem","Pagination","pagination","defaultPageSize","pageSize","PageSize","Links","ReleaseDetailsPage","navigate","useNavigate","releaseModalShown","setReleaseModalShown","React","useState","showWarningSubmit","setWarningSubmit","isSuccess","isSuccessDetails","dataTimezone","isLoadingTimezone","useGetReleaseSettingsQuery","updateRelease","isSubmittingForm","useUpdateReleaseMutation","deleteRelease","useDeleteReleaseMutation","prev","getTimezoneValue","defaultTimezone","prevState","utcToZonedTime","format","undefined","handleEditRelease","values","handleDeleteRelease","ReleaseModal","open","handleClose","handleSubmit","initialValues","Dialog","onOpenChange","ConfirmDialog","onConfirm"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ReleaseDetailsPage.mjs","sources":["../../../admin/src/pages/ReleaseDetailsPage.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport {\n Page,\n Pagination,\n Table,\n BackButton,\n ConfirmDialog,\n useTracking,\n useAPIErrorHandler,\n useNotification,\n useQueryParams,\n useRBAC,\n isFetchError,\n useStrapiApp,\n Layouts,\n} from '@strapi/admin/strapi-admin';\nimport {\n Button,\n Flex,\n Main,\n Tr,\n Td,\n Typography,\n Badge,\n SingleSelect,\n SingleSelectOption,\n EmptyStateLayout,\n LinkButton,\n Dialog,\n SimpleMenu,\n Menu,\n} from '@strapi/design-system';\nimport { More, Pencil, Trash } from '@strapi/icons';\nimport { EmptyDocuments } from '@strapi/icons/symbols';\nimport format from 'date-fns/format';\nimport { utcToZonedTime } from 'date-fns-tz';\nimport { useIntl } from 'react-intl';\nimport { useParams, useNavigate, Link as ReactRouterLink, Navigate } from 'react-router-dom';\nimport { styled } from 'styled-components';\n\nimport { EntryValidationPopover } from '../components/EntryValidationPopover';\nimport { RelativeTime } from '../components/RelativeTime';\nimport { ReleaseActionMenu } from '../components/ReleaseActionMenu';\nimport { ReleaseActionOptions } from '../components/ReleaseActionOptions';\nimport { ReleaseModal, FormValues } from '../components/ReleaseModal';\nimport { PERMISSIONS } from '../constants';\nimport {\n GetReleaseActionsQueryParams,\n useGetReleaseActionsQuery,\n useGetReleaseQuery,\n useGetReleaseSettingsQuery,\n useUpdateReleaseMutation,\n useUpdateReleaseActionMutation,\n usePublishReleaseMutation,\n useDeleteReleaseMutation,\n releaseApi,\n} from '../services/release';\nimport { useTypedDispatch } from '../store/hooks';\nimport { isBaseQueryError } from '../utils/api';\nimport { getTimezoneOffset } from '../utils/time';\n\nimport { getBadgeProps } from './ReleasesPage';\n\nimport type {\n ReleaseAction,\n ReleaseActionGroupBy,\n} from '../../../shared/contracts/release-actions';\n\n/* -------------------------------------------------------------------------------------------------\n * ReleaseDetailsLayout\n * -----------------------------------------------------------------------------------------------*/\nconst ReleaseInfoWrapper = styled(Flex)`\n align-self: stretch;\n border-bottom-right-radius: ${({ theme }) => theme.borderRadius};\n border-bottom-left-radius: ${({ theme }) => theme.borderRadius};\n border-top: 1px solid ${({ theme }) => theme.colors.neutral150};\n`;\n\ninterface ReleaseDetailsLayoutProps {\n toggleEditReleaseModal: () => void;\n toggleWarningSubmit: () => void;\n children: React.ReactNode;\n}\n\nconst ReleaseDetailsLayout = ({\n toggleEditReleaseModal,\n toggleWarningSubmit,\n children,\n}: ReleaseDetailsLayoutProps) => {\n const { formatMessage, formatDate, formatTime } = useIntl();\n const { releaseId } = useParams<{ releaseId: string }>();\n const {\n data,\n isLoading: isLoadingDetails,\n error,\n } = useGetReleaseQuery(\n { id: releaseId! },\n {\n skip: !releaseId,\n }\n );\n const [publishRelease, { isLoading: isPublishing }] = usePublishReleaseMutation();\n const { toggleNotification } = useNotification();\n const { formatAPIError } = useAPIErrorHandler();\n const { allowedActions } = useRBAC(PERMISSIONS);\n const { canUpdate, canDelete, canPublish } = allowedActions;\n const dispatch = useTypedDispatch();\n const { trackUsage } = useTracking();\n\n const release = data?.data;\n\n const handlePublishRelease = (id: string) => async () => {\n const response = await publishRelease({ id });\n\n if ('data' in response) {\n // When the response returns an object with 'data', handle success\n toggleNotification({\n type: 'success',\n message: formatMessage({\n id: 'content-releases.pages.ReleaseDetails.publish-notification-success',\n defaultMessage: 'Release was published successfully.',\n }),\n });\n\n const { totalEntries, totalPublishedEntries, totalUnpublishedEntries } = response.data.meta;\n\n trackUsage('didPublishRelease', {\n totalEntries,\n totalPublishedEntries,\n totalUnpublishedEntries,\n });\n } else if (isFetchError(response.error)) {\n // When the response returns an object with 'error', handle fetch error\n toggleNotification({\n type: 'danger',\n message: formatAPIError(response.error),\n });\n } else {\n // Otherwise, the response returns an object with 'error', handle a generic error\n toggleNotification({\n type: 'danger',\n message: formatMessage({ id: 'notification.error', defaultMessage: 'An error occurred' }),\n });\n }\n };\n\n const handleRefresh = () => {\n dispatch(\n releaseApi.util.invalidateTags([\n { type: 'ReleaseAction', id: 'LIST' },\n { type: 'Release', id: releaseId },\n ])\n );\n };\n\n const getCreatedByUser = () => {\n if (!release?.createdBy) {\n return null;\n }\n\n // Favor the username\n if (release.createdBy.username) {\n return release.createdBy.username;\n }\n\n // Firstname may not exist if created with SSO\n if (release.createdBy.firstname) {\n return `${release.createdBy.firstname} ${release.createdBy.lastname || ''}`.trim();\n }\n\n // All users must have at least an email\n return release.createdBy.email;\n };\n\n if (isLoadingDetails) {\n return <Page.Loading />;\n }\n\n if ((isBaseQueryError(error) && 'code' in error) || !release) {\n return (\n <Navigate\n to=\"..\"\n state={{\n errors: [\n {\n // @ts-expect-error – TODO: fix this weird error flow\n code: error?.code,\n },\n ],\n }}\n />\n );\n }\n\n const totalEntries = release.actions.meta.count || 0;\n const hasCreatedByUser = Boolean(getCreatedByUser());\n\n const isScheduled = release.scheduledAt && release.timezone;\n const numberOfEntriesText = formatMessage(\n {\n id: 'content-releases.pages.Details.header-subtitle',\n defaultMessage: '{number, plural, =0 {No entries} one {# entry} other {# entries}}',\n },\n { number: totalEntries }\n );\n const scheduledText = isScheduled\n ? formatMessage(\n {\n id: 'content-releases.pages.ReleaseDetails.header-subtitle.scheduled',\n defaultMessage: 'Scheduled for {date} at {time} ({offset})',\n },\n {\n date: formatDate(new Date(release.scheduledAt!), {\n weekday: 'long',\n day: 'numeric',\n month: 'long',\n year: 'numeric',\n timeZone: release.timezone!,\n }),\n time: formatTime(new Date(release.scheduledAt!), {\n timeZone: release.timezone!,\n hourCycle: 'h23',\n }),\n offset: getTimezoneOffset(release.timezone!, new Date(release.scheduledAt!)),\n }\n )\n : '';\n\n return (\n <Main aria-busy={isLoadingDetails}>\n <Layouts.Header\n title={release.name}\n subtitle={\n <Flex gap={2} lineHeight={6}>\n <Typography textColor=\"neutral600\" variant=\"epsilon\">\n {numberOfEntriesText + (isScheduled ? ` - ${scheduledText}` : '')}\n </Typography>\n <Badge {...getBadgeProps(release.status)}>{release.status}</Badge>\n </Flex>\n }\n navigationAction={<BackButton fallback=\"..\" />}\n primaryAction={\n !release.releasedAt && (\n <Flex gap={2}>\n <SimpleMenuButton\n label={<More />}\n variant=\"tertiary\"\n endIcon={null}\n paddingLeft=\"7px\"\n paddingRight=\"7px\"\n aria-label={formatMessage({\n id: 'content-releases.header.actions.open-release-actions',\n defaultMessage: 'Release edit and delete menu',\n })}\n popoverPlacement=\"bottom-end\"\n >\n <Menu.Item\n disabled={!canUpdate}\n onSelect={toggleEditReleaseModal}\n startIcon={<Pencil />}\n >\n {formatMessage({\n id: 'content-releases.header.actions.edit',\n defaultMessage: 'Edit',\n })}\n </Menu.Item>\n <Menu.Item\n disabled={!canDelete}\n onSelect={toggleWarningSubmit}\n variant=\"danger\"\n startIcon={<Trash />}\n >\n {formatMessage({\n id: 'content-releases.header.actions.delete',\n defaultMessage: 'Delete',\n })}\n </Menu.Item>\n <ReleaseInfoWrapper\n direction=\"column\"\n justifyContent=\"center\"\n alignItems=\"flex-start\"\n gap={1}\n padding={4}\n >\n <Typography variant=\"pi\" fontWeight=\"bold\">\n {formatMessage({\n id: 'content-releases.header.actions.created',\n defaultMessage: 'Created',\n })}\n </Typography>\n <Typography variant=\"pi\" color=\"neutral300\">\n <RelativeTime timestamp={new Date(release.createdAt)} />\n {formatMessage(\n {\n id: 'content-releases.header.actions.created.description',\n defaultMessage:\n '{hasCreatedByUser, select, true { by {createdBy}} other { by deleted user}}',\n },\n { createdBy: getCreatedByUser(), hasCreatedByUser }\n )}\n </Typography>\n </ReleaseInfoWrapper>\n </SimpleMenuButton>\n <Button size=\"S\" variant=\"tertiary\" onClick={handleRefresh}>\n {formatMessage({\n id: 'content-releases.header.actions.refresh',\n defaultMessage: 'Refresh',\n })}\n </Button>\n {canPublish ? (\n <Button\n size=\"S\"\n variant=\"default\"\n onClick={handlePublishRelease(release.id.toString())}\n loading={isPublishing}\n disabled={release.actions.meta.count === 0}\n >\n {formatMessage({\n id: 'content-releases.header.actions.publish',\n defaultMessage: 'Publish',\n })}\n </Button>\n ) : null}\n </Flex>\n )\n }\n />\n {children}\n </Main>\n );\n};\n\nconst SimpleMenuButton = styled(SimpleMenu)`\n & > span {\n display: flex;\n }\n`;\n\n/* -------------------------------------------------------------------------------------------------\n * ReleaseDetailsBody\n * -----------------------------------------------------------------------------------------------*/\nconst GROUP_BY_OPTIONS = ['contentType', 'locale', 'action'] as const;\nconst GROUP_BY_OPTIONS_NO_LOCALE = ['contentType', 'action'] as const;\nconst getGroupByOptionLabel = (value: (typeof GROUP_BY_OPTIONS)[number]) => {\n if (value === 'locale') {\n return {\n id: 'content-releases.pages.ReleaseDetails.groupBy.option.locales',\n defaultMessage: 'Locales',\n };\n }\n\n if (value === 'action') {\n return {\n id: 'content-releases.pages.ReleaseDetails.groupBy.option.actions',\n defaultMessage: 'Actions',\n };\n }\n\n return {\n id: 'content-releases.pages.ReleaseDetails.groupBy.option.content-type',\n defaultMessage: 'Content-Types',\n };\n};\n\ninterface ReleaseDetailsBodyProps {\n releaseId: string;\n}\n\nconst ReleaseDetailsBody = ({ releaseId }: ReleaseDetailsBodyProps) => {\n const { formatMessage } = useIntl();\n const [{ query }, setQuery] = useQueryParams<GetReleaseActionsQueryParams>();\n const { toggleNotification } = useNotification();\n const { formatAPIError } = useAPIErrorHandler();\n const {\n data: releaseData,\n isLoading: isReleaseLoading,\n error: releaseError,\n } = useGetReleaseQuery({ id: releaseId });\n const {\n allowedActions: { canUpdate },\n } = useRBAC(PERMISSIONS);\n const runHookWaterfall = useStrapiApp('ReleaseDetailsPage', (state) => state.runHookWaterfall);\n\n // TODO: Migrated displayedHeader to v5\n const { displayedHeaders, hasI18nEnabled }: { displayedHeaders: any; hasI18nEnabled: boolean } =\n runHookWaterfall('ContentReleases/pages/ReleaseDetails/add-locale-in-releases', {\n displayedHeaders: [\n {\n label: {\n id: 'content-releases.page.ReleaseDetails.table.header.label.name',\n defaultMessage: 'name',\n },\n name: 'name',\n },\n ],\n hasI18nEnabled: false,\n });\n\n const release = releaseData?.data;\n const selectedGroupBy = query?.groupBy || 'contentType';\n\n const {\n isLoading,\n isFetching,\n isError,\n data,\n error: releaseActionsError,\n } = useGetReleaseActionsQuery({\n ...query,\n releaseId,\n });\n\n const [updateReleaseAction] = useUpdateReleaseActionMutation();\n\n const handleChangeType = async (\n e: React.ChangeEvent<HTMLInputElement>,\n actionId: ReleaseAction['id'],\n actionPath: [string, number]\n ) => {\n const response = await updateReleaseAction({\n params: {\n releaseId,\n actionId,\n },\n body: {\n type: e.target.value as ReleaseAction['type'],\n },\n query, // We are passing the query params to make optimistic updates\n actionPath, // We are passing the action path to found the position in the cache of the action for optimistic updates\n });\n\n if ('error' in response) {\n if (isFetchError(response.error)) {\n // When the response returns an object with 'error', handle fetch error\n toggleNotification({\n type: 'danger',\n message: formatAPIError(response.error),\n });\n } else {\n // Otherwise, the response returns an object with 'error', handle a generic error\n toggleNotification({\n type: 'danger',\n message: formatMessage({ id: 'notification.error', defaultMessage: 'An error occurred' }),\n });\n }\n }\n };\n\n if (isLoading || isReleaseLoading) {\n return <Page.Loading />;\n }\n\n const releaseActions = data?.data;\n const releaseMeta = data?.meta;\n const contentTypes = releaseMeta?.contentTypes || {};\n const components = releaseMeta?.components || {};\n\n if (isBaseQueryError(releaseError) || !release) {\n const errorsArray = [];\n if (releaseError && 'code' in releaseError) {\n errorsArray.push({\n code: releaseError.code,\n });\n }\n if (releaseActionsError && 'code' in releaseActionsError) {\n errorsArray.push({\n code: releaseActionsError.code,\n });\n }\n return (\n <Navigate\n to=\"..\"\n state={{\n errors: errorsArray,\n }}\n />\n );\n }\n\n if (isError || !releaseActions) {\n return <Page.Error />;\n }\n\n if (Object.keys(releaseActions).length === 0) {\n return (\n <Layouts.Content>\n <EmptyStateLayout\n action={\n <LinkButton\n tag={ReactRouterLink}\n to={{\n pathname: '/content-manager',\n }}\n style={{ textDecoration: 'none' }}\n variant=\"secondary\"\n >\n {formatMessage({\n id: 'content-releases.page.Details.button.openContentManager',\n defaultMessage: 'Open the Content Manager',\n })}\n </LinkButton>\n }\n icon={<EmptyDocuments width=\"16rem\" />}\n content={formatMessage({\n id: 'content-releases.pages.Details.tab.emptyEntries',\n defaultMessage:\n 'This release is empty. Open the Content Manager, select an entry and add it to the release.',\n })}\n />\n </Layouts.Content>\n );\n }\n\n const groupByLabel = formatMessage({\n id: 'content-releases.pages.ReleaseDetails.groupBy.aria-label',\n defaultMessage: 'Group by',\n });\n const headers = [\n ...displayedHeaders,\n {\n label: {\n id: 'content-releases.page.ReleaseDetails.table.header.label.content-type',\n defaultMessage: 'content-type',\n },\n name: 'content-type',\n },\n {\n label: {\n id: 'content-releases.page.ReleaseDetails.table.header.label.action',\n defaultMessage: 'action',\n },\n name: 'action',\n },\n ...(!release.releasedAt\n ? [\n {\n label: {\n id: 'content-releases.page.ReleaseDetails.table.header.label.status',\n defaultMessage: 'status',\n },\n name: 'status',\n },\n ]\n : []),\n ];\n\n const options = hasI18nEnabled ? GROUP_BY_OPTIONS : GROUP_BY_OPTIONS_NO_LOCALE;\n\n return (\n <Layouts.Content>\n <Flex gap={8} direction=\"column\" alignItems=\"stretch\">\n <Flex>\n <SingleSelect\n placeholder={groupByLabel}\n aria-label={groupByLabel}\n customizeContent={(value) =>\n formatMessage(\n {\n id: `content-releases.pages.ReleaseDetails.groupBy.label`,\n defaultMessage: `Group by {groupBy}`,\n },\n {\n groupBy: value,\n }\n )\n }\n value={formatMessage(getGroupByOptionLabel(selectedGroupBy))}\n onChange={(value) => setQuery({ groupBy: value as ReleaseActionGroupBy })}\n >\n {options.map((option) => (\n <SingleSelectOption key={option} value={option}>\n {formatMessage(getGroupByOptionLabel(option))}\n </SingleSelectOption>\n ))}\n </SingleSelect>\n </Flex>\n {Object.keys(releaseActions).map((key) => (\n <Flex key={`releases-group-${key}`} gap={4} direction=\"column\" alignItems=\"stretch\">\n <Flex role=\"separator\" aria-label={key}>\n <Badge>{key}</Badge>\n </Flex>\n <Table.Root\n rows={releaseActions[key].map((item) => ({\n ...item,\n id: Number(item.entry.id),\n }))}\n headers={headers}\n isLoading={isLoading || isFetching}\n >\n <Table.Content>\n <Table.Head>\n {headers.map(({ label, name }) => (\n <Table.HeaderCell key={name} label={formatMessage(label)} name={name} />\n ))}\n </Table.Head>\n <Table.Loading />\n <Table.Body>\n {releaseActions[key].map(\n ({ id, contentType, locale, type, entry, status }, actionIndex) => (\n <Tr key={id}>\n <Td width=\"25%\" maxWidth=\"200px\">\n <Typography ellipsis>{`${\n contentType.mainFieldValue || entry.id\n }`}</Typography>\n </Td>\n {hasI18nEnabled && (\n <Td width=\"10%\">\n <Typography>{`${locale?.name ? locale.name : '-'}`}</Typography>\n </Td>\n )}\n\n <Td width=\"10%\">\n <Typography>{contentType.displayName || ''}</Typography>\n </Td>\n <Td width=\"20%\">\n {release.releasedAt ? (\n <Typography>\n {formatMessage(\n {\n id: 'content-releases.page.ReleaseDetails.table.action-published',\n defaultMessage:\n 'This entry was <b>{isPublish, select, true {published} other {unpublished}}</b>.',\n },\n {\n isPublish: type === 'publish',\n b: (children: React.ReactNode) => (\n <Typography fontWeight=\"bold\">{children}</Typography>\n ),\n }\n )}\n </Typography>\n ) : (\n <ReleaseActionOptions\n selected={type}\n handleChange={(e) => handleChangeType(e, id, [key, actionIndex])}\n name={`release-action-${id}-type`}\n disabled={!canUpdate}\n />\n )}\n </Td>\n {!release.releasedAt && (\n <>\n <Td width=\"20%\" minWidth=\"200px\">\n <EntryValidationPopover\n action={type}\n schema={contentTypes?.[contentType.uid]}\n entry={entry}\n status={status}\n />\n </Td>\n <Td>\n <Flex justifyContent=\"flex-end\">\n <ReleaseActionMenu.Root>\n <ReleaseActionMenu.ReleaseActionEntryLinkItem\n contentTypeUid={contentType.uid}\n documentId={entry.documentId}\n locale={locale?.code}\n />\n <ReleaseActionMenu.DeleteReleaseActionItem\n releaseId={release.id}\n actionId={id}\n />\n </ReleaseActionMenu.Root>\n </Flex>\n </Td>\n </>\n )}\n </Tr>\n )\n )}\n </Table.Body>\n </Table.Content>\n </Table.Root>\n </Flex>\n ))}\n <Pagination.Root\n {...releaseMeta?.pagination}\n defaultPageSize={releaseMeta?.pagination?.pageSize}\n >\n <Pagination.PageSize />\n <Pagination.Links />\n </Pagination.Root>\n </Flex>\n </Layouts.Content>\n );\n};\n\n/* -------------------------------------------------------------------------------------------------\n * ReleaseDetailsPage\n * -----------------------------------------------------------------------------------------------*/\nconst ReleaseDetailsPage = () => {\n const { formatMessage } = useIntl();\n const { releaseId } = useParams<{ releaseId: string }>();\n const { toggleNotification } = useNotification();\n const { formatAPIError } = useAPIErrorHandler();\n const navigate = useNavigate();\n const [releaseModalShown, setReleaseModalShown] = React.useState(false);\n const [showWarningSubmit, setWarningSubmit] = React.useState(false);\n\n const {\n isLoading: isLoadingDetails,\n data,\n isSuccess: isSuccessDetails,\n } = useGetReleaseQuery(\n { id: releaseId! },\n {\n skip: !releaseId,\n }\n );\n const { data: dataTimezone, isLoading: isLoadingTimezone } = useGetReleaseSettingsQuery();\n const [updateRelease, { isLoading: isSubmittingForm }] = useUpdateReleaseMutation();\n const [deleteRelease] = useDeleteReleaseMutation();\n\n const toggleEditReleaseModal = () => {\n setReleaseModalShown((prev) => !prev);\n };\n\n const getTimezoneValue = () => {\n if (releaseData?.timezone) {\n return releaseData.timezone;\n } else {\n if (dataTimezone?.data.defaultTimezone) {\n return dataTimezone.data.defaultTimezone;\n }\n return null;\n }\n };\n\n const toggleWarningSubmit = () => setWarningSubmit((prevState) => !prevState);\n\n if (isLoadingDetails || isLoadingTimezone) {\n return (\n <ReleaseDetailsLayout\n toggleEditReleaseModal={toggleEditReleaseModal}\n toggleWarningSubmit={toggleWarningSubmit}\n >\n <Page.Loading />\n </ReleaseDetailsLayout>\n );\n }\n\n if (!releaseId) {\n return <Navigate to=\"..\" />;\n }\n\n const releaseData = (isSuccessDetails && data?.data) || null;\n\n const title = releaseData?.name || '';\n const timezone = getTimezoneValue();\n const scheduledAt =\n releaseData?.scheduledAt && timezone ? utcToZonedTime(releaseData.scheduledAt, timezone) : null;\n // Just get the date and time to display without considering updated timezone time\n const date = scheduledAt ? format(scheduledAt, 'yyyy-MM-dd') : undefined;\n const time = scheduledAt ? format(scheduledAt, 'HH:mm') : '';\n\n const handleEditRelease = async (values: FormValues) => {\n const response = await updateRelease({\n id: releaseId,\n name: values.name,\n scheduledAt: values.scheduledAt,\n timezone: values.timezone,\n });\n\n if ('data' in response) {\n // When the response returns an object with 'data', handle success\n toggleNotification({\n type: 'success',\n message: formatMessage({\n id: 'content-releases.modal.release-updated-notification-success',\n defaultMessage: 'Release updated.',\n }),\n });\n toggleEditReleaseModal();\n } else if (isFetchError(response.error)) {\n // When the response returns an object with 'error', handle fetch error\n toggleNotification({\n type: 'danger',\n message: formatAPIError(response.error),\n });\n } else {\n // Otherwise, the response returns an object with 'error', handle a generic error\n toggleNotification({\n type: 'danger',\n message: formatMessage({ id: 'notification.error', defaultMessage: 'An error occurred' }),\n });\n }\n };\n\n const handleDeleteRelease = async () => {\n const response = await deleteRelease({\n id: releaseId,\n });\n\n if ('data' in response) {\n navigate('..');\n } else if (isFetchError(response.error)) {\n // When the response returns an object with 'error', handle fetch error\n toggleNotification({\n type: 'danger',\n message: formatAPIError(response.error),\n });\n } else {\n // Otherwise, the response returns an object with 'error', handle a generic error\n toggleNotification({\n type: 'danger',\n message: formatMessage({ id: 'notification.error', defaultMessage: 'An error occurred' }),\n });\n }\n };\n\n return (\n <ReleaseDetailsLayout\n toggleEditReleaseModal={toggleEditReleaseModal}\n toggleWarningSubmit={toggleWarningSubmit}\n >\n <ReleaseDetailsBody releaseId={releaseId} />\n <ReleaseModal\n open={releaseModalShown}\n handleClose={toggleEditReleaseModal}\n handleSubmit={handleEditRelease}\n isLoading={isLoadingDetails || isSubmittingForm}\n initialValues={{\n name: title || '',\n scheduledAt,\n date,\n time,\n isScheduled: Boolean(scheduledAt),\n timezone,\n }}\n />\n <Dialog.Root open={showWarningSubmit} onOpenChange={toggleWarningSubmit}>\n <ConfirmDialog onConfirm={handleDeleteRelease}>\n {formatMessage({\n id: 'content-releases.dialog.confirmation-message',\n defaultMessage: 'Are you sure you want to delete this release?',\n })}\n </ConfirmDialog>\n </Dialog.Root>\n </ReleaseDetailsLayout>\n );\n};\n\nexport { ReleaseDetailsPage };\n"],"names":["ReleaseInfoWrapper","styled","Flex","theme","borderRadius","colors","neutral150","ReleaseDetailsLayout","toggleEditReleaseModal","toggleWarningSubmit","children","formatMessage","formatDate","formatTime","useIntl","releaseId","useParams","data","isLoading","isLoadingDetails","error","useGetReleaseQuery","id","skip","publishRelease","isPublishing","usePublishReleaseMutation","toggleNotification","useNotification","formatAPIError","useAPIErrorHandler","allowedActions","useRBAC","PERMISSIONS","canUpdate","canDelete","canPublish","dispatch","useTypedDispatch","trackUsage","useTracking","release","handlePublishRelease","response","type","message","defaultMessage","totalEntries","totalPublishedEntries","totalUnpublishedEntries","meta","isFetchError","handleRefresh","releaseApi","util","invalidateTags","getCreatedByUser","createdBy","username","firstname","lastname","trim","email","_jsx","Page","Loading","Navigate","to","state","errors","code","actions","count","hasCreatedByUser","Boolean","isScheduled","scheduledAt","timezone","numberOfEntriesText","number","scheduledText","date","Date","weekday","day","month","year","timeZone","time","hourCycle","offset","getTimezoneOffset","_jsxs","Main","aria-busy","Layouts","Header","title","name","subtitle","gap","lineHeight","Typography","textColor","variant","Badge","getBadgeProps","status","navigationAction","BackButton","fallback","primaryAction","releasedAt","SimpleMenuButton","label","More","endIcon","paddingLeft","paddingRight","aria-label","popoverPlacement","Menu","Item","disabled","onSelect","startIcon","Pencil","Trash","direction","justifyContent","alignItems","padding","fontWeight","color","RelativeTime","timestamp","createdAt","Button","size","onClick","toString","loading","SimpleMenu","GROUP_BY_OPTIONS","GROUP_BY_OPTIONS_NO_LOCALE","getGroupByOptionLabel","value","ReleaseDetailsBody","query","setQuery","useQueryParams","releaseData","isReleaseLoading","releaseError","runHookWaterfall","useStrapiApp","displayedHeaders","hasI18nEnabled","selectedGroupBy","groupBy","isFetching","isError","releaseActionsError","useGetReleaseActionsQuery","updateReleaseAction","useUpdateReleaseActionMutation","handleChangeType","e","actionId","actionPath","params","body","target","releaseActions","releaseMeta","contentTypes","components","isBaseQueryError","errorsArray","push","Error","Object","keys","length","Content","EmptyStateLayout","action","LinkButton","tag","ReactRouterLink","pathname","style","textDecoration","icon","EmptyDocuments","width","content","groupByLabel","headers","options","SingleSelect","placeholder","customizeContent","onChange","map","option","SingleSelectOption","key","role","Table","Root","rows","item","Number","entry","Head","HeaderCell","Body","contentType","locale","actionIndex","Tr","Td","maxWidth","ellipsis","mainFieldValue","displayName","isPublish","b","ReleaseActionOptions","selected","handleChange","_Fragment","minWidth","EntryValidationPopover","schema","uid","ReleaseActionMenu","ReleaseActionEntryLinkItem","contentTypeUid","documentId","DeleteReleaseActionItem","Pagination","pagination","defaultPageSize","pageSize","PageSize","Links","ReleaseDetailsPage","navigate","useNavigate","releaseModalShown","setReleaseModalShown","React","useState","showWarningSubmit","setWarningSubmit","isSuccess","isSuccessDetails","dataTimezone","isLoadingTimezone","useGetReleaseSettingsQuery","updateRelease","isSubmittingForm","useUpdateReleaseMutation","deleteRelease","useDeleteReleaseMutation","prev","getTimezoneValue","defaultTimezone","prevState","utcToZonedTime","format","undefined","handleEditRelease","values","handleDeleteRelease","ReleaseModal","open","handleClose","handleSubmit","initialValues","Dialog","onOpenChange","ConfirmDialog","onConfirm"],"mappings":"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"}
|
package/dist/server/destroy.js
CHANGED
|
@@ -6,8 +6,8 @@ const destroy = async ({ strapi })=>{
|
|
|
6
6
|
const scheduledJobs = index.getService('scheduling', {
|
|
7
7
|
strapi
|
|
8
8
|
}).getAll();
|
|
9
|
-
for (const [,
|
|
10
|
-
|
|
9
|
+
for (const [, taskName] of scheduledJobs){
|
|
10
|
+
strapi.cron.remove(taskName);
|
|
11
11
|
}
|
|
12
12
|
};
|
|
13
13
|
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"destroy.js","sources":["../../server/src/destroy.ts"],"sourcesContent":["import
|
|
1
|
+
{"version":3,"file":"destroy.js","sources":["../../server/src/destroy.ts"],"sourcesContent":["import type { Core } from '@strapi/types';\n\nimport { Release } from '../../shared/contracts/releases';\nimport { getService } from './utils';\n\nexport const destroy = async ({ strapi }: { strapi: Core.Strapi }) => {\n const scheduledJobs: Map<Release['id'], string> = getService('scheduling', {\n strapi,\n }).getAll();\n\n for (const [, taskName] of scheduledJobs) {\n strapi.cron.remove(taskName);\n }\n};\n"],"names":["destroy","strapi","scheduledJobs","getService","getAll","taskName","cron","remove"],"mappings":";;;;AAKaA,MAAAA,OAAAA,GAAU,OAAO,EAAEC,MAAM,EAA2B,GAAA;IAC/D,MAAMC,aAAAA,GAA4CC,iBAAW,YAAc,EAAA;AACzEF,QAAAA;AACF,KAAA,CAAA,CAAGG,MAAM,EAAA;AAET,IAAA,KAAK,MAAM,GAAGC,QAAS,CAAA,IAAIH,aAAe,CAAA;QACxCD,MAAOK,CAAAA,IAAI,CAACC,MAAM,CAACF,QAAAA,CAAAA;AACrB;AACF;;;;"}
|
package/dist/server/destroy.mjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"destroy.mjs","sources":["../../server/src/destroy.ts"],"sourcesContent":["import
|
|
1
|
+
{"version":3,"file":"destroy.mjs","sources":["../../server/src/destroy.ts"],"sourcesContent":["import type { Core } from '@strapi/types';\n\nimport { Release } from '../../shared/contracts/releases';\nimport { getService } from './utils';\n\nexport const destroy = async ({ strapi }: { strapi: Core.Strapi }) => {\n const scheduledJobs: Map<Release['id'], string> = getService('scheduling', {\n strapi,\n }).getAll();\n\n for (const [, taskName] of scheduledJobs) {\n strapi.cron.remove(taskName);\n }\n};\n"],"names":["destroy","strapi","scheduledJobs","getService","getAll","taskName","cron","remove"],"mappings":";;AAKaA,MAAAA,OAAAA,GAAU,OAAO,EAAEC,MAAM,EAA2B,GAAA;IAC/D,MAAMC,aAAAA,GAA4CC,WAAW,YAAc,EAAA;AACzEF,QAAAA;AACF,KAAA,CAAA,CAAGG,MAAM,EAAA;AAET,IAAA,KAAK,MAAM,GAAGC,QAAS,CAAA,IAAIH,aAAe,CAAA;QACxCD,MAAOK,CAAAA,IAAI,CAACC,MAAM,CAACF,QAAAA,CAAAA;AACrB;AACF;;;;"}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var nodeSchedule = require('node-schedule');
|
|
4
3
|
var utils = require('@strapi/utils');
|
|
5
4
|
var index = require('../utils/index.js');
|
|
6
5
|
var constants = require('../constants.js');
|
|
@@ -18,26 +17,31 @@ const createSchedulingService = ({ strapi })=>{
|
|
|
18
17
|
if (!release) {
|
|
19
18
|
throw new utils.errors.NotFoundError(`No release found for id ${releaseId}`);
|
|
20
19
|
}
|
|
21
|
-
const
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
20
|
+
const taskName = `publishRelease_${releaseId}`;
|
|
21
|
+
strapi.cron.add({
|
|
22
|
+
[taskName]: {
|
|
23
|
+
async task () {
|
|
24
|
+
try {
|
|
25
|
+
await index.getService('release', {
|
|
26
|
+
strapi
|
|
27
|
+
}).publish(releaseId);
|
|
28
|
+
// @TODO: Trigger webhook with success message
|
|
29
|
+
} catch (error) {
|
|
30
|
+
// @TODO: Trigger webhook with error message
|
|
31
|
+
}
|
|
32
|
+
},
|
|
33
|
+
options: scheduleDate
|
|
29
34
|
}
|
|
30
|
-
this.cancel(releaseId);
|
|
31
35
|
});
|
|
32
36
|
if (scheduledJobs.has(releaseId)) {
|
|
33
37
|
this.cancel(releaseId);
|
|
34
38
|
}
|
|
35
|
-
scheduledJobs.set(releaseId,
|
|
39
|
+
scheduledJobs.set(releaseId, taskName);
|
|
36
40
|
return scheduledJobs;
|
|
37
41
|
},
|
|
38
42
|
cancel (releaseId) {
|
|
39
43
|
if (scheduledJobs.has(releaseId)) {
|
|
40
|
-
scheduledJobs.get(releaseId)
|
|
44
|
+
strapi.cron.remove(scheduledJobs.get(releaseId));
|
|
41
45
|
scheduledJobs.delete(releaseId);
|
|
42
46
|
}
|
|
43
47
|
return scheduledJobs;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"scheduling.js","sources":["../../../server/src/services/scheduling.ts"],"sourcesContent":["import
|
|
1
|
+
{"version":3,"file":"scheduling.js","sources":["../../../server/src/services/scheduling.ts"],"sourcesContent":["import type { Core } from '@strapi/types';\n\nimport { errors } from '@strapi/utils';\nimport { Release } from '../../../shared/contracts/releases';\nimport { getService } from '../utils';\nimport { RELEASE_MODEL_UID } from '../constants';\n\nconst createSchedulingService = ({ strapi }: { strapi: Core.Strapi }) => {\n const scheduledJobs = new Map<Release['id'], string>();\n\n return {\n async set(releaseId: Release['id'], scheduleDate: Date) {\n const release = await strapi.db\n .query(RELEASE_MODEL_UID)\n .findOne({ where: { id: releaseId, releasedAt: null } });\n\n if (!release) {\n throw new errors.NotFoundError(`No release found for id ${releaseId}`);\n }\n\n const taskName = `publishRelease_${releaseId}`;\n\n strapi.cron.add({\n [taskName]: {\n async task() {\n try {\n await getService('release', { strapi }).publish(releaseId);\n // @TODO: Trigger webhook with success message\n } catch (error) {\n // @TODO: Trigger webhook with error message\n }\n },\n options: scheduleDate,\n },\n });\n\n if (scheduledJobs.has(releaseId)) {\n this.cancel(releaseId);\n }\n\n scheduledJobs.set(releaseId, taskName);\n\n return scheduledJobs;\n },\n\n cancel(releaseId: Release['id']) {\n if (scheduledJobs.has(releaseId)) {\n strapi.cron.remove(scheduledJobs.get(releaseId)!);\n scheduledJobs.delete(releaseId);\n }\n\n return scheduledJobs;\n },\n\n getAll() {\n return scheduledJobs;\n },\n\n /**\n * On bootstrap, we can use this function to make sure to sync the scheduled jobs from the database that are not yet released\n * This is useful in case the server was restarted and the scheduled jobs were lost\n * This also could be used to sync different Strapi instances in case of a cluster\n */\n async syncFromDatabase() {\n const releases = await strapi.db.query(RELEASE_MODEL_UID).findMany({\n where: {\n scheduledAt: {\n $gte: new Date(),\n },\n releasedAt: null,\n },\n });\n\n for (const release of releases) {\n this.set(release.id, release.scheduledAt);\n }\n\n return scheduledJobs;\n },\n };\n};\n\nexport default createSchedulingService;\n"],"names":["createSchedulingService","strapi","scheduledJobs","Map","set","releaseId","scheduleDate","release","db","query","RELEASE_MODEL_UID","findOne","where","id","releasedAt","errors","NotFoundError","taskName","cron","add","task","getService","publish","error","options","has","cancel","remove","get","delete","getAll","syncFromDatabase","releases","findMany","scheduledAt","$gte","Date"],"mappings":";;;;;;AAOA,MAAMA,uBAA0B,GAAA,CAAC,EAAEC,MAAM,EAA2B,GAAA;AAClE,IAAA,MAAMC,gBAAgB,IAAIC,GAAAA,EAAAA;IAE1B,OAAO;QACL,MAAMC,GAAAA,CAAAA,CAAIC,SAAwB,EAAEC,YAAkB,EAAA;YACpD,MAAMC,OAAAA,GAAU,MAAMN,MAAOO,CAAAA,EAAE,CAC5BC,KAAK,CAACC,2BACNC,CAAAA,CAAAA,OAAO,CAAC;gBAAEC,KAAO,EAAA;oBAAEC,EAAIR,EAAAA,SAAAA;oBAAWS,UAAY,EAAA;AAAK;AAAE,aAAA,CAAA;AAExD,YAAA,IAAI,CAACP,OAAS,EAAA;gBACZ,MAAM,IAAIQ,aAAOC,aAAa,CAAC,CAAC,wBAAwB,EAAEX,UAAU,CAAC,CAAA;AACvE;AAEA,YAAA,MAAMY,QAAW,GAAA,CAAC,eAAe,EAAEZ,UAAU,CAAC;YAE9CJ,MAAOiB,CAAAA,IAAI,CAACC,GAAG,CAAC;AACd,gBAAA,CAACF,WAAW;oBACV,MAAMG,IAAAA,CAAAA,GAAAA;wBACJ,IAAI;AACF,4BAAA,MAAMC,iBAAW,SAAW,EAAA;AAAEpB,gCAAAA;AAAO,6BAAA,CAAA,CAAGqB,OAAO,CAACjB,SAAAA,CAAAA;;AAElD,yBAAA,CAAE,OAAOkB,KAAO,EAAA;;AAEhB;AACF,qBAAA;oBACAC,OAASlB,EAAAA;AACX;AACF,aAAA,CAAA;YAEA,IAAIJ,aAAAA,CAAcuB,GAAG,CAACpB,SAAY,CAAA,EAAA;gBAChC,IAAI,CAACqB,MAAM,CAACrB,SAAAA,CAAAA;AACd;YAEAH,aAAcE,CAAAA,GAAG,CAACC,SAAWY,EAAAA,QAAAA,CAAAA;YAE7B,OAAOf,aAAAA;AACT,SAAA;AAEAwB,QAAAA,MAAAA,CAAAA,CAAOrB,SAAwB,EAAA;YAC7B,IAAIH,aAAAA,CAAcuB,GAAG,CAACpB,SAAY,CAAA,EAAA;AAChCJ,gBAAAA,MAAAA,CAAOiB,IAAI,CAACS,MAAM,CAACzB,aAAAA,CAAc0B,GAAG,CAACvB,SAAAA,CAAAA,CAAAA;AACrCH,gBAAAA,aAAAA,CAAc2B,MAAM,CAACxB,SAAAA,CAAAA;AACvB;YAEA,OAAOH,aAAAA;AACT,SAAA;AAEA4B,QAAAA,MAAAA,CAAAA,GAAAA;YACE,OAAO5B,aAAAA;AACT,SAAA;AAEA;;;;AAIC,QACD,MAAM6B,gBAAAA,CAAAA,GAAAA;YACJ,MAAMC,QAAAA,GAAW,MAAM/B,MAAOO,CAAAA,EAAE,CAACC,KAAK,CAACC,2BAAmBuB,CAAAA,CAAAA,QAAQ,CAAC;gBACjErB,KAAO,EAAA;oBACLsB,WAAa,EAAA;AACXC,wBAAAA,IAAAA,EAAM,IAAIC,IAAAA;AACZ,qBAAA;oBACAtB,UAAY,EAAA;AACd;AACF,aAAA,CAAA;YAEA,KAAK,MAAMP,WAAWyB,QAAU,CAAA;AAC9B,gBAAA,IAAI,CAAC5B,GAAG,CAACG,QAAQM,EAAE,EAAEN,QAAQ2B,WAAW,CAAA;AAC1C;YAEA,OAAOhC,aAAAA;AACT;AACF,KAAA;AACF;;;;"}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { scheduleJob } from 'node-schedule';
|
|
2
1
|
import { errors } from '@strapi/utils';
|
|
3
2
|
import { getService } from '../utils/index.mjs';
|
|
4
3
|
import { RELEASE_MODEL_UID } from '../constants.mjs';
|
|
@@ -16,26 +15,31 @@ const createSchedulingService = ({ strapi })=>{
|
|
|
16
15
|
if (!release) {
|
|
17
16
|
throw new errors.NotFoundError(`No release found for id ${releaseId}`);
|
|
18
17
|
}
|
|
19
|
-
const
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
18
|
+
const taskName = `publishRelease_${releaseId}`;
|
|
19
|
+
strapi.cron.add({
|
|
20
|
+
[taskName]: {
|
|
21
|
+
async task () {
|
|
22
|
+
try {
|
|
23
|
+
await getService('release', {
|
|
24
|
+
strapi
|
|
25
|
+
}).publish(releaseId);
|
|
26
|
+
// @TODO: Trigger webhook with success message
|
|
27
|
+
} catch (error) {
|
|
28
|
+
// @TODO: Trigger webhook with error message
|
|
29
|
+
}
|
|
30
|
+
},
|
|
31
|
+
options: scheduleDate
|
|
27
32
|
}
|
|
28
|
-
this.cancel(releaseId);
|
|
29
33
|
});
|
|
30
34
|
if (scheduledJobs.has(releaseId)) {
|
|
31
35
|
this.cancel(releaseId);
|
|
32
36
|
}
|
|
33
|
-
scheduledJobs.set(releaseId,
|
|
37
|
+
scheduledJobs.set(releaseId, taskName);
|
|
34
38
|
return scheduledJobs;
|
|
35
39
|
},
|
|
36
40
|
cancel (releaseId) {
|
|
37
41
|
if (scheduledJobs.has(releaseId)) {
|
|
38
|
-
scheduledJobs.get(releaseId)
|
|
42
|
+
strapi.cron.remove(scheduledJobs.get(releaseId));
|
|
39
43
|
scheduledJobs.delete(releaseId);
|
|
40
44
|
}
|
|
41
45
|
return scheduledJobs;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"scheduling.mjs","sources":["../../../server/src/services/scheduling.ts"],"sourcesContent":["import
|
|
1
|
+
{"version":3,"file":"scheduling.mjs","sources":["../../../server/src/services/scheduling.ts"],"sourcesContent":["import type { Core } from '@strapi/types';\n\nimport { errors } from '@strapi/utils';\nimport { Release } from '../../../shared/contracts/releases';\nimport { getService } from '../utils';\nimport { RELEASE_MODEL_UID } from '../constants';\n\nconst createSchedulingService = ({ strapi }: { strapi: Core.Strapi }) => {\n const scheduledJobs = new Map<Release['id'], string>();\n\n return {\n async set(releaseId: Release['id'], scheduleDate: Date) {\n const release = await strapi.db\n .query(RELEASE_MODEL_UID)\n .findOne({ where: { id: releaseId, releasedAt: null } });\n\n if (!release) {\n throw new errors.NotFoundError(`No release found for id ${releaseId}`);\n }\n\n const taskName = `publishRelease_${releaseId}`;\n\n strapi.cron.add({\n [taskName]: {\n async task() {\n try {\n await getService('release', { strapi }).publish(releaseId);\n // @TODO: Trigger webhook with success message\n } catch (error) {\n // @TODO: Trigger webhook with error message\n }\n },\n options: scheduleDate,\n },\n });\n\n if (scheduledJobs.has(releaseId)) {\n this.cancel(releaseId);\n }\n\n scheduledJobs.set(releaseId, taskName);\n\n return scheduledJobs;\n },\n\n cancel(releaseId: Release['id']) {\n if (scheduledJobs.has(releaseId)) {\n strapi.cron.remove(scheduledJobs.get(releaseId)!);\n scheduledJobs.delete(releaseId);\n }\n\n return scheduledJobs;\n },\n\n getAll() {\n return scheduledJobs;\n },\n\n /**\n * On bootstrap, we can use this function to make sure to sync the scheduled jobs from the database that are not yet released\n * This is useful in case the server was restarted and the scheduled jobs were lost\n * This also could be used to sync different Strapi instances in case of a cluster\n */\n async syncFromDatabase() {\n const releases = await strapi.db.query(RELEASE_MODEL_UID).findMany({\n where: {\n scheduledAt: {\n $gte: new Date(),\n },\n releasedAt: null,\n },\n });\n\n for (const release of releases) {\n this.set(release.id, release.scheduledAt);\n }\n\n return scheduledJobs;\n },\n };\n};\n\nexport default createSchedulingService;\n"],"names":["createSchedulingService","strapi","scheduledJobs","Map","set","releaseId","scheduleDate","release","db","query","RELEASE_MODEL_UID","findOne","where","id","releasedAt","errors","NotFoundError","taskName","cron","add","task","getService","publish","error","options","has","cancel","remove","get","delete","getAll","syncFromDatabase","releases","findMany","scheduledAt","$gte","Date"],"mappings":";;;;AAOA,MAAMA,uBAA0B,GAAA,CAAC,EAAEC,MAAM,EAA2B,GAAA;AAClE,IAAA,MAAMC,gBAAgB,IAAIC,GAAAA,EAAAA;IAE1B,OAAO;QACL,MAAMC,GAAAA,CAAAA,CAAIC,SAAwB,EAAEC,YAAkB,EAAA;YACpD,MAAMC,OAAAA,GAAU,MAAMN,MAAOO,CAAAA,EAAE,CAC5BC,KAAK,CAACC,iBACNC,CAAAA,CAAAA,OAAO,CAAC;gBAAEC,KAAO,EAAA;oBAAEC,EAAIR,EAAAA,SAAAA;oBAAWS,UAAY,EAAA;AAAK;AAAE,aAAA,CAAA;AAExD,YAAA,IAAI,CAACP,OAAS,EAAA;gBACZ,MAAM,IAAIQ,OAAOC,aAAa,CAAC,CAAC,wBAAwB,EAAEX,UAAU,CAAC,CAAA;AACvE;AAEA,YAAA,MAAMY,QAAW,GAAA,CAAC,eAAe,EAAEZ,UAAU,CAAC;YAE9CJ,MAAOiB,CAAAA,IAAI,CAACC,GAAG,CAAC;AACd,gBAAA,CAACF,WAAW;oBACV,MAAMG,IAAAA,CAAAA,GAAAA;wBACJ,IAAI;AACF,4BAAA,MAAMC,WAAW,SAAW,EAAA;AAAEpB,gCAAAA;AAAO,6BAAA,CAAA,CAAGqB,OAAO,CAACjB,SAAAA,CAAAA;;AAElD,yBAAA,CAAE,OAAOkB,KAAO,EAAA;;AAEhB;AACF,qBAAA;oBACAC,OAASlB,EAAAA;AACX;AACF,aAAA,CAAA;YAEA,IAAIJ,aAAAA,CAAcuB,GAAG,CAACpB,SAAY,CAAA,EAAA;gBAChC,IAAI,CAACqB,MAAM,CAACrB,SAAAA,CAAAA;AACd;YAEAH,aAAcE,CAAAA,GAAG,CAACC,SAAWY,EAAAA,QAAAA,CAAAA;YAE7B,OAAOf,aAAAA;AACT,SAAA;AAEAwB,QAAAA,MAAAA,CAAAA,CAAOrB,SAAwB,EAAA;YAC7B,IAAIH,aAAAA,CAAcuB,GAAG,CAACpB,SAAY,CAAA,EAAA;AAChCJ,gBAAAA,MAAAA,CAAOiB,IAAI,CAACS,MAAM,CAACzB,aAAAA,CAAc0B,GAAG,CAACvB,SAAAA,CAAAA,CAAAA;AACrCH,gBAAAA,aAAAA,CAAc2B,MAAM,CAACxB,SAAAA,CAAAA;AACvB;YAEA,OAAOH,aAAAA;AACT,SAAA;AAEA4B,QAAAA,MAAAA,CAAAA,GAAAA;YACE,OAAO5B,aAAAA;AACT,SAAA;AAEA;;;;AAIC,QACD,MAAM6B,gBAAAA,CAAAA,GAAAA;YACJ,MAAMC,QAAAA,GAAW,MAAM/B,MAAOO,CAAAA,EAAE,CAACC,KAAK,CAACC,iBAAmBuB,CAAAA,CAAAA,QAAQ,CAAC;gBACjErB,KAAO,EAAA;oBACLsB,WAAa,EAAA;AACXC,wBAAAA,IAAAA,EAAM,IAAIC,IAAAA;AACZ,qBAAA;oBACAtB,UAAY,EAAA;AACd;AACF,aAAA,CAAA;YAEA,KAAK,MAAMP,WAAWyB,QAAU,CAAA;AAC9B,gBAAA,IAAI,CAAC5B,GAAG,CAACG,QAAQM,EAAE,EAAEN,QAAQ2B,WAAW,CAAA;AAC1C;YAEA,OAAOhC,aAAAA;AACT;AACF,KAAA;AACF;;;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"destroy.d.ts","sourceRoot":"","sources":["../../../server/src/destroy.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"destroy.d.ts","sourceRoot":"","sources":["../../../server/src/destroy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAK1C,eAAO,MAAM,OAAO,eAAsB;IAAE,MAAM,EAAE,KAAK,MAAM,CAAA;CAAE,kBAQhE,CAAC"}
|
|
@@ -1914,10 +1914,10 @@ declare const _default: {
|
|
|
1914
1914
|
scheduling: ({ strapi }: {
|
|
1915
1915
|
strapi: import("@strapi/types/dist/core").Strapi;
|
|
1916
1916
|
}) => {
|
|
1917
|
-
set(releaseId: import("@strapi/types/dist/data").ID, scheduleDate: Date): Promise<Map<import("@strapi/types/dist/data").ID,
|
|
1918
|
-
cancel(releaseId: import("@strapi/types/dist/data").ID): Map<import("@strapi/types/dist/data").ID,
|
|
1919
|
-
getAll(): Map<import("@strapi/types/dist/data").ID,
|
|
1920
|
-
syncFromDatabase(): Promise<Map<import("@strapi/types/dist/data").ID,
|
|
1917
|
+
set(releaseId: import("@strapi/types/dist/data").ID, scheduleDate: Date): Promise<Map<import("@strapi/types/dist/data").ID, string>>;
|
|
1918
|
+
cancel(releaseId: import("@strapi/types/dist/data").ID): Map<import("@strapi/types/dist/data").ID, string>;
|
|
1919
|
+
getAll(): Map<import("@strapi/types/dist/data").ID, string>;
|
|
1920
|
+
syncFromDatabase(): Promise<Map<import("@strapi/types/dist/data").ID, string>>;
|
|
1921
1921
|
};
|
|
1922
1922
|
settings: ({ strapi }: {
|
|
1923
1923
|
strapi: import("@strapi/types/dist/core").Strapi;
|
|
@@ -1807,10 +1807,10 @@ export declare const services: {
|
|
|
1807
1807
|
scheduling: ({ strapi }: {
|
|
1808
1808
|
strapi: import("@strapi/types/dist/core").Strapi;
|
|
1809
1809
|
}) => {
|
|
1810
|
-
set(releaseId: import("@strapi/types/dist/data").ID, scheduleDate: Date): Promise<Map<import("@strapi/types/dist/data").ID,
|
|
1811
|
-
cancel(releaseId: import("@strapi/types/dist/data").ID): Map<import("@strapi/types/dist/data").ID,
|
|
1812
|
-
getAll(): Map<import("@strapi/types/dist/data").ID,
|
|
1813
|
-
syncFromDatabase(): Promise<Map<import("@strapi/types/dist/data").ID,
|
|
1810
|
+
set(releaseId: import("@strapi/types/dist/data").ID, scheduleDate: Date): Promise<Map<import("@strapi/types/dist/data").ID, string>>;
|
|
1811
|
+
cancel(releaseId: import("@strapi/types/dist/data").ID): Map<import("@strapi/types/dist/data").ID, string>;
|
|
1812
|
+
getAll(): Map<import("@strapi/types/dist/data").ID, string>;
|
|
1813
|
+
syncFromDatabase(): Promise<Map<import("@strapi/types/dist/data").ID, string>>;
|
|
1814
1814
|
};
|
|
1815
1815
|
settings: ({ strapi }: {
|
|
1816
1816
|
strapi: import("@strapi/types/dist/core").Strapi;
|
|
@@ -1,18 +1,17 @@
|
|
|
1
|
-
import { Job } from 'node-schedule';
|
|
2
1
|
import type { Core } from '@strapi/types';
|
|
3
2
|
import { Release } from '../../../shared/contracts/releases';
|
|
4
3
|
declare const createSchedulingService: ({ strapi }: {
|
|
5
4
|
strapi: Core.Strapi;
|
|
6
5
|
}) => {
|
|
7
|
-
set(releaseId: Release['id'], scheduleDate: Date): Promise<Map<import("@strapi/types/dist/data").ID,
|
|
8
|
-
cancel(releaseId: Release['id']): Map<import("@strapi/types/dist/data").ID,
|
|
9
|
-
getAll(): Map<import("@strapi/types/dist/data").ID,
|
|
6
|
+
set(releaseId: Release['id'], scheduleDate: Date): Promise<Map<import("@strapi/types/dist/data").ID, string>>;
|
|
7
|
+
cancel(releaseId: Release['id']): Map<import("@strapi/types/dist/data").ID, string>;
|
|
8
|
+
getAll(): Map<import("@strapi/types/dist/data").ID, string>;
|
|
10
9
|
/**
|
|
11
10
|
* On bootstrap, we can use this function to make sure to sync the scheduled jobs from the database that are not yet released
|
|
12
11
|
* This is useful in case the server was restarted and the scheduled jobs were lost
|
|
13
12
|
* This also could be used to sync different Strapi instances in case of a cluster
|
|
14
13
|
*/
|
|
15
|
-
syncFromDatabase(): Promise<Map<import("@strapi/types/dist/data").ID,
|
|
14
|
+
syncFromDatabase(): Promise<Map<import("@strapi/types/dist/data").ID, string>>;
|
|
16
15
|
};
|
|
17
16
|
export default createSchedulingService;
|
|
18
17
|
//# sourceMappingURL=scheduling.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"scheduling.d.ts","sourceRoot":"","sources":["../../../../server/src/services/scheduling.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"scheduling.d.ts","sourceRoot":"","sources":["../../../../server/src/services/scheduling.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,eAAe,CAAC;AAG1C,OAAO,EAAE,OAAO,EAAE,MAAM,oCAAoC,CAAC;AAI7D,QAAA,MAAM,uBAAuB,eAAgB;IAAE,MAAM,EAAE,KAAK,MAAM,CAAA;CAAE;mBAI3C,OAAO,CAAC,IAAI,CAAC,gBAAgB,IAAI;sBAkCpC,OAAO,CAAC,IAAI,CAAC;;IAa/B;;;;OAIG;;CAkBN,CAAC;AAEF,eAAe,uBAAuB,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@strapi/content-releases",
|
|
3
|
-
"version": "0.0.0-next.
|
|
3
|
+
"version": "0.0.0-next.8f0cdd4f9e4697ffed86c783465297fe532713f8",
|
|
4
4
|
"description": "Strapi plugin for organizing and releasing content",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -59,25 +59,24 @@
|
|
|
59
59
|
},
|
|
60
60
|
"dependencies": {
|
|
61
61
|
"@reduxjs/toolkit": "1.9.7",
|
|
62
|
-
"@strapi/database": "0.0.0-next.
|
|
63
|
-
"@strapi/design-system": "2.0.0-rc.
|
|
64
|
-
"@strapi/icons": "2.0.0-rc.
|
|
65
|
-
"@strapi/types": "0.0.0-next.
|
|
66
|
-
"@strapi/utils": "0.0.0-next.
|
|
62
|
+
"@strapi/database": "0.0.0-next.8f0cdd4f9e4697ffed86c783465297fe532713f8",
|
|
63
|
+
"@strapi/design-system": "2.0.0-rc.29",
|
|
64
|
+
"@strapi/icons": "2.0.0-rc.29",
|
|
65
|
+
"@strapi/types": "0.0.0-next.8f0cdd4f9e4697ffed86c783465297fe532713f8",
|
|
66
|
+
"@strapi/utils": "0.0.0-next.8f0cdd4f9e4697ffed86c783465297fe532713f8",
|
|
67
67
|
"date-fns": "2.30.0",
|
|
68
68
|
"date-fns-tz": "2.0.1",
|
|
69
69
|
"formik": "2.4.5",
|
|
70
70
|
"lodash": "4.17.21",
|
|
71
|
-
"node-schedule": "2.1.1",
|
|
72
71
|
"qs": "6.11.1",
|
|
73
72
|
"react-intl": "6.6.2",
|
|
74
73
|
"react-redux": "8.1.3",
|
|
75
74
|
"yup": "0.32.9"
|
|
76
75
|
},
|
|
77
76
|
"devDependencies": {
|
|
78
|
-
"@strapi/admin": "0.0.0-next.
|
|
79
|
-
"@strapi/admin-test-utils": "0.0.0-next.
|
|
80
|
-
"@strapi/content-manager": "0.0.0-next.
|
|
77
|
+
"@strapi/admin": "0.0.0-next.8f0cdd4f9e4697ffed86c783465297fe532713f8",
|
|
78
|
+
"@strapi/admin-test-utils": "0.0.0-next.8f0cdd4f9e4697ffed86c783465297fe532713f8",
|
|
79
|
+
"@strapi/content-manager": "0.0.0-next.8f0cdd4f9e4697ffed86c783465297fe532713f8",
|
|
81
80
|
"@testing-library/dom": "10.1.0",
|
|
82
81
|
"@testing-library/react": "15.0.7",
|
|
83
82
|
"@testing-library/user-event": "14.5.2",
|