@strapi/plugin-users-permissions 5.0.0-beta.7 → 5.0.0-beta.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (37) hide show
  1. package/admin/src/components/Permissions/index.jsx +26 -35
  2. package/admin/src/pages/EmailTemplates/components/EmailTable.jsx +10 -6
  3. package/admin/src/pages/Providers/index.jsx +4 -3
  4. package/admin/src/pages/Roles/pages/ListPage/components/TableBody.jsx +4 -4
  5. package/dist/_chunks/{index-Du8DLJcX.mjs → index-00_Lq0-y.mjs} +6 -6
  6. package/dist/_chunks/{index-Du8DLJcX.mjs.map → index-00_Lq0-y.mjs.map} +1 -1
  7. package/dist/_chunks/{index--VHJr8__-a6vFdIyj.js → index-69WUS0qJ-621Sl9hj.js} +54 -53
  8. package/dist/_chunks/index-69WUS0qJ-621Sl9hj.js.map +1 -0
  9. package/dist/_chunks/{index--VHJr8__-Cx-PmaTb.mjs → index-69WUS0qJ-DzUzGVgd.mjs} +54 -53
  10. package/dist/_chunks/index-69WUS0qJ-DzUzGVgd.mjs.map +1 -0
  11. package/dist/_chunks/{index-BEhglMSg.mjs → index-B6AAcVOR.mjs} +15 -15
  12. package/dist/_chunks/{index-BEhglMSg.mjs.map → index-B6AAcVOR.mjs.map} +1 -1
  13. package/dist/_chunks/{index-QrGtUO_1.js → index-BGu68xEV.js} +15 -15
  14. package/dist/_chunks/{index-QrGtUO_1.js.map → index-BGu68xEV.js.map} +1 -1
  15. package/dist/_chunks/{index-lnrC9bmZ.js → index-BSqwdKVh.js} +20 -39
  16. package/dist/_chunks/index-BSqwdKVh.js.map +1 -0
  17. package/dist/_chunks/{index-B-kWBHFg.mjs → index-B_rNTZBF.mjs} +21 -40
  18. package/dist/_chunks/index-B_rNTZBF.mjs.map +1 -0
  19. package/dist/_chunks/{index-B0IECp2U.js → index-CIJz4WB2.js} +2 -2
  20. package/dist/_chunks/{index-B0IECp2U.js.map → index-CIJz4WB2.js.map} +1 -1
  21. package/dist/_chunks/{index-CvBfU3H9.js → index-DGyiWVHr.js} +10 -10
  22. package/dist/_chunks/{index-CvBfU3H9.js.map → index-DGyiWVHr.js.map} +1 -1
  23. package/dist/_chunks/{index-D6s_GV1d.js → index-DTK4DMrt.js} +10 -8
  24. package/dist/_chunks/index-DTK4DMrt.js.map +1 -0
  25. package/dist/_chunks/{index-CYVy1i0_.mjs → index-DaCuO0x_.mjs} +2 -2
  26. package/dist/_chunks/{index-CYVy1i0_.mjs.map → index-DaCuO0x_.mjs.map} +1 -1
  27. package/dist/_chunks/{index-BRZCpa1U.mjs → index-fnfzDsYv.mjs} +9 -7
  28. package/dist/_chunks/index-fnfzDsYv.mjs.map +1 -0
  29. package/dist/admin/index.js +1 -1
  30. package/dist/admin/index.mjs +1 -1
  31. package/package.json +11 -11
  32. package/dist/_chunks/index--VHJr8__-Cx-PmaTb.mjs.map +0 -1
  33. package/dist/_chunks/index--VHJr8__-a6vFdIyj.js.map +0 -1
  34. package/dist/_chunks/index-B-kWBHFg.mjs.map +0 -1
  35. package/dist/_chunks/index-BRZCpa1U.mjs.map +0 -1
  36. package/dist/_chunks/index-D6s_GV1d.js.map +0 -1
  37. package/dist/_chunks/index-lnrC9bmZ.js.map +0 -1
@@ -1,6 +1,6 @@
1
1
  import React, { useReducer } from 'react';
2
2
 
3
- import { Accordion, AccordionContent, AccordionToggle, Flex } from '@strapi/design-system';
3
+ import { Accordion, Flex } from '@strapi/design-system';
4
4
  import { useIntl } from 'react-intl';
5
5
 
6
6
  import { useUsersPermissions } from '../../contexts/UsersPermissionsContext';
@@ -13,42 +13,33 @@ import { initialState, reducer } from './reducer';
13
13
  const Permissions = () => {
14
14
  const { modifiedData } = useUsersPermissions();
15
15
  const { formatMessage } = useIntl();
16
- const [{ collapses }, dispatch] = useReducer(reducer, initialState, (state) =>
17
- init(state, modifiedData)
18
- );
19
-
20
- const handleToggle = (index) =>
21
- dispatch({
22
- type: 'TOGGLE_COLLAPSE',
23
- index,
24
- });
16
+ const [{ collapses }] = useReducer(reducer, initialState, (state) => init(state, modifiedData));
25
17
 
26
18
  return (
27
- <Flex direction="column" alignItems="stretch" gap={1}>
28
- {collapses.map((collapse, index) => (
29
- <Accordion
30
- expanded={collapse.isOpen}
31
- onToggle={() => handleToggle(index)}
32
- key={collapse.name}
33
- variant={index % 2 === 0 ? 'secondary' : undefined}
34
- >
35
- <AccordionToggle
36
- title={formatPluginName(collapse.name)}
37
- description={formatMessage(
38
- {
39
- id: 'users-permissions.Plugin.permissions.plugins.description',
40
- defaultMessage: 'Define all allowed actions for the {name} plugin.',
41
- },
42
- { name: collapse.name }
43
- )}
44
- variant={index % 2 ? 'primary' : 'secondary'}
45
- />
46
- <AccordionContent>
47
- <PermissionRow permissions={modifiedData[collapse.name]} name={collapse.name} />
48
- </AccordionContent>
49
- </Accordion>
50
- ))}
51
- </Flex>
19
+ <Accordion.Root size="M">
20
+ <Flex direction="column" alignItems="stretch" gap={1}>
21
+ {collapses.map((collapse, index) => (
22
+ <Accordion.Item key={collapse.name} value={collapse.name}>
23
+ <Accordion.Header variant={index % 2 === 0 ? 'secondary' : undefined}>
24
+ <Accordion.Trigger
25
+ description={formatMessage(
26
+ {
27
+ id: 'users-permissions.Plugin.permissions.plugins.description',
28
+ defaultMessage: 'Define all allowed actions for the {name} plugin.',
29
+ },
30
+ { name: collapse.name }
31
+ )}
32
+ >
33
+ {formatPluginName(collapse.name)}
34
+ </Accordion.Trigger>
35
+ </Accordion.Header>
36
+ <Accordion.Content>
37
+ <PermissionRow permissions={modifiedData[collapse.name]} name={collapse.name} />
38
+ </Accordion.Content>
39
+ </Accordion.Item>
40
+ ))}
41
+ </Flex>
42
+ </Accordion.Root>
52
43
  );
53
44
  };
54
45
 
@@ -75,9 +75,11 @@ const EmailTable = ({ canUpdate, onEditClick }) => {
75
75
  id: getTrad('Email.template.form.edit.label'),
76
76
  defaultMessage: 'Edit a template',
77
77
  })}
78
- noBorder
79
- icon={canUpdate && <Pencil />}
80
- />
78
+ borderWidth={0}
79
+ disabled={!canUpdate}
80
+ >
81
+ <Pencil />
82
+ </IconButton>
81
83
  </Td>
82
84
  </Tr>
83
85
  <Tr onClick={() => onEditClick('email_confirmation')}>
@@ -104,9 +106,11 @@ const EmailTable = ({ canUpdate, onEditClick }) => {
104
106
  id: getTrad('Email.template.form.edit.label'),
105
107
  defaultMessage: 'Edit a template',
106
108
  })}
107
- noBorder
108
- icon={canUpdate && <Pencil />}
109
- />
109
+ borderWidth={0}
110
+ disabled={!canUpdate}
111
+ >
112
+ <Pencil />
113
+ </IconButton>
110
114
  </Td>
111
115
  </Tr>
112
116
  </Tbody>
