@strapi/content-releases 5.9.0 → 5.10.1
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/chunks/App-B9yCdSLJ.js +1866 -0
- package/dist/admin/chunks/App-B9yCdSLJ.js.map +1 -0
- package/dist/admin/chunks/App-CuOosufQ.mjs +1845 -0
- package/dist/admin/chunks/App-CuOosufQ.mjs.map +1 -0
- package/dist/admin/chunks/PurchaseContentReleases-BCME5SQU.js +55 -0
- package/dist/admin/chunks/PurchaseContentReleases-BCME5SQU.js.map +1 -0
- package/dist/admin/chunks/PurchaseContentReleases-S1ccDSwp.mjs +53 -0
- package/dist/admin/chunks/PurchaseContentReleases-S1ccDSwp.mjs.map +1 -0
- package/dist/admin/chunks/ReleasesSettingsPage-BzdLEfxa.mjs +206 -0
- package/dist/admin/chunks/ReleasesSettingsPage-BzdLEfxa.mjs.map +1 -0
- package/dist/admin/chunks/ReleasesSettingsPage-DFVGppsl.js +208 -0
- package/dist/admin/chunks/ReleasesSettingsPage-DFVGppsl.js.map +1 -0
- package/dist/admin/chunks/en-B2EeDoOz.mjs +101 -0
- package/dist/{_chunks/en-D9Q4YW03.mjs.map → admin/chunks/en-B2EeDoOz.mjs.map} +1 -1
- package/dist/admin/chunks/en-BzpFfVeO.js +103 -0
- package/dist/{_chunks/en-BWPPsSH-.js.map → admin/chunks/en-BzpFfVeO.js.map} +1 -1
- package/dist/admin/chunks/index-1nn-zHX-.js +1657 -0
- package/dist/admin/chunks/index-1nn-zHX-.js.map +1 -0
- package/dist/admin/chunks/index-CmAFGQWf.mjs +1618 -0
- package/dist/admin/chunks/index-CmAFGQWf.mjs.map +1 -0
- package/dist/admin/chunks/schemas-DMt8h1z-.mjs +43 -0
- package/dist/admin/chunks/schemas-DMt8h1z-.mjs.map +1 -0
- package/dist/admin/chunks/schemas-DS7NeFDN.js +65 -0
- package/dist/admin/chunks/schemas-DS7NeFDN.js.map +1 -0
- package/dist/admin/index.js +18 -3
- package/dist/admin/index.js.map +1 -1
- package/dist/admin/index.mjs +13 -5
- package/dist/admin/index.mjs.map +1 -1
- package/dist/admin/src/components/ReleaseListCell.d.ts +1 -1
- package/dist/server/index.js +2166 -1870
- package/dist/server/index.js.map +1 -1
- package/dist/server/index.mjs +2156 -1861
- package/dist/server/index.mjs.map +1 -1
- package/dist/server/src/destroy.d.ts +1 -1
- package/dist/server/src/destroy.d.ts.map +1 -1
- package/dist/server/src/middlewares/documents.d.ts +1 -1
- package/dist/server/src/middlewares/documents.d.ts.map +1 -1
- package/dist/server/src/services/scheduling.d.ts +1 -1
- package/dist/server/src/services/scheduling.d.ts.map +1 -1
- package/dist/server/src/services/validation.d.ts +1 -1
- package/dist/server/src/services/validation.d.ts.map +1 -1
- package/dist/shared/contracts/release-actions.d.ts +0 -1
- package/dist/shared/contracts/releases.d.ts +0 -1
- package/dist/shared/contracts/settings.d.ts +1 -2
- package/dist/shared/contracts/settings.d.ts.map +1 -1
- package/dist/shared/types.d.ts +0 -1
- package/package.json +16 -13
- package/dist/_chunks/App-CiZCkScI.mjs +0 -1558
- package/dist/_chunks/App-CiZCkScI.mjs.map +0 -1
- package/dist/_chunks/App-SGjO5UPV.js +0 -1578
- package/dist/_chunks/App-SGjO5UPV.js.map +0 -1
- package/dist/_chunks/PurchaseContentReleases--qQepXpP.js +0 -52
- package/dist/_chunks/PurchaseContentReleases--qQepXpP.js.map +0 -1
- package/dist/_chunks/PurchaseContentReleases-D-n-w-st.mjs +0 -52
- package/dist/_chunks/PurchaseContentReleases-D-n-w-st.mjs.map +0 -1
- package/dist/_chunks/ReleasesSettingsPage-Cto_NLUd.js +0 -178
- package/dist/_chunks/ReleasesSettingsPage-Cto_NLUd.js.map +0 -1
- package/dist/_chunks/ReleasesSettingsPage-DQT8N3A-.mjs +0 -178
- package/dist/_chunks/ReleasesSettingsPage-DQT8N3A-.mjs.map +0 -1
- package/dist/_chunks/en-BWPPsSH-.js +0 -102
- package/dist/_chunks/en-D9Q4YW03.mjs +0 -102
- package/dist/_chunks/index-BjvFfTtA.mjs +0 -1386
- package/dist/_chunks/index-BjvFfTtA.mjs.map +0 -1
- package/dist/_chunks/index-CyU534vL.js +0 -1404
- package/dist/_chunks/index-CyU534vL.js.map +0 -1
- package/dist/_chunks/schemas-DBYv9gK8.js +0 -61
- package/dist/_chunks/schemas-DBYv9gK8.js.map +0 -1
- package/dist/_chunks/schemas-DdA2ic2U.mjs +0 -44
- package/dist/_chunks/schemas-DdA2ic2U.mjs.map +0 -1
|
@@ -0,0 +1,206 @@
|
|
|
1
|
+
import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
|
|
2
|
+
import { Page, useAPIErrorHandler, useNotification, useRBAC, Layouts, Form, useField, isFetchError } from '@strapi/admin/strapi-admin';
|
|
3
|
+
import { Button, Flex, Typography, Grid, Field, Combobox, ComboboxOption } from '@strapi/design-system';
|
|
4
|
+
import { Check } from '@strapi/icons';
|
|
5
|
+
import { useIntl } from 'react-intl';
|
|
6
|
+
import { useSelector } from 'react-redux';
|
|
7
|
+
import { a as useGetReleaseSettingsQuery, l as useUpdateReleaseSettingsMutation, g as getTimezones } from './index-CmAFGQWf.mjs';
|
|
8
|
+
import { S as SETTINGS_SCHEMA } from './schemas-DMt8h1z-.mjs';
|
|
9
|
+
import 'react';
|
|
10
|
+
import 'formik';
|
|
11
|
+
import '@strapi/content-manager/strapi-admin';
|
|
12
|
+
import '@strapi/icons/symbols';
|
|
13
|
+
import 'react-router-dom';
|
|
14
|
+
import 'yup';
|
|
15
|
+
import 'styled-components';
|
|
16
|
+
import 'date-fns-tz';
|
|
17
|
+
|
|
18
|
+
const useTypedSelector = useSelector;
|
|
19
|
+
|
|
20
|
+
const ReleasesSettingsPage = ()=>{
|
|
21
|
+
const { formatMessage } = useIntl();
|
|
22
|
+
const { formatAPIError } = useAPIErrorHandler();
|
|
23
|
+
const { toggleNotification } = useNotification();
|
|
24
|
+
const { data, isLoading: isLoadingSettings } = useGetReleaseSettingsQuery();
|
|
25
|
+
const [updateReleaseSettings, { isLoading: isSubmittingForm }] = useUpdateReleaseSettingsMutation();
|
|
26
|
+
const permissions = useTypedSelector((state)=>state.admin_app.permissions['settings']?.['releases']);
|
|
27
|
+
const { allowedActions: { canUpdate } } = useRBAC(permissions);
|
|
28
|
+
const { timezoneList } = getTimezones(new Date());
|
|
29
|
+
const handleSubmit = async (body)=>{
|
|
30
|
+
const { defaultTimezone } = body;
|
|
31
|
+
const isBodyTimezoneValid = timezoneList.some((timezone)=>timezone.value === defaultTimezone);
|
|
32
|
+
const newBody = !defaultTimezone || !isBodyTimezoneValid ? {
|
|
33
|
+
defaultTimezone: null
|
|
34
|
+
} : {
|
|
35
|
+
...body
|
|
36
|
+
};
|
|
37
|
+
try {
|
|
38
|
+
const response = await updateReleaseSettings(newBody);
|
|
39
|
+
if ('data' in response) {
|
|
40
|
+
toggleNotification({
|
|
41
|
+
type: 'success',
|
|
42
|
+
message: formatMessage({
|
|
43
|
+
id: 'content-releases.pages.Settings.releases.setting.default-timezone-notification-success',
|
|
44
|
+
defaultMessage: 'Default timezone updated.'
|
|
45
|
+
})
|
|
46
|
+
});
|
|
47
|
+
} else if (isFetchError(response.error)) {
|
|
48
|
+
toggleNotification({
|
|
49
|
+
type: 'danger',
|
|
50
|
+
message: formatAPIError(response.error)
|
|
51
|
+
});
|
|
52
|
+
} else {
|
|
53
|
+
toggleNotification({
|
|
54
|
+
type: 'danger',
|
|
55
|
+
message: formatMessage({
|
|
56
|
+
id: 'notification.error',
|
|
57
|
+
defaultMessage: 'An error occurred'
|
|
58
|
+
})
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
} catch (error) {
|
|
62
|
+
toggleNotification({
|
|
63
|
+
type: 'danger',
|
|
64
|
+
message: formatMessage({
|
|
65
|
+
id: 'notification.error',
|
|
66
|
+
defaultMessage: 'An error occurred'
|
|
67
|
+
})
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
if (isLoadingSettings) {
|
|
72
|
+
return /*#__PURE__*/ jsx(Page.Loading, {});
|
|
73
|
+
}
|
|
74
|
+
return /*#__PURE__*/ jsxs(Layouts.Root, {
|
|
75
|
+
children: [
|
|
76
|
+
/*#__PURE__*/ jsx(Page.Title, {
|
|
77
|
+
children: formatMessage({
|
|
78
|
+
id: 'Settings.PageTitle',
|
|
79
|
+
defaultMessage: 'Settings - {name}'
|
|
80
|
+
}, {
|
|
81
|
+
name: 'Releases'
|
|
82
|
+
})
|
|
83
|
+
}),
|
|
84
|
+
/*#__PURE__*/ jsx(Page.Main, {
|
|
85
|
+
"aria-busy": isLoadingSettings,
|
|
86
|
+
tabIndex: -1,
|
|
87
|
+
children: /*#__PURE__*/ jsx(Form, {
|
|
88
|
+
method: "PUT",
|
|
89
|
+
initialValues: {
|
|
90
|
+
defaultTimezone: data?.data.defaultTimezone
|
|
91
|
+
},
|
|
92
|
+
onSubmit: handleSubmit,
|
|
93
|
+
validationSchema: SETTINGS_SCHEMA,
|
|
94
|
+
children: ({ modified, isSubmitting })=>{
|
|
95
|
+
return /*#__PURE__*/ jsxs(Fragment, {
|
|
96
|
+
children: [
|
|
97
|
+
/*#__PURE__*/ jsx(Layouts.Header, {
|
|
98
|
+
primaryAction: canUpdate ? /*#__PURE__*/ jsx(Button, {
|
|
99
|
+
disabled: !modified || isSubmittingForm,
|
|
100
|
+
loading: isSubmitting,
|
|
101
|
+
startIcon: /*#__PURE__*/ jsx(Check, {}),
|
|
102
|
+
type: "submit",
|
|
103
|
+
children: formatMessage({
|
|
104
|
+
id: 'global.save',
|
|
105
|
+
defaultMessage: 'Save'
|
|
106
|
+
})
|
|
107
|
+
}) : null,
|
|
108
|
+
title: formatMessage({
|
|
109
|
+
id: 'content-releases.pages.Settings.releases.title',
|
|
110
|
+
defaultMessage: 'Releases'
|
|
111
|
+
}),
|
|
112
|
+
subtitle: formatMessage({
|
|
113
|
+
id: 'content-releases.pages.Settings.releases.description',
|
|
114
|
+
defaultMessage: 'Create and manage content updates'
|
|
115
|
+
})
|
|
116
|
+
}),
|
|
117
|
+
/*#__PURE__*/ jsx(Layouts.Content, {
|
|
118
|
+
children: /*#__PURE__*/ jsxs(Flex, {
|
|
119
|
+
direction: "column",
|
|
120
|
+
background: "neutral0",
|
|
121
|
+
alignItems: "stretch",
|
|
122
|
+
padding: 6,
|
|
123
|
+
gap: 6,
|
|
124
|
+
shadow: "filterShadow",
|
|
125
|
+
hasRadius: true,
|
|
126
|
+
children: [
|
|
127
|
+
/*#__PURE__*/ jsx(Typography, {
|
|
128
|
+
variant: "delta",
|
|
129
|
+
tag: "h2",
|
|
130
|
+
children: formatMessage({
|
|
131
|
+
id: 'content-releases.pages.Settings.releases.preferences.title',
|
|
132
|
+
defaultMessage: 'Preferences'
|
|
133
|
+
})
|
|
134
|
+
}),
|
|
135
|
+
/*#__PURE__*/ jsx(Grid.Root, {
|
|
136
|
+
children: /*#__PURE__*/ jsx(Grid.Item, {
|
|
137
|
+
col: 6,
|
|
138
|
+
s: 12,
|
|
139
|
+
direction: "column",
|
|
140
|
+
alignItems: "stretch",
|
|
141
|
+
children: /*#__PURE__*/ jsx(TimezoneDropdown, {})
|
|
142
|
+
})
|
|
143
|
+
})
|
|
144
|
+
]
|
|
145
|
+
})
|
|
146
|
+
})
|
|
147
|
+
]
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
})
|
|
151
|
+
})
|
|
152
|
+
]
|
|
153
|
+
});
|
|
154
|
+
};
|
|
155
|
+
const TimezoneDropdown = ()=>{
|
|
156
|
+
const permissions = useTypedSelector((state)=>state.admin_app.permissions['settings']?.['releases']);
|
|
157
|
+
const { allowedActions: { canUpdate } } = useRBAC(permissions);
|
|
158
|
+
const { formatMessage } = useIntl();
|
|
159
|
+
const { timezoneList } = getTimezones(new Date());
|
|
160
|
+
const field = useField('defaultTimezone');
|
|
161
|
+
return /*#__PURE__*/ jsxs(Field.Root, {
|
|
162
|
+
name: "defaultTimezone",
|
|
163
|
+
hint: formatMessage({
|
|
164
|
+
id: 'content-releases.pages.Settings.releases.timezone.hint',
|
|
165
|
+
defaultMessage: 'The timezone of every release can still be changed individually. '
|
|
166
|
+
}),
|
|
167
|
+
error: field.error,
|
|
168
|
+
children: [
|
|
169
|
+
/*#__PURE__*/ jsx(Field.Label, {
|
|
170
|
+
children: formatMessage({
|
|
171
|
+
id: 'content-releases.pages.Settings.releases.timezone.label',
|
|
172
|
+
defaultMessage: 'Default timezone'
|
|
173
|
+
})
|
|
174
|
+
}),
|
|
175
|
+
/*#__PURE__*/ jsx(Combobox, {
|
|
176
|
+
autocomplete: {
|
|
177
|
+
type: 'list',
|
|
178
|
+
filter: 'contains'
|
|
179
|
+
},
|
|
180
|
+
onChange: (value)=>field.onChange('defaultTimezone', value),
|
|
181
|
+
onTextValueChange: (value)=>field.onChange('defaultTimezone', value),
|
|
182
|
+
onClear: ()=>field.onChange('defaultTimezone', ''),
|
|
183
|
+
value: field.value,
|
|
184
|
+
disabled: !canUpdate,
|
|
185
|
+
children: timezoneList.map((timezone)=>/*#__PURE__*/ jsx(ComboboxOption, {
|
|
186
|
+
value: timezone.value,
|
|
187
|
+
children: timezone.value.replace(/&/, ' ')
|
|
188
|
+
}, timezone.value))
|
|
189
|
+
}),
|
|
190
|
+
/*#__PURE__*/ jsx(Field.Hint, {}),
|
|
191
|
+
/*#__PURE__*/ jsx(Field.Error, {})
|
|
192
|
+
]
|
|
193
|
+
});
|
|
194
|
+
};
|
|
195
|
+
/* -------------------------------------------------------------------------------------------------
|
|
196
|
+
* ProtectedSettingsPage
|
|
197
|
+
* -----------------------------------------------------------------------------------------------*/ const ProtectedReleasesSettingsPage = ()=>{
|
|
198
|
+
const permissions = useTypedSelector((state)=>state.admin_app.permissions['settings']?.['releases']?.read);
|
|
199
|
+
return /*#__PURE__*/ jsx(Page.Protect, {
|
|
200
|
+
permissions: permissions,
|
|
201
|
+
children: /*#__PURE__*/ jsx(ReleasesSettingsPage, {})
|
|
202
|
+
});
|
|
203
|
+
};
|
|
204
|
+
|
|
205
|
+
export { ProtectedReleasesSettingsPage };
|
|
206
|
+
//# sourceMappingURL=ReleasesSettingsPage-BzdLEfxa.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ReleasesSettingsPage-BzdLEfxa.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":["useTypedSelector","useSelector","ReleasesSettingsPage","formatMessage","useIntl","formatAPIError","useAPIErrorHandler","toggleNotification","useNotification","data","isLoading","isLoadingSettings","useGetReleaseSettingsQuery","updateReleaseSettings","isSubmittingForm","useUpdateReleaseSettingsMutation","permissions","state","admin_app","allowedActions","canUpdate","useRBAC","timezoneList","getTimezones","Date","handleSubmit","body","defaultTimezone","isBodyTimezoneValid","some","timezone","value","newBody","response","type","message","id","defaultMessage","isFetchError","error","_jsx","Page","Loading","_jsxs","Layouts","Root","Title","name","Main","aria-busy","tabIndex","Form","method","initialValues","onSubmit","validationSchema","SETTINGS_SCHEMA","modified","isSubmitting","_Fragment","Header","primaryAction","Button","disabled","loading","startIcon","Check","title","subtitle","Content","Flex","direction","background","alignItems","padding","gap","shadow","hasRadius","Typography","variant","tag","Grid","Item","col","s","TimezoneDropdown","field","useField","Field","hint","Label","Combobox","autocomplete","filter","onChange","onTextValueChange","onClear","map","ComboboxOption","replace","Hint","Error","ProtectedReleasesSettingsPage","read","Protect"],"mappings":"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"}
|
|
@@ -0,0 +1,208 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var jsxRuntime = require('react/jsx-runtime');
|
|
4
|
+
var strapiAdmin = require('@strapi/admin/strapi-admin');
|
|
5
|
+
var designSystem = require('@strapi/design-system');
|
|
6
|
+
var icons = require('@strapi/icons');
|
|
7
|
+
var reactIntl = require('react-intl');
|
|
8
|
+
var reactRedux = require('react-redux');
|
|
9
|
+
var index = require('./index-1nn-zHX-.js');
|
|
10
|
+
var schemas = require('./schemas-DS7NeFDN.js');
|
|
11
|
+
require('react');
|
|
12
|
+
require('formik');
|
|
13
|
+
require('@strapi/content-manager/strapi-admin');
|
|
14
|
+
require('@strapi/icons/symbols');
|
|
15
|
+
require('react-router-dom');
|
|
16
|
+
require('yup');
|
|
17
|
+
require('styled-components');
|
|
18
|
+
require('date-fns-tz');
|
|
19
|
+
|
|
20
|
+
const useTypedSelector = reactRedux.useSelector;
|
|
21
|
+
|
|
22
|
+
const ReleasesSettingsPage = ()=>{
|
|
23
|
+
const { formatMessage } = reactIntl.useIntl();
|
|
24
|
+
const { formatAPIError } = strapiAdmin.useAPIErrorHandler();
|
|
25
|
+
const { toggleNotification } = strapiAdmin.useNotification();
|
|
26
|
+
const { data, isLoading: isLoadingSettings } = index.useGetReleaseSettingsQuery();
|
|
27
|
+
const [updateReleaseSettings, { isLoading: isSubmittingForm }] = index.useUpdateReleaseSettingsMutation();
|
|
28
|
+
const permissions = useTypedSelector((state)=>state.admin_app.permissions['settings']?.['releases']);
|
|
29
|
+
const { allowedActions: { canUpdate } } = strapiAdmin.useRBAC(permissions);
|
|
30
|
+
const { timezoneList } = index.getTimezones(new Date());
|
|
31
|
+
const handleSubmit = async (body)=>{
|
|
32
|
+
const { defaultTimezone } = body;
|
|
33
|
+
const isBodyTimezoneValid = timezoneList.some((timezone)=>timezone.value === defaultTimezone);
|
|
34
|
+
const newBody = !defaultTimezone || !isBodyTimezoneValid ? {
|
|
35
|
+
defaultTimezone: null
|
|
36
|
+
} : {
|
|
37
|
+
...body
|
|
38
|
+
};
|
|
39
|
+
try {
|
|
40
|
+
const response = await updateReleaseSettings(newBody);
|
|
41
|
+
if ('data' in response) {
|
|
42
|
+
toggleNotification({
|
|
43
|
+
type: 'success',
|
|
44
|
+
message: formatMessage({
|
|
45
|
+
id: 'content-releases.pages.Settings.releases.setting.default-timezone-notification-success',
|
|
46
|
+
defaultMessage: 'Default timezone updated.'
|
|
47
|
+
})
|
|
48
|
+
});
|
|
49
|
+
} else if (strapiAdmin.isFetchError(response.error)) {
|
|
50
|
+
toggleNotification({
|
|
51
|
+
type: 'danger',
|
|
52
|
+
message: formatAPIError(response.error)
|
|
53
|
+
});
|
|
54
|
+
} else {
|
|
55
|
+
toggleNotification({
|
|
56
|
+
type: 'danger',
|
|
57
|
+
message: formatMessage({
|
|
58
|
+
id: 'notification.error',
|
|
59
|
+
defaultMessage: 'An error occurred'
|
|
60
|
+
})
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
} catch (error) {
|
|
64
|
+
toggleNotification({
|
|
65
|
+
type: 'danger',
|
|
66
|
+
message: formatMessage({
|
|
67
|
+
id: 'notification.error',
|
|
68
|
+
defaultMessage: 'An error occurred'
|
|
69
|
+
})
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
if (isLoadingSettings) {
|
|
74
|
+
return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Page.Loading, {});
|
|
75
|
+
}
|
|
76
|
+
return /*#__PURE__*/ jsxRuntime.jsxs(strapiAdmin.Layouts.Root, {
|
|
77
|
+
children: [
|
|
78
|
+
/*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Page.Title, {
|
|
79
|
+
children: formatMessage({
|
|
80
|
+
id: 'Settings.PageTitle',
|
|
81
|
+
defaultMessage: 'Settings - {name}'
|
|
82
|
+
}, {
|
|
83
|
+
name: 'Releases'
|
|
84
|
+
})
|
|
85
|
+
}),
|
|
86
|
+
/*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Page.Main, {
|
|
87
|
+
"aria-busy": isLoadingSettings,
|
|
88
|
+
tabIndex: -1,
|
|
89
|
+
children: /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Form, {
|
|
90
|
+
method: "PUT",
|
|
91
|
+
initialValues: {
|
|
92
|
+
defaultTimezone: data?.data.defaultTimezone
|
|
93
|
+
},
|
|
94
|
+
onSubmit: handleSubmit,
|
|
95
|
+
validationSchema: schemas.SETTINGS_SCHEMA,
|
|
96
|
+
children: ({ modified, isSubmitting })=>{
|
|
97
|
+
return /*#__PURE__*/ jsxRuntime.jsxs(jsxRuntime.Fragment, {
|
|
98
|
+
children: [
|
|
99
|
+
/*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Layouts.Header, {
|
|
100
|
+
primaryAction: canUpdate ? /*#__PURE__*/ jsxRuntime.jsx(designSystem.Button, {
|
|
101
|
+
disabled: !modified || isSubmittingForm,
|
|
102
|
+
loading: isSubmitting,
|
|
103
|
+
startIcon: /*#__PURE__*/ jsxRuntime.jsx(icons.Check, {}),
|
|
104
|
+
type: "submit",
|
|
105
|
+
children: formatMessage({
|
|
106
|
+
id: 'global.save',
|
|
107
|
+
defaultMessage: 'Save'
|
|
108
|
+
})
|
|
109
|
+
}) : null,
|
|
110
|
+
title: formatMessage({
|
|
111
|
+
id: 'content-releases.pages.Settings.releases.title',
|
|
112
|
+
defaultMessage: 'Releases'
|
|
113
|
+
}),
|
|
114
|
+
subtitle: formatMessage({
|
|
115
|
+
id: 'content-releases.pages.Settings.releases.description',
|
|
116
|
+
defaultMessage: 'Create and manage content updates'
|
|
117
|
+
})
|
|
118
|
+
}),
|
|
119
|
+
/*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Layouts.Content, {
|
|
120
|
+
children: /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Flex, {
|
|
121
|
+
direction: "column",
|
|
122
|
+
background: "neutral0",
|
|
123
|
+
alignItems: "stretch",
|
|
124
|
+
padding: 6,
|
|
125
|
+
gap: 6,
|
|
126
|
+
shadow: "filterShadow",
|
|
127
|
+
hasRadius: true,
|
|
128
|
+
children: [
|
|
129
|
+
/*#__PURE__*/ jsxRuntime.jsx(designSystem.Typography, {
|
|
130
|
+
variant: "delta",
|
|
131
|
+
tag: "h2",
|
|
132
|
+
children: formatMessage({
|
|
133
|
+
id: 'content-releases.pages.Settings.releases.preferences.title',
|
|
134
|
+
defaultMessage: 'Preferences'
|
|
135
|
+
})
|
|
136
|
+
}),
|
|
137
|
+
/*#__PURE__*/ jsxRuntime.jsx(designSystem.Grid.Root, {
|
|
138
|
+
children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Grid.Item, {
|
|
139
|
+
col: 6,
|
|
140
|
+
s: 12,
|
|
141
|
+
direction: "column",
|
|
142
|
+
alignItems: "stretch",
|
|
143
|
+
children: /*#__PURE__*/ jsxRuntime.jsx(TimezoneDropdown, {})
|
|
144
|
+
})
|
|
145
|
+
})
|
|
146
|
+
]
|
|
147
|
+
})
|
|
148
|
+
})
|
|
149
|
+
]
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
})
|
|
153
|
+
})
|
|
154
|
+
]
|
|
155
|
+
});
|
|
156
|
+
};
|
|
157
|
+
const TimezoneDropdown = ()=>{
|
|
158
|
+
const permissions = useTypedSelector((state)=>state.admin_app.permissions['settings']?.['releases']);
|
|
159
|
+
const { allowedActions: { canUpdate } } = strapiAdmin.useRBAC(permissions);
|
|
160
|
+
const { formatMessage } = reactIntl.useIntl();
|
|
161
|
+
const { timezoneList } = index.getTimezones(new Date());
|
|
162
|
+
const field = strapiAdmin.useField('defaultTimezone');
|
|
163
|
+
return /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Field.Root, {
|
|
164
|
+
name: "defaultTimezone",
|
|
165
|
+
hint: formatMessage({
|
|
166
|
+
id: 'content-releases.pages.Settings.releases.timezone.hint',
|
|
167
|
+
defaultMessage: 'The timezone of every release can still be changed individually. '
|
|
168
|
+
}),
|
|
169
|
+
error: field.error,
|
|
170
|
+
children: [
|
|
171
|
+
/*#__PURE__*/ jsxRuntime.jsx(designSystem.Field.Label, {
|
|
172
|
+
children: formatMessage({
|
|
173
|
+
id: 'content-releases.pages.Settings.releases.timezone.label',
|
|
174
|
+
defaultMessage: 'Default timezone'
|
|
175
|
+
})
|
|
176
|
+
}),
|
|
177
|
+
/*#__PURE__*/ jsxRuntime.jsx(designSystem.Combobox, {
|
|
178
|
+
autocomplete: {
|
|
179
|
+
type: 'list',
|
|
180
|
+
filter: 'contains'
|
|
181
|
+
},
|
|
182
|
+
onChange: (value)=>field.onChange('defaultTimezone', value),
|
|
183
|
+
onTextValueChange: (value)=>field.onChange('defaultTimezone', value),
|
|
184
|
+
onClear: ()=>field.onChange('defaultTimezone', ''),
|
|
185
|
+
value: field.value,
|
|
186
|
+
disabled: !canUpdate,
|
|
187
|
+
children: timezoneList.map((timezone)=>/*#__PURE__*/ jsxRuntime.jsx(designSystem.ComboboxOption, {
|
|
188
|
+
value: timezone.value,
|
|
189
|
+
children: timezone.value.replace(/&/, ' ')
|
|
190
|
+
}, timezone.value))
|
|
191
|
+
}),
|
|
192
|
+
/*#__PURE__*/ jsxRuntime.jsx(designSystem.Field.Hint, {}),
|
|
193
|
+
/*#__PURE__*/ jsxRuntime.jsx(designSystem.Field.Error, {})
|
|
194
|
+
]
|
|
195
|
+
});
|
|
196
|
+
};
|
|
197
|
+
/* -------------------------------------------------------------------------------------------------
|
|
198
|
+
* ProtectedSettingsPage
|
|
199
|
+
* -----------------------------------------------------------------------------------------------*/ const ProtectedReleasesSettingsPage = ()=>{
|
|
200
|
+
const permissions = useTypedSelector((state)=>state.admin_app.permissions['settings']?.['releases']?.read);
|
|
201
|
+
return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Page.Protect, {
|
|
202
|
+
permissions: permissions,
|
|
203
|
+
children: /*#__PURE__*/ jsxRuntime.jsx(ReleasesSettingsPage, {})
|
|
204
|
+
});
|
|
205
|
+
};
|
|
206
|
+
|
|
207
|
+
exports.ProtectedReleasesSettingsPage = ProtectedReleasesSettingsPage;
|
|
208
|
+
//# sourceMappingURL=ReleasesSettingsPage-DFVGppsl.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ReleasesSettingsPage-DFVGppsl.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":["useTypedSelector","useSelector","ReleasesSettingsPage","formatMessage","useIntl","formatAPIError","useAPIErrorHandler","toggleNotification","useNotification","data","isLoading","isLoadingSettings","useGetReleaseSettingsQuery","updateReleaseSettings","isSubmittingForm","useUpdateReleaseSettingsMutation","permissions","state","admin_app","allowedActions","canUpdate","useRBAC","timezoneList","getTimezones","Date","handleSubmit","body","defaultTimezone","isBodyTimezoneValid","some","timezone","value","newBody","response","type","message","id","defaultMessage","isFetchError","error","_jsx","Page","Loading","_jsxs","Layouts","Root","Title","name","Main","aria-busy","tabIndex","Form","method","initialValues","onSubmit","validationSchema","SETTINGS_SCHEMA","modified","isSubmitting","_Fragment","Header","primaryAction","Button","disabled","loading","startIcon","Check","title","subtitle","Content","Flex","direction","background","alignItems","padding","gap","shadow","hasRadius","Typography","variant","tag","Grid","Item","col","s","TimezoneDropdown","field","useField","Field","hint","Label","Combobox","autocomplete","filter","onChange","onTextValueChange","onClear","map","ComboboxOption","replace","Hint","Error","ProtectedReleasesSettingsPage","read","Protect"],"mappings":";;;;;;;;;;;;;;;;;;;AAQA,MAAMA,gBAAoDC,GAAAA,sBAAAA;;ACqB1D,MAAMC,oBAAuB,GAAA,IAAA;IAC3B,MAAM,EAAEC,aAAa,EAAE,GAAGC,iBAAAA,EAAAA;IAC1B,MAAM,EAAEC,cAAc,EAAE,GAAGC,8BAAAA,EAAAA;IAC3B,MAAM,EAAEC,kBAAkB,EAAE,GAAGC,2BAAAA,EAAAA;AAC/B,IAAA,MAAM,EAAEC,IAAI,EAAEC,SAAWC,EAAAA,iBAAiB,EAAE,GAAGC,gCAAAA,EAAAA;AAC/C,IAAA,MAAM,CAACC,qBAAuB,EAAA,EAAEH,WAAWI,gBAAgB,EAAE,CAAC,GAC5DC,sCAAAA,EAAAA;AACF,IAAA,MAAMC,WAAchB,GAAAA,gBAAAA,CAClB,CAACiB,KAAAA,GAAUA,KAAMC,CAAAA,SAAS,CAACF,WAAW,CAAC,UAAA,CAAW,GAAG,UAAW,CAAA,CAAA;AAElE,IAAA,MAAM,EACJG,cAAgB,EAAA,EAAEC,SAAS,EAAE,EAC9B,GAAGC,mBAAQL,CAAAA,WAAAA,CAAAA;AAEZ,IAAA,MAAM,EAAEM,YAAY,EAAE,GAAGC,mBAAa,IAAIC,IAAAA,EAAAA,CAAAA;AAE1C,IAAA,MAAMC,eAAe,OAAOC,IAAAA,GAAAA;QAC1B,MAAM,EAAEC,eAAe,EAAE,GAAGD,IAAAA;QAC5B,MAAME,mBAAAA,GAAsBN,aAAaO,IAAI,CAAC,CAACC,QAAaA,GAAAA,QAAAA,CAASC,KAAK,KAAKJ,eAAAA,CAAAA;AAC/E,QAAA,MAAMK,OACJ,GAAA,CAACL,eAAmB,IAAA,CAACC,mBAAsB,GAAA;YAAED,eAAiB,EAAA;SAAS,GAAA;AAAE,YAAA,GAAGD;AAAK,SAAA;QACnF,IAAI;YACF,MAAMO,QAAAA,GAAW,MAAMpB,qBAAsBmB,CAAAA,OAAAA,CAAAA;AAE7C,YAAA,IAAI,UAAUC,QAAU,EAAA;gBACtB1B,kBAAmB,CAAA;oBACjB2B,IAAM,EAAA,SAAA;AACNC,oBAAAA,OAAAA,EAAShC,aAAc,CAAA;wBACrBiC,EAAI,EAAA,wFAAA;wBACJC,cAAgB,EAAA;AAClB,qBAAA;AACF,iBAAA,CAAA;AACF,aAAA,MAAO,IAAIC,wBAAAA,CAAaL,QAASM,CAAAA,KAAK,CAAG,EAAA;gBACvChC,kBAAmB,CAAA;oBACjB2B,IAAM,EAAA,QAAA;oBACNC,OAAS9B,EAAAA,cAAAA,CAAe4B,SAASM,KAAK;AACxC,iBAAA,CAAA;aACK,MAAA;gBACLhC,kBAAmB,CAAA;oBACjB2B,IAAM,EAAA,QAAA;AACNC,oBAAAA,OAAAA,EAAShC,aAAc,CAAA;wBAAEiC,EAAI,EAAA,oBAAA;wBAAsBC,cAAgB,EAAA;AAAoB,qBAAA;AACzF,iBAAA,CAAA;AACF;AACF,SAAA,CAAE,OAAOE,KAAO,EAAA;YACdhC,kBAAmB,CAAA;gBACjB2B,IAAM,EAAA,QAAA;AACNC,gBAAAA,OAAAA,EAAShC,aAAc,CAAA;oBAAEiC,EAAI,EAAA,oBAAA;oBAAsBC,cAAgB,EAAA;AAAoB,iBAAA;AACzF,aAAA,CAAA;AACF;AACF,KAAA;AAEA,IAAA,IAAI1B,iBAAmB,EAAA;QACrB,qBAAO6B,cAAA,CAACC,iBAAKC,OAAO,EAAA,EAAA,CAAA;AACtB;IAEA,qBACEC,eAAA,CAACC,oBAAQC,IAAI,EAAA;;AACX,0BAAAL,cAAA,CAACC,iBAAKK,KAAK,EAAA;0BACR3C,aACC,CAAA;oBAAEiC,EAAI,EAAA,oBAAA;oBAAsBC,cAAgB,EAAA;iBAC5C,EAAA;oBACEU,IAAM,EAAA;AACR,iBAAA;;AAGJ,0BAAAP,cAAA,CAACC,iBAAKO,IAAI,EAAA;gBAACC,WAAWtC,EAAAA,iBAAAA;AAAmBuC,gBAAAA,QAAAA,EAAU,CAAC,CAAA;AAClD,gBAAA,QAAA,gBAAAV,cAACW,CAAAA,gBAAAA,EAAAA;oBACCC,MAAO,EAAA,KAAA;oBACPC,aAAe,EAAA;AACb1B,wBAAAA,eAAAA,EAAiBlB,MAAMA,IAAKkB,CAAAA;AAC9B,qBAAA;oBACA2B,QAAU7B,EAAAA,YAAAA;oBACV8B,gBAAkBC,EAAAA,uBAAAA;AAEjB,oBAAA,QAAA,EAAA,CAAC,EAAEC,QAAQ,EAAEC,YAAY,EAAgD,GAAA;wBACxE,qBACEf,eAAA,CAAAgB,mBAAA,EAAA;;AACE,8CAAAnB,cAAA,CAACI,oBAAQgB,MAAM,EAAA;AACbC,oCAAAA,aAAAA,EACEzC,0BACEoB,cAACsB,CAAAA,mBAAAA,EAAAA;AACCC,wCAAAA,QAAAA,EAAU,CAACN,QAAY3C,IAAAA,gBAAAA;wCACvBkD,OAASN,EAAAA,YAAAA;AACTO,wCAAAA,SAAAA,gBAAWzB,cAAC0B,CAAAA,WAAAA,EAAAA,EAAAA,CAAAA;wCACZhC,IAAK,EAAA,QAAA;kDAEJ/B,aAAc,CAAA;4CACbiC,EAAI,EAAA,aAAA;4CACJC,cAAgB,EAAA;AAClB,yCAAA;AAEA,qCAAA,CAAA,GAAA,IAAA;AAEN8B,oCAAAA,KAAAA,EAAOhE,aAAc,CAAA;wCACnBiC,EAAI,EAAA,gDAAA;wCACJC,cAAgB,EAAA;AAClB,qCAAA,CAAA;AACA+B,oCAAAA,QAAAA,EAAUjE,aAAc,CAAA;wCACtBiC,EAAI,EAAA,sDAAA;wCACJC,cAAgB,EAAA;AAClB,qCAAA;;AAEF,8CAAAG,cAAA,CAACI,oBAAQyB,OAAO,EAAA;AACd,oCAAA,QAAA,gBAAA1B,eAAC2B,CAAAA,iBAAAA,EAAAA;wCACCC,SAAU,EAAA,QAAA;wCACVC,UAAW,EAAA,UAAA;wCACXC,UAAW,EAAA,SAAA;wCACXC,OAAS,EAAA,CAAA;wCACTC,GAAK,EAAA,CAAA;wCACLC,MAAO,EAAA,cAAA;wCACPC,SAAS,EAAA,IAAA;;0DAETrC,cAACsC,CAAAA,uBAAAA,EAAAA;gDAAWC,OAAQ,EAAA,OAAA;gDAAQC,GAAI,EAAA,IAAA;0DAC7B7E,aAAc,CAAA;oDACbiC,EAAI,EAAA,4DAAA;oDACJC,cAAgB,EAAA;AAClB,iDAAA;;AAEF,0DAAAG,cAAA,CAACyC,kBAAKpC,IAAI,EAAA;wEACRL,cAAA,CAACyC,kBAAKC,IAAI,EAAA;oDAACC,GAAK,EAAA,CAAA;oDAAGC,CAAG,EAAA,EAAA;oDAAIb,SAAU,EAAA,QAAA;oDAASE,UAAW,EAAA,SAAA;AACtD,oDAAA,QAAA,gBAAAjC,cAAC6C,CAAAA,gBAAAA,EAAAA,EAAAA;;;;;;;;AAOf;;;;;AAKV,CAAA;AAEA,MAAMA,gBAAmB,GAAA,IAAA;AACvB,IAAA,MAAMrE,WAAchB,GAAAA,gBAAAA,CAClB,CAACiB,KAAAA,GAAUA,KAAMC,CAAAA,SAAS,CAACF,WAAW,CAAC,UAAA,CAAW,GAAG,UAAW,CAAA,CAAA;AAElE,IAAA,MAAM,EACJG,cAAgB,EAAA,EAAEC,SAAS,EAAE,EAC9B,GAAGC,mBAAQL,CAAAA,WAAAA,CAAAA;IACZ,MAAM,EAAEb,aAAa,EAAE,GAAGC,iBAAAA,EAAAA;AAC1B,IAAA,MAAM,EAAEkB,YAAY,EAAE,GAAGC,mBAAa,IAAIC,IAAAA,EAAAA,CAAAA;AAC1C,IAAA,MAAM8D,QAAQC,oBAAS,CAAA,iBAAA,CAAA;IACvB,qBACE5C,eAAA,CAAC6C,mBAAM3C,IAAI,EAAA;QACTE,IAAK,EAAA,iBAAA;AACL0C,QAAAA,IAAAA,EAAMtF,aAAc,CAAA;YAClBiC,EAAI,EAAA,wDAAA;YACJC,cAAgB,EAAA;AAClB,SAAA,CAAA;AACAE,QAAAA,KAAAA,EAAO+C,MAAM/C,KAAK;;AAElB,0BAAAC,cAAA,CAACgD,mBAAME,KAAK,EAAA;0BACTvF,aAAc,CAAA;oBACbiC,EAAI,EAAA,yDAAA;oBACJC,cAAgB,EAAA;AAClB,iBAAA;;0BAEFG,cAACmD,CAAAA,qBAAAA,EAAAA;gBACCC,YAAc,EAAA;oBAAE1D,IAAM,EAAA,MAAA;oBAAQ2D,MAAQ,EAAA;AAAW,iBAAA;AACjDC,gBAAAA,QAAAA,EAAU,CAAC/D,KAAAA,GAAUuD,KAAMQ,CAAAA,QAAQ,CAAC,iBAAmB/D,EAAAA,KAAAA,CAAAA;AACvDgE,gBAAAA,iBAAAA,EAAmB,CAAChE,KAAAA,GAAUuD,KAAMQ,CAAAA,QAAQ,CAAC,iBAAmB/D,EAAAA,KAAAA,CAAAA;AAChEiE,gBAAAA,OAAAA,EAAS,IAAMV,KAAAA,CAAMQ,QAAQ,CAAC,iBAAmB,EAAA,EAAA,CAAA;AACjD/D,gBAAAA,KAAAA,EAAOuD,MAAMvD,KAAK;AAClBgC,gBAAAA,QAAAA,EAAU,CAAC3C,SAAAA;AAEVE,gBAAAA,QAAAA,EAAAA,YAAAA,CAAa2E,GAAG,CAAC,CAACnE,QAAAA,iBACjBU,cAAC0D,CAAAA,2BAAAA,EAAAA;AAAoCnE,wBAAAA,KAAAA,EAAOD,SAASC,KAAK;AACvDD,wBAAAA,QAAAA,EAAAA,QAAAA,CAASC,KAAK,CAACoE,OAAO,CAAC,GAAK,EAAA,GAAA;AADVrE,qBAAAA,EAAAA,QAAAA,CAASC,KAAK,CAAA;;AAKvC,0BAAAS,cAAA,CAACgD,mBAAMY,IAAI,EAAA,EAAA,CAAA;AACX,0BAAA5D,cAAA,CAACgD,mBAAMa,KAAK,EAAA,EAAA;;;AAGlB,CAAA;AAEA;;2GAIaC,6BAAgC,GAAA,IAAA;AAC3C,IAAA,MAAMtF,WAAchB,GAAAA,gBAAAA,CAClB,CAACiB,KAAAA,GAAUA,KAAMC,CAAAA,SAAS,CAACF,WAAW,CAAC,UAAA,CAAW,GAAG,WAAW,EAAEuF,IAAAA,CAAAA;IAGpE,qBACE/D,cAAA,CAACC,iBAAK+D,OAAO,EAAA;QAACxF,WAAaA,EAAAA,WAAAA;AACzB,QAAA,QAAA,gBAAAwB,cAACtC,CAAAA,oBAAAA,EAAAA,EAAAA;;AAGP;;;;"}
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
var en = {
|
|
2
|
+
"content-manager-edit-view.add-to-release.select-label": "Select a release",
|
|
3
|
+
"content-manager-edit-view.add-to-release.select-placeholder": "Select",
|
|
4
|
+
"content-manager-edit-view.add-to-release.action-type-label": "What do you want to do with this entry?",
|
|
5
|
+
"content-manager-edit-view.add-to-release.cancel-button": "Cancel",
|
|
6
|
+
"content-manager-edit-view.add-to-release.continue-button": "Continue",
|
|
7
|
+
"content-manager-edit-view.add-to-release": "Add to release",
|
|
8
|
+
"content-manager-edit-view.add-to-release.notification.success": "Entry added to release",
|
|
9
|
+
"content-manager-edit-view.add-to-release.no-releases-message": "No available releases. Open the list of releases and create a new one from there.",
|
|
10
|
+
"content-manager-edit-view.add-to-release.redirect-button": "Open the list of releases",
|
|
11
|
+
"content-manager-edit-view.list-releases.title": "{isPublish, select, true {Will be published in} other {Will be unpublished in}}",
|
|
12
|
+
"content-manager-edit-view.remove-from-release": "Remove from release",
|
|
13
|
+
"content-manager-edit-view.scheduled.date": "{date} at {time} ({offset})",
|
|
14
|
+
"content-manager-edit-view.edit-release": "Edit release",
|
|
15
|
+
"content-releases.content-manager-edit-view.edit-entry": "Edit entry",
|
|
16
|
+
"content-manager-edit-view.remove-from-release.notification.success": "Entry removed from release",
|
|
17
|
+
"content-manager-edit-view.release-action-menu": "Release action options",
|
|
18
|
+
"content-manager.list-view.releases.header": "To be released in",
|
|
19
|
+
"content-manager-list-view.add-to-release": "Add to release",
|
|
20
|
+
"content-manager-list-view.add-to-release.cancel-button": "Cancel",
|
|
21
|
+
"content-manager-list-view.add-to-release.continue-button": "Continue",
|
|
22
|
+
"content-manager-list-view.add-to-release.select-label": "Select a release",
|
|
23
|
+
"content-manager-list-view.add-to-release.select-placeholder": "Select",
|
|
24
|
+
"content-manager-list-view.add-to-release.action-type-label": "What do you want to do with these entries?",
|
|
25
|
+
"content-manager-list-view.add-to-release.notification.success.title": "Successfully added to release.",
|
|
26
|
+
"content-manager-list-view.add-to-release.notification.success.message": "{entriesAlreadyInRelease} out of {totalEntries} entries were already in the release.",
|
|
27
|
+
"content-manager.notification.entry-error": "Failed to get entry data",
|
|
28
|
+
"content-manager.list-view.releases-number": "{number} {number, plural, one {release} other {releases}}",
|
|
29
|
+
"plugin.name": "Releases",
|
|
30
|
+
"pages.Releases.title": "Releases",
|
|
31
|
+
"pages.Releases.header-subtitle": "Create and manage content updates",
|
|
32
|
+
"pages.Releases.max-limit-reached.title": "You have reached the {number} pending {number, plural, one {release} other {releases}} limit.",
|
|
33
|
+
"pages.Releases.max-limit-reached.message": "Upgrade to manage an unlimited number of releases.",
|
|
34
|
+
"pages.Releases.max-limit-reached.action": "Explore plans",
|
|
35
|
+
"pages.PurchaseRelease.subTitle": "Manage content updates and releases.",
|
|
36
|
+
"pages.PurchaseRelease.not-available": "Releases is only available as part of a paid plan. Upgrade to create and manage releases.",
|
|
37
|
+
"header.actions.add-release": "New Release",
|
|
38
|
+
"header.actions.refresh": "Refresh",
|
|
39
|
+
"header.actions.publish": "Publish",
|
|
40
|
+
"header.actions.open-release-actions": "Release edit and delete menu",
|
|
41
|
+
"header.actions.edit": "Edit",
|
|
42
|
+
"header.actions.delete": "Delete",
|
|
43
|
+
"header.actions.created": "Created",
|
|
44
|
+
"header.actions.created.description": "{hasCreatedByUser, select, true { by {createdBy}} other { by deleted user}}",
|
|
45
|
+
"modal.release-created-notification-success": "Release created",
|
|
46
|
+
"modal.release-updated-notification-success": "Release updated",
|
|
47
|
+
"modal.title": "{isCreatingRelease, select, true {New release} other {Edit release}}",
|
|
48
|
+
"modal.form.input.label.release-name": "Name",
|
|
49
|
+
"modal.form.input.label.schedule-release": "Schedule release",
|
|
50
|
+
"modal.form.input.label.date": "Date",
|
|
51
|
+
"modal.form.input.label.time": "Time",
|
|
52
|
+
"modal.form.input.label.timezone": "Timezone",
|
|
53
|
+
"modal.form.input.clearLabel": "Clear",
|
|
54
|
+
"modal.form.button.submit": "{isCreatingRelease, select, true {Continue} other {Save}}",
|
|
55
|
+
"modal.form.time.has-passed": "Selected time has already passed.",
|
|
56
|
+
"pages.Details.header-subtitle": "{number, plural, =0 {No entries} one {# entry} other {# entries}}",
|
|
57
|
+
"pages.Releases.tab-group.label": "Releases list",
|
|
58
|
+
"pages.Releases.tab.pending": "Pending ({count})",
|
|
59
|
+
"pages.Releases.tab.done": "Done",
|
|
60
|
+
"page.Releases.tab.emptyEntries": "No releases",
|
|
61
|
+
"pages.Details.tab.emptyEntries": "This release is empty. Open the Content Manager, select an entry and add it to the release.",
|
|
62
|
+
"page.ReleaseDetails.table.header.label.name": "name",
|
|
63
|
+
"page.ReleaseDetails.table.header.label.locale": "locale",
|
|
64
|
+
"page.ReleaseDetails.table.header.label.content-type": "content-type",
|
|
65
|
+
"page.ReleaseDetails.table.header.label.action": "action",
|
|
66
|
+
"content-releases.page.ReleaseDetails.table.header.label.status": "status",
|
|
67
|
+
"page.ReleaseDetails.table.action-published": "This entry was <b>{isPublish, select, true {published} other {unpublished}}</b>.",
|
|
68
|
+
"pages.ReleaseDetails.publish-notification-success": "Release was published successfully.",
|
|
69
|
+
"dialog.confirmation-message": "Are you sure you want to delete this release?",
|
|
70
|
+
"page.Details.button.openContentManager": "Open the Content Manager",
|
|
71
|
+
"pages.Releases.notification.error.title": "Your request could not be processed.",
|
|
72
|
+
"pages.Releases.notification.error.message": "Please try again or open another release.",
|
|
73
|
+
"pages.Releases.not-scheduled": "Not scheduled",
|
|
74
|
+
"pages.ReleaseDetails.groupBy.label": "Group by {groupBy}",
|
|
75
|
+
"pages.ReleaseDetails.groupBy.aria-label": "Group by",
|
|
76
|
+
"pages.ReleaseDetails.entry-validation.already-published": "Already published",
|
|
77
|
+
"pages.ReleaseDetails.entry-validation.ready-to-publish": "Ready to publish",
|
|
78
|
+
"pages.ReleaseDetails.entry-validation.modified": "Ready to publish changes",
|
|
79
|
+
"pages.ReleaseDetails.entry-validation.already-unpublished": "Already unpublished",
|
|
80
|
+
"pages.ReleaseDetails.entry-validation.ready-to-unpublish": "Ready to unpublish",
|
|
81
|
+
"pages.ReleaseDetails.entry-validation.not-ready": "Not ready to publish",
|
|
82
|
+
"pages.ReleaseDetails.groupBy.option.content-type": "Content-Types",
|
|
83
|
+
"pages.ReleaseDetails.groupBy.option.locales": "Locales",
|
|
84
|
+
"pages.ReleaseDetails.groupBy.option.actions": "Actions",
|
|
85
|
+
"pages.ReleaseDetails.header-subtitle.scheduled": "Scheduled for {date} at {time} ({offset})",
|
|
86
|
+
"pages.ReleaseDetails.entry-validation.fields": "Fields",
|
|
87
|
+
"pages.Settings.releases.title": "Releases",
|
|
88
|
+
"pages.Settings.releases.description": "Create and manage content updates",
|
|
89
|
+
"pages.Settings.releases.timezone.label": "Default timezone",
|
|
90
|
+
"pages.Settings.releases.setting.default-timezone-notification-success": "Default timezone updated.",
|
|
91
|
+
"pages.ReleaseDetails.entry-validation.fields.error": "{errors} errors on fields.",
|
|
92
|
+
"pages.ReleaseDetails.entry-validation.fields.success": "All fields are filled correctly.",
|
|
93
|
+
"pages.ReleaseDetails.entry-validation.fields.see-errors": "See errors",
|
|
94
|
+
"pages.ReleaseDetails.entry-validation.review-stage.not-enabled": "This entry is not associated to any workflow.",
|
|
95
|
+
"pages.ReleaseDetails.entry-validation.review-stage.not-ready": "This entry is not at the required stage for publishing. ({stageName})",
|
|
96
|
+
"pages.ReleaseDetails.entry-validation.review-stage.ready": "This entry is at the required stage for publishing. ({stageName})",
|
|
97
|
+
"pages.ReleaseDetails.entry-validation.review-stage.stage-not-required": "No required stage for publication."
|
|
98
|
+
};
|
|
99
|
+
|
|
100
|
+
export { en as default };
|
|
101
|
+
//# sourceMappingURL=en-B2EeDoOz.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"en-
|
|
1
|
+
{"version":3,"file":"en-B2EeDoOz.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|