@strapi/plugin-users-permissions 5.0.0-rc.1 → 5.0.0-rc.11
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/admin/src/components/FormModal/index.jsx +7 -1
- package/admin/src/components/Permissions/PermissionRow/SubCategory.jsx +1 -1
- package/admin/src/components/Policies/index.jsx +2 -0
- package/admin/src/components/UsersPermissions/index.jsx +9 -1
- package/admin/src/pages/AdvancedSettings/index.jsx +6 -1
- package/admin/src/pages/EmailTemplates/components/EmailForm.jsx +6 -1
- package/admin/src/pages/EmailTemplates/components/EmailTable.jsx +2 -2
- package/admin/src/pages/Providers/index.jsx +1 -1
- package/admin/src/pages/Roles/pages/CreatePage.jsx +2 -2
- package/admin/src/pages/Roles/pages/EditPage.jsx +2 -2
- package/admin/src/pages/Roles/pages/ListPage/components/TableBody.jsx +1 -1
- package/dist/_chunks/{index-DWXD_v0p.js → index-C63Uuxtf.js} +16 -7
- package/dist/_chunks/index-C63Uuxtf.js.map +1 -0
- package/dist/_chunks/{index-CKip12uF.mjs → index-CMwq-8wx.mjs} +10 -10
- package/dist/_chunks/{index-CKip12uF.mjs.map → index-CMwq-8wx.mjs.map} +1 -1
- package/dist/_chunks/{index-BM3Y3D1I.mjs → index-CWLVetj5.mjs} +35 -21
- package/dist/_chunks/index-CWLVetj5.mjs.map +1 -0
- package/dist/_chunks/{index-Cz7MvAfK.mjs → index-CmaIewQS.mjs} +15 -6
- package/dist/_chunks/index-CmaIewQS.mjs.map +1 -0
- package/dist/_chunks/{index-B-NW87wS.js → index-DVBNFt5t.js} +20 -11
- package/dist/_chunks/{index-B-NW87wS.js.map → index-DVBNFt5t.js.map} +1 -1
- package/dist/_chunks/{index-koxBwffB.js → index-DbFr_t5R.js} +35 -21
- package/dist/_chunks/index-DbFr_t5R.js.map +1 -0
- package/dist/_chunks/{index-DzkSvFbj.mjs → index-DtCT27Ac.mjs} +23 -13
- package/dist/_chunks/index-DtCT27Ac.mjs.map +1 -0
- package/dist/_chunks/{index-D96sR0jc.mjs → index-VzSi-Vm6.mjs} +20 -11
- package/dist/_chunks/{index-D96sR0jc.mjs.map → index-VzSi-Vm6.mjs.map} +1 -1
- package/dist/_chunks/{index-f6STHGSC-qR3QHvSP.js → index-ivyMOLZZ-B_CbEB2q.js} +5 -10
- package/dist/_chunks/{index-f6STHGSC-qR3QHvSP.js.map → index-ivyMOLZZ-B_CbEB2q.js.map} +1 -1
- package/dist/_chunks/{index-f6STHGSC-BHUgmsKx.mjs → index-ivyMOLZZ-CJ1KIk95.mjs} +5 -10
- package/dist/_chunks/{index-f6STHGSC-BHUgmsKx.mjs.map → index-ivyMOLZZ-CJ1KIk95.mjs.map} +1 -1
- package/dist/_chunks/{index-bWmIxmrB.js → index-n_X8Wl-9.js} +10 -10
- package/dist/_chunks/{index-bWmIxmrB.js.map → index-n_X8Wl-9.js.map} +1 -1
- package/dist/_chunks/{index-CepSm1g8.js → index-tMJFLsgx.js} +27 -17
- package/dist/_chunks/index-tMJFLsgx.js.map +1 -0
- package/dist/admin/index.js +1 -1
- package/dist/admin/index.mjs +1 -1
- package/package.json +6 -6
- package/server/bootstrap/users-permissions-actions.js +6 -0
- package/dist/_chunks/index-BM3Y3D1I.mjs.map +0 -1
- package/dist/_chunks/index-CepSm1g8.js.map +0 -1
- package/dist/_chunks/index-Cz7MvAfK.mjs.map +0 -1
- package/dist/_chunks/index-DWXD_v0p.js.map +0 -1
- package/dist/_chunks/index-DzkSvFbj.mjs.map +0 -1
- package/dist/_chunks/index-koxBwffB.js.map +0 -1
|
@@ -52,7 +52,13 @@ const FormModal = ({
|
|
|
52
52
|
{layout.form.map((row) => {
|
|
53
53
|
return row.map((input) => {
|
|
54
54
|
return (
|
|
55
|
-
<Grid.Item
|
|
55
|
+
<Grid.Item
|
|
56
|
+
key={input.name}
|
|
57
|
+
col={input.size}
|
|
58
|
+
xs={12}
|
|
59
|
+
direction="column"
|
|
60
|
+
alignItems="stretch"
|
|
61
|
+
>
|
|
56
62
|
<Input
|
|
57
63
|
{...input}
|
|
58
64
|
error={errors[input.name]}
|
|
@@ -78,7 +78,7 @@ const SubCategory = ({ subCategory }) => {
|
|
|
78
78
|
const name = `${action.name}.enabled`;
|
|
79
79
|
|
|
80
80
|
return (
|
|
81
|
-
<Grid.Item col={6} key={action.name}>
|
|
81
|
+
<Grid.Item col={6} key={action.name} direction="column" alignItems="stretch">
|
|
82
82
|
<CheckboxWrapper isActive={isActionSelected(action.name)} padding={2} hasRadius>
|
|
83
83
|
<Checkbox
|
|
84
84
|
checked={get(modifiedData, name, false)}
|
|
@@ -62,7 +62,15 @@ const UsersPermissions = forwardRef(({ permissions, routes }, ref) => {
|
|
|
62
62
|
return (
|
|
63
63
|
<UsersPermissionsProvider value={providerValue}>
|
|
64
64
|
<Grid.Root gap={0} shadow="filterShadow" hasRadius background="neutral0">
|
|
65
|
-
<Grid.Item
|
|
65
|
+
<Grid.Item
|
|
66
|
+
col={7}
|
|
67
|
+
paddingTop={6}
|
|
68
|
+
paddingBottom={6}
|
|
69
|
+
paddingLeft={7}
|
|
70
|
+
paddingRight={7}
|
|
71
|
+
direction="column"
|
|
72
|
+
alignItems="stretch"
|
|
73
|
+
>
|
|
66
74
|
<Flex direction="column" alignItems="stretch" gap={6}>
|
|
67
75
|
<Flex direction="column" alignItems="stretch" gap={2}>
|
|
68
76
|
<Typography variant="delta" tag="h2">
|
|
@@ -179,7 +179,12 @@ const AdvancedSettingsPage = () => {
|
|
|
179
179
|
},
|
|
180
180
|
...layout,
|
|
181
181
|
].map(({ size, ...field }) => (
|
|
182
|
-
<Grid.Item
|
|
182
|
+
<Grid.Item
|
|
183
|
+
key={field.name}
|
|
184
|
+
col={size}
|
|
185
|
+
direction="column"
|
|
186
|
+
alignItems="stretch"
|
|
187
|
+
>
|
|
183
188
|
<InputRenderer
|
|
184
189
|
{...field}
|
|
185
190
|
disabled={
|
|
@@ -102,7 +102,12 @@ const EmailForm = ({ template = {}, onToggle, open, onSubmit }) => {
|
|
|
102
102
|
type: 'text',
|
|
103
103
|
},
|
|
104
104
|
].map(({ size, ...field }) => (
|
|
105
|
-
<Grid.Item
|
|
105
|
+
<Grid.Item
|
|
106
|
+
key={field.name}
|
|
107
|
+
col={size}
|
|
108
|
+
direction="column"
|
|
109
|
+
alignItems="stretch"
|
|
110
|
+
>
|
|
106
111
|
<InputRenderer {...field} />
|
|
107
112
|
</Grid.Item>
|
|
108
113
|
))}
|
|
@@ -78,7 +78,7 @@ const EmailTable = ({ canUpdate, onEditClick }) => {
|
|
|
78
78
|
id: getTrad('Email.template.form.edit.label'),
|
|
79
79
|
defaultMessage: 'Edit a template',
|
|
80
80
|
})}
|
|
81
|
-
|
|
81
|
+
variant="ghost"
|
|
82
82
|
disabled={!canUpdate}
|
|
83
83
|
>
|
|
84
84
|
<Pencil />
|
|
@@ -111,7 +111,7 @@ const EmailTable = ({ canUpdate, onEditClick }) => {
|
|
|
111
111
|
id: getTrad('Email.template.form.edit.label'),
|
|
112
112
|
defaultMessage: 'Edit a template',
|
|
113
113
|
})}
|
|
114
|
-
|
|
114
|
+
variant="ghost"
|
|
115
115
|
disabled={!canUpdate}
|
|
116
116
|
>
|
|
117
117
|
<Pencil />
|
|
@@ -125,7 +125,7 @@ export const CreatePage = () => {
|
|
|
125
125
|
</Typography>
|
|
126
126
|
|
|
127
127
|
<Grid.Root gap={4}>
|
|
128
|
-
<Grid.Item col={6}>
|
|
128
|
+
<Grid.Item col={6} direction="column" alignItems="stretch">
|
|
129
129
|
<Field.Root
|
|
130
130
|
name="name"
|
|
131
131
|
error={
|
|
@@ -145,7 +145,7 @@ export const CreatePage = () => {
|
|
|
145
145
|
<Field.Error />
|
|
146
146
|
</Field.Root>
|
|
147
147
|
</Grid.Item>
|
|
148
|
-
<Grid.Item col={6}>
|
|
148
|
+
<Grid.Item col={6} direction="column" alignItems="stretch">
|
|
149
149
|
<Field.Root
|
|
150
150
|
name="description"
|
|
151
151
|
error={
|
|
@@ -143,7 +143,7 @@ export const EditPage = () => {
|
|
|
143
143
|
</Typography>
|
|
144
144
|
|
|
145
145
|
<Grid.Root gap={4}>
|
|
146
|
-
<Grid.Item col={6}>
|
|
146
|
+
<Grid.Item col={6} direction="column" alignItems="stretch">
|
|
147
147
|
<Field.Root
|
|
148
148
|
name="name"
|
|
149
149
|
error={
|
|
@@ -166,7 +166,7 @@ export const EditPage = () => {
|
|
|
166
166
|
<Field.Error />
|
|
167
167
|
</Field.Root>
|
|
168
168
|
</Grid.Item>
|
|
169
|
-
<Grid.Item col={6}>
|
|
169
|
+
<Grid.Item col={6} direction="column" alignItems="stretch">
|
|
170
170
|
<Field.Root
|
|
171
171
|
name="description"
|
|
172
172
|
error={
|
|
@@ -86,7 +86,7 @@ const TableBody = ({ sortedRoles, canDelete, canUpdate, setRoleToDelete, onDelet
|
|
|
86
86
|
{checkCanDeleteRole(role) && (
|
|
87
87
|
<IconButton
|
|
88
88
|
onClick={() => handleClickDelete(role.id.toString())}
|
|
89
|
-
|
|
89
|
+
variant="ghost"
|
|
90
90
|
label={formatMessage(
|
|
91
91
|
{ id: 'global.delete-target', defaultMessage: 'Delete {target}' },
|
|
92
92
|
{ target: `${role.name}` }
|
|
@@ -2,12 +2,12 @@
|
|
|
2
2
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
3
|
const jsxRuntime = require("react/jsx-runtime");
|
|
4
4
|
const React = require("react");
|
|
5
|
-
const
|
|
5
|
+
const indexIvyMOLZZ = require("./index-ivyMOLZZ-B_CbEB2q.js");
|
|
6
6
|
const designSystem = require("@strapi/design-system");
|
|
7
7
|
const admin = require("@strapi/strapi/admin");
|
|
8
8
|
const reactIntl = require("react-intl");
|
|
9
9
|
const reactQuery = require("react-query");
|
|
10
|
-
const index = require("./index-
|
|
10
|
+
const index = require("./index-n_X8Wl-9.js");
|
|
11
11
|
require("lodash/isEmpty");
|
|
12
12
|
const PropTypes = require("prop-types");
|
|
13
13
|
const yup = require("yup");
|
|
@@ -133,7 +133,16 @@ const EmailForm = ({ template = {}, onToggle, open, onSubmit }) => {
|
|
|
133
133
|
size: 12,
|
|
134
134
|
type: "text"
|
|
135
135
|
}
|
|
136
|
-
].map(({ size, ...field }) => /* @__PURE__ */ jsxRuntime.jsx(
|
|
136
|
+
].map(({ size, ...field }) => /* @__PURE__ */ jsxRuntime.jsx(
|
|
137
|
+
designSystem.Grid.Item,
|
|
138
|
+
{
|
|
139
|
+
col: size,
|
|
140
|
+
direction: "column",
|
|
141
|
+
alignItems: "stretch",
|
|
142
|
+
children: /* @__PURE__ */ jsxRuntime.jsx(admin.InputRenderer, { ...field })
|
|
143
|
+
},
|
|
144
|
+
field.name
|
|
145
|
+
)) }) }),
|
|
137
146
|
/* @__PURE__ */ jsxRuntime.jsxs(designSystem.Modal.Footer, { children: [
|
|
138
147
|
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Modal.Close, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Button, { variant: "tertiary", children: "Cancel" }) }),
|
|
139
148
|
/* @__PURE__ */ jsxRuntime.jsx(designSystem.Button, { loading: isSubmitting, type: "submit", children: "Finish" })
|
|
@@ -203,7 +212,7 @@ const EmailTable = ({ canUpdate, onEditClick }) => {
|
|
|
203
212
|
id: index.getTrad("Email.template.form.edit.label"),
|
|
204
213
|
defaultMessage: "Edit a template"
|
|
205
214
|
}),
|
|
206
|
-
|
|
215
|
+
variant: "ghost",
|
|
207
216
|
disabled: !canUpdate,
|
|
208
217
|
children: /* @__PURE__ */ jsxRuntime.jsx(icons.Pencil, {})
|
|
209
218
|
}
|
|
@@ -231,7 +240,7 @@ const EmailTable = ({ canUpdate, onEditClick }) => {
|
|
|
231
240
|
id: index.getTrad("Email.template.form.edit.label"),
|
|
232
241
|
defaultMessage: "Edit a template"
|
|
233
242
|
}),
|
|
234
|
-
|
|
243
|
+
variant: "ghost",
|
|
235
244
|
disabled: !canUpdate,
|
|
236
245
|
children: /* @__PURE__ */ jsxRuntime.jsx(icons.Pencil, {})
|
|
237
246
|
}
|
|
@@ -247,7 +256,7 @@ EmailTable.propTypes = {
|
|
|
247
256
|
const ProtectedEmailTemplatesPage = () => /* @__PURE__ */ jsxRuntime.jsx(admin.Page.Protect, { permissions: index.PERMISSIONS.readEmailTemplates, children: /* @__PURE__ */ jsxRuntime.jsx(EmailTemplatesPage, {}) });
|
|
248
257
|
const EmailTemplatesPage = () => {
|
|
249
258
|
const { formatMessage } = reactIntl.useIntl();
|
|
250
|
-
const { trackUsage } =
|
|
259
|
+
const { trackUsage } = indexIvyMOLZZ.useTracking();
|
|
251
260
|
const { notifyStatus } = designSystem.useNotifyAT();
|
|
252
261
|
const { toggleNotification } = admin.useNotification();
|
|
253
262
|
const queryClient = reactQuery.useQueryClient();
|
|
@@ -354,4 +363,4 @@ const EmailTemplatesPage = () => {
|
|
|
354
363
|
};
|
|
355
364
|
exports.EmailTemplatesPage = EmailTemplatesPage;
|
|
356
365
|
exports.ProtectedEmailTemplatesPage = ProtectedEmailTemplatesPage;
|
|
357
|
-
//# sourceMappingURL=index-
|
|
366
|
+
//# sourceMappingURL=index-C63Uuxtf.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index-C63Uuxtf.js","sources":["../../admin/src/pages/EmailTemplates/utils/schema.js","../../admin/src/pages/EmailTemplates/components/EmailForm.jsx","../../admin/src/pages/EmailTemplates/components/EmailTable.jsx","../../admin/src/pages/EmailTemplates/index.jsx"],"sourcesContent":["import { translatedErrors } from '@strapi/strapi/admin';\nimport * as yup from 'yup';\n\nconst schema = yup.object().shape({\n options: yup\n .object()\n .shape({\n from: yup\n .object()\n .shape({\n name: yup.string().required({\n id: translatedErrors.required.id,\n defaultMessage: 'This field is required',\n }),\n email: yup.string().email(translatedErrors.email).required({\n id: translatedErrors.required.id,\n defaultMessage: 'This field is required',\n }),\n })\n .required(),\n response_email: yup.string().email(translatedErrors.email),\n object: yup.string().required({\n id: translatedErrors.required.id,\n defaultMessage: 'This field is required',\n }),\n message: yup.string().required({\n id: translatedErrors.required.id,\n defaultMessage: 'This field is required',\n }),\n })\n .required(translatedErrors.required.id),\n});\n\nexport default schema;\n","import React from 'react';\n\nimport { Button, Grid, Modal, Breadcrumbs, Crumb, VisuallyHidden } from '@strapi/design-system';\nimport { Form, InputRenderer } from '@strapi/strapi/admin';\nimport PropTypes from 'prop-types';\nimport { useIntl } from 'react-intl';\n\nimport { getTrad } from '../../../utils';\nimport schema from '../utils/schema';\n\nconst EmailForm = ({ template = {}, onToggle, open, onSubmit }) => {\n const { formatMessage } = useIntl();\n\n return (\n <Modal.Root open={open} onOpenChange={onToggle}>\n <Modal.Content>\n <Modal.Header>\n <Breadcrumbs\n label={`${formatMessage({\n id: getTrad('PopUpForm.header.edit.email-templates'),\n defaultMessage: 'Edit email template',\n })}, ${\n template.display\n ? formatMessage({\n id: getTrad(template.display),\n defaultMessage: template.display,\n })\n : ''\n }`}\n >\n <Crumb>\n {formatMessage({\n id: getTrad('PopUpForm.header.edit.email-templates'),\n defaultMessage: 'Edit email template',\n })}\n </Crumb>\n <Crumb isCurrent>\n {template.display\n ? formatMessage({ id: getTrad(template.display), defaultMessage: template.display })\n : ''}\n </Crumb>\n </Breadcrumbs>\n <VisuallyHidden>\n <Modal.Title>\n {`${formatMessage({\n id: getTrad('PopUpForm.header.edit.email-templates'),\n defaultMessage: 'Edit email template',\n })}, ${template.display ? formatMessage({ id: getTrad(template.display), defaultMessage: template.display }) : ''}`}\n </Modal.Title>\n </VisuallyHidden>\n </Modal.Header>\n <Form onSubmit={onSubmit} initialValues={template} validationSchema={schema}>\n {({ isSubmitting }) => {\n return (\n <>\n <Modal.Body>\n <Grid.Root gap={5}>\n {[\n {\n label: formatMessage({\n id: getTrad('PopUpForm.Email.options.from.name.label'),\n defaultMessage: 'Shipper name',\n }),\n name: 'options.from.name',\n size: 6,\n type: 'string',\n },\n {\n label: formatMessage({\n id: getTrad('PopUpForm.Email.options.from.email.label'),\n defaultMessage: 'Shipper email',\n }),\n name: 'options.from.email',\n size: 6,\n type: 'string',\n },\n {\n label: formatMessage({\n id: getTrad('PopUpForm.Email.options.response_email.label'),\n defaultMessage: 'Response email',\n }),\n name: 'options.response_email',\n size: 6,\n type: 'string',\n },\n {\n label: formatMessage({\n id: getTrad('PopUpForm.Email.options.object.label'),\n defaultMessage: 'Subject',\n }),\n name: 'options.object',\n size: 6,\n type: 'string',\n },\n {\n label: formatMessage({\n id: getTrad('PopUpForm.Email.options.message.label'),\n defaultMessage: 'Message',\n }),\n name: 'options.message',\n size: 12,\n type: 'text',\n },\n ].map(({ size, ...field }) => (\n <Grid.Item\n key={field.name}\n col={size}\n direction=\"column\"\n alignItems=\"stretch\"\n >\n <InputRenderer {...field} />\n </Grid.Item>\n ))}\n </Grid.Root>\n </Modal.Body>\n <Modal.Footer>\n <Modal.Close>\n <Button variant=\"tertiary\">Cancel</Button>\n </Modal.Close>\n <Button loading={isSubmitting} type=\"submit\">\n Finish\n </Button>\n </Modal.Footer>\n </>\n );\n }}\n </Form>\n </Modal.Content>\n </Modal.Root>\n );\n};\n\nEmailForm.defaultProps = {\n template: {},\n};\n\nEmailForm.propTypes = {\n template: PropTypes.shape({\n display: PropTypes.string,\n icon: PropTypes.string,\n options: PropTypes.shape({\n from: PropTypes.shape({\n name: PropTypes.string,\n email: PropTypes.string,\n }),\n message: PropTypes.string,\n object: PropTypes.string,\n response_email: PropTypes.string,\n }),\n }),\n open: PropTypes.bool.isRequired,\n onSubmit: PropTypes.func.isRequired,\n onToggle: PropTypes.func.isRequired,\n};\n\nexport default EmailForm;\n","import React from 'react';\n\nimport {\n IconButton,\n Table,\n Tbody,\n Td,\n Th,\n Thead,\n Tr,\n Typography,\n VisuallyHidden,\n Box,\n} from '@strapi/design-system';\nimport { Check, Pencil, ArrowClockwise as Refresh } from '@strapi/icons';\nimport PropTypes from 'prop-types';\nimport { useIntl } from 'react-intl';\n\nimport { getTrad } from '../../../utils';\n\nconst EmailTable = ({ canUpdate, onEditClick }) => {\n const { formatMessage } = useIntl();\n\n return (\n <Table colCount={3} rowCount={3}>\n <Thead>\n <Tr>\n <Th width=\"1%\">\n <VisuallyHidden>\n {formatMessage({\n id: getTrad('Email.template.table.icon.label'),\n defaultMessage: 'icon',\n })}\n </VisuallyHidden>\n </Th>\n <Th>\n <Typography variant=\"sigma\" textColor=\"neutral600\">\n {formatMessage({\n id: getTrad('Email.template.table.name.label'),\n defaultMessage: 'name',\n })}\n </Typography>\n </Th>\n <Th width=\"1%\">\n <VisuallyHidden>\n {formatMessage({\n id: getTrad('Email.template.table.action.label'),\n defaultMessage: 'action',\n })}\n </VisuallyHidden>\n </Th>\n </Tr>\n </Thead>\n <Tbody>\n <Tr onClick={() => onEditClick('reset_password')}>\n <Td>\n <Box width=\"3.2rem\" height=\"3.2rem\" padding=\"0.8rem\">\n <Refresh\n aria-label={formatMessage({\n id: 'global.reset-password',\n defaultMessage: 'Reset password',\n })}\n />\n </Box>\n </Td>\n <Td>\n <Typography>\n {formatMessage({\n id: 'global.reset-password',\n defaultMessage: 'Reset password',\n })}\n </Typography>\n </Td>\n <Td onClick={(e) => e.stopPropagation()}>\n <IconButton\n onClick={() => onEditClick('reset_password')}\n label={formatMessage({\n id: getTrad('Email.template.form.edit.label'),\n defaultMessage: 'Edit a template',\n })}\n variant=\"ghost\"\n disabled={!canUpdate}\n >\n <Pencil />\n </IconButton>\n </Td>\n </Tr>\n <Tr onClick={() => onEditClick('email_confirmation')}>\n <Td>\n <Box width=\"3.2rem\" height=\"3.2rem\" padding=\"0.8rem\">\n <Check\n aria-label={formatMessage({\n id: getTrad('Email.template.email_confirmation'),\n defaultMessage: 'Email address confirmation',\n })}\n />\n </Box>\n </Td>\n <Td>\n <Typography>\n {formatMessage({\n id: getTrad('Email.template.email_confirmation'),\n defaultMessage: 'Email address confirmation',\n })}\n </Typography>\n </Td>\n <Td onClick={(e) => e.stopPropagation()}>\n <IconButton\n onClick={() => onEditClick('email_confirmation')}\n label={formatMessage({\n id: getTrad('Email.template.form.edit.label'),\n defaultMessage: 'Edit a template',\n })}\n variant=\"ghost\"\n disabled={!canUpdate}\n >\n <Pencil />\n </IconButton>\n </Td>\n </Tr>\n </Tbody>\n </Table>\n );\n};\n\nEmailTable.propTypes = {\n canUpdate: PropTypes.bool.isRequired,\n onEditClick: PropTypes.func.isRequired,\n};\n\nexport default EmailTable;\n","import * as React from 'react';\n\nimport { useTracking } from '@strapi/admin/strapi-admin';\nimport { useNotifyAT } from '@strapi/design-system';\nimport {\n Page,\n useAPIErrorHandler,\n useNotification,\n useFetchClient,\n useRBAC,\n Layouts,\n} from '@strapi/strapi/admin';\nimport { useIntl } from 'react-intl';\nimport { useMutation, useQuery, useQueryClient } from 'react-query';\n\nimport { PERMISSIONS } from '../../constants';\nimport { getTrad } from '../../utils';\n\nimport EmailForm from './components/EmailForm';\nimport EmailTable from './components/EmailTable';\n\nconst ProtectedEmailTemplatesPage = () => (\n <Page.Protect permissions={PERMISSIONS.readEmailTemplates}>\n <EmailTemplatesPage />\n </Page.Protect>\n);\nconst EmailTemplatesPage = () => {\n const { formatMessage } = useIntl();\n const { trackUsage } = useTracking();\n const { notifyStatus } = useNotifyAT();\n const { toggleNotification } = useNotification();\n const queryClient = useQueryClient();\n const { get, put } = useFetchClient();\n const { formatAPIError } = useAPIErrorHandler();\n\n const [isModalOpen, setIsModalOpen] = React.useState(false);\n const [templateToEdit, setTemplateToEdit] = React.useState(null);\n\n const {\n isLoading: isLoadingForPermissions,\n allowedActions: { canUpdate },\n } = useRBAC({ update: PERMISSIONS.updateEmailTemplates });\n\n const { isLoading: isLoadingData, data } = useQuery(\n ['users-permissions', 'email-templates'],\n async () => {\n const { data } = await get('/users-permissions/email-templates');\n\n return data;\n },\n {\n onSuccess() {\n notifyStatus(\n formatMessage({\n id: getTrad('Email.template.data.loaded'),\n defaultMessage: 'Email templates has been loaded',\n })\n );\n },\n onError(error) {\n toggleNotification({\n type: 'danger',\n message: formatAPIError(error),\n });\n },\n }\n );\n\n const isLoading = isLoadingForPermissions || isLoadingData;\n\n const handleToggle = () => {\n setIsModalOpen((prev) => !prev);\n };\n\n const handleEditClick = (template) => {\n setTemplateToEdit(template);\n handleToggle();\n };\n\n const submitMutation = useMutation(\n (body) => put('/users-permissions/email-templates', { 'email-templates': body }),\n {\n async onSuccess() {\n await queryClient.invalidateQueries(['users-permissions', 'email-templates']);\n\n toggleNotification({\n type: 'success',\n message: formatMessage({ id: 'notification.success.saved', defaultMessage: 'Saved' }),\n });\n\n trackUsage('didEditEmailTemplates');\n\n handleToggle();\n },\n onError(error) {\n toggleNotification({\n type: 'danger',\n message: formatAPIError(error),\n });\n },\n refetchActive: true,\n }\n );\n\n const handleSubmit = (body) => {\n trackUsage('willEditEmailTemplates');\n\n const editedTemplates = { ...data, [templateToEdit]: body };\n submitMutation.mutate(editedTemplates);\n };\n\n if (isLoading) {\n return <Page.Loading />;\n }\n\n return (\n <Page.Main aria-busy={submitMutation.isLoading}>\n <Page.Title>\n {formatMessage(\n { id: 'Settings.PageTitle', defaultMessage: 'Settings - {name}' },\n {\n name: formatMessage({\n id: getTrad('HeaderNav.link.emailTemplates'),\n defaultMessage: 'Email templates',\n }),\n }\n )}\n </Page.Title>\n <Layouts.Header\n title={formatMessage({\n id: getTrad('HeaderNav.link.emailTemplates'),\n defaultMessage: 'Email templates',\n })}\n />\n <Layouts.Content>\n <EmailTable onEditClick={handleEditClick} canUpdate={canUpdate} />\n <EmailForm\n template={data[templateToEdit]}\n onToggle={handleToggle}\n open={isModalOpen}\n onSubmit={handleSubmit}\n />\n </Layouts.Content>\n </Page.Main>\n );\n};\n\nexport { ProtectedEmailTemplatesPage, EmailTemplatesPage };\n"],"names":["yup","translatedErrors","useIntl","jsx","Modal","jsxs","Breadcrumbs","getTrad","Crumb","VisuallyHidden","Form","Fragment","Grid","InputRenderer","Button","PropTypes","Table","Thead","Tr","Th","Typography","Tbody","Td","Box","Refresh","IconButton","Pencil","Check","Page","PERMISSIONS","useTracking","useNotifyAT","useNotification","useQueryClient","useFetchClient","useAPIErrorHandler","React","useRBAC","useQuery","data","useMutation","Layouts"],"mappings":"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"}
|
|
@@ -8,7 +8,7 @@ const __variableDynamicImportRuntimeHelper = (glob, path) => {
|
|
|
8
8
|
});
|
|
9
9
|
};
|
|
10
10
|
const name$1 = "@strapi/plugin-users-permissions";
|
|
11
|
-
const version = "5.0.0-rc.
|
|
11
|
+
const version = "5.0.0-rc.10";
|
|
12
12
|
const description = "Protect your API with a full-authentication process based on JWT";
|
|
13
13
|
const repository = {
|
|
14
14
|
type: "git",
|
|
@@ -54,9 +54,9 @@ const scripts = {
|
|
|
54
54
|
watch: "pack-up watch"
|
|
55
55
|
};
|
|
56
56
|
const dependencies = {
|
|
57
|
-
"@strapi/design-system": "2.0.0-
|
|
58
|
-
"@strapi/icons": "2.0.0-
|
|
59
|
-
"@strapi/utils": "
|
|
57
|
+
"@strapi/design-system": "2.0.0-rc.7",
|
|
58
|
+
"@strapi/icons": "2.0.0-rc.7",
|
|
59
|
+
"@strapi/utils": "workspace:*",
|
|
60
60
|
bcryptjs: "2.4.3",
|
|
61
61
|
formik: "2.4.5",
|
|
62
62
|
"grant-koa": "5.4.8",
|
|
@@ -76,7 +76,7 @@ const dependencies = {
|
|
|
76
76
|
};
|
|
77
77
|
const devDependencies = {
|
|
78
78
|
"@strapi/pack-up": "5.0.0",
|
|
79
|
-
"@strapi/strapi": "
|
|
79
|
+
"@strapi/strapi": "workspace:*",
|
|
80
80
|
"@testing-library/dom": "10.1.0",
|
|
81
81
|
"@testing-library/react": "15.0.7",
|
|
82
82
|
"@testing-library/user-event": "14.5.2",
|
|
@@ -176,7 +176,7 @@ const index = {
|
|
|
176
176
|
},
|
|
177
177
|
id: "roles",
|
|
178
178
|
to: `users-permissions/roles`,
|
|
179
|
-
Component: () => import("./index-
|
|
179
|
+
Component: () => import("./index-CWLVetj5.mjs"),
|
|
180
180
|
permissions: PERMISSIONS.accessRoles
|
|
181
181
|
},
|
|
182
182
|
{
|
|
@@ -186,7 +186,7 @@ const index = {
|
|
|
186
186
|
},
|
|
187
187
|
id: "providers",
|
|
188
188
|
to: `users-permissions/providers`,
|
|
189
|
-
Component: () => import("./index-
|
|
189
|
+
Component: () => import("./index-DtCT27Ac.mjs"),
|
|
190
190
|
permissions: PERMISSIONS.readProviders
|
|
191
191
|
},
|
|
192
192
|
{
|
|
@@ -196,7 +196,7 @@ const index = {
|
|
|
196
196
|
},
|
|
197
197
|
id: "email-templates",
|
|
198
198
|
to: `users-permissions/email-templates`,
|
|
199
|
-
Component: () => import("./index-
|
|
199
|
+
Component: () => import("./index-CmaIewQS.mjs").then((mod) => ({
|
|
200
200
|
default: mod.ProtectedEmailTemplatesPage
|
|
201
201
|
})),
|
|
202
202
|
permissions: PERMISSIONS.readEmailTemplates
|
|
@@ -208,7 +208,7 @@ const index = {
|
|
|
208
208
|
},
|
|
209
209
|
id: "advanced-settings",
|
|
210
210
|
to: `users-permissions/advanced-settings`,
|
|
211
|
-
Component: () => import("./index-
|
|
211
|
+
Component: () => import("./index-VzSi-Vm6.mjs").then((mod) => ({
|
|
212
212
|
default: mod.ProtectedAdvancedSettingsPage
|
|
213
213
|
})),
|
|
214
214
|
permissions: PERMISSIONS.readAdvancedSettings
|
|
@@ -246,4 +246,4 @@ export {
|
|
|
246
246
|
getTrad as g,
|
|
247
247
|
index as i
|
|
248
248
|
};
|
|
249
|
-
//# sourceMappingURL=index-
|
|
249
|
+
//# sourceMappingURL=index-CMwq-8wx.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index-
|
|
1
|
+
{"version":3,"file":"index-CMwq-8wx.mjs","sources":["../../admin/src/constants.js","../../admin/src/pluginId.js","../../admin/src/utils/getTrad.js","../../admin/src/utils/prefixPluginTranslations.js","../../admin/src/index.js"],"sourcesContent":["export const PERMISSIONS = {\n // Roles\n accessRoles: [\n { action: 'plugin::users-permissions.roles.create', subject: null },\n { action: 'plugin::users-permissions.roles.read', subject: null },\n ],\n createRole: [{ action: 'plugin::users-permissions.roles.create', subject: null }],\n deleteRole: [{ action: 'plugin::users-permissions.roles.delete', subject: null }],\n readRoles: [{ action: 'plugin::users-permissions.roles.read', subject: null }],\n updateRole: [{ action: 'plugin::users-permissions.roles.update', subject: null }],\n\n // AdvancedSettings\n readAdvancedSettings: [\n { action: 'plugin::users-permissions.advanced-settings.read', subject: null },\n ],\n updateAdvancedSettings: [\n { action: 'plugin::users-permissions.advanced-settings.update', subject: null },\n ],\n\n // Emails\n readEmailTemplates: [{ action: 'plugin::users-permissions.email-templates.read', subject: null }],\n updateEmailTemplates: [\n { action: 'plugin::users-permissions.email-templates.update', subject: null },\n ],\n\n // Providers\n readProviders: [{ action: 'plugin::users-permissions.providers.read', subject: null }],\n updateProviders: [{ action: 'plugin::users-permissions.providers.update', subject: null }],\n};\n","import pluginPkg from '../../package.json';\n\nconst pluginId = pluginPkg.name.replace(/^@strapi\\/plugin-/i, '');\n\nexport default pluginId;\n","import pluginId from '../pluginId';\n\nconst getTrad = (id) => `${pluginId}.${id}`;\n\nexport default getTrad;\n","const prefixPluginTranslations = (trad, pluginId) => {\n if (!pluginId) {\n throw new TypeError(\"pluginId can't be empty\");\n }\n\n return Object.keys(trad).reduce((acc, current) => {\n acc[`${pluginId}.${current}`] = trad[current];\n\n return acc;\n }, {});\n};\n\nexport { prefixPluginTranslations };\n","import pluginPkg from '../../package.json';\n\nimport { PERMISSIONS } from './constants';\nimport getTrad from './utils/getTrad';\nimport { prefixPluginTranslations } from './utils/prefixPluginTranslations';\n\nconst name = pluginPkg.strapi.name;\n\nexport default {\n register(app) {\n // Create the plugin's settings section\n app.createSettingSection(\n {\n id: 'users-permissions',\n intlLabel: {\n id: getTrad('Settings.section-label'),\n defaultMessage: 'Users & Permissions plugin',\n },\n },\n [\n {\n intlLabel: {\n id: 'global.roles',\n defaultMessage: 'Roles',\n },\n id: 'roles',\n to: `users-permissions/roles`,\n Component: () => import('./pages/Roles'),\n permissions: PERMISSIONS.accessRoles,\n },\n {\n intlLabel: {\n id: getTrad('HeaderNav.link.providers'),\n defaultMessage: 'Providers',\n },\n id: 'providers',\n to: `users-permissions/providers`,\n Component: () => import('./pages/Providers'),\n permissions: PERMISSIONS.readProviders,\n },\n {\n intlLabel: {\n id: getTrad('HeaderNav.link.emailTemplates'),\n defaultMessage: 'Email templates',\n },\n id: 'email-templates',\n to: `users-permissions/email-templates`,\n Component: () =>\n import('./pages/EmailTemplates').then((mod) => ({\n default: mod.ProtectedEmailTemplatesPage,\n })),\n permissions: PERMISSIONS.readEmailTemplates,\n },\n {\n intlLabel: {\n id: getTrad('HeaderNav.link.advancedSettings'),\n defaultMessage: 'Advanced Settings',\n },\n id: 'advanced-settings',\n to: `users-permissions/advanced-settings`,\n Component: () =>\n import('./pages/AdvancedSettings').then((mod) => ({\n default: mod.ProtectedAdvancedSettingsPage,\n })),\n permissions: PERMISSIONS.readAdvancedSettings,\n },\n ]\n );\n\n app.registerPlugin({\n id: 'users-permissions',\n name,\n });\n },\n bootstrap() {},\n async registerTrads({ locales }) {\n const importedTrads = await Promise.all(\n locales.map((locale) => {\n return import(`./translations/${locale}.json`)\n .then(({ default: data }) => {\n return {\n data: prefixPluginTranslations(data, 'users-permissions'),\n locale,\n };\n })\n .catch(() => {\n return {\n data: {},\n locale,\n };\n });\n })\n );\n\n return Promise.resolve(importedTrads);\n },\n};\n"],"names":["pluginId"],"mappings":"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"}
|
|
@@ -3,7 +3,7 @@ import * as React from "react";
|
|
|
3
3
|
import { createContext, useContext, useMemo, useCallback, useReducer, forwardRef, useImperativeHandle, memo, useEffect, useState } from "react";
|
|
4
4
|
import { translatedErrors, useNotification, useFetchClient, useAPIErrorHandler, Page, useTracking, Layouts, BackButton, useQueryParams, useRBAC, SearchInput, ConfirmDialog } from "@strapi/strapi/admin";
|
|
5
5
|
import { useNavigate, useMatch, NavLink, Routes, Route } from "react-router-dom";
|
|
6
|
-
import { g as getTrad, P as PERMISSIONS } from "./index-
|
|
6
|
+
import { g as getTrad, P as PERMISSIONS } from "./index-CMwq-8wx.mjs";
|
|
7
7
|
import { Box, Flex, Typography, Checkbox, Grid, VisuallyHidden, Accordion, Main, Button, Field, TextInput, Textarea, Link, Tbody, Tr, Td, IconButton, useNotifyAT, useFilter, useCollator, LinkButton, Table, Thead, Th, EmptyStateLayout, Dialog } from "@strapi/design-system";
|
|
8
8
|
import { Cog, Check, Pencil, Trash, Plus } from "@strapi/icons";
|
|
9
9
|
import { Formik, Form } from "formik";
|
|
@@ -127,7 +127,7 @@ const SubCategory = ({ subCategory }) => {
|
|
|
127
127
|
] }),
|
|
128
128
|
/* @__PURE__ */ jsx(Flex, { paddingTop: 6, paddingBottom: 6, children: /* @__PURE__ */ jsx(Grid.Root, { gap: 2, style: { flex: 1 }, children: subCategory.actions.map((action) => {
|
|
129
129
|
const name = `${action.name}.enabled`;
|
|
130
|
-
return /* @__PURE__ */ jsx(Grid.Item, { col: 6, children: /* @__PURE__ */ jsxs(CheckboxWrapper, { isActive: isActionSelected(action.name), padding: 2, hasRadius: true, children: [
|
|
130
|
+
return /* @__PURE__ */ jsx(Grid.Item, { col: 6, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsxs(CheckboxWrapper, { isActive: isActionSelected(action.name), padding: 2, hasRadius: true, children: [
|
|
131
131
|
/* @__PURE__ */ jsx(
|
|
132
132
|
Checkbox,
|
|
133
133
|
{
|
|
@@ -345,6 +345,8 @@ const Policies = () => {
|
|
|
345
345
|
paddingLeft: 7,
|
|
346
346
|
paddingRight: 7,
|
|
347
347
|
style: { minHeight: "100%" },
|
|
348
|
+
direction: "column",
|
|
349
|
+
alignItems: "stretch",
|
|
348
350
|
children: selectedAction ? /* @__PURE__ */ jsx(Flex, { direction: "column", alignItems: "stretch", gap: 2, children: displayedRoutes.map((route, key) => (
|
|
349
351
|
// eslint-disable-next-line react/no-array-index-key
|
|
350
352
|
/* @__PURE__ */ jsx(BoundRoute, { route }, key)
|
|
@@ -456,19 +458,31 @@ const UsersPermissions = forwardRef(({ permissions, routes }, ref) => {
|
|
|
456
458
|
onSelectedAction: handleSelectedAction
|
|
457
459
|
};
|
|
458
460
|
return /* @__PURE__ */ jsx(UsersPermissionsProvider, { value: providerValue, children: /* @__PURE__ */ jsxs(Grid.Root, { gap: 0, shadow: "filterShadow", hasRadius: true, background: "neutral0", children: [
|
|
459
|
-
/* @__PURE__ */ jsx(
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
461
|
+
/* @__PURE__ */ jsx(
|
|
462
|
+
Grid.Item,
|
|
463
|
+
{
|
|
464
|
+
col: 7,
|
|
465
|
+
paddingTop: 6,
|
|
466
|
+
paddingBottom: 6,
|
|
467
|
+
paddingLeft: 7,
|
|
468
|
+
paddingRight: 7,
|
|
469
|
+
direction: "column",
|
|
470
|
+
alignItems: "stretch",
|
|
471
|
+
children: /* @__PURE__ */ jsxs(Flex, { direction: "column", alignItems: "stretch", gap: 6, children: [
|
|
472
|
+
/* @__PURE__ */ jsxs(Flex, { direction: "column", alignItems: "stretch", gap: 2, children: [
|
|
473
|
+
/* @__PURE__ */ jsx(Typography, { variant: "delta", tag: "h2", children: formatMessage({
|
|
474
|
+
id: getTrad("Plugins.header.title"),
|
|
475
|
+
defaultMessage: "Permissions"
|
|
476
|
+
}) }),
|
|
477
|
+
/* @__PURE__ */ jsx(Typography, { tag: "p", textColor: "neutral600", children: formatMessage({
|
|
478
|
+
id: getTrad("Plugins.header.description"),
|
|
479
|
+
defaultMessage: "Only actions bound by a route are listed below."
|
|
480
|
+
}) })
|
|
481
|
+
] }),
|
|
482
|
+
/* @__PURE__ */ jsx(Permissions, {})
|
|
483
|
+
] })
|
|
484
|
+
}
|
|
485
|
+
),
|
|
472
486
|
/* @__PURE__ */ jsx(Policies, {})
|
|
473
487
|
] }) });
|
|
474
488
|
});
|
|
@@ -642,7 +656,7 @@ const CreatePage = () => {
|
|
|
642
656
|
defaultMessage: "Role details"
|
|
643
657
|
}) }),
|
|
644
658
|
/* @__PURE__ */ jsxs(Grid.Root, { gap: 4, children: [
|
|
645
|
-
/* @__PURE__ */ jsx(Grid.Item, { col: 6, children: /* @__PURE__ */ jsxs(
|
|
659
|
+
/* @__PURE__ */ jsx(Grid.Item, { col: 6, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsxs(
|
|
646
660
|
Field.Root,
|
|
647
661
|
{
|
|
648
662
|
name: "name",
|
|
@@ -658,7 +672,7 @@ const CreatePage = () => {
|
|
|
658
672
|
]
|
|
659
673
|
}
|
|
660
674
|
) }),
|
|
661
|
-
/* @__PURE__ */ jsx(Grid.Item, { col: 6, children: /* @__PURE__ */ jsxs(
|
|
675
|
+
/* @__PURE__ */ jsx(Grid.Item, { col: 6, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsxs(
|
|
662
676
|
Field.Root,
|
|
663
677
|
{
|
|
664
678
|
name: "description",
|
|
@@ -796,7 +810,7 @@ const EditPage = () => {
|
|
|
796
810
|
defaultMessage: "Role details"
|
|
797
811
|
}) }),
|
|
798
812
|
/* @__PURE__ */ jsxs(Grid.Root, { gap: 4, children: [
|
|
799
|
-
/* @__PURE__ */ jsx(Grid.Item, { col: 6, children: /* @__PURE__ */ jsxs(
|
|
813
|
+
/* @__PURE__ */ jsx(Grid.Item, { col: 6, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsxs(
|
|
800
814
|
Field.Root,
|
|
801
815
|
{
|
|
802
816
|
name: "name",
|
|
@@ -815,7 +829,7 @@ const EditPage = () => {
|
|
|
815
829
|
]
|
|
816
830
|
}
|
|
817
831
|
) }),
|
|
818
|
-
/* @__PURE__ */ jsx(Grid.Item, { col: 6, children: /* @__PURE__ */ jsxs(
|
|
832
|
+
/* @__PURE__ */ jsx(Grid.Item, { col: 6, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsxs(
|
|
819
833
|
Field.Root,
|
|
820
834
|
{
|
|
821
835
|
name: "description",
|
|
@@ -915,7 +929,7 @@ const TableBody = ({ sortedRoles, canDelete, canUpdate, setRoleToDelete, onDelet
|
|
|
915
929
|
IconButton,
|
|
916
930
|
{
|
|
917
931
|
onClick: () => handleClickDelete(role.id.toString()),
|
|
918
|
-
|
|
932
|
+
variant: "ghost",
|
|
919
933
|
label: formatMessage(
|
|
920
934
|
{ id: "global.delete-target", defaultMessage: "Delete {target}" },
|
|
921
935
|
{ target: `${role.name}` }
|
|
@@ -1126,4 +1140,4 @@ const Roles = () => {
|
|
|
1126
1140
|
export {
|
|
1127
1141
|
Roles as default
|
|
1128
1142
|
};
|
|
1129
|
-
//# sourceMappingURL=index-
|
|
1143
|
+
//# sourceMappingURL=index-CWLVetj5.mjs.map
|