@strapi/plugin-users-permissions 5.0.0-beta.6 → 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 (146) hide show
  1. package/admin/src/components/BoundRoute/index.jsx +2 -2
  2. package/admin/src/components/FormModal/Input/index.jsx +32 -31
  3. package/admin/src/components/Permissions/PermissionRow/CheckboxWrapper.jsx +1 -1
  4. package/admin/src/components/Permissions/PermissionRow/SubCategory.jsx +2 -2
  5. package/admin/src/components/Permissions/index.jsx +26 -35
  6. package/admin/src/components/Policies/index.jsx +2 -2
  7. package/admin/src/components/UsersPermissions/index.jsx +2 -2
  8. package/admin/src/pages/AdvancedSettings/index.jsx +6 -16
  9. package/admin/src/pages/EmailTemplates/components/EmailForm.jsx +2 -1
  10. package/admin/src/pages/EmailTemplates/components/EmailTable.jsx +10 -6
  11. package/admin/src/pages/EmailTemplates/index.jsx +5 -4
  12. package/admin/src/pages/Providers/index.jsx +10 -12
  13. package/admin/src/pages/Roles/pages/CreatePage.jsx +29 -24
  14. package/admin/src/pages/Roles/pages/EditPage.jsx +33 -24
  15. package/admin/src/pages/Roles/pages/ListPage/components/TableBody.jsx +5 -5
  16. package/admin/src/pages/Roles/pages/ListPage/index.jsx +8 -11
  17. package/dist/_chunks/ar-BguGUqwK.js +44 -0
  18. package/dist/_chunks/ar-BguGUqwK.js.map +1 -0
  19. package/dist/_chunks/ar-CK8BRRXB.mjs +44 -0
  20. package/dist/_chunks/ar-CK8BRRXB.mjs.map +1 -0
  21. package/dist/_chunks/cs-BVigMk0l.mjs +50 -0
  22. package/dist/_chunks/cs-BVigMk0l.mjs.map +1 -0
  23. package/dist/_chunks/cs-BW8-K_GY.js +50 -0
  24. package/dist/_chunks/cs-BW8-K_GY.js.map +1 -0
  25. package/dist/_chunks/de-BKUdRFI4.mjs +62 -0
  26. package/dist/_chunks/de-BKUdRFI4.mjs.map +1 -0
  27. package/dist/_chunks/de-owXpVluI.js +62 -0
  28. package/dist/_chunks/de-owXpVluI.js.map +1 -0
  29. package/dist/_chunks/dk-BQiTK50l.mjs +86 -0
  30. package/dist/_chunks/dk-BQiTK50l.mjs.map +1 -0
  31. package/dist/_chunks/dk-LXAnbuBk.js +86 -0
  32. package/dist/_chunks/dk-LXAnbuBk.js.map +1 -0
  33. package/dist/_chunks/en-DOHtPf-2.mjs +86 -0
  34. package/dist/_chunks/en-DOHtPf-2.mjs.map +1 -0
  35. package/dist/_chunks/en-MHo5mcsU.js +86 -0
  36. package/dist/_chunks/en-MHo5mcsU.js.map +1 -0
  37. package/dist/_chunks/es-BwLCLXAQ.js +86 -0
  38. package/dist/_chunks/es-BwLCLXAQ.js.map +1 -0
  39. package/dist/_chunks/es-DNgOVMjD.mjs +86 -0
  40. package/dist/_chunks/es-DNgOVMjD.mjs.map +1 -0
  41. package/dist/_chunks/fr-DkgRugiU.mjs +50 -0
  42. package/dist/_chunks/fr-DkgRugiU.mjs.map +1 -0
  43. package/dist/_chunks/fr-DkhpSjjm.js +50 -0
  44. package/dist/_chunks/fr-DkhpSjjm.js.map +1 -0
  45. package/dist/_chunks/id-BTemOeTZ.js +62 -0
  46. package/dist/_chunks/id-BTemOeTZ.js.map +1 -0
  47. package/dist/_chunks/id-BdEsvnaF.mjs +62 -0
  48. package/dist/_chunks/id-BdEsvnaF.mjs.map +1 -0
  49. package/dist/_chunks/index-00_Lq0-y.mjs +611 -0
  50. package/dist/_chunks/index-00_Lq0-y.mjs.map +1 -0
  51. package/dist/_chunks/index-69WUS0qJ-621Sl9hj.js +10602 -0
  52. package/dist/_chunks/index-69WUS0qJ-621Sl9hj.js.map +1 -0
  53. package/dist/_chunks/index-69WUS0qJ-DzUzGVgd.mjs +10578 -0
  54. package/dist/_chunks/index-69WUS0qJ-DzUzGVgd.mjs.map +1 -0
  55. package/dist/_chunks/index-B6AAcVOR.mjs +249 -0
  56. package/dist/_chunks/index-B6AAcVOR.mjs.map +1 -0
  57. package/dist/_chunks/index-BGu68xEV.js +248 -0
  58. package/dist/_chunks/index-BGu68xEV.js.map +1 -0
  59. package/dist/_chunks/index-BSqwdKVh.js +1164 -0
  60. package/dist/_chunks/index-BSqwdKVh.js.map +1 -0
  61. package/dist/_chunks/index-B_rNTZBF.mjs +1134 -0
  62. package/dist/_chunks/index-B_rNTZBF.mjs.map +1 -0
  63. package/dist/_chunks/index-CIJz4WB2.js +272 -0
  64. package/dist/_chunks/index-CIJz4WB2.js.map +1 -0
  65. package/dist/_chunks/index-DGyiWVHr.js +634 -0
  66. package/dist/_chunks/index-DGyiWVHr.js.map +1 -0
  67. package/dist/_chunks/index-DTK4DMrt.js +359 -0
  68. package/dist/_chunks/index-DTK4DMrt.js.map +1 -0
  69. package/dist/_chunks/index-DaCuO0x_.mjs +253 -0
  70. package/dist/_chunks/index-DaCuO0x_.mjs.map +1 -0
  71. package/dist/_chunks/index-fnfzDsYv.mjs +337 -0
  72. package/dist/_chunks/index-fnfzDsYv.mjs.map +1 -0
  73. package/dist/_chunks/it-B-rv0E24.mjs +62 -0
  74. package/dist/_chunks/it-B-rv0E24.mjs.map +1 -0
  75. package/dist/_chunks/it-D1rH6V6_.js +62 -0
  76. package/dist/_chunks/it-D1rH6V6_.js.map +1 -0
  77. package/dist/_chunks/ja-C8K-VBPD.mjs +48 -0
  78. package/dist/_chunks/ja-C8K-VBPD.mjs.map +1 -0
  79. package/dist/_chunks/ja-DqShgTMf.js +48 -0
  80. package/dist/_chunks/ja-DqShgTMf.js.map +1 -0
  81. package/dist/_chunks/ko-B9DGEPWH.js +86 -0
  82. package/dist/_chunks/ko-B9DGEPWH.js.map +1 -0
  83. package/dist/_chunks/ko-Busb0wIY.mjs +86 -0
  84. package/dist/_chunks/ko-Busb0wIY.mjs.map +1 -0
  85. package/dist/_chunks/ms-ByvsQjRt.mjs +49 -0
  86. package/dist/_chunks/ms-ByvsQjRt.mjs.map +1 -0
  87. package/dist/_chunks/ms-CPBU3LWf.js +49 -0
  88. package/dist/_chunks/ms-CPBU3LWf.js.map +1 -0
  89. package/dist/_chunks/nl-5qO8Rpcy.mjs +48 -0
  90. package/dist/_chunks/nl-5qO8Rpcy.mjs.map +1 -0
  91. package/dist/_chunks/nl-CwNB6YoO.js +48 -0
  92. package/dist/_chunks/nl-CwNB6YoO.js.map +1 -0
  93. package/dist/_chunks/pl-BdIzifBE.mjs +86 -0
  94. package/dist/_chunks/pl-BdIzifBE.mjs.map +1 -0
  95. package/dist/_chunks/pl-Do9UD69f.js +86 -0
  96. package/dist/_chunks/pl-Do9UD69f.js.map +1 -0
  97. package/dist/_chunks/pt-BIO24ioG.mjs +48 -0
  98. package/dist/_chunks/pt-BIO24ioG.mjs.map +1 -0
  99. package/dist/_chunks/pt-BR-D7dZhxuP.js +44 -0
  100. package/dist/_chunks/pt-BR-D7dZhxuP.js.map +1 -0
  101. package/dist/_chunks/pt-BR-f0p23AQZ.mjs +44 -0
  102. package/dist/_chunks/pt-BR-f0p23AQZ.mjs.map +1 -0
  103. package/dist/_chunks/pt-fdvyOnUp.js +48 -0
  104. package/dist/_chunks/pt-fdvyOnUp.js.map +1 -0
  105. package/dist/_chunks/ru-C94rjPGA.js +86 -0
  106. package/dist/_chunks/ru-C94rjPGA.js.map +1 -0
  107. package/dist/_chunks/ru-VWy-IB7K.mjs +86 -0
  108. package/dist/_chunks/ru-VWy-IB7K.mjs.map +1 -0
  109. package/dist/_chunks/sk-BABEhykl.js +50 -0
  110. package/dist/_chunks/sk-BABEhykl.js.map +1 -0
  111. package/dist/_chunks/sk-B_LIcepm.mjs +50 -0
  112. package/dist/_chunks/sk-B_LIcepm.mjs.map +1 -0
  113. package/dist/_chunks/sv-ABLKOokl.mjs +86 -0
  114. package/dist/_chunks/sv-ABLKOokl.mjs.map +1 -0
  115. package/dist/_chunks/sv-Be43LhA9.js +86 -0
  116. package/dist/_chunks/sv-Be43LhA9.js.map +1 -0
  117. package/dist/_chunks/th-DKyP7ueR.mjs +60 -0
  118. package/dist/_chunks/th-DKyP7ueR.mjs.map +1 -0
  119. package/dist/_chunks/th-DgVhVLhL.js +60 -0
  120. package/dist/_chunks/th-DgVhVLhL.js.map +1 -0
  121. package/dist/_chunks/tr-B_idhkEs.js +85 -0
  122. package/dist/_chunks/tr-B_idhkEs.js.map +1 -0
  123. package/dist/_chunks/tr-qa1Q5UjC.mjs +85 -0
  124. package/dist/_chunks/tr-qa1Q5UjC.mjs.map +1 -0
  125. package/dist/_chunks/uk-BmRqbeQc.mjs +49 -0
  126. package/dist/_chunks/uk-BmRqbeQc.mjs.map +1 -0
  127. package/dist/_chunks/uk-LHOivnhP.js +49 -0
  128. package/dist/_chunks/uk-LHOivnhP.js.map +1 -0
  129. package/dist/_chunks/vi-CdVRdKDw.js +50 -0
  130. package/dist/_chunks/vi-CdVRdKDw.js.map +1 -0
  131. package/dist/_chunks/vi-HW-EdMea.mjs +50 -0
  132. package/dist/_chunks/vi-HW-EdMea.mjs.map +1 -0
  133. package/dist/_chunks/zh-5hKkVPA4.mjs +86 -0
  134. package/dist/_chunks/zh-5hKkVPA4.mjs.map +1 -0
  135. package/dist/_chunks/zh-Cuq8gMnF.js +86 -0
  136. package/dist/_chunks/zh-Cuq8gMnF.js.map +1 -0
  137. package/dist/_chunks/zh-Hans-BHilK-yc.mjs +86 -0
  138. package/dist/_chunks/zh-Hans-BHilK-yc.mjs.map +1 -0
  139. package/dist/_chunks/zh-Hans-GQDMKtY4.js +86 -0
  140. package/dist/_chunks/zh-Hans-GQDMKtY4.js.map +1 -0
  141. package/dist/admin/index.js +4 -0
  142. package/dist/admin/index.js.map +1 -0
  143. package/dist/admin/index.mjs +5 -0
  144. package/dist/admin/index.mjs.map +1 -0
  145. package/package.json +13 -13
  146. package/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.js +2 -2
