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