@@ -220,10 +220,11 @@ export const ProvidersPage = () => {
220
220
  {canUpdate && (
221
221
  <IconButton
222
222
  onClick={() => handleClickEdit(provider)}
223
- noBorder
224
- icon={<Pencil />}
223
+ borderWidth={0}
225
224
  label="Edit"
226
- />
225
+ >
226
+ <Pencil />
227
+ </IconButton>
227
228
  )}
228
229
  </Td>
229
230
  </Tr>
@@ -85,13 +85,14 @@ const TableBody = ({ sortedRoles, canDelete, canUpdate, setRoleToDelete, onDelet
85
85
  {checkCanDeleteRole(role) && (
86
86
  <IconButton
87
87
  onClick={() => handleClickDelete(role.id.toString())}
88
- noBorder
89
- icon={<Trash />}
88
+ borderWidth={0}
90
89
  label={formatMessage(
91
90
  { id: 'global.delete-target', defaultMessage: 'Delete {target}' },
92
91
  { target: `${role.name}` }
93
92
  )}
94
- />
93
+ >
94
+ <Trash />
95
+ </IconButton>
95
96
  )}
96
97
  </Flex>
97
98
  </Td>
@@ -110,7 +111,6 @@ TableBody.defaultProps = {
110
111
 
111
112
  TableBody.propTypes = {
112
113
  onDelete: PropTypes.array.isRequired,
113
- permissions: PropTypes.object.isRequired,
114
114
  setRoleToDelete: PropTypes.func.isRequired,
115
115
  sortedRoles: PropTypes.array.isRequired,
116
116
  canDelete: PropTypes.bool,
@@ -1,6 +1,6 @@
1
1
  import { jsxs, jsx } from "react/jsx-runtime";
2
2
  import * as React from "react";
3
- import { u as useTracking, L as Layouts } from "./index--VHJr8__-Cx-PmaTb.mjs";
3
+ import { u as useTracking, L as Layouts } from "./index-69WUS0qJ-DzUzGVgd.mjs";
4
4
  import { Field, Toggle, TextInput, ModalLayout, ModalHeader, Breadcrumbs, Crumb, ModalBody, Flex, Grid, GridItem, ModalFooter, Button, useCollator, Table, Thead, Tr, Th, Typography, VisuallyHidden, Tbody, Td, IconButton } from "@strapi/design-system";
5
5
  import { Pencil } from "@strapi/icons";
6
6
  import { translatedErrors, useNotification, useFetchClient, useAPIErrorHandler, useRBAC, Page } from "@strapi/strapi/admin";
@@ -9,7 +9,7 @@ import { useIntl } from "react-intl";
9
9
  import { useQueryClient, useQuery, useMutation } from "react-query";
10
10
  import { Formik, Form } from "formik";
11
11
  import PropTypes from "prop-types";
12
- import { g as getTrad, P as PERMISSIONS } from "./index-BEhglMSg.mjs";
12
+ import { g as getTrad, P as PERMISSIONS } from "./index-B6AAcVOR.mjs";
13
13
  import "lodash/isEmpty";
14
14
  import * as yup from "yup";
15
15
  const Input = ({
@@ -571,9 +571,9 @@ const ProvidersPage = () => {
571
571
  IconButton,
572
572
  {
573
573
  onClick: () => handleClickEdit(provider),
574
- noBorder: true,
575
- icon: /* @__PURE__ */ jsx(Pencil, {}),
576
- label: "Edit"
574
+ borderWidth: 0,
575
+ label: "Edit",
576
+ children: /* @__PURE__ */ jsx(Pencil, {})
577
577
  }
578
578
  ) })
579
579
  ]
@@ -608,4 +608,4 @@ export {
608
608
  ProvidersPage,
609
609
  ProtectedProvidersPage as default
610
610
  };
611
- //# sourceMappingURL=index-Du8DLJcX.mjs.map
611
+ //# sourceMappingURL=index-00_Lq0-y.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index-Du8DLJcX.mjs","sources":["../../admin/src/components/FormModal/Input/index.jsx","../../admin/src/components/FormModal/index.jsx","../../admin/src/pages/Providers/utils/forms.js","../../admin/src/pages/Providers/index.jsx"],"sourcesContent":["/**\n *\n * Input\n *\n */\n\nimport React from 'react';\n\nimport { TextInput, Toggle, Field } from '@strapi/design-system';\nimport PropTypes from 'prop-types';\nimport { useIntl } from 'react-intl';\n\nconst Input = ({\n description,\n disabled,\n intlLabel,\n error,\n name,\n onChange,\n placeholder,\n providerToEditName,\n type,\n value,\n}) => {\n const { formatMessage } = useIntl();\n const inputValue =\n name === 'noName'\n ? `${window.strapi.backendURL}/api/connect/${providerToEditName}/callback`\n : value;\n\n const label = formatMessage(\n { id: intlLabel.id, defaultMessage: intlLabel.defaultMessage },\n { provider: providerToEditName, ...intlLabel.values }\n );\n const hint = description\n ? formatMessage(\n { id: description.id, defaultMessage: description.defaultMessage },\n { provider: providerToEditName, ...description.values }\n )\n : '';\n\n if (type === 'bool') {\n return (\n <Field.Root hint={hint} name={name}>\n <Field.Label>{label}</Field.Label>\n <Toggle\n aria-label={name}\n checked={value}\n disabled={disabled}\n offLabel={formatMessage({\n id: 'app.components.ToggleCheckbox.off-label',\n defaultMessage: 'Off',\n })}\n onLabel={formatMessage({\n id: 'app.components.ToggleCheckbox.on-label',\n defaultMessage: 'On',\n })}\n onChange={(e) => {\n onChange({ target: { name, value: e.target.checked } });\n }}\n />\n <Field.Hint />\n </Field.Root>\n );\n }\n\n const formattedPlaceholder = placeholder\n ? formatMessage(\n { id: placeholder.id, defaultMessage: placeholder.defaultMessage },\n { ...placeholder.values }\n )\n : '';\n\n const errorMessage = error ? formatMessage({ id: error, defaultMessage: error }) : '';\n\n return (\n <Field.Root error={errorMessage} name={name}>\n <Field.Label>{label}</Field.Label>\n <TextInput\n disabled={disabled}\n onChange={onChange}\n placeholder={formattedPlaceholder}\n type={type}\n value={inputValue}\n />\n <Field.Error />\n </Field.Root>\n );\n};\n\nInput.defaultProps = {\n description: null,\n disabled: false,\n error: '',\n placeholder: null,\n value: '',\n};\n\nInput.propTypes = {\n description: PropTypes.shape({\n id: PropTypes.string.isRequired,\n defaultMessage: PropTypes.string.isRequired,\n values: PropTypes.object,\n }),\n disabled: PropTypes.bool,\n error: PropTypes.string,\n intlLabel: PropTypes.shape({\n id: PropTypes.string.isRequired,\n defaultMessage: PropTypes.string.isRequired,\n values: PropTypes.object,\n }).isRequired,\n name: PropTypes.string.isRequired,\n onChange: PropTypes.func.isRequired,\n placeholder: PropTypes.shape({\n id: PropTypes.string.isRequired,\n defaultMessage: PropTypes.string.isRequired,\n values: PropTypes.object,\n }),\n providerToEditName: PropTypes.string.isRequired,\n type: PropTypes.string.isRequired,\n value: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),\n};\n\nexport default Input;\n","/**\n *\n * FormModal\n *\n */\n\nimport React from 'react';\n\nimport {\n Button,\n Flex,\n Grid,\n GridItem,\n ModalBody,\n ModalFooter,\n ModalHeader,\n ModalLayout,\n} from '@strapi/design-system';\nimport { Breadcrumbs, Crumb } from '@strapi/design-system';\nimport { Form, Formik } from 'formik';\nimport PropTypes from 'prop-types';\nimport { useIntl } from 'react-intl';\n\nimport Input from './Input';\n\nconst FormModal = ({\n headerBreadcrumbs,\n initialData,\n isSubmiting,\n layout,\n isOpen,\n onSubmit,\n onToggle,\n providerToEditName,\n}) => {\n const { formatMessage } = useIntl();\n\n if (!isOpen) {\n return null;\n }\n\n return (\n <ModalLayout onClose={onToggle} labelledBy=\"title\">\n <ModalHeader>\n <Breadcrumbs label={headerBreadcrumbs.join(', ')}>\n {headerBreadcrumbs.map((crumb, index, arr) => (\n <Crumb isCurrent={index === arr.length - 1} key={crumb}>\n {crumb}\n </Crumb>\n ))}\n </Breadcrumbs>\n </ModalHeader>\n <Formik\n onSubmit={(values) => onSubmit(values)}\n initialValues={initialData}\n validationSchema={layout.schema}\n validateOnChange={false}\n >\n {({ errors, handleChange, values }) => {\n return (\n <Form>\n <ModalBody>\n <Flex direction=\"column\" alignItems=\"stretch\" gap={1}>\n <Grid gap={5}>\n {layout.form.map((row) => {\n return row.map((input) => {\n return (\n <GridItem key={input.name} col={input.size} xs={12}>\n <Input\n {...input}\n error={errors[input.name]}\n onChange={handleChange}\n value={values[input.name]}\n providerToEditName={providerToEditName}\n />\n </GridItem>\n );\n });\n })}\n </Grid>\n </Flex>\n </ModalBody>\n <ModalFooter\n startActions={\n <Button variant=\"tertiary\" onClick={onToggle} type=\"button\">\n {formatMessage({\n id: 'app.components.Button.cancel',\n defaultMessage: 'Cancel',\n })}\n </Button>\n }\n endActions={\n <Button type=\"submit\" loading={isSubmiting}>\n {formatMessage({ id: 'global.save', defaultMessage: 'Save' })}\n </Button>\n }\n />\n </Form>\n );\n }}\n </Formik>\n </ModalLayout>\n );\n};\n\nFormModal.defaultProps = {\n initialData: null,\n providerToEditName: null,\n};\n\nFormModal.propTypes = {\n headerBreadcrumbs: PropTypes.arrayOf(PropTypes.string).isRequired,\n initialData: PropTypes.object,\n layout: PropTypes.shape({\n form: PropTypes.arrayOf(PropTypes.array),\n schema: PropTypes.object,\n }).isRequired,\n isOpen: PropTypes.bool.isRequired,\n isSubmiting: PropTypes.bool.isRequired,\n onSubmit: PropTypes.func.isRequired,\n onToggle: PropTypes.func.isRequired,\n providerToEditName: PropTypes.string,\n};\n\nexport default FormModal;\n","import { translatedErrors } from '@strapi/strapi/admin';\nimport * as yup from 'yup';\n\nimport { getTrad } from '../../../utils';\n\nconst callbackLabel = {\n id: getTrad('PopUpForm.Providers.redirectURL.front-end.label'),\n defaultMessage: 'The redirect URL to your front-end app',\n};\nconst callbackPlaceholder = {\n id: 'http://www.client-app.com',\n defaultMessage: 'http://www.client-app.com',\n};\nconst enabledDescription = {\n id: getTrad('PopUpForm.Providers.enabled.description'),\n defaultMessage: \"If disabled, users won't be able to use this provider.\",\n};\nconst enabledLabel = {\n id: getTrad('PopUpForm.Providers.enabled.label'),\n defaultMessage: 'Enable',\n};\nconst keyLabel = { id: getTrad('PopUpForm.Providers.key.label'), defaultMessage: 'Client ID' };\nconst hintLabel = {\n id: getTrad('PopUpForm.Providers.redirectURL.label'),\n defaultMessage: 'The redirect URL to add in your {provider} application configurations',\n};\nconst textPlaceholder = {\n id: getTrad('PopUpForm.Providers.key.placeholder'),\n defaultMessage: 'TEXT',\n};\n\nconst secretLabel = {\n id: getTrad('PopUpForm.Providers.secret.label'),\n defaultMessage: 'Client Secret',\n};\n\nconst forms = {\n email: {\n form: [\n [\n {\n intlLabel: enabledLabel,\n name: 'enabled',\n type: 'bool',\n description: enabledDescription,\n size: 6,\n // TODO check if still needed\n // validations: {\n // required: true,\n // },\n },\n ],\n ],\n schema: yup.object().shape({\n enabled: yup.bool().required(translatedErrors.required.id),\n }),\n },\n providers: {\n form: [\n [\n {\n intlLabel: enabledLabel,\n name: 'enabled',\n type: 'bool',\n description: enabledDescription,\n size: 6,\n validations: {\n required: true,\n },\n },\n ],\n [\n {\n intlLabel: keyLabel,\n name: 'key',\n type: 'text',\n placeholder: textPlaceholder,\n size: 12,\n validations: {\n required: true,\n },\n },\n ],\n [\n {\n intlLabel: secretLabel,\n name: 'secret',\n type: 'text',\n placeholder: textPlaceholder,\n size: 12,\n validations: {\n required: true,\n },\n },\n ],\n [\n {\n intlLabel: callbackLabel,\n placeholder: callbackPlaceholder,\n name: 'callback',\n type: 'text',\n size: 12,\n validations: {\n required: true,\n },\n },\n ],\n [\n {\n intlLabel: hintLabel,\n name: 'noName',\n type: 'text',\n validations: {},\n size: 12,\n disabled: true,\n },\n ],\n ],\n schema: yup.object().shape({\n enabled: yup.bool().required(translatedErrors.required.id),\n key: yup.string().when('enabled', {\n is: true,\n then: yup.string().required(translatedErrors.required.id),\n otherwise: yup.string(),\n }),\n secret: yup.string().when('enabled', {\n is: true,\n then: yup.string().required(translatedErrors.required.id),\n otherwise: yup.string(),\n }),\n callback: yup.string().when('enabled', {\n is: true,\n then: yup.string().required(translatedErrors.required.id),\n otherwise: yup.string(),\n }),\n }),\n },\n providersWithSubdomain: {\n form: [\n [\n {\n intlLabel: enabledLabel,\n name: 'enabled',\n type: 'bool',\n description: enabledDescription,\n size: 6,\n validations: {\n required: true,\n },\n },\n ],\n [\n {\n intlLabel: keyLabel,\n name: 'key',\n type: 'text',\n placeholder: textPlaceholder,\n size: 12,\n validations: {\n required: true,\n },\n },\n ],\n [\n {\n intlLabel: secretLabel,\n name: 'secret',\n type: 'text',\n placeholder: textPlaceholder,\n size: 12,\n validations: {\n required: true,\n },\n },\n ],\n [\n {\n intlLabel: {\n id: getTrad({ id: 'PopUpForm.Providers.jwksurl.label' }),\n defaultMessage: 'JWKS URL',\n },\n name: 'jwksurl',\n type: 'text',\n placeholder: textPlaceholder,\n size: 12,\n validations: {\n required: false,\n },\n },\n ],\n\n [\n {\n intlLabel: {\n id: getTrad('PopUpForm.Providers.subdomain.label'),\n defaultMessage: 'Host URI (Subdomain)',\n },\n name: 'subdomain',\n type: 'text',\n placeholder: {\n id: getTrad('PopUpForm.Providers.subdomain.placeholder'),\n defaultMessage: 'my.subdomain.com',\n },\n size: 12,\n validations: {\n required: true,\n },\n },\n ],\n [\n {\n intlLabel: callbackLabel,\n placeholder: callbackPlaceholder,\n name: 'callback',\n type: 'text',\n size: 12,\n validations: {\n required: true,\n },\n },\n ],\n [\n {\n intlLabel: hintLabel,\n name: 'noName',\n type: 'text',\n validations: {},\n size: 12,\n disabled: true,\n },\n ],\n ],\n schema: yup.object().shape({\n enabled: yup.bool().required(translatedErrors.required.id),\n key: yup.string().when('enabled', {\n is: true,\n then: yup.string().required(translatedErrors.required.id),\n otherwise: yup.string(),\n }),\n secret: yup.string().when('enabled', {\n is: true,\n then: yup.string().required(translatedErrors.required.id),\n otherwise: yup.string(),\n }),\n subdomain: yup.string().when('enabled', {\n is: true,\n then: yup.string().required(translatedErrors.required.id),\n otherwise: yup.string(),\n }),\n callback: yup.string().when('enabled', {\n is: true,\n then: yup.string().required(translatedErrors.required.id),\n otherwise: yup.string(),\n }),\n }),\n },\n};\n\nexport default forms;\n","import * as React from 'react';\n\nimport { useTracking, Layouts } from '@strapi/admin/strapi-admin';\nimport {\n IconButton,\n Table,\n Tbody,\n Td,\n Th,\n Thead,\n Tr,\n Typography,\n VisuallyHidden,\n useCollator,\n} from '@strapi/design-system';\nimport { Pencil } from '@strapi/icons';\nimport {\n Page,\n useAPIErrorHandler,\n useNotification,\n useFetchClient,\n useRBAC,\n} from '@strapi/strapi/admin';\nimport upperFirst from 'lodash/upperFirst';\nimport { useIntl } from 'react-intl';\nimport { useMutation, useQuery, useQueryClient } from 'react-query';\n\nimport FormModal from '../../components/FormModal';\nimport { PERMISSIONS } from '../../constants';\nimport { getTrad } from '../../utils';\n\nimport forms from './utils/forms';\n\nexport const ProvidersPage = () => {\n const { formatMessage, locale } = useIntl();\n const queryClient = useQueryClient();\n const { trackUsage } = useTracking();\n const [isOpen, setIsOpen] = React.useState(false);\n const [providerToEditName, setProviderToEditName] = React.useState(null);\n const { toggleNotification } = useNotification();\n const { get, put } = useFetchClient();\n const { formatAPIError } = useAPIErrorHandler();\n const formatter = useCollator(locale, {\n sensitivity: 'base',\n });\n\n const {\n isLoading: isLoadingPermissions,\n allowedActions: { canUpdate },\n } = useRBAC({ update: PERMISSIONS.updateProviders });\n\n const { isLoading: isLoadingData, data } = useQuery(\n ['users-permissions', 'get-providers'],\n async () => {\n const { data } = await get('/users-permissions/providers');\n\n return data;\n },\n {\n initialData: {},\n }\n );\n\n const submitMutation = useMutation((body) => put('/users-permissions/providers', body), {\n async onSuccess() {\n await queryClient.invalidateQueries(['users-permissions', 'providers']);\n\n toggleNotification({\n type: 'success',\n message: formatMessage({ id: getTrad('notification.success.submit') }),\n });\n\n trackUsage('didEditAuthenticationProvider');\n\n handleToggleModal();\n },\n onError(error) {\n toggleNotification({\n type: 'danger',\n message: formatAPIError(error),\n });\n },\n refetchActive: false,\n });\n\n const providers = Object.entries(data)\n .reduce((acc, [name, provider]) => {\n const { icon, enabled, subdomain } = provider;\n\n acc.push({\n name,\n icon: icon === 'envelope' ? ['fas', 'envelope'] : ['fab', icon],\n enabled,\n subdomain,\n });\n\n return acc;\n }, [])\n .sort((a, b) => formatter.compare(a.name, b.name));\n\n const isLoading = isLoadingData || isLoadingPermissions;\n\n const isProviderWithSubdomain = React.useMemo(() => {\n if (!providerToEditName) {\n return false;\n }\n\n const providerToEdit = providers.find((obj) => obj.name === providerToEditName);\n\n return !!providerToEdit?.subdomain;\n }, [providers, providerToEditName]);\n\n const layoutToRender = React.useMemo(() => {\n if (providerToEditName === 'email') {\n return forms.email;\n }\n\n if (isProviderWithSubdomain) {\n return forms.providersWithSubdomain;\n }\n\n return forms.providers;\n }, [providerToEditName, isProviderWithSubdomain]);\n\n const handleToggleModal = () => {\n setIsOpen((prev) => !prev);\n };\n\n const handleClickEdit = (provider) => {\n if (canUpdate) {\n setProviderToEditName(provider.name);\n handleToggleModal();\n }\n };\n\n const handleSubmit = async (values) => {\n trackUsage('willEditAuthenticationProvider');\n\n submitMutation.mutate({ providers: { ...data, [providerToEditName]: values } });\n };\n\n if (isLoading) {\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: formatMessage({\n id: getTrad('HeaderNav.link.providers'),\n defaultMessage: 'Providers',\n }),\n }\n )}\n </Page.Title>\n <Page.Main>\n <Layouts.Header\n title={formatMessage({\n id: getTrad('HeaderNav.link.providers'),\n defaultMessage: 'Providers',\n })}\n />\n <Layouts.Content>\n <Table colCount={3} rowCount={providers.length + 1}>\n <Thead>\n <Tr>\n <Th>\n <Typography variant=\"sigma\" textColor=\"neutral600\">\n {formatMessage({ id: 'global.name', defaultMessage: 'Name' })}\n </Typography>\n </Th>\n <Th>\n <Typography variant=\"sigma\" textColor=\"neutral600\">\n {formatMessage({ id: getTrad('Providers.status'), defaultMessage: 'Status' })}\n </Typography>\n </Th>\n <Th>\n <Typography variant=\"sigma\">\n <VisuallyHidden>\n {formatMessage({\n id: 'global.settings',\n defaultMessage: 'Settings',\n })}\n </VisuallyHidden>\n </Typography>\n </Th>\n </Tr>\n </Thead>\n <Tbody>\n {providers.map((provider) => (\n <Tr\n key={provider.name}\n onClick={() => (canUpdate ? handleClickEdit(provider) : undefined)}\n >\n <Td width=\"45%\">\n <Typography fontWeight=\"semiBold\" textColor=\"neutral800\">\n {provider.name}\n </Typography>\n </Td>\n <Td width=\"65%\">\n <Typography\n textColor={provider.enabled ? 'success600' : 'danger600'}\n data-testid={`enable-${provider.name}`}\n >\n {provider.enabled\n ? formatMessage({\n id: 'global.enabled',\n defaultMessage: 'Enabled',\n })\n : formatMessage({\n id: 'global.disabled',\n defaultMessage: 'Disabled',\n })}\n </Typography>\n </Td>\n <Td onClick={(e) => e.stopPropagation()}>\n {canUpdate && (\n <IconButton\n onClick={() => handleClickEdit(provider)}\n noBorder\n icon={<Pencil />}\n label=\"Edit\"\n />\n )}\n </Td>\n </Tr>\n ))}\n </Tbody>\n </Table>\n </Layouts.Content>\n </Page.Main>\n <FormModal\n initialData={data[providerToEditName]}\n isOpen={isOpen}\n isSubmiting={submitMutation.isLoading}\n layout={layoutToRender}\n headerBreadcrumbs={[\n formatMessage({\n id: getTrad('PopUpForm.header.edit.providers'),\n defaultMessage: 'Edit Provider',\n }),\n upperFirst(providerToEditName),\n ]}\n onToggle={handleToggleModal}\n onSubmit={handleSubmit}\n providerToEditName={providerToEditName}\n />\n </Layouts.Root>\n );\n};\n\nconst ProtectedProvidersPage = () => (\n <Page.Protect permissions={PERMISSIONS.readProviders}>\n <ProvidersPage />\n </Page.Protect>\n);\n\nexport default ProtectedProvidersPage;\n"],"names":["data"],"mappings":"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"}
1
+ {"version":3,"file":"index-00_Lq0-y.mjs","sources":["../../admin/src/components/FormModal/Input/index.jsx","../../admin/src/components/FormModal/index.jsx","../../admin/src/pages/Providers/utils/forms.js","../../admin/src/pages/Providers/index.jsx"],"sourcesContent":["/**\n *\n * Input\n *\n */\n\nimport React from 'react';\n\nimport { TextInput, Toggle, Field } from '@strapi/design-system';\nimport PropTypes from 'prop-types';\nimport { useIntl } from 'react-intl';\n\nconst Input = ({\n description,\n disabled,\n intlLabel,\n error,\n name,\n onChange,\n placeholder,\n providerToEditName,\n type,\n value,\n}) => {\n const { formatMessage } = useIntl();\n const inputValue =\n name === 'noName'\n ? `${window.strapi.backendURL}/api/connect/${providerToEditName}/callback`\n : value;\n\n const label = formatMessage(\n { id: intlLabel.id, defaultMessage: intlLabel.defaultMessage },\n { provider: providerToEditName, ...intlLabel.values }\n );\n const hint = description\n ? formatMessage(\n { id: description.id, defaultMessage: description.defaultMessage },\n { provider: providerToEditName, ...description.values }\n )\n : '';\n\n if (type === 'bool') {\n return (\n <Field.Root hint={hint} name={name}>\n <Field.Label>{label}</Field.Label>\n <Toggle\n aria-label={name}\n checked={value}\n disabled={disabled}\n offLabel={formatMessage({\n id: 'app.components.ToggleCheckbox.off-label',\n defaultMessage: 'Off',\n })}\n onLabel={formatMessage({\n id: 'app.components.ToggleCheckbox.on-label',\n defaultMessage: 'On',\n })}\n onChange={(e) => {\n onChange({ target: { name, value: e.target.checked } });\n }}\n />\n <Field.Hint />\n </Field.Root>\n );\n }\n\n const formattedPlaceholder = placeholder\n ? formatMessage(\n { id: placeholder.id, defaultMessage: placeholder.defaultMessage },\n { ...placeholder.values }\n )\n : '';\n\n const errorMessage = error ? formatMessage({ id: error, defaultMessage: error }) : '';\n\n return (\n <Field.Root error={errorMessage} name={name}>\n <Field.Label>{label}</Field.Label>\n <TextInput\n disabled={disabled}\n onChange={onChange}\n placeholder={formattedPlaceholder}\n type={type}\n value={inputValue}\n />\n <Field.Error />\n </Field.Root>\n );\n};\n\nInput.defaultProps = {\n description: null,\n disabled: false,\n error: '',\n placeholder: null,\n value: '',\n};\n\nInput.propTypes = {\n description: PropTypes.shape({\n id: PropTypes.string.isRequired,\n defaultMessage: PropTypes.string.isRequired,\n values: PropTypes.object,\n }),\n disabled: PropTypes.bool,\n error: PropTypes.string,\n intlLabel: PropTypes.shape({\n id: PropTypes.string.isRequired,\n defaultMessage: PropTypes.string.isRequired,\n values: PropTypes.object,\n }).isRequired,\n name: PropTypes.string.isRequired,\n onChange: PropTypes.func.isRequired,\n placeholder: PropTypes.shape({\n id: PropTypes.string.isRequired,\n defaultMessage: PropTypes.string.isRequired,\n values: PropTypes.object,\n }),\n providerToEditName: PropTypes.string.isRequired,\n type: PropTypes.string.isRequired,\n value: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),\n};\n\nexport default Input;\n","/**\n *\n * FormModal\n *\n */\n\nimport React from 'react';\n\nimport {\n Button,\n Flex,\n Grid,\n GridItem,\n ModalBody,\n ModalFooter,\n ModalHeader,\n ModalLayout,\n} from '@strapi/design-system';\nimport { Breadcrumbs, Crumb } from '@strapi/design-system';\nimport { Form, Formik } from 'formik';\nimport PropTypes from 'prop-types';\nimport { useIntl } from 'react-intl';\n\nimport Input from './Input';\n\nconst FormModal = ({\n headerBreadcrumbs,\n initialData,\n isSubmiting,\n layout,\n isOpen,\n onSubmit,\n onToggle,\n providerToEditName,\n}) => {\n const { formatMessage } = useIntl();\n\n if (!isOpen) {\n return null;\n }\n\n return (\n <ModalLayout onClose={onToggle} labelledBy=\"title\">\n <ModalHeader>\n <Breadcrumbs label={headerBreadcrumbs.join(', ')}>\n {headerBreadcrumbs.map((crumb, index, arr) => (\n <Crumb isCurrent={index === arr.length - 1} key={crumb}>\n {crumb}\n </Crumb>\n ))}\n </Breadcrumbs>\n </ModalHeader>\n <Formik\n onSubmit={(values) => onSubmit(values)}\n initialValues={initialData}\n validationSchema={layout.schema}\n validateOnChange={false}\n >\n {({ errors, handleChange, values }) => {\n return (\n <Form>\n <ModalBody>\n <Flex direction=\"column\" alignItems=\"stretch\" gap={1}>\n <Grid gap={5}>\n {layout.form.map((row) => {\n return row.map((input) => {\n return (\n <GridItem key={input.name} col={input.size} xs={12}>\n <Input\n {...input}\n error={errors[input.name]}\n onChange={handleChange}\n value={values[input.name]}\n providerToEditName={providerToEditName}\n />\n </GridItem>\n );\n });\n })}\n </Grid>\n </Flex>\n </ModalBody>\n <ModalFooter\n startActions={\n <Button variant=\"tertiary\" onClick={onToggle} type=\"button\">\n {formatMessage({\n id: 'app.components.Button.cancel',\n defaultMessage: 'Cancel',\n })}\n </Button>\n }\n endActions={\n <Button type=\"submit\" loading={isSubmiting}>\n {formatMessage({ id: 'global.save', defaultMessage: 'Save' })}\n </Button>\n }\n />\n </Form>\n );\n }}\n </Formik>\n </ModalLayout>\n );\n};\n\nFormModal.defaultProps = {\n initialData: null,\n providerToEditName: null,\n};\n\nFormModal.propTypes = {\n headerBreadcrumbs: PropTypes.arrayOf(PropTypes.string).isRequired,\n initialData: PropTypes.object,\n layout: PropTypes.shape({\n form: PropTypes.arrayOf(PropTypes.array),\n schema: PropTypes.object,\n }).isRequired,\n isOpen: PropTypes.bool.isRequired,\n isSubmiting: PropTypes.bool.isRequired,\n onSubmit: PropTypes.func.isRequired,\n onToggle: PropTypes.func.isRequired,\n providerToEditName: PropTypes.string,\n};\n\nexport default FormModal;\n","import { translatedErrors } from '@strapi/strapi/admin';\nimport * as yup from 'yup';\n\nimport { getTrad } from '../../../utils';\n\nconst callbackLabel = {\n id: getTrad('PopUpForm.Providers.redirectURL.front-end.label'),\n defaultMessage: 'The redirect URL to your front-end app',\n};\nconst callbackPlaceholder = {\n id: 'http://www.client-app.com',\n defaultMessage: 'http://www.client-app.com',\n};\nconst enabledDescription = {\n id: getTrad('PopUpForm.Providers.enabled.description'),\n defaultMessage: \"If disabled, users won't be able to use this provider.\",\n};\nconst enabledLabel = {\n id: getTrad('PopUpForm.Providers.enabled.label'),\n defaultMessage: 'Enable',\n};\nconst keyLabel = { id: getTrad('PopUpForm.Providers.key.label'), defaultMessage: 'Client ID' };\nconst hintLabel = {\n id: getTrad('PopUpForm.Providers.redirectURL.label'),\n defaultMessage: 'The redirect URL to add in your {provider} application configurations',\n};\nconst textPlaceholder = {\n id: getTrad('PopUpForm.Providers.key.placeholder'),\n defaultMessage: 'TEXT',\n};\n\nconst secretLabel = {\n id: getTrad('PopUpForm.Providers.secret.label'),\n defaultMessage: 'Client Secret',\n};\n\nconst forms = {\n email: {\n form: [\n [\n {\n intlLabel: enabledLabel,\n name: 'enabled',\n type: 'bool',\n description: enabledDescription,\n size: 6,\n // TODO check if still needed\n // validations: {\n // required: true,\n // },\n },\n ],\n ],\n schema: yup.object().shape({\n enabled: yup.bool().required(translatedErrors.required.id),\n }),\n },\n providers: {\n form: [\n [\n {\n intlLabel: enabledLabel,\n name: 'enabled',\n type: 'bool',\n description: enabledDescription,\n size: 6,\n validations: {\n required: true,\n },\n },\n ],\n [\n {\n intlLabel: keyLabel,\n name: 'key',\n type: 'text',\n placeholder: textPlaceholder,\n size: 12,\n validations: {\n required: true,\n },\n },\n ],\n [\n {\n intlLabel: secretLabel,\n name: 'secret',\n type: 'text',\n placeholder: textPlaceholder,\n size: 12,\n validations: {\n required: true,\n },\n },\n ],\n [\n {\n intlLabel: callbackLabel,\n placeholder: callbackPlaceholder,\n name: 'callback',\n type: 'text',\n size: 12,\n validations: {\n required: true,\n },\n },\n ],\n [\n {\n intlLabel: hintLabel,\n name: 'noName',\n type: 'text',\n validations: {},\n size: 12,\n disabled: true,\n },\n ],\n ],\n schema: yup.object().shape({\n enabled: yup.bool().required(translatedErrors.required.id),\n key: yup.string().when('enabled', {\n is: true,\n then: yup.string().required(translatedErrors.required.id),\n otherwise: yup.string(),\n }),\n secret: yup.string().when('enabled', {\n is: true,\n then: yup.string().required(translatedErrors.required.id),\n otherwise: yup.string(),\n }),\n callback: yup.string().when('enabled', {\n is: true,\n then: yup.string().required(translatedErrors.required.id),\n otherwise: yup.string(),\n }),\n }),\n },\n providersWithSubdomain: {\n form: [\n [\n {\n intlLabel: enabledLabel,\n name: 'enabled',\n type: 'bool',\n description: enabledDescription,\n size: 6,\n validations: {\n required: true,\n },\n },\n ],\n [\n {\n intlLabel: keyLabel,\n name: 'key',\n type: 'text',\n placeholder: textPlaceholder,\n size: 12,\n validations: {\n required: true,\n },\n },\n ],\n [\n {\n intlLabel: secretLabel,\n name: 'secret',\n type: 'text',\n placeholder: textPlaceholder,\n size: 12,\n validations: {\n required: true,\n },\n },\n ],\n [\n {\n intlLabel: {\n id: getTrad({ id: 'PopUpForm.Providers.jwksurl.label' }),\n defaultMessage: 'JWKS URL',\n },\n name: 'jwksurl',\n type: 'text',\n placeholder: textPlaceholder,\n size: 12,\n validations: {\n required: false,\n },\n },\n ],\n\n [\n {\n intlLabel: {\n id: getTrad('PopUpForm.Providers.subdomain.label'),\n defaultMessage: 'Host URI (Subdomain)',\n },\n name: 'subdomain',\n type: 'text',\n placeholder: {\n id: getTrad('PopUpForm.Providers.subdomain.placeholder'),\n defaultMessage: 'my.subdomain.com',\n },\n size: 12,\n validations: {\n required: true,\n },\n },\n ],\n [\n {\n intlLabel: callbackLabel,\n placeholder: callbackPlaceholder,\n name: 'callback',\n type: 'text',\n size: 12,\n validations: {\n required: true,\n },\n },\n ],\n [\n {\n intlLabel: hintLabel,\n name: 'noName',\n type: 'text',\n validations: {},\n size: 12,\n disabled: true,\n },\n ],\n ],\n schema: yup.object().shape({\n enabled: yup.bool().required(translatedErrors.required.id),\n key: yup.string().when('enabled', {\n is: true,\n then: yup.string().required(translatedErrors.required.id),\n otherwise: yup.string(),\n }),\n secret: yup.string().when('enabled', {\n is: true,\n then: yup.string().required(translatedErrors.required.id),\n otherwise: yup.string(),\n }),\n subdomain: yup.string().when('enabled', {\n is: true,\n then: yup.string().required(translatedErrors.required.id),\n otherwise: yup.string(),\n }),\n callback: yup.string().when('enabled', {\n is: true,\n then: yup.string().required(translatedErrors.required.id),\n otherwise: yup.string(),\n }),\n }),\n },\n};\n\nexport default forms;\n","import * as React from 'react';\n\nimport { useTracking, Layouts } from '@strapi/admin/strapi-admin';\nimport {\n IconButton,\n Table,\n Tbody,\n Td,\n Th,\n Thead,\n Tr,\n Typography,\n VisuallyHidden,\n useCollator,\n} from '@strapi/design-system';\nimport { Pencil } from '@strapi/icons';\nimport {\n Page,\n useAPIErrorHandler,\n useNotification,\n useFetchClient,\n useRBAC,\n} from '@strapi/strapi/admin';\nimport upperFirst from 'lodash/upperFirst';\nimport { useIntl } from 'react-intl';\nimport { useMutation, useQuery, useQueryClient } from 'react-query';\n\nimport FormModal from '../../components/FormModal';\nimport { PERMISSIONS } from '../../constants';\nimport { getTrad } from '../../utils';\n\nimport forms from './utils/forms';\n\nexport const ProvidersPage = () => {\n const { formatMessage, locale } = useIntl();\n const queryClient = useQueryClient();\n const { trackUsage } = useTracking();\n const [isOpen, setIsOpen] = React.useState(false);\n const [providerToEditName, setProviderToEditName] = React.useState(null);\n const { toggleNotification } = useNotification();\n const { get, put } = useFetchClient();\n const { formatAPIError } = useAPIErrorHandler();\n const formatter = useCollator(locale, {\n sensitivity: 'base',\n });\n\n const {\n isLoading: isLoadingPermissions,\n allowedActions: { canUpdate },\n } = useRBAC({ update: PERMISSIONS.updateProviders });\n\n const { isLoading: isLoadingData, data } = useQuery(\n ['users-permissions', 'get-providers'],\n async () => {\n const { data } = await get('/users-permissions/providers');\n\n return data;\n },\n {\n initialData: {},\n }\n );\n\n const submitMutation = useMutation((body) => put('/users-permissions/providers', body), {\n async onSuccess() {\n await queryClient.invalidateQueries(['users-permissions', 'providers']);\n\n toggleNotification({\n type: 'success',\n message: formatMessage({ id: getTrad('notification.success.submit') }),\n });\n\n trackUsage('didEditAuthenticationProvider');\n\n handleToggleModal();\n },\n onError(error) {\n toggleNotification({\n type: 'danger',\n message: formatAPIError(error),\n });\n },\n refetchActive: false,\n });\n\n const providers = Object.entries(data)\n .reduce((acc, [name, provider]) => {\n const { icon, enabled, subdomain } = provider;\n\n acc.push({\n name,\n icon: icon === 'envelope' ? ['fas', 'envelope'] : ['fab', icon],\n enabled,\n subdomain,\n });\n\n return acc;\n }, [])\n .sort((a, b) => formatter.compare(a.name, b.name));\n\n const isLoading = isLoadingData || isLoadingPermissions;\n\n const isProviderWithSubdomain = React.useMemo(() => {\n if (!providerToEditName) {\n return false;\n }\n\n const providerToEdit = providers.find((obj) => obj.name === providerToEditName);\n\n return !!providerToEdit?.subdomain;\n }, [providers, providerToEditName]);\n\n const layoutToRender = React.useMemo(() => {\n if (providerToEditName === 'email') {\n return forms.email;\n }\n\n if (isProviderWithSubdomain) {\n return forms.providersWithSubdomain;\n }\n\n return forms.providers;\n }, [providerToEditName, isProviderWithSubdomain]);\n\n const handleToggleModal = () => {\n setIsOpen((prev) => !prev);\n };\n\n const handleClickEdit = (provider) => {\n if (canUpdate) {\n setProviderToEditName(provider.name);\n handleToggleModal();\n }\n };\n\n const handleSubmit = async (values) => {\n trackUsage('willEditAuthenticationProvider');\n\n submitMutation.mutate({ providers: { ...data, [providerToEditName]: values } });\n };\n\n if (isLoading) {\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: formatMessage({\n id: getTrad('HeaderNav.link.providers'),\n defaultMessage: 'Providers',\n }),\n }\n )}\n </Page.Title>\n <Page.Main>\n <Layouts.Header\n title={formatMessage({\n id: getTrad('HeaderNav.link.providers'),\n defaultMessage: 'Providers',\n })}\n />\n <Layouts.Content>\n <Table colCount={3} rowCount={providers.length + 1}>\n <Thead>\n <Tr>\n <Th>\n <Typography variant=\"sigma\" textColor=\"neutral600\">\n {formatMessage({ id: 'global.name', defaultMessage: 'Name' })}\n </Typography>\n </Th>\n <Th>\n <Typography variant=\"sigma\" textColor=\"neutral600\">\n {formatMessage({ id: getTrad('Providers.status'), defaultMessage: 'Status' })}\n </Typography>\n </Th>\n <Th>\n <Typography variant=\"sigma\">\n <VisuallyHidden>\n {formatMessage({\n id: 'global.settings',\n defaultMessage: 'Settings',\n })}\n </VisuallyHidden>\n </Typography>\n </Th>\n </Tr>\n </Thead>\n <Tbody>\n {providers.map((provider) => (\n <Tr\n key={provider.name}\n onClick={() => (canUpdate ? handleClickEdit(provider) : undefined)}\n >\n <Td width=\"45%\">\n <Typography fontWeight=\"semiBold\" textColor=\"neutral800\">\n {provider.name}\n </Typography>\n </Td>\n <Td width=\"65%\">\n <Typography\n textColor={provider.enabled ? 'success600' : 'danger600'}\n data-testid={`enable-${provider.name}`}\n >\n {provider.enabled\n ? formatMessage({\n id: 'global.enabled',\n defaultMessage: 'Enabled',\n })\n : formatMessage({\n id: 'global.disabled',\n defaultMessage: 'Disabled',\n })}\n </Typography>\n </Td>\n <Td onClick={(e) => e.stopPropagation()}>\n {canUpdate && (\n <IconButton\n onClick={() => handleClickEdit(provider)}\n borderWidth={0}\n label=\"Edit\"\n >\n <Pencil />\n </IconButton>\n )}\n </Td>\n </Tr>\n ))}\n </Tbody>\n </Table>\n </Layouts.Content>\n </Page.Main>\n <FormModal\n initialData={data[providerToEditName]}\n isOpen={isOpen}\n isSubmiting={submitMutation.isLoading}\n layout={layoutToRender}\n headerBreadcrumbs={[\n formatMessage({\n id: getTrad('PopUpForm.header.edit.providers'),\n defaultMessage: 'Edit Provider',\n }),\n upperFirst(providerToEditName),\n ]}\n onToggle={handleToggleModal}\n onSubmit={handleSubmit}\n providerToEditName={providerToEditName}\n />\n </Layouts.Root>\n );\n};\n\nconst ProtectedProvidersPage = () => (\n <Page.Protect permissions={PERMISSIONS.readProviders}>\n <ProvidersPage />\n </Page.Protect>\n);\n\nexport default ProtectedProvidersPage;\n"],"names":["data"],"mappings":"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"}
@@ -6432,35 +6432,15 @@ const fetchBaseQuery = () => async (query, { signal }) => {
6432
6432
  const adminApi = createApi({
6433
6433
  reducerPath: "adminApi",
6434
6434
  baseQuery: fetchBaseQuery(),
6435
- tagTypes: [
6436
- "ApiToken",
6437
- "LicenseLimits",
6438
- "Me",
6439
- "ProjectSettings",
6440
- "ProvidersOptions",
6441
- "Role",
6442
- "RolePermissions",
6443
- "TransferToken",
6444
- "User",
6445
- "Webhook"
6446
- ],
6447
- endpoints: (builder) => ({
6448
- /**
6449
- * This is here because it's shared between the transfer-token routes & the api-tokens.
6450
- */
6451
- regenerateToken: builder.mutation({
6452
- query: (url) => ({
6453
- method: "POST",
6454
- url: `${url}/regenerate`
6455
- }),
6456
- transformResponse: (response) => response.data
6457
- })
6458
- })
6435
+ tagTypes: [],
6436
+ endpoints: () => ({})
6459
6437
  });
6460
6438
  const prefixFileUrlWithBackendUrl = (fileURL) => {
6461
6439
  return !!fileURL && fileURL.startsWith("/") ? `${window.strapi.backendURL}${fileURL}` : fileURL;
6462
6440
  };
6463
- adminApi.injectEndpoints({
6441
+ adminApi.enhanceEndpoints({
6442
+ addTagTypes: ["ProjectSettings", "LicenseLimits"]
6443
+ }).injectEndpoints({
6464
6444
  endpoints: (builder) => ({
6465
6445
  init: builder.query({
6466
6446
  query: () => ({
@@ -8612,7 +8592,9 @@ const adminSlice = createSlice({
8612
8592
  }
8613
8593
  });
8614
8594
  const reducer$1 = adminSlice.reducer;
8615
- adminApi.injectEndpoints({
8595
+ adminApi.enhanceEndpoints({
8596
+ addTagTypes: ["User", "Me", "ProvidersOptions"]
8597
+ }).injectEndpoints({
8616
8598
  endpoints: (builder) => ({
8617
8599
  /**
8618
8600
  * ME
@@ -9233,17 +9215,7 @@ React__namespace.forwardRef(
9233
9215
  return { data };
9234
9216
  } catch (err) {
9235
9217
  if (isErrorYupValidationError(err)) {
9236
- let errors = {};
9237
- if (err.inner) {
9238
- if (err.inner.length === 0) {
9239
- return setIn(errors, err.path, err.message);
9240
- }
9241
- for (const error of err.inner) {
9242
- if (!getIn(errors, error.path)) {
9243
- errors = setIn(errors, error.path, error.message);
9244
- }
9245
- }
9246
- }
9218
+ const errors = getYupValidationErrors(err);
9247
9219
  if (shouldSetErrors) {
9248
9220
  setErrors(errors);
9249
9221
  }
@@ -9418,6 +9390,20 @@ React__namespace.forwardRef(
9418
9390
  }
9419
9391
  );
9420
9392
  const isErrorYupValidationError = (err) => typeof err === "object" && err !== null && "name" in err && typeof err.name === "string" && err.name === "ValidationError";
9393
+ const getYupValidationErrors = (err) => {
9394
+ let errors = {};
9395
+ if (err.inner) {
9396
+ if (err.inner.length === 0) {
9397
+ return setIn(errors, err.path, err.message);
9398
+ }
9399
+ for (const error of err.inner) {
9400
+ if (!getIn(errors, error.path)) {
9401
+ errors = setIn(errors, error.path, error.message);
9402
+ }
9403
+ }
9404
+ }
9405
+ return errors;
9406
+ };
9421
9407
  const reducer = (state, action) => createNextState2.produce(state, (draft) => {
9422
9408
  switch (action.type) {
9423
9409
  case "SET_INITIAL_VALUES":
@@ -9579,6 +9565,7 @@ const BooleanInput = React.forwardRef(
9579
9565
  ] });
9580
9566
  }
9581
9567
  );
9568
+ const MemoizedBooleanInput = React.memo(BooleanInput);
9582
9569
  const CheckboxInput = React.forwardRef(
9583
9570
  ({ name, required, label, hint, ...props }, ref) => {
9584
9571
  const field = useField(name);
@@ -9600,6 +9587,7 @@ const CheckboxInput = React.forwardRef(
9600
9587
  ] });
9601
9588
  }
9602
9589
  );
9590
+ const MemoizedCheckboxInput = React.memo(CheckboxInput);
9603
9591
  const DateInput = React.forwardRef(
9604
9592
  ({ name, required, label, hint, labelAction, type: _type, ...props }, ref) => {
9605
9593
  const { formatMessage } = reactIntl.useIntl();
@@ -9618,7 +9606,7 @@ const DateInput = React.forwardRef(
9618
9606
  field.onChange(name, date);
9619
9607
  },
9620
9608
  onClear: () => field.onChange(name, void 0),
9621
- selectedDate: value,
9609
+ value,
9622
9610
  ...props
9623
9611
  }
9624
9612
  ),
@@ -9627,6 +9615,7 @@ const DateInput = React.forwardRef(
9627
9615
  ] });
9628
9616
  }
9629
9617
  );
9618
+ const MemoizedDateInput = React.memo(DateInput);
9630
9619
  const DateTimeInput = React.forwardRef(
9631
9620
  ({ name, required, label, hint, labelAction, ...props }, ref) => {
9632
9621
  const { formatMessage } = reactIntl.useIntl();
@@ -9654,6 +9643,7 @@ const DateTimeInput = React.forwardRef(
9654
9643
  ] });
9655
9644
  }
9656
9645
  );
9646
+ const MemoizedDateTimeInput = React.memo(DateTimeInput);
9657
9647
  const EmailInput = React.forwardRef(
9658
9648
  ({ name, required, label, hint, labelAction, ...props }, ref) => {
9659
9649
  const field = useField(name);
@@ -9678,6 +9668,7 @@ const EmailInput = React.forwardRef(
9678
9668
  ] });
9679
9669
  }
9680
9670
  );
9671
+ const MemoizedEmailInput = React.memo(EmailInput);
9681
9672
  const EnumerationInput = React.forwardRef(
9682
9673
  ({ name, required, label, hint, labelAction, options = [], ...props }, ref) => {
9683
9674
  const field = useField(name);
@@ -9704,6 +9695,7 @@ const EnumerationInput = React.forwardRef(
9704
9695
  ] });
9705
9696
  }
9706
9697
  );
9698
+ const MemoizedEnumerationInput = React.memo(EnumerationInput);
9707
9699
  const JsonInput = React.forwardRef(
9708
9700
  ({ name, required, label, hint, labelAction, ...props }, ref) => {
9709
9701
  const field = useField(name);
@@ -9730,6 +9722,7 @@ const JsonInput = React.forwardRef(
9730
9722
  ] });
9731
9723
  }
9732
9724
  );
9725
+ const MemoizedJsonInput = React.memo(JsonInput);
9733
9726
  const NumberInputImpl = React.forwardRef(
9734
9727
  ({ name, required, label, hint, labelAction, type, ...props }, ref) => {
9735
9728
  const field = useField(name);
@@ -9755,6 +9748,7 @@ const NumberInputImpl = React.forwardRef(
9755
9748
  ] });
9756
9749
  }
9757
9750
  );
9751
+ const MemoizedNumberInput = React.memo(NumberInputImpl);
9758
9752
  const PasswordInput = React.forwardRef(
9759
9753
  ({ name, required, label, hint, labelAction, ...props }, ref) => {
9760
9754
  const [showPassword, setShowPassword] = React.useState(false);
@@ -9800,6 +9794,7 @@ const PasswordInput = React.forwardRef(
9800
9794
  ] });
9801
9795
  }
9802
9796
  );
9797
+ const MemoizedPasswordInput = React.memo(PasswordInput);
9803
9798
  const StringInput = React.forwardRef(
9804
9799
  ({ name, required, label, hint, labelAction, ...props }, ref) => {
9805
9800
  const field = useField(name);
@@ -9822,6 +9817,7 @@ const StringInput = React.forwardRef(
9822
9817
  ] });
9823
9818
  }
9824
9819
  );
9820
+ const MemoizedStringInput = React.memo(StringInput);
9825
9821
  const TextareaInput = React.forwardRef(
9826
9822
  ({ name, required, label, hint, labelAction, ...props }, ref) => {
9827
9823
  const field = useField(name);
@@ -9844,6 +9840,7 @@ const TextareaInput = React.forwardRef(
9844
9840
  ] });
9845
9841
  }
9846
9842
  );
9843
+ const MemoizedTextareaInput = React.memo(TextareaInput);
9847
9844
  const TimeInput = React.forwardRef(
9848
9845
  ({ name, required, label, hint, labelAction, ...props }, ref) => {
9849
9846
  const { formatMessage } = reactIntl.useIntl();
@@ -9870,37 +9867,38 @@ const TimeInput = React.forwardRef(
9870
9867
  ] });
9871
9868
  }
9872
9869
  );
9873
- React.memo(
9870
+ const MemoizedTimeInput = React.memo(TimeInput);
9871
+ const InputRenderer = React.memo(
9874
9872
  React.forwardRef((props, forwardRef2) => {
9875
9873
  switch (props.type) {
9876
9874
  case "biginteger":
9877
9875
  case "timestamp":
9878
9876
  case "string":
9879
- return /* @__PURE__ */ jsxRuntime.jsx(StringInput, { ref: forwardRef2, ...props });
9877
+ return /* @__PURE__ */ jsxRuntime.jsx(MemoizedStringInput, { ref: forwardRef2, ...props });
9880
9878
  case "boolean":
9881
- return /* @__PURE__ */ jsxRuntime.jsx(BooleanInput, { ref: forwardRef2, ...props });
9879
+ return /* @__PURE__ */ jsxRuntime.jsx(MemoizedBooleanInput, { ref: forwardRef2, ...props });
9882
9880
  case "checkbox":
9883
- return /* @__PURE__ */ jsxRuntime.jsx(CheckboxInput, { ref: forwardRef2, ...props });
9881
+ return /* @__PURE__ */ jsxRuntime.jsx(MemoizedCheckboxInput, { ref: forwardRef2, ...props });
9884
9882
  case "datetime":
9885
- return /* @__PURE__ */ jsxRuntime.jsx(DateTimeInput, { ref: forwardRef2, ...props });
9883
+ return /* @__PURE__ */ jsxRuntime.jsx(MemoizedDateTimeInput, { ref: forwardRef2, ...props });
9886
9884
  case "date":
9887
- return /* @__PURE__ */ jsxRuntime.jsx(DateInput, { ref: forwardRef2, ...props });
9885
+ return /* @__PURE__ */ jsxRuntime.jsx(MemoizedDateInput, { ref: forwardRef2, ...props });
9888
9886
  case "decimal":
9889
9887
  case "float":
9890
9888
  case "integer":
9891
- return /* @__PURE__ */ jsxRuntime.jsx(NumberInputImpl, { ref: forwardRef2, ...props });
9889
+ return /* @__PURE__ */ jsxRuntime.jsx(MemoizedNumberInput, { ref: forwardRef2, ...props });
9892
9890
  case "json":
9893
- return /* @__PURE__ */ jsxRuntime.jsx(JsonInput, { ref: forwardRef2, ...props });
9891
+ return /* @__PURE__ */ jsxRuntime.jsx(MemoizedJsonInput, { ref: forwardRef2, ...props });
9894
9892
  case "email":
9895
- return /* @__PURE__ */ jsxRuntime.jsx(EmailInput, { ref: forwardRef2, ...props });
9893
+ return /* @__PURE__ */ jsxRuntime.jsx(MemoizedEmailInput, { ref: forwardRef2, ...props });
9896
9894
  case "enumeration":
9897
- return /* @__PURE__ */ jsxRuntime.jsx(EnumerationInput, { ref: forwardRef2, ...props });
9895
+ return /* @__PURE__ */ jsxRuntime.jsx(MemoizedEnumerationInput, { ref: forwardRef2, ...props });
9898
9896
  case "password":
9899
- return /* @__PURE__ */ jsxRuntime.jsx(PasswordInput, { ref: forwardRef2, ...props });
9897
+ return /* @__PURE__ */ jsxRuntime.jsx(MemoizedPasswordInput, { ref: forwardRef2, ...props });
9900
9898
  case "text":
9901
- return /* @__PURE__ */ jsxRuntime.jsx(TextareaInput, { ref: forwardRef2, ...props });
9899
+ return /* @__PURE__ */ jsxRuntime.jsx(MemoizedTextareaInput, { ref: forwardRef2, ...props });
9902
9900
  case "time":
9903
- return /* @__PURE__ */ jsxRuntime.jsx(TimeInput, { ref: forwardRef2, ...props });
9901
+ return /* @__PURE__ */ jsxRuntime.jsx(MemoizedTimeInput, { ref: forwardRef2, ...props });
9904
9902
  default:
9905
9903
  return /* @__PURE__ */ jsxRuntime.jsx(NotSupportedField, { ref: forwardRef2, ...props });
9906
9904
  }
@@ -9929,6 +9927,7 @@ const NotSupportedField = React.forwardRef(
9929
9927
  ] });
9930
9928
  }
9931
9929
  );
9930
+ React.memo(InputRenderer);
9932
9931
  styledComponents.styled.img`
9933
9932
  height: 7.2rem;
9934
9933
  `;
@@ -10440,7 +10439,9 @@ createContext("Table");
10440
10439
  styledComponents.styled(icons.CaretDown)`
10441
10440
  transform: ${({ $isUp }) => `rotate(${$isUp ? "180" : "0"}deg)`};
10442
10441
  `;
10443
- adminApi.injectEndpoints({
10442
+ adminApi.enhanceEndpoints({
10443
+ addTagTypes: ["LicenseLimits", "User", "Role", "RolePermissions"]
10444
+ }).injectEndpoints({
10444
10445
  endpoints: (builder) => ({
10445
10446
  /**
10446
10447
  * users
@@ -10598,4 +10599,4 @@ adminApi.injectEndpoints({
10598
10599
  });
10599
10600
  exports.Layouts = Layouts;
10600
10601
  exports.useTracking = useTracking;
10601
- //# sourceMappingURL=index--VHJr8__-a6vFdIyj.js.map
10602
+ //# sourceMappingURL=index-69WUS0qJ-621Sl9hj.js.map