@@ -0,0 +1,611 @@
1
+ import { jsxs, jsx } from "react/jsx-runtime";
2
+ import * as React from "react";
3
+ import { u as useTracking, L as Layouts } from "./index-69WUS0qJ-DzUzGVgd.mjs";
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
+ import { Pencil } from "@strapi/icons";
6
+ import { translatedErrors, useNotification, useFetchClient, useAPIErrorHandler, useRBAC, Page } from "@strapi/strapi/admin";
7
+ import upperFirst from "lodash/upperFirst";
8
+ import { useIntl } from "react-intl";
9
+ import { useQueryClient, useQuery, useMutation } from "react-query";
10
+ import { Formik, Form } from "formik";
11
+ import PropTypes from "prop-types";
12
+ import { g as getTrad, P as PERMISSIONS } from "./index-B6AAcVOR.mjs";
13
+ import "lodash/isEmpty";
14
+ import * as yup from "yup";
15
+ const Input = ({
16
+ description,
17
+ disabled,
18
+ intlLabel,
19
+ error,
20
+ name,
21
+ onChange,
22
+ placeholder,
23
+ providerToEditName,
24
+ type,
25
+ value
26
+ }) => {
27
+ const { formatMessage } = useIntl();
28
+ const inputValue = name === "noName" ? `${window.strapi.backendURL}/api/connect/${providerToEditName}/callback` : value;
29
+ const label = formatMessage(
30
+ { id: intlLabel.id, defaultMessage: intlLabel.defaultMessage },
31
+ { provider: providerToEditName, ...intlLabel.values }
32
+ );
33
+ const hint = description ? formatMessage(
34
+ { id: description.id, defaultMessage: description.defaultMessage },
35
+ { provider: providerToEditName, ...description.values }
36
+ ) : "";
37
+ if (type === "bool") {
38
+ return /* @__PURE__ */ jsxs(Field.Root, { hint, name, children: [
39
+ /* @__PURE__ */ jsx(Field.Label, { children: label }),
40
+ /* @__PURE__ */ jsx(
41
+ Toggle,
42
+ {
43
+ "aria-label": name,
44
+ checked: value,
45
+ disabled,
46
+ offLabel: formatMessage({
47
+ id: "app.components.ToggleCheckbox.off-label",
48
+ defaultMessage: "Off"
49
+ }),
50
+ onLabel: formatMessage({
51
+ id: "app.components.ToggleCheckbox.on-label",
52
+ defaultMessage: "On"
53
+ }),
54
+ onChange: (e) => {
55
+ onChange({ target: { name, value: e.target.checked } });
56
+ }
57
+ }
58
+ ),
59
+ /* @__PURE__ */ jsx(Field.Hint, {})
60
+ ] });
61
+ }
62
+ const formattedPlaceholder = placeholder ? formatMessage(
63
+ { id: placeholder.id, defaultMessage: placeholder.defaultMessage },
64
+ { ...placeholder.values }
65
+ ) : "";
66
+ const errorMessage = error ? formatMessage({ id: error, defaultMessage: error }) : "";
67
+ return /* @__PURE__ */ jsxs(Field.Root, { error: errorMessage, name, children: [
68
+ /* @__PURE__ */ jsx(Field.Label, { children: label }),
69
+ /* @__PURE__ */ jsx(
70
+ TextInput,
71
+ {
72
+ disabled,
73
+ onChange,
74
+ placeholder: formattedPlaceholder,
75
+ type,
76
+ value: inputValue
77
+ }
78
+ ),
79
+ /* @__PURE__ */ jsx(Field.Error, {})
80
+ ] });
81
+ };
82
+ Input.defaultProps = {
83
+ description: null,
84
+ disabled: false,
85
+ error: "",
86
+ placeholder: null,
87
+ value: ""
88
+ };
89
+ Input.propTypes = {
90
+ description: PropTypes.shape({
91
+ id: PropTypes.string.isRequired,
92
+ defaultMessage: PropTypes.string.isRequired,
93
+ values: PropTypes.object
94
+ }),
95
+ disabled: PropTypes.bool,
96
+ error: PropTypes.string,
97
+ intlLabel: PropTypes.shape({
98
+ id: PropTypes.string.isRequired,
99
+ defaultMessage: PropTypes.string.isRequired,
100
+ values: PropTypes.object
101
+ }).isRequired,
102
+ name: PropTypes.string.isRequired,
103
+ onChange: PropTypes.func.isRequired,
104
+ placeholder: PropTypes.shape({
105
+ id: PropTypes.string.isRequired,
106
+ defaultMessage: PropTypes.string.isRequired,
107
+ values: PropTypes.object
108
+ }),
109
+ providerToEditName: PropTypes.string.isRequired,
110
+ type: PropTypes.string.isRequired,
111
+ value: PropTypes.oneOfType([PropTypes.bool, PropTypes.string])
112
+ };
113
+ const FormModal = ({
114
+ headerBreadcrumbs,
115
+ initialData,
116
+ isSubmiting,
117
+ layout,
118
+ isOpen,
119
+ onSubmit,
120
+ onToggle,
121
+ providerToEditName
122
+ }) => {
123
+ const { formatMessage } = useIntl();
124
+ if (!isOpen) {
125
+ return null;
126
+ }
127
+ return /* @__PURE__ */ jsxs(ModalLayout, { onClose: onToggle, labelledBy: "title", children: [
128
+ /* @__PURE__ */ jsx(ModalHeader, { children: /* @__PURE__ */ jsx(Breadcrumbs, { label: headerBreadcrumbs.join(", "), children: headerBreadcrumbs.map((crumb, index, arr) => /* @__PURE__ */ jsx(Crumb, { isCurrent: index === arr.length - 1, children: crumb }, crumb)) }) }),
129
+ /* @__PURE__ */ jsx(
130
+ Formik,
131
+ {
132
+ onSubmit: (values) => onSubmit(values),
133
+ initialValues: initialData,
134
+ validationSchema: layout.schema,
135
+ validateOnChange: false,
136
+ children: ({ errors, handleChange, values }) => {
137
+ return /* @__PURE__ */ jsxs(Form, { children: [
138
+ /* @__PURE__ */ jsx(ModalBody, { children: /* @__PURE__ */ jsx(Flex, { direction: "column", alignItems: "stretch", gap: 1, children: /* @__PURE__ */ jsx(Grid, { gap: 5, children: layout.form.map((row) => {
139
+ return row.map((input) => {
140
+ return /* @__PURE__ */ jsx(GridItem, { col: input.size, xs: 12, children: /* @__PURE__ */ jsx(
141
+ Input,
142
+ {
143
+ ...input,
144
+ error: errors[input.name],
145
+ onChange: handleChange,
146
+ value: values[input.name],
147
+ providerToEditName
148
+ }
149
+ ) }, input.name);
150
+ });
151
+ }) }) }) }),
152
+ /* @__PURE__ */ jsx(
153
+ ModalFooter,
154
+ {
155
+ startActions: /* @__PURE__ */ jsx(Button, { variant: "tertiary", onClick: onToggle, type: "button", children: formatMessage({
156
+ id: "app.components.Button.cancel",
157
+ defaultMessage: "Cancel"
158
+ }) }),
159
+ endActions: /* @__PURE__ */ jsx(Button, { type: "submit", loading: isSubmiting, children: formatMessage({ id: "global.save", defaultMessage: "Save" }) })
160
+ }
161
+ )
162
+ ] });
163
+ }
164
+ }
165
+ )
166
+ ] });
167
+ };
168
+ FormModal.defaultProps = {
169
+ initialData: null,
170
+ providerToEditName: null
171
+ };
172
+ FormModal.propTypes = {
173
+ headerBreadcrumbs: PropTypes.arrayOf(PropTypes.string).isRequired,
174
+ initialData: PropTypes.object,
175
+ layout: PropTypes.shape({
176
+ form: PropTypes.arrayOf(PropTypes.array),
177
+ schema: PropTypes.object
178
+ }).isRequired,
179
+ isOpen: PropTypes.bool.isRequired,
180
+ isSubmiting: PropTypes.bool.isRequired,
181
+ onSubmit: PropTypes.func.isRequired,
182
+ onToggle: PropTypes.func.isRequired,
183
+ providerToEditName: PropTypes.string
184
+ };
185
+ const callbackLabel = {
186
+ id: getTrad("PopUpForm.Providers.redirectURL.front-end.label"),
187
+ defaultMessage: "The redirect URL to your front-end app"
188
+ };
189
+ const callbackPlaceholder = {
190
+ id: "http://www.client-app.com",
191
+ defaultMessage: "http://www.client-app.com"
192
+ };
193
+ const enabledDescription = {
194
+ id: getTrad("PopUpForm.Providers.enabled.description"),
195
+ defaultMessage: "If disabled, users won't be able to use this provider."
196
+ };
197
+ const enabledLabel = {
198
+ id: getTrad("PopUpForm.Providers.enabled.label"),
199
+ defaultMessage: "Enable"
200
+ };
201
+ const keyLabel = { id: getTrad("PopUpForm.Providers.key.label"), defaultMessage: "Client ID" };
202
+ const hintLabel = {
203
+ id: getTrad("PopUpForm.Providers.redirectURL.label"),
204
+ defaultMessage: "The redirect URL to add in your {provider} application configurations"
205
+ };
206
+ const textPlaceholder = {
207
+ id: getTrad("PopUpForm.Providers.key.placeholder"),
208
+ defaultMessage: "TEXT"
209
+ };
210
+ const secretLabel = {
211
+ id: getTrad("PopUpForm.Providers.secret.label"),
212
+ defaultMessage: "Client Secret"
213
+ };
214
+ const forms = {
215
+ email: {
216
+ form: [
217
+ [
218
+ {
219
+ intlLabel: enabledLabel,
220
+ name: "enabled",
221
+ type: "bool",
222
+ description: enabledDescription,
223
+ size: 6
224
+ // TODO check if still needed
225
+ // validations: {
226
+ // required: true,
227
+ // },
228
+ }
229
+ ]
230
+ ],
231
+ schema: yup.object().shape({
232
+ enabled: yup.bool().required(translatedErrors.required.id)
233
+ })
234
+ },
235
+ providers: {
236
+ form: [
237
+ [
238
+ {
239
+ intlLabel: enabledLabel,
240
+ name: "enabled",
241
+ type: "bool",
242
+ description: enabledDescription,
243
+ size: 6,
244
+ validations: {
245
+ required: true
246
+ }
247
+ }
248
+ ],
249
+ [
250
+ {
251
+ intlLabel: keyLabel,
252
+ name: "key",
253
+ type: "text",
254
+ placeholder: textPlaceholder,
255
+ size: 12,
256
+ validations: {
257
+ required: true
258
+ }
259
+ }
260
+ ],
261
+ [
262
+ {
263
+ intlLabel: secretLabel,
264
+ name: "secret",
265
+ type: "text",
266
+ placeholder: textPlaceholder,
267
+ size: 12,
268
+ validations: {
269
+ required: true
270
+ }
271
+ }
272
+ ],
273
+ [
274
+ {
275
+ intlLabel: callbackLabel,
276
+ placeholder: callbackPlaceholder,
277
+ name: "callback",
278
+ type: "text",
279
+ size: 12,
280
+ validations: {
281
+ required: true
282
+ }
283
+ }
284
+ ],
285
+ [
286
+ {
287
+ intlLabel: hintLabel,
288
+ name: "noName",
289
+ type: "text",
290
+ validations: {},
291
+ size: 12,
292
+ disabled: true
293
+ }
294
+ ]
295
+ ],
296
+ schema: yup.object().shape({
297
+ enabled: yup.bool().required(translatedErrors.required.id),
298
+ key: yup.string().when("enabled", {
299
+ is: true,
300
+ then: yup.string().required(translatedErrors.required.id),
301
+ otherwise: yup.string()
302
+ }),
303
+ secret: yup.string().when("enabled", {
304
+ is: true,
305
+ then: yup.string().required(translatedErrors.required.id),
306
+ otherwise: yup.string()
307
+ }),
308
+ callback: yup.string().when("enabled", {
309
+ is: true,
310
+ then: yup.string().required(translatedErrors.required.id),
311
+ otherwise: yup.string()
312
+ })
313
+ })
314
+ },
315
+ providersWithSubdomain: {
316
+ form: [
317
+ [
318
+ {
319
+ intlLabel: enabledLabel,
320
+ name: "enabled",
321
+ type: "bool",
322
+ description: enabledDescription,
323
+ size: 6,
324
+ validations: {
325
+ required: true
326
+ }
327
+ }
328
+ ],
329
+ [
330
+ {
331
+ intlLabel: keyLabel,
332
+ name: "key",
333
+ type: "text",
334
+ placeholder: textPlaceholder,
335
+ size: 12,
336
+ validations: {
337
+ required: true
338
+ }
339
+ }
340
+ ],
341
+ [
342
+ {
343
+ intlLabel: secretLabel,
344
+ name: "secret",
345
+ type: "text",
346
+ placeholder: textPlaceholder,
347
+ size: 12,
348
+ validations: {
349
+ required: true
350
+ }
351
+ }
352
+ ],
353
+ [
354
+ {
355
+ intlLabel: {
356
+ id: getTrad({ id: "PopUpForm.Providers.jwksurl.label" }),
357
+ defaultMessage: "JWKS URL"
358
+ },
359
+ name: "jwksurl",
360
+ type: "text",
361
+ placeholder: textPlaceholder,
362
+ size: 12,
363
+ validations: {
364
+ required: false
365
+ }
366
+ }
367
+ ],
368
+ [
369
+ {
370
+ intlLabel: {
371
+ id: getTrad("PopUpForm.Providers.subdomain.label"),
372
+ defaultMessage: "Host URI (Subdomain)"
373
+ },
374
+ name: "subdomain",
375
+ type: "text",
376
+ placeholder: {
377
+ id: getTrad("PopUpForm.Providers.subdomain.placeholder"),
378
+ defaultMessage: "my.subdomain.com"
379
+ },
380
+ size: 12,
381
+ validations: {
382
+ required: true
383
+ }
384
+ }
385
+ ],
386
+ [
387
+ {
388
+ intlLabel: callbackLabel,
389
+ placeholder: callbackPlaceholder,
390
+ name: "callback",
391
+ type: "text",
392
+ size: 12,
393
+ validations: {
394
+ required: true
395
+ }
396
+ }
397
+ ],
398
+ [
399
+ {
400
+ intlLabel: hintLabel,
401
+ name: "noName",
402
+ type: "text",
403
+ validations: {},
404
+ size: 12,
405
+ disabled: true
406
+ }
407
+ ]
408
+ ],
409
+ schema: yup.object().shape({
410
+ enabled: yup.bool().required(translatedErrors.required.id),
411
+ key: yup.string().when("enabled", {
412
+ is: true,
413
+ then: yup.string().required(translatedErrors.required.id),
414
+ otherwise: yup.string()
415
+ }),
416
+ secret: yup.string().when("enabled", {
417
+ is: true,
418
+ then: yup.string().required(translatedErrors.required.id),
419
+ otherwise: yup.string()
420
+ }),
421
+ subdomain: yup.string().when("enabled", {
422
+ is: true,
423
+ then: yup.string().required(translatedErrors.required.id),
424
+ otherwise: yup.string()
425
+ }),
426
+ callback: yup.string().when("enabled", {
427
+ is: true,
428
+ then: yup.string().required(translatedErrors.required.id),
429
+ otherwise: yup.string()
430
+ })
431
+ })
432
+ }
433
+ };
434
+ const ProvidersPage = () => {
435
+ const { formatMessage, locale } = useIntl();
436
+ const queryClient = useQueryClient();
437
+ const { trackUsage } = useTracking();
438
+ const [isOpen, setIsOpen] = React.useState(false);
439
+ const [providerToEditName, setProviderToEditName] = React.useState(null);
440
+ const { toggleNotification } = useNotification();
441
+ const { get, put } = useFetchClient();
442
+ const { formatAPIError } = useAPIErrorHandler();
443
+ const formatter = useCollator(locale, {
444
+ sensitivity: "base"
445
+ });
446
+ const {
447
+ isLoading: isLoadingPermissions,
448
+ allowedActions: { canUpdate }
449
+ } = useRBAC({ update: PERMISSIONS.updateProviders });
450
+ const { isLoading: isLoadingData, data } = useQuery(
451
+ ["users-permissions", "get-providers"],
452
+ async () => {
453
+ const { data: data2 } = await get("/users-permissions/providers");
454
+ return data2;
455
+ },
456
+ {
457
+ initialData: {}
458
+ }
459
+ );
460
+ const submitMutation = useMutation((body) => put("/users-permissions/providers", body), {
461
+ async onSuccess() {
462
+ await queryClient.invalidateQueries(["users-permissions", "providers"]);
463
+ toggleNotification({
464
+ type: "success",
465
+ message: formatMessage({ id: getTrad("notification.success.submit") })
466
+ });
467
+ trackUsage("didEditAuthenticationProvider");
468
+ handleToggleModal();
469
+ },
470
+ onError(error) {
471
+ toggleNotification({
472
+ type: "danger",
473
+ message: formatAPIError(error)
474
+ });
475
+ },
476
+ refetchActive: false
477
+ });
478
+ const providers = Object.entries(data).reduce((acc, [name, provider]) => {
479
+ const { icon, enabled, subdomain } = provider;
480
+ acc.push({
481
+ name,
482
+ icon: icon === "envelope" ? ["fas", "envelope"] : ["fab", icon],
483
+ enabled,
484
+ subdomain
485
+ });
486
+ return acc;
487
+ }, []).sort((a, b) => formatter.compare(a.name, b.name));
488
+ const isLoading = isLoadingData || isLoadingPermissions;
489
+ const isProviderWithSubdomain = React.useMemo(() => {
490
+ if (!providerToEditName) {
491
+ return false;
492
+ }
493
+ const providerToEdit = providers.find((obj) => obj.name === providerToEditName);
494
+ return !!providerToEdit?.subdomain;
495
+ }, [providers, providerToEditName]);
496
+ const layoutToRender = React.useMemo(() => {
497
+ if (providerToEditName === "email") {
498
+ return forms.email;
499
+ }
500
+ if (isProviderWithSubdomain) {
501
+ return forms.providersWithSubdomain;
502
+ }
503
+ return forms.providers;
504
+ }, [providerToEditName, isProviderWithSubdomain]);
505
+ const handleToggleModal = () => {
506
+ setIsOpen((prev) => !prev);
507
+ };
508
+ const handleClickEdit = (provider) => {
509
+ if (canUpdate) {
510
+ setProviderToEditName(provider.name);
511
+ handleToggleModal();
512
+ }
513
+ };
514
+ const handleSubmit = async (values) => {
515
+ trackUsage("willEditAuthenticationProvider");
516
+ submitMutation.mutate({ providers: { ...data, [providerToEditName]: values } });
517
+ };
518
+ if (isLoading) {
519
+ return /* @__PURE__ */ jsx(Page.Loading, {});
520
+ }
521
+ return /* @__PURE__ */ jsxs(Layouts.Root, { children: [
522
+ /* @__PURE__ */ jsx(Page.Title, { children: formatMessage(
523
+ { id: "Settings.PageTitle", defaultMessage: "Settings - {name}" },
524
+ {
525
+ name: formatMessage({
526
+ id: getTrad("HeaderNav.link.providers"),
527
+ defaultMessage: "Providers"
528
+ })
529
+ }
530
+ ) }),
531
+ /* @__PURE__ */ jsxs(Page.Main, { children: [
532
+ /* @__PURE__ */ jsx(
533
+ Layouts.Header,
534
+ {
535
+ title: formatMessage({
536
+ id: getTrad("HeaderNav.link.providers"),
537
+ defaultMessage: "Providers"
538
+ })
539
+ }
540
+ ),
541
+ /* @__PURE__ */ jsx(Layouts.Content, { children: /* @__PURE__ */ jsxs(Table, { colCount: 3, rowCount: providers.length + 1, children: [
542
+ /* @__PURE__ */ jsx(Thead, { children: /* @__PURE__ */ jsxs(Tr, { children: [
543
+ /* @__PURE__ */ jsx(Th, { children: /* @__PURE__ */ jsx(Typography, { variant: "sigma", textColor: "neutral600", children: formatMessage({ id: "global.name", defaultMessage: "Name" }) }) }),
544
+ /* @__PURE__ */ jsx(Th, { children: /* @__PURE__ */ jsx(Typography, { variant: "sigma", textColor: "neutral600", children: formatMessage({ id: getTrad("Providers.status"), defaultMessage: "Status" }) }) }),
545
+ /* @__PURE__ */ jsx(Th, { children: /* @__PURE__ */ jsx(Typography, { variant: "sigma", children: /* @__PURE__ */ jsx(VisuallyHidden, { children: formatMessage({
546
+ id: "global.settings",
547
+ defaultMessage: "Settings"
548
+ }) }) }) })
549
+ ] }) }),
550
+ /* @__PURE__ */ jsx(Tbody, { children: providers.map((provider) => /* @__PURE__ */ jsxs(
551
+ Tr,
552
+ {
553
+ onClick: () => canUpdate ? handleClickEdit(provider) : void 0,
554
+ children: [
555
+ /* @__PURE__ */ jsx(Td, { width: "45%", children: /* @__PURE__ */ jsx(Typography, { fontWeight: "semiBold", textColor: "neutral800", children: provider.name }) }),
556
+ /* @__PURE__ */ jsx(Td, { width: "65%", children: /* @__PURE__ */ jsx(
557
+ Typography,
558
+ {
559
+ textColor: provider.enabled ? "success600" : "danger600",
560
+ "data-testid": `enable-${provider.name}`,
561
+ children: provider.enabled ? formatMessage({
562
+ id: "global.enabled",
563
+ defaultMessage: "Enabled"
564
+ }) : formatMessage({
565
+ id: "global.disabled",
566
+ defaultMessage: "Disabled"
567
+ })
568
+ }
569
+ ) }),
570
+ /* @__PURE__ */ jsx(Td, { onClick: (e) => e.stopPropagation(), children: canUpdate && /* @__PURE__ */ jsx(
571
+ IconButton,
572
+ {
573
+ onClick: () => handleClickEdit(provider),
574
+ borderWidth: 0,
575
+ label: "Edit",
576
+ children: /* @__PURE__ */ jsx(Pencil, {})
577
+ }
578
+ ) })
579
+ ]
580
+ },
581
+ provider.name
582
+ )) })
583
+ ] }) })
584
+ ] }),
585
+ /* @__PURE__ */ jsx(
586
+ FormModal,
587
+ {
588
+ initialData: data[providerToEditName],
589
+ isOpen,
590
+ isSubmiting: submitMutation.isLoading,
591
+ layout: layoutToRender,
592
+ headerBreadcrumbs: [
593
+ formatMessage({
594
+ id: getTrad("PopUpForm.header.edit.providers"),
595
+ defaultMessage: "Edit Provider"
596
+ }),
597
+ upperFirst(providerToEditName)
598
+ ],
599
+ onToggle: handleToggleModal,
600
+ onSubmit: handleSubmit,
601
+ providerToEditName
602
+ }
603
+ )
604
+ ] });
605
+ };
606
+ const ProtectedProvidersPage = () => /* @__PURE__ */ jsx(Page.Protect, { permissions: PERMISSIONS.readProviders, children: /* @__PURE__ */ jsx(ProvidersPage, {}) });
607
+ export {
608
+ ProvidersPage,
609
+ ProtectedProvidersPage as default
610
+ };
611
+ //# sourceMappingURL=index-00_Lq0-y.mjs.map
@@ -0,0 +1 @@
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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"}