@strapi/plugin-users-permissions 0.0.0-next.f6dca5adf05ef6bed9605a1535999ab0bbbf063e → 0.0.0-next.f86041c89a8c1545c6437a881dc613e98bc52bd7

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 (740) hide show
  1. package/.eslintignore +2 -1
  2. package/admin/src/components/BoundRoute/index.jsx +1 -1
  3. package/admin/src/components/FormModal/Input/index.jsx +1 -1
  4. package/admin/src/components/FormModal/index.jsx +1 -1
  5. package/admin/src/components/Permissions/PermissionRow/SubCategory.jsx +9 -2
  6. package/admin/src/components/Policies/index.jsx +2 -1
  7. package/admin/src/components/UsersPermissions/index.jsx +1 -0
  8. package/admin/src/index.js +2 -2
  9. package/admin/src/pages/AdvancedSettings/index.jsx +1 -1
  10. package/admin/src/pages/EmailTemplates/components/EmailForm.jsx +3 -2
  11. package/admin/src/pages/EmailTemplates/components/EmailTable.jsx +3 -3
  12. package/admin/src/pages/Providers/index.jsx +74 -76
  13. package/admin/src/pages/Roles/index.jsx +1 -1
  14. package/admin/src/pages/Roles/pages/CreatePage.jsx +20 -7
  15. package/admin/src/pages/Roles/pages/EditPage.jsx +12 -7
  16. package/admin/src/pages/Roles/pages/ListPage/components/TableBody.jsx +2 -2
  17. package/admin/src/pages/Roles/pages/ListPage/index.jsx +91 -93
  18. package/admin/src/pluginId.js +2 -2
  19. package/admin/src/translations/en.json +1 -0
  20. package/admin/src/translations/uk.json +41 -4
  21. package/admin/src/utils/formatPluginName.js +1 -1
  22. package/dist/admin/components/BoundRoute/getMethodColor.js +49 -0
  23. package/dist/admin/components/BoundRoute/getMethodColor.js.map +1 -0
  24. package/dist/admin/components/BoundRoute/getMethodColor.mjs +47 -0
  25. package/dist/admin/components/BoundRoute/getMethodColor.mjs.map +1 -0
  26. package/dist/admin/components/BoundRoute/index.js +98 -0
  27. package/dist/admin/components/BoundRoute/index.js.map +1 -0
  28. package/dist/admin/components/BoundRoute/index.mjs +96 -0
  29. package/dist/admin/components/BoundRoute/index.mjs.map +1 -0
  30. package/dist/admin/components/FormModal/Input/index.js +123 -0
  31. package/dist/admin/components/FormModal/Input/index.js.map +1 -0
  32. package/dist/admin/components/FormModal/Input/index.mjs +121 -0
  33. package/dist/admin/components/FormModal/Input/index.mjs.map +1 -0
  34. package/dist/admin/components/FormModal/index.js +110 -0
  35. package/dist/admin/components/FormModal/index.js.map +1 -0
  36. package/dist/admin/components/FormModal/index.mjs +108 -0
  37. package/dist/admin/components/FormModal/index.mjs.map +1 -0
  38. package/dist/admin/components/Permissions/PermissionRow/CheckboxWrapper.js +33 -0
  39. package/dist/admin/components/Permissions/PermissionRow/CheckboxWrapper.js.map +1 -0
  40. package/dist/admin/components/Permissions/PermissionRow/CheckboxWrapper.mjs +31 -0
  41. package/dist/admin/components/Permissions/PermissionRow/CheckboxWrapper.mjs.map +1 -0
  42. package/dist/admin/components/Permissions/PermissionRow/SubCategory.js +158 -0
  43. package/dist/admin/components/Permissions/PermissionRow/SubCategory.js.map +1 -0
  44. package/dist/admin/components/Permissions/PermissionRow/SubCategory.mjs +156 -0
  45. package/dist/admin/components/Permissions/PermissionRow/SubCategory.mjs.map +1 -0
  46. package/dist/admin/components/Permissions/PermissionRow/index.js +50 -0
  47. package/dist/admin/components/Permissions/PermissionRow/index.js.map +1 -0
  48. package/dist/admin/components/Permissions/PermissionRow/index.mjs +48 -0
  49. package/dist/admin/components/Permissions/PermissionRow/index.mjs.map +1 -0
  50. package/dist/admin/components/Permissions/index.js +52 -0
  51. package/dist/admin/components/Permissions/index.js.map +1 -0
  52. package/dist/admin/components/Permissions/index.mjs +50 -0
  53. package/dist/admin/components/Permissions/index.mjs.map +1 -0
  54. package/dist/admin/components/Permissions/init.js +15 -0
  55. package/dist/admin/components/Permissions/init.js.map +1 -0
  56. package/dist/admin/components/Permissions/init.mjs +13 -0
  57. package/dist/admin/components/Permissions/init.mjs.map +1 -0
  58. package/dist/admin/components/Permissions/reducer.js +34 -0
  59. package/dist/admin/components/Permissions/reducer.js.map +1 -0
  60. package/dist/admin/components/Permissions/reducer.mjs +31 -0
  61. package/dist/admin/components/Permissions/reducer.mjs.map +1 -0
  62. package/dist/admin/components/Policies/index.js +68 -0
  63. package/dist/admin/components/Policies/index.js.map +1 -0
  64. package/dist/admin/components/Policies/index.mjs +66 -0
  65. package/dist/admin/components/Policies/index.mjs.map +1 -0
  66. package/dist/admin/components/UsersPermissions/index.js +116 -0
  67. package/dist/admin/components/UsersPermissions/index.js.map +1 -0
  68. package/dist/admin/components/UsersPermissions/index.mjs +114 -0
  69. package/dist/admin/components/UsersPermissions/index.mjs.map +1 -0
  70. package/dist/admin/components/UsersPermissions/init.js +13 -0
  71. package/dist/admin/components/UsersPermissions/init.js.map +1 -0
  72. package/dist/admin/components/UsersPermissions/init.mjs +11 -0
  73. package/dist/admin/components/UsersPermissions/init.mjs.map +1 -0
  74. package/dist/admin/components/UsersPermissions/reducer.js +73 -0
  75. package/dist/admin/components/UsersPermissions/reducer.js.map +1 -0
  76. package/dist/admin/components/UsersPermissions/reducer.mjs +68 -0
  77. package/dist/admin/components/UsersPermissions/reducer.mjs.map +1 -0
  78. package/dist/admin/constants.js +81 -0
  79. package/dist/admin/constants.js.map +1 -0
  80. package/dist/admin/constants.mjs +79 -0
  81. package/dist/admin/constants.mjs.map +1 -0
  82. package/dist/admin/contexts/UsersPermissionsContext/index.js +23 -0
  83. package/dist/admin/contexts/UsersPermissionsContext/index.js.map +1 -0
  84. package/dist/admin/contexts/UsersPermissionsContext/index.mjs +19 -0
  85. package/dist/admin/contexts/UsersPermissionsContext/index.mjs.map +1 -0
  86. package/dist/admin/index.js +124 -3
  87. package/dist/admin/index.js.map +1 -1
  88. package/dist/admin/index.mjs +119 -3
  89. package/dist/admin/index.mjs.map +1 -1
  90. package/dist/admin/package.json.js +14 -0
  91. package/dist/admin/package.json.js.map +1 -0
  92. package/dist/admin/package.json.mjs +11 -0
  93. package/dist/admin/package.json.mjs.map +1 -0
  94. package/dist/admin/pages/AdvancedSettings/index.js +194 -0
  95. package/dist/admin/pages/AdvancedSettings/index.js.map +1 -0
  96. package/dist/admin/pages/AdvancedSettings/index.mjs +191 -0
  97. package/dist/admin/pages/AdvancedSettings/index.mjs.map +1 -0
  98. package/dist/admin/pages/AdvancedSettings/utils/layout.js +83 -0
  99. package/dist/admin/pages/AdvancedSettings/utils/layout.js.map +1 -0
  100. package/dist/admin/pages/AdvancedSettings/utils/layout.mjs +81 -0
  101. package/dist/admin/pages/AdvancedSettings/utils/layout.mjs.map +1 -0
  102. package/dist/admin/pages/AdvancedSettings/utils/schema.js +40 -0
  103. package/dist/admin/pages/AdvancedSettings/utils/schema.js.map +1 -0
  104. package/dist/admin/pages/AdvancedSettings/utils/schema.mjs +19 -0
  105. package/dist/admin/pages/AdvancedSettings/utils/schema.mjs.map +1 -0
  106. package/dist/admin/pages/EmailTemplates/components/EmailForm.js +172 -0
  107. package/dist/admin/pages/EmailTemplates/components/EmailForm.js.map +1 -0
  108. package/dist/admin/pages/EmailTemplates/components/EmailForm.mjs +170 -0
  109. package/dist/admin/pages/EmailTemplates/components/EmailForm.mjs.map +1 -0
  110. package/dist/admin/pages/EmailTemplates/components/EmailTable.js +145 -0
  111. package/dist/admin/pages/EmailTemplates/components/EmailTable.js.map +1 -0
  112. package/dist/admin/pages/EmailTemplates/components/EmailTable.mjs +143 -0
  113. package/dist/admin/pages/EmailTemplates/components/EmailTable.mjs.map +1 -0
  114. package/dist/admin/pages/EmailTemplates/index.js +157 -0
  115. package/dist/admin/pages/EmailTemplates/index.js.map +1 -0
  116. package/dist/admin/pages/EmailTemplates/index.mjs +135 -0
  117. package/dist/admin/pages/EmailTemplates/index.mjs.map +1 -0
  118. package/dist/admin/pages/EmailTemplates/utils/schema.js +50 -0
  119. package/dist/admin/pages/EmailTemplates/utils/schema.js.map +1 -0
  120. package/dist/admin/pages/EmailTemplates/utils/schema.mjs +29 -0
  121. package/dist/admin/pages/EmailTemplates/utils/schema.mjs.map +1 -0
  122. package/dist/admin/pages/Providers/index.js +274 -0
  123. package/dist/admin/pages/Providers/index.js.map +1 -0
  124. package/dist/admin/pages/Providers/index.mjs +250 -0
  125. package/dist/admin/pages/Providers/index.mjs.map +1 -0
  126. package/dist/admin/pages/Providers/utils/forms.js +281 -0
  127. package/dist/admin/pages/Providers/utils/forms.js.map +1 -0
  128. package/dist/admin/pages/Providers/utils/forms.mjs +260 -0
  129. package/dist/admin/pages/Providers/utils/forms.mjs.map +1 -0
  130. package/dist/admin/pages/Roles/constants.js +31 -0
  131. package/dist/admin/pages/Roles/constants.js.map +1 -0
  132. package/dist/admin/pages/Roles/constants.mjs +10 -0
  133. package/dist/admin/pages/Roles/constants.mjs.map +1 -0
  134. package/dist/admin/pages/Roles/hooks/usePlugins.js +78 -0
  135. package/dist/admin/pages/Roles/hooks/usePlugins.js.map +1 -0
  136. package/dist/admin/pages/Roles/hooks/usePlugins.mjs +76 -0
  137. package/dist/admin/pages/Roles/hooks/usePlugins.mjs.map +1 -0
  138. package/dist/admin/pages/Roles/index.js +35 -0
  139. package/dist/admin/pages/Roles/index.js.map +1 -0
  140. package/dist/admin/pages/Roles/index.mjs +33 -0
  141. package/dist/admin/pages/Roles/index.mjs.map +1 -0
  142. package/dist/admin/pages/Roles/pages/CreatePage.js +238 -0
  143. package/dist/admin/pages/Roles/pages/CreatePage.js.map +1 -0
  144. package/dist/admin/pages/Roles/pages/CreatePage.mjs +216 -0
  145. package/dist/admin/pages/Roles/pages/CreatePage.mjs.map +1 -0
  146. package/dist/admin/pages/Roles/pages/EditPage.js +239 -0
  147. package/dist/admin/pages/Roles/pages/EditPage.js.map +1 -0
  148. package/dist/admin/pages/Roles/pages/EditPage.mjs +217 -0
  149. package/dist/admin/pages/Roles/pages/EditPage.mjs.map +1 -0
  150. package/dist/admin/pages/Roles/pages/ListPage/components/TableBody.js +125 -0
  151. package/dist/admin/pages/Roles/pages/ListPage/components/TableBody.js.map +1 -0
  152. package/dist/admin/pages/Roles/pages/ListPage/components/TableBody.mjs +123 -0
  153. package/dist/admin/pages/Roles/pages/ListPage/components/TableBody.mjs.map +1 -0
  154. package/dist/admin/pages/Roles/pages/ListPage/index.js +233 -0
  155. package/dist/admin/pages/Roles/pages/ListPage/index.js.map +1 -0
  156. package/dist/admin/pages/Roles/pages/ListPage/index.mjs +230 -0
  157. package/dist/admin/pages/Roles/pages/ListPage/index.mjs.map +1 -0
  158. package/dist/admin/pluginId.js +8 -0
  159. package/dist/admin/pluginId.js.map +1 -0
  160. package/dist/admin/pluginId.mjs +6 -0
  161. package/dist/admin/pluginId.mjs.map +1 -0
  162. package/dist/admin/translations/ar.json.js +45 -0
  163. package/dist/admin/translations/ar.json.js.map +1 -0
  164. package/dist/admin/translations/ar.json.mjs +43 -0
  165. package/dist/admin/translations/ar.json.mjs.map +1 -0
  166. package/dist/admin/translations/cs.json.js +51 -0
  167. package/dist/admin/translations/cs.json.js.map +1 -0
  168. package/dist/admin/translations/cs.json.mjs +49 -0
  169. package/dist/admin/translations/cs.json.mjs.map +1 -0
  170. package/dist/admin/translations/de.json.js +63 -0
  171. package/dist/admin/translations/de.json.js.map +1 -0
  172. package/dist/admin/translations/de.json.mjs +61 -0
  173. package/dist/admin/translations/de.json.mjs.map +1 -0
  174. package/dist/admin/translations/dk.json.js +87 -0
  175. package/dist/admin/translations/dk.json.js.map +1 -0
  176. package/dist/admin/translations/dk.json.mjs +85 -0
  177. package/dist/admin/translations/dk.json.mjs.map +1 -0
  178. package/dist/admin/translations/en.json.js +88 -0
  179. package/dist/admin/translations/en.json.js.map +1 -0
  180. package/dist/admin/translations/en.json.mjs +86 -0
  181. package/dist/admin/translations/en.json.mjs.map +1 -0
  182. package/dist/admin/translations/es.json.js +87 -0
  183. package/dist/admin/translations/es.json.js.map +1 -0
  184. package/dist/admin/translations/es.json.mjs +85 -0
  185. package/dist/admin/translations/es.json.mjs.map +1 -0
  186. package/dist/admin/translations/fr.json.js +51 -0
  187. package/dist/admin/translations/fr.json.js.map +1 -0
  188. package/dist/admin/translations/fr.json.mjs +49 -0
  189. package/dist/admin/translations/fr.json.mjs.map +1 -0
  190. package/dist/admin/translations/id.json.js +63 -0
  191. package/dist/admin/translations/id.json.js.map +1 -0
  192. package/dist/admin/translations/id.json.mjs +61 -0
  193. package/dist/admin/translations/id.json.mjs.map +1 -0
  194. package/dist/admin/translations/it.json.js +63 -0
  195. package/dist/admin/translations/it.json.js.map +1 -0
  196. package/dist/admin/translations/it.json.mjs +61 -0
  197. package/dist/admin/translations/it.json.mjs.map +1 -0
  198. package/dist/admin/translations/ja.json.js +49 -0
  199. package/dist/admin/translations/ja.json.js.map +1 -0
  200. package/dist/admin/translations/ja.json.mjs +47 -0
  201. package/dist/admin/translations/ja.json.mjs.map +1 -0
  202. package/dist/admin/translations/ko.json.js +87 -0
  203. package/dist/admin/translations/ko.json.js.map +1 -0
  204. package/dist/admin/translations/ko.json.mjs +85 -0
  205. package/dist/admin/translations/ko.json.mjs.map +1 -0
  206. package/dist/admin/translations/ms.json.js +50 -0
  207. package/dist/admin/translations/ms.json.js.map +1 -0
  208. package/dist/admin/translations/ms.json.mjs +48 -0
  209. package/dist/admin/translations/ms.json.mjs.map +1 -0
  210. package/dist/admin/translations/nl.json.js +49 -0
  211. package/dist/admin/translations/nl.json.js.map +1 -0
  212. package/dist/admin/translations/nl.json.mjs +47 -0
  213. package/dist/admin/translations/nl.json.mjs.map +1 -0
  214. package/dist/admin/translations/pl.json.js +87 -0
  215. package/dist/admin/translations/pl.json.js.map +1 -0
  216. package/dist/admin/translations/pl.json.mjs +85 -0
  217. package/dist/admin/translations/pl.json.mjs.map +1 -0
  218. package/dist/admin/translations/pt-BR.json.js +45 -0
  219. package/dist/admin/translations/pt-BR.json.js.map +1 -0
  220. package/dist/admin/translations/pt-BR.json.mjs +43 -0
  221. package/dist/admin/translations/pt-BR.json.mjs.map +1 -0
  222. package/dist/admin/translations/pt.json.js +49 -0
  223. package/dist/admin/translations/pt.json.js.map +1 -0
  224. package/dist/admin/translations/pt.json.mjs +47 -0
  225. package/dist/admin/translations/pt.json.mjs.map +1 -0
  226. package/dist/admin/translations/ru.json.js +87 -0
  227. package/dist/admin/translations/ru.json.js.map +1 -0
  228. package/dist/admin/translations/ru.json.mjs +85 -0
  229. package/dist/admin/translations/ru.json.mjs.map +1 -0
  230. package/dist/admin/translations/sk.json.js +51 -0
  231. package/dist/admin/translations/sk.json.js.map +1 -0
  232. package/dist/admin/translations/sk.json.mjs +49 -0
  233. package/dist/admin/translations/sk.json.mjs.map +1 -0
  234. package/dist/admin/translations/sv.json.js +87 -0
  235. package/dist/admin/translations/sv.json.js.map +1 -0
  236. package/dist/admin/translations/sv.json.mjs +85 -0
  237. package/dist/admin/translations/sv.json.mjs.map +1 -0
  238. package/dist/admin/translations/th.json.js +61 -0
  239. package/dist/admin/translations/th.json.js.map +1 -0
  240. package/dist/admin/translations/th.json.mjs +59 -0
  241. package/dist/admin/translations/th.json.mjs.map +1 -0
  242. package/dist/admin/translations/tr.json.js +86 -0
  243. package/dist/admin/translations/tr.json.js.map +1 -0
  244. package/dist/admin/translations/tr.json.mjs +84 -0
  245. package/dist/admin/translations/tr.json.mjs.map +1 -0
  246. package/dist/admin/translations/uk.json.js +87 -0
  247. package/dist/admin/translations/uk.json.js.map +1 -0
  248. package/dist/admin/translations/uk.json.mjs +85 -0
  249. package/dist/admin/translations/uk.json.mjs.map +1 -0
  250. package/dist/admin/translations/vi.json.js +51 -0
  251. package/dist/admin/translations/vi.json.js.map +1 -0
  252. package/dist/admin/translations/vi.json.mjs +49 -0
  253. package/dist/admin/translations/vi.json.mjs.map +1 -0
  254. package/dist/admin/translations/zh-Hans.json.js +87 -0
  255. package/dist/admin/translations/zh-Hans.json.js.map +1 -0
  256. package/dist/admin/translations/zh-Hans.json.mjs +85 -0
  257. package/dist/admin/translations/zh-Hans.json.mjs.map +1 -0
  258. package/dist/admin/translations/zh.json.js +87 -0
  259. package/dist/admin/translations/zh.json.js.map +1 -0
  260. package/dist/admin/translations/zh.json.mjs +85 -0
  261. package/dist/admin/translations/zh.json.mjs.map +1 -0
  262. package/dist/admin/utils/cleanPermissions.js +24 -0
  263. package/dist/admin/utils/cleanPermissions.js.map +1 -0
  264. package/dist/admin/utils/cleanPermissions.mjs +22 -0
  265. package/dist/admin/utils/cleanPermissions.mjs.map +1 -0
  266. package/dist/admin/utils/formatPluginName.js +29 -0
  267. package/dist/admin/utils/formatPluginName.js.map +1 -0
  268. package/dist/admin/utils/formatPluginName.mjs +27 -0
  269. package/dist/admin/utils/formatPluginName.mjs.map +1 -0
  270. package/dist/admin/utils/getTrad.js +8 -0
  271. package/dist/admin/utils/getTrad.js.map +1 -0
  272. package/dist/admin/utils/getTrad.mjs +6 -0
  273. package/dist/admin/utils/getTrad.mjs.map +1 -0
  274. package/dist/admin/utils/prefixPluginTranslations.js +11 -0
  275. package/dist/admin/utils/prefixPluginTranslations.js.map +1 -0
  276. package/dist/admin/utils/prefixPluginTranslations.mjs +9 -0
  277. package/dist/admin/utils/prefixPluginTranslations.mjs.map +1 -0
  278. package/dist/server/_virtual/_commonjsHelpers.js +8 -0
  279. package/dist/server/_virtual/_commonjsHelpers.js.map +1 -0
  280. package/dist/server/_virtual/_commonjsHelpers.mjs +6 -0
  281. package/dist/server/_virtual/_commonjsHelpers.mjs.map +1 -0
  282. package/dist/server/bootstrap/index.js +166 -0
  283. package/dist/server/bootstrap/index.js.map +1 -0
  284. package/dist/server/bootstrap/index.mjs +164 -0
  285. package/dist/server/bootstrap/index.mjs.map +1 -0
  286. package/dist/server/bootstrap/users-permissions-actions.js +98 -0
  287. package/dist/server/bootstrap/users-permissions-actions.js.map +1 -0
  288. package/dist/server/bootstrap/users-permissions-actions.mjs +96 -0
  289. package/dist/server/bootstrap/users-permissions-actions.mjs.map +1 -0
  290. package/dist/server/config.js +70 -0
  291. package/dist/server/config.js.map +1 -0
  292. package/dist/server/config.mjs +68 -0
  293. package/dist/server/config.mjs.map +1 -0
  294. package/dist/server/content-types/index.js +30 -0
  295. package/dist/server/content-types/index.js.map +1 -0
  296. package/dist/server/content-types/index.mjs +28 -0
  297. package/dist/server/content-types/index.mjs.map +1 -0
  298. package/dist/server/content-types/permission/index.js +44 -0
  299. package/dist/server/content-types/permission/index.js.map +1 -0
  300. package/dist/server/content-types/permission/index.mjs +42 -0
  301. package/dist/server/content-types/permission/index.mjs.map +1 -0
  302. package/dist/server/content-types/role/index.js +61 -0
  303. package/dist/server/content-types/role/index.js.map +1 -0
  304. package/dist/server/content-types/role/index.mjs +59 -0
  305. package/dist/server/content-types/role/index.mjs.map +1 -0
  306. package/dist/server/content-types/user/index.js +84 -0
  307. package/dist/server/content-types/user/index.js.map +1 -0
  308. package/dist/server/content-types/user/index.mjs +82 -0
  309. package/dist/server/content-types/user/index.mjs.map +1 -0
  310. package/dist/server/content-types/user/schema-config.js +25 -0
  311. package/dist/server/content-types/user/schema-config.js.map +1 -0
  312. package/dist/server/content-types/user/schema-config.mjs +23 -0
  313. package/dist/server/content-types/user/schema-config.mjs.map +1 -0
  314. package/dist/server/controllers/auth.js +630 -0
  315. package/dist/server/controllers/auth.js.map +1 -0
  316. package/dist/server/controllers/auth.mjs +628 -0
  317. package/dist/server/controllers/auth.mjs.map +1 -0
  318. package/dist/server/controllers/content-manager-user.js +168 -0
  319. package/dist/server/controllers/content-manager-user.js.map +1 -0
  320. package/dist/server/controllers/content-manager-user.mjs +166 -0
  321. package/dist/server/controllers/content-manager-user.mjs.map +1 -0
  322. package/dist/server/controllers/index.js +33 -0
  323. package/dist/server/controllers/index.js.map +1 -0
  324. package/dist/server/controllers/index.mjs +31 -0
  325. package/dist/server/controllers/index.mjs.map +1 -0
  326. package/dist/server/controllers/permissions.js +37 -0
  327. package/dist/server/controllers/permissions.js.map +1 -0
  328. package/dist/server/controllers/permissions.mjs +35 -0
  329. package/dist/server/controllers/permissions.mjs.map +1 -0
  330. package/dist/server/controllers/role.js +91 -0
  331. package/dist/server/controllers/role.js.map +1 -0
  332. package/dist/server/controllers/role.mjs +89 -0
  333. package/dist/server/controllers/role.mjs.map +1 -0
  334. package/dist/server/controllers/settings.js +107 -0
  335. package/dist/server/controllers/settings.js.map +1 -0
  336. package/dist/server/controllers/settings.mjs +105 -0
  337. package/dist/server/controllers/settings.mjs.map +1 -0
  338. package/dist/server/controllers/user.js +201 -0
  339. package/dist/server/controllers/user.js.map +1 -0
  340. package/dist/server/controllers/user.mjs +199 -0
  341. package/dist/server/controllers/user.mjs.map +1 -0
  342. package/dist/server/controllers/validation/auth.js +131 -0
  343. package/dist/server/controllers/validation/auth.js.map +1 -0
  344. package/dist/server/controllers/validation/auth.mjs +129 -0
  345. package/dist/server/controllers/validation/auth.mjs.map +1 -0
  346. package/dist/server/controllers/validation/email-template.js +72 -0
  347. package/dist/server/controllers/validation/email-template.js.map +1 -0
  348. package/dist/server/controllers/validation/email-template.mjs +70 -0
  349. package/dist/server/controllers/validation/email-template.mjs.map +1 -0
  350. package/dist/server/controllers/validation/user.js +54 -0
  351. package/dist/server/controllers/validation/user.js.map +1 -0
  352. package/dist/server/controllers/validation/user.mjs +52 -0
  353. package/dist/server/controllers/validation/user.mjs.map +1 -0
  354. package/dist/server/graphql/index.js +66 -0
  355. package/dist/server/graphql/index.js.map +1 -0
  356. package/dist/server/graphql/index.mjs +64 -0
  357. package/dist/server/graphql/index.mjs.map +1 -0
  358. package/dist/server/graphql/mutations/auth/change-password.js +40 -0
  359. package/dist/server/graphql/mutations/auth/change-password.js.map +1 -0
  360. package/dist/server/graphql/mutations/auth/change-password.mjs +38 -0
  361. package/dist/server/graphql/mutations/auth/change-password.mjs.map +1 -0
  362. package/dist/server/graphql/mutations/auth/email-confirmation.js +38 -0
  363. package/dist/server/graphql/mutations/auth/email-confirmation.js.map +1 -0
  364. package/dist/server/graphql/mutations/auth/email-confirmation.mjs +36 -0
  365. package/dist/server/graphql/mutations/auth/email-confirmation.mjs.map +1 -0
  366. package/dist/server/graphql/mutations/auth/forgot-password.js +37 -0
  367. package/dist/server/graphql/mutations/auth/forgot-password.js.map +1 -0
  368. package/dist/server/graphql/mutations/auth/forgot-password.mjs +35 -0
  369. package/dist/server/graphql/mutations/auth/forgot-password.mjs.map +1 -0
  370. package/dist/server/graphql/mutations/auth/login.js +40 -0
  371. package/dist/server/graphql/mutations/auth/login.js.map +1 -0
  372. package/dist/server/graphql/mutations/auth/login.mjs +38 -0
  373. package/dist/server/graphql/mutations/auth/login.mjs.map +1 -0
  374. package/dist/server/graphql/mutations/auth/register.js +38 -0
  375. package/dist/server/graphql/mutations/auth/register.js.map +1 -0
  376. package/dist/server/graphql/mutations/auth/register.mjs +36 -0
  377. package/dist/server/graphql/mutations/auth/register.mjs.map +1 -0
  378. package/dist/server/graphql/mutations/auth/reset-password.js +40 -0
  379. package/dist/server/graphql/mutations/auth/reset-password.js.map +1 -0
  380. package/dist/server/graphql/mutations/auth/reset-password.mjs +38 -0
  381. package/dist/server/graphql/mutations/auth/reset-password.mjs.map +1 -0
  382. package/dist/server/graphql/mutations/crud/role/create-role.js +37 -0
  383. package/dist/server/graphql/mutations/crud/role/create-role.js.map +1 -0
  384. package/dist/server/graphql/mutations/crud/role/create-role.mjs +35 -0
  385. package/dist/server/graphql/mutations/crud/role/create-role.mjs.map +1 -0
  386. package/dist/server/graphql/mutations/crud/role/delete-role.js +32 -0
  387. package/dist/server/graphql/mutations/crud/role/delete-role.js.map +1 -0
  388. package/dist/server/graphql/mutations/crud/role/delete-role.mjs +30 -0
  389. package/dist/server/graphql/mutations/crud/role/delete-role.mjs.map +1 -0
  390. package/dist/server/graphql/mutations/crud/role/update-role.js +39 -0
  391. package/dist/server/graphql/mutations/crud/role/update-role.js.map +1 -0
  392. package/dist/server/graphql/mutations/crud/role/update-role.mjs +37 -0
  393. package/dist/server/graphql/mutations/crud/role/update-role.mjs.map +1 -0
  394. package/dist/server/graphql/mutations/crud/user/create-user.js +46 -0
  395. package/dist/server/graphql/mutations/crud/user/create-user.js.map +1 -0
  396. package/dist/server/graphql/mutations/crud/user/create-user.mjs +44 -0
  397. package/dist/server/graphql/mutations/crud/user/create-user.mjs.map +1 -0
  398. package/dist/server/graphql/mutations/crud/user/delete-user.js +44 -0
  399. package/dist/server/graphql/mutations/crud/user/delete-user.js.map +1 -0
  400. package/dist/server/graphql/mutations/crud/user/delete-user.mjs +42 -0
  401. package/dist/server/graphql/mutations/crud/user/delete-user.mjs.map +1 -0
  402. package/dist/server/graphql/mutations/crud/user/update-user.js +49 -0
  403. package/dist/server/graphql/mutations/crud/user/update-user.js.map +1 -0
  404. package/dist/server/graphql/mutations/crud/user/update-user.mjs +47 -0
  405. package/dist/server/graphql/mutations/crud/user/update-user.mjs.map +1 -0
  406. package/dist/server/graphql/mutations/index.js +58 -0
  407. package/dist/server/graphql/mutations/index.js.map +1 -0
  408. package/dist/server/graphql/mutations/index.mjs +56 -0
  409. package/dist/server/graphql/mutations/index.mjs.map +1 -0
  410. package/dist/server/graphql/queries/index.js +25 -0
  411. package/dist/server/graphql/queries/index.js.map +1 -0
  412. package/dist/server/graphql/queries/index.mjs +23 -0
  413. package/dist/server/graphql/queries/index.mjs.map +1 -0
  414. package/dist/server/graphql/queries/me.js +23 -0
  415. package/dist/server/graphql/queries/me.js.map +1 -0
  416. package/dist/server/graphql/queries/me.mjs +21 -0
  417. package/dist/server/graphql/queries/me.mjs.map +1 -0
  418. package/dist/server/graphql/resolvers-configs.js +93 -0
  419. package/dist/server/graphql/resolvers-configs.js.map +1 -0
  420. package/dist/server/graphql/resolvers-configs.mjs +91 -0
  421. package/dist/server/graphql/resolvers-configs.mjs.map +1 -0
  422. package/dist/server/graphql/types/create-role-payload.js +20 -0
  423. package/dist/server/graphql/types/create-role-payload.js.map +1 -0
  424. package/dist/server/graphql/types/create-role-payload.mjs +18 -0
  425. package/dist/server/graphql/types/create-role-payload.mjs.map +1 -0
  426. package/dist/server/graphql/types/delete-role-payload.js +20 -0
  427. package/dist/server/graphql/types/delete-role-payload.js.map +1 -0
  428. package/dist/server/graphql/types/delete-role-payload.mjs +18 -0
  429. package/dist/server/graphql/types/delete-role-payload.mjs.map +1 -0
  430. package/dist/server/graphql/types/index.js +41 -0
  431. package/dist/server/graphql/types/index.js.map +1 -0
  432. package/dist/server/graphql/types/index.mjs +39 -0
  433. package/dist/server/graphql/types/index.mjs.map +1 -0
  434. package/dist/server/graphql/types/login-input.js +24 -0
  435. package/dist/server/graphql/types/login-input.js.map +1 -0
  436. package/dist/server/graphql/types/login-input.mjs +22 -0
  437. package/dist/server/graphql/types/login-input.mjs.map +1 -0
  438. package/dist/server/graphql/types/login-payload.js +23 -0
  439. package/dist/server/graphql/types/login-payload.js.map +1 -0
  440. package/dist/server/graphql/types/login-payload.mjs +21 -0
  441. package/dist/server/graphql/types/login-payload.mjs.map +1 -0
  442. package/dist/server/graphql/types/me-role.js +23 -0
  443. package/dist/server/graphql/types/me-role.js.map +1 -0
  444. package/dist/server/graphql/types/me-role.mjs +21 -0
  445. package/dist/server/graphql/types/me-role.mjs.map +1 -0
  446. package/dist/server/graphql/types/me.js +28 -0
  447. package/dist/server/graphql/types/me.js.map +1 -0
  448. package/dist/server/graphql/types/me.mjs +26 -0
  449. package/dist/server/graphql/types/me.mjs.map +1 -0
  450. package/dist/server/graphql/types/password-payload.js +20 -0
  451. package/dist/server/graphql/types/password-payload.js.map +1 -0
  452. package/dist/server/graphql/types/password-payload.mjs +18 -0
  453. package/dist/server/graphql/types/password-payload.mjs.map +1 -0
  454. package/dist/server/graphql/types/register-input.js +22 -0
  455. package/dist/server/graphql/types/register-input.js.map +1 -0
  456. package/dist/server/graphql/types/register-input.mjs +20 -0
  457. package/dist/server/graphql/types/register-input.mjs.map +1 -0
  458. package/dist/server/graphql/types/update-role-payload.js +20 -0
  459. package/dist/server/graphql/types/update-role-payload.js.map +1 -0
  460. package/dist/server/graphql/types/update-role-payload.mjs +18 -0
  461. package/dist/server/graphql/types/update-role-payload.mjs.map +1 -0
  462. package/dist/server/graphql/types/user-input.js +26 -0
  463. package/dist/server/graphql/types/user-input.js.map +1 -0
  464. package/dist/server/graphql/types/user-input.mjs +24 -0
  465. package/dist/server/graphql/types/user-input.mjs.map +1 -0
  466. package/dist/server/graphql/utils.js +32 -0
  467. package/dist/server/graphql/utils.js.map +1 -0
  468. package/dist/server/graphql/utils.mjs +30 -0
  469. package/dist/server/graphql/utils.mjs.map +1 -0
  470. package/dist/server/index.js +10 -0
  471. package/dist/server/index.js.map +1 -0
  472. package/dist/server/index.mjs +8 -0
  473. package/dist/server/index.mjs.map +1 -0
  474. package/dist/server/index2.js +39 -0
  475. package/dist/server/index2.js.map +1 -0
  476. package/dist/server/index2.mjs +37 -0
  477. package/dist/server/index2.mjs.map +1 -0
  478. package/dist/server/middlewares/index.js +18 -0
  479. package/dist/server/middlewares/index.js.map +1 -0
  480. package/dist/server/middlewares/index.mjs +16 -0
  481. package/dist/server/middlewares/index.mjs.map +1 -0
  482. package/dist/server/middlewares/rateLimit.js +51 -0
  483. package/dist/server/middlewares/rateLimit.js.map +1 -0
  484. package/dist/server/middlewares/rateLimit.mjs +49 -0
  485. package/dist/server/middlewares/rateLimit.mjs.map +1 -0
  486. package/dist/server/register.js +41 -0
  487. package/dist/server/register.js.map +1 -0
  488. package/dist/server/register.mjs +39 -0
  489. package/dist/server/register.mjs.map +1 -0
  490. package/dist/server/routes/admin/index.js +27 -0
  491. package/dist/server/routes/admin/index.js.map +1 -0
  492. package/dist/server/routes/admin/index.mjs +25 -0
  493. package/dist/server/routes/admin/index.mjs.map +1 -0
  494. package/dist/server/routes/admin/permissions.js +29 -0
  495. package/dist/server/routes/admin/permissions.js.map +1 -0
  496. package/dist/server/routes/admin/permissions.mjs +27 -0
  497. package/dist/server/routes/admin/permissions.mjs.map +1 -0
  498. package/dist/server/routes/admin/role.js +99 -0
  499. package/dist/server/routes/admin/role.js.map +1 -0
  500. package/dist/server/routes/admin/role.mjs +97 -0
  501. package/dist/server/routes/admin/role.mjs.map +1 -0
  502. package/dist/server/routes/admin/settings.js +116 -0
  503. package/dist/server/routes/admin/settings.js.map +1 -0
  504. package/dist/server/routes/admin/settings.mjs +114 -0
  505. package/dist/server/routes/admin/settings.mjs.map +1 -0
  506. package/dist/server/routes/content-api/auth.js +168 -0
  507. package/dist/server/routes/content-api/auth.js.map +1 -0
  508. package/dist/server/routes/content-api/auth.mjs +166 -0
  509. package/dist/server/routes/content-api/auth.mjs.map +1 -0
  510. package/dist/server/routes/content-api/index.js +32 -0
  511. package/dist/server/routes/content-api/index.js.map +1 -0
  512. package/dist/server/routes/content-api/index.mjs +30 -0
  513. package/dist/server/routes/content-api/index.mjs.map +1 -0
  514. package/dist/server/routes/content-api/permissions.js +26 -0
  515. package/dist/server/routes/content-api/permissions.js.map +1 -0
  516. package/dist/server/routes/content-api/permissions.mjs +24 -0
  517. package/dist/server/routes/content-api/permissions.mjs.map +1 -0
  518. package/dist/server/routes/content-api/role.js +73 -0
  519. package/dist/server/routes/content-api/role.js.map +1 -0
  520. package/dist/server/routes/content-api/role.mjs +71 -0
  521. package/dist/server/routes/content-api/role.mjs.map +1 -0
  522. package/dist/server/routes/content-api/user.js +132 -0
  523. package/dist/server/routes/content-api/user.js.map +1 -0
  524. package/dist/server/routes/content-api/user.mjs +130 -0
  525. package/dist/server/routes/content-api/user.mjs.map +1 -0
  526. package/dist/server/routes/content-api/validation.js +217 -0
  527. package/dist/server/routes/content-api/validation.js.map +1 -0
  528. package/dist/server/routes/content-api/validation.mjs +215 -0
  529. package/dist/server/routes/content-api/validation.mjs.map +1 -0
  530. package/dist/server/routes/index.js +19 -0
  531. package/dist/server/routes/index.js.map +1 -0
  532. package/dist/server/routes/index.mjs +17 -0
  533. package/dist/server/routes/index.mjs.map +1 -0
  534. package/dist/server/services/constants.js +19 -0
  535. package/dist/server/services/constants.js.map +1 -0
  536. package/dist/server/services/constants.mjs +17 -0
  537. package/dist/server/services/constants.mjs.map +1 -0
  538. package/dist/server/services/index.js +36 -0
  539. package/dist/server/services/index.js.map +1 -0
  540. package/dist/server/services/index.mjs +34 -0
  541. package/dist/server/services/index.mjs.map +1 -0
  542. package/dist/server/services/jwt.js +93 -0
  543. package/dist/server/services/jwt.js.map +1 -0
  544. package/dist/server/services/jwt.mjs +91 -0
  545. package/dist/server/services/jwt.mjs.map +1 -0
  546. package/dist/server/services/permission.js +52 -0
  547. package/dist/server/services/permission.js.map +1 -0
  548. package/dist/server/services/permission.mjs +50 -0
  549. package/dist/server/services/permission.mjs.map +1 -0
  550. package/dist/server/services/providers-registry.js +555 -0
  551. package/dist/server/services/providers-registry.js.map +1 -0
  552. package/dist/server/services/providers-registry.mjs +553 -0
  553. package/dist/server/services/providers-registry.mjs.map +1 -0
  554. package/dist/server/services/providers.js +111 -0
  555. package/dist/server/services/providers.js.map +1 -0
  556. package/dist/server/services/providers.mjs +109 -0
  557. package/dist/server/services/providers.mjs.map +1 -0
  558. package/dist/server/services/role.js +186 -0
  559. package/dist/server/services/role.js.map +1 -0
  560. package/dist/server/services/role.mjs +184 -0
  561. package/dist/server/services/role.mjs.map +1 -0
  562. package/dist/server/services/user.js +188 -0
  563. package/dist/server/services/user.js.map +1 -0
  564. package/dist/server/services/user.mjs +186 -0
  565. package/dist/server/services/user.mjs.map +1 -0
  566. package/dist/server/services/users-permissions.js +256 -0
  567. package/dist/server/services/users-permissions.js.map +1 -0
  568. package/dist/server/services/users-permissions.mjs +254 -0
  569. package/dist/server/services/users-permissions.mjs.map +1 -0
  570. package/dist/server/strategies/users-permissions.js +114 -0
  571. package/dist/server/strategies/users-permissions.js.map +1 -0
  572. package/dist/server/strategies/users-permissions.mjs +112 -0
  573. package/dist/server/strategies/users-permissions.mjs.map +1 -0
  574. package/dist/server/utils/index.js +22 -0
  575. package/dist/server/utils/index.js.map +1 -0
  576. package/dist/server/utils/index.mjs +20 -0
  577. package/dist/server/utils/index.mjs.map +1 -0
  578. package/dist/server/utils/sanitize/index.js +21 -0
  579. package/dist/server/utils/sanitize/index.js.map +1 -0
  580. package/dist/server/utils/sanitize/index.mjs +19 -0
  581. package/dist/server/utils/sanitize/index.mjs.map +1 -0
  582. package/dist/server/utils/sanitize/sanitizers.js +32 -0
  583. package/dist/server/utils/sanitize/sanitizers.js.map +1 -0
  584. package/dist/server/utils/sanitize/sanitizers.mjs +30 -0
  585. package/dist/server/utils/sanitize/sanitizers.mjs.map +1 -0
  586. package/dist/server/utils/sanitize/visitors/index.js +17 -0
  587. package/dist/server/utils/sanitize/visitors/index.js.map +1 -0
  588. package/dist/server/utils/sanitize/visitors/index.mjs +15 -0
  589. package/dist/server/utils/sanitize/visitors/index.mjs.map +1 -0
  590. package/dist/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.js +17 -0
  591. package/dist/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.js.map +1 -0
  592. package/dist/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.mjs +15 -0
  593. package/dist/server/utils/sanitize/visitors/remove-user-relation-from-role-entities.mjs.map +1 -0
  594. package/package.json +21 -20
  595. package/rollup.config.mjs +19 -0
  596. package/server/bootstrap/index.js +31 -0
  597. package/server/config.js +22 -0
  598. package/server/controllers/auth.js +249 -9
  599. package/server/controllers/content-manager-user.js +3 -4
  600. package/server/controllers/validation/auth.js +24 -1
  601. package/server/controllers/validation/user.js +12 -1
  602. package/server/graphql/types/index.js +1 -0
  603. package/server/graphql/types/me.js +1 -0
  604. package/server/graphql/types/user-input.js +20 -0
  605. package/server/register.js +1 -1
  606. package/server/routes/content-api/auth.js +119 -71
  607. package/server/routes/content-api/index.js +11 -4
  608. package/server/routes/content-api/permissions.js +14 -7
  609. package/server/routes/content-api/role.js +57 -27
  610. package/server/routes/content-api/user.js +108 -51
  611. package/server/routes/content-api/validation.js +250 -0
  612. package/server/services/constants.js +9 -0
  613. package/server/services/jwt.js +50 -2
  614. package/server/services/user.js +11 -0
  615. package/server/services/users-permissions.js +6 -2
  616. package/dist/_chunks/ar-BguGUqwK.js +0 -44
  617. package/dist/_chunks/ar-BguGUqwK.js.map +0 -1
  618. package/dist/_chunks/ar-CK8BRRXB.mjs +0 -44
  619. package/dist/_chunks/ar-CK8BRRXB.mjs.map +0 -1
  620. package/dist/_chunks/cs-BVigMk0l.mjs +0 -50
  621. package/dist/_chunks/cs-BVigMk0l.mjs.map +0 -1
  622. package/dist/_chunks/cs-BW8-K_GY.js +0 -50
  623. package/dist/_chunks/cs-BW8-K_GY.js.map +0 -1
  624. package/dist/_chunks/de-BKUdRFI4.mjs +0 -62
  625. package/dist/_chunks/de-BKUdRFI4.mjs.map +0 -1
  626. package/dist/_chunks/de-owXpVluI.js +0 -62
  627. package/dist/_chunks/de-owXpVluI.js.map +0 -1
  628. package/dist/_chunks/dk-BQiTK50l.mjs +0 -86
  629. package/dist/_chunks/dk-BQiTK50l.mjs.map +0 -1
  630. package/dist/_chunks/dk-LXAnbuBk.js +0 -86
  631. package/dist/_chunks/dk-LXAnbuBk.js.map +0 -1
  632. package/dist/_chunks/en-DOHtPf-2.mjs +0 -86
  633. package/dist/_chunks/en-DOHtPf-2.mjs.map +0 -1
  634. package/dist/_chunks/en-MHo5mcsU.js +0 -86
  635. package/dist/_chunks/en-MHo5mcsU.js.map +0 -1
  636. package/dist/_chunks/es-BwLCLXAQ.js +0 -86
  637. package/dist/_chunks/es-BwLCLXAQ.js.map +0 -1
  638. package/dist/_chunks/es-DNgOVMjD.mjs +0 -86
  639. package/dist/_chunks/es-DNgOVMjD.mjs.map +0 -1
  640. package/dist/_chunks/fr-DkgRugiU.mjs +0 -50
  641. package/dist/_chunks/fr-DkgRugiU.mjs.map +0 -1
  642. package/dist/_chunks/fr-DkhpSjjm.js +0 -50
  643. package/dist/_chunks/fr-DkhpSjjm.js.map +0 -1
  644. package/dist/_chunks/id-BTemOeTZ.js +0 -62
  645. package/dist/_chunks/id-BTemOeTZ.js.map +0 -1
  646. package/dist/_chunks/id-BdEsvnaF.mjs +0 -62
  647. package/dist/_chunks/id-BdEsvnaF.mjs.map +0 -1
  648. package/dist/_chunks/index-BH6NqE8I.js +0 -245
  649. package/dist/_chunks/index-BH6NqE8I.js.map +0 -1
  650. package/dist/_chunks/index-C3i__jX-.js +0 -281
  651. package/dist/_chunks/index-C3i__jX-.js.map +0 -1
  652. package/dist/_chunks/index-CFzpNgIL.js +0 -640
  653. package/dist/_chunks/index-CFzpNgIL.js.map +0 -1
  654. package/dist/_chunks/index-CJUWqtrZ.mjs +0 -344
  655. package/dist/_chunks/index-CJUWqtrZ.mjs.map +0 -1
  656. package/dist/_chunks/index-CcWTKtCY.js +0 -366
  657. package/dist/_chunks/index-CcWTKtCY.js.map +0 -1
  658. package/dist/_chunks/index-CnX2wiLY.mjs +0 -1142
  659. package/dist/_chunks/index-CnX2wiLY.mjs.map +0 -1
  660. package/dist/_chunks/index-DUWx-KG9-C1E7ADbJ.mjs +0 -11984
  661. package/dist/_chunks/index-DUWx-KG9-C1E7ADbJ.mjs.map +0 -1
  662. package/dist/_chunks/index-DUWx-KG9-fMZ4nmrb.js +0 -12008
  663. package/dist/_chunks/index-DUWx-KG9-fMZ4nmrb.js.map +0 -1
  664. package/dist/_chunks/index-DruWuFWL.js +0 -1172
  665. package/dist/_chunks/index-DruWuFWL.js.map +0 -1
  666. package/dist/_chunks/index-PJoz36kJ.mjs +0 -262
  667. package/dist/_chunks/index-PJoz36kJ.mjs.map +0 -1
  668. package/dist/_chunks/index-R4R0dEOv.mjs +0 -246
  669. package/dist/_chunks/index-R4R0dEOv.mjs.map +0 -1
  670. package/dist/_chunks/index-XOcQhJMB.mjs +0 -617
  671. package/dist/_chunks/index-XOcQhJMB.mjs.map +0 -1
  672. package/dist/_chunks/it-B-rv0E24.mjs +0 -62
  673. package/dist/_chunks/it-B-rv0E24.mjs.map +0 -1
  674. package/dist/_chunks/it-D1rH6V6_.js +0 -62
  675. package/dist/_chunks/it-D1rH6V6_.js.map +0 -1
  676. package/dist/_chunks/ja-C8K-VBPD.mjs +0 -48
  677. package/dist/_chunks/ja-C8K-VBPD.mjs.map +0 -1
  678. package/dist/_chunks/ja-DqShgTMf.js +0 -48
  679. package/dist/_chunks/ja-DqShgTMf.js.map +0 -1
  680. package/dist/_chunks/ko-B9DGEPWH.js +0 -86
  681. package/dist/_chunks/ko-B9DGEPWH.js.map +0 -1
  682. package/dist/_chunks/ko-Busb0wIY.mjs +0 -86
  683. package/dist/_chunks/ko-Busb0wIY.mjs.map +0 -1
  684. package/dist/_chunks/ms-ByvsQjRt.mjs +0 -49
  685. package/dist/_chunks/ms-ByvsQjRt.mjs.map +0 -1
  686. package/dist/_chunks/ms-CPBU3LWf.js +0 -49
  687. package/dist/_chunks/ms-CPBU3LWf.js.map +0 -1
  688. package/dist/_chunks/nl-5qO8Rpcy.mjs +0 -48
  689. package/dist/_chunks/nl-5qO8Rpcy.mjs.map +0 -1
  690. package/dist/_chunks/nl-CwNB6YoO.js +0 -48
  691. package/dist/_chunks/nl-CwNB6YoO.js.map +0 -1
  692. package/dist/_chunks/pl-BdIzifBE.mjs +0 -86
  693. package/dist/_chunks/pl-BdIzifBE.mjs.map +0 -1
  694. package/dist/_chunks/pl-Do9UD69f.js +0 -86
  695. package/dist/_chunks/pl-Do9UD69f.js.map +0 -1
  696. package/dist/_chunks/pt-BIO24ioG.mjs +0 -48
  697. package/dist/_chunks/pt-BIO24ioG.mjs.map +0 -1
  698. package/dist/_chunks/pt-BR-D7dZhxuP.js +0 -44
  699. package/dist/_chunks/pt-BR-D7dZhxuP.js.map +0 -1
  700. package/dist/_chunks/pt-BR-f0p23AQZ.mjs +0 -44
  701. package/dist/_chunks/pt-BR-f0p23AQZ.mjs.map +0 -1
  702. package/dist/_chunks/pt-fdvyOnUp.js +0 -48
  703. package/dist/_chunks/pt-fdvyOnUp.js.map +0 -1
  704. package/dist/_chunks/ru-C94rjPGA.js +0 -86
  705. package/dist/_chunks/ru-C94rjPGA.js.map +0 -1
  706. package/dist/_chunks/ru-VWy-IB7K.mjs +0 -86
  707. package/dist/_chunks/ru-VWy-IB7K.mjs.map +0 -1
  708. package/dist/_chunks/sk-BABEhykl.js +0 -50
  709. package/dist/_chunks/sk-BABEhykl.js.map +0 -1
  710. package/dist/_chunks/sk-B_LIcepm.mjs +0 -50
  711. package/dist/_chunks/sk-B_LIcepm.mjs.map +0 -1
  712. package/dist/_chunks/sv-ABLKOokl.mjs +0 -86
  713. package/dist/_chunks/sv-ABLKOokl.mjs.map +0 -1
  714. package/dist/_chunks/sv-Be43LhA9.js +0 -86
  715. package/dist/_chunks/sv-Be43LhA9.js.map +0 -1
  716. package/dist/_chunks/th-DKyP7ueR.mjs +0 -60
  717. package/dist/_chunks/th-DKyP7ueR.mjs.map +0 -1
  718. package/dist/_chunks/th-DgVhVLhL.js +0 -60
  719. package/dist/_chunks/th-DgVhVLhL.js.map +0 -1
  720. package/dist/_chunks/tr-B_idhkEs.js +0 -85
  721. package/dist/_chunks/tr-B_idhkEs.js.map +0 -1
  722. package/dist/_chunks/tr-qa1Q5UjC.mjs +0 -85
  723. package/dist/_chunks/tr-qa1Q5UjC.mjs.map +0 -1
  724. package/dist/_chunks/uk-BmRqbeQc.mjs +0 -49
  725. package/dist/_chunks/uk-BmRqbeQc.mjs.map +0 -1
  726. package/dist/_chunks/uk-LHOivnhP.js +0 -49
  727. package/dist/_chunks/uk-LHOivnhP.js.map +0 -1
  728. package/dist/_chunks/vi-CdVRdKDw.js +0 -50
  729. package/dist/_chunks/vi-CdVRdKDw.js.map +0 -1
  730. package/dist/_chunks/vi-HW-EdMea.mjs +0 -50
  731. package/dist/_chunks/vi-HW-EdMea.mjs.map +0 -1
  732. package/dist/_chunks/zh-5hKkVPA4.mjs +0 -86
  733. package/dist/_chunks/zh-5hKkVPA4.mjs.map +0 -1
  734. package/dist/_chunks/zh-Cuq8gMnF.js +0 -86
  735. package/dist/_chunks/zh-Cuq8gMnF.js.map +0 -1
  736. package/dist/_chunks/zh-Hans-BHilK-yc.mjs +0 -86
  737. package/dist/_chunks/zh-Hans-BHilK-yc.mjs.map +0 -1
  738. package/dist/_chunks/zh-Hans-GQDMKtY4.js +0 -86
  739. package/dist/_chunks/zh-Hans-GQDMKtY4.js.map +0 -1
  740. package/packup.config.ts +0 -22
@@ -1,1172 +0,0 @@
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 admin = require("@strapi/strapi/admin");
6
- const reactRouterDom = require("react-router-dom");
7
- const index = require("./index-BH6NqE8I.js");
8
- const designSystem = require("@strapi/design-system");
9
- const icons = require("@strapi/icons");
10
- const formik = require("formik");
11
- const reactIntl = require("react-intl");
12
- const reactQuery = require("react-query");
13
- const PropTypes = require("prop-types");
14
- const upperFirst = require("lodash/upperFirst");
15
- const sortBy = require("lodash/sortBy");
16
- const get = require("lodash/get");
17
- const styledComponents = require("styled-components");
18
- const createNextState2 = require("immer");
19
- const isEmpty = require("lodash/isEmpty");
20
- const without = require("lodash/without");
21
- const map = require("lodash/map");
22
- const tail = require("lodash/tail");
23
- const set = require("lodash/set");
24
- const take = require("lodash/take");
25
- const yup = require("yup");
26
- const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
27
- function _interopNamespace(e) {
28
- if (e && e.__esModule)
29
- return e;
30
- const n = Object.create(null, { [Symbol.toStringTag]: { value: "Module" } });
31
- if (e) {
32
- for (const k in e) {
33
- if (k !== "default") {
34
- const d = Object.getOwnPropertyDescriptor(e, k);
35
- Object.defineProperty(n, k, d.get ? d : {
36
- enumerable: true,
37
- get: () => e[k]
38
- });
39
- }
40
- }
41
- }
42
- n.default = e;
43
- return Object.freeze(n);
44
- }
45
- const React__namespace = /* @__PURE__ */ _interopNamespace(React);
46
- const PropTypes__default = /* @__PURE__ */ _interopDefault(PropTypes);
47
- const upperFirst__default = /* @__PURE__ */ _interopDefault(upperFirst);
48
- const sortBy__default = /* @__PURE__ */ _interopDefault(sortBy);
49
- const get__default = /* @__PURE__ */ _interopDefault(get);
50
- const isEmpty__default = /* @__PURE__ */ _interopDefault(isEmpty);
51
- const without__default = /* @__PURE__ */ _interopDefault(without);
52
- const map__default = /* @__PURE__ */ _interopDefault(map);
53
- const tail__default = /* @__PURE__ */ _interopDefault(tail);
54
- const set__default = /* @__PURE__ */ _interopDefault(set);
55
- const take__default = /* @__PURE__ */ _interopDefault(take);
56
- const yup__namespace = /* @__PURE__ */ _interopNamespace(yup);
57
- const UsersPermissions$2 = React.createContext({});
58
- const UsersPermissionsProvider = ({ children, value }) => {
59
- return /* @__PURE__ */ jsxRuntime.jsx(UsersPermissions$2.Provider, { value, children });
60
- };
61
- const useUsersPermissions = () => React.useContext(UsersPermissions$2);
62
- UsersPermissionsProvider.propTypes = {
63
- children: PropTypes__default.default.node.isRequired,
64
- value: PropTypes__default.default.object.isRequired
65
- };
66
- function formatPluginName(pluginSlug) {
67
- switch (pluginSlug) {
68
- case "application":
69
- return "Application";
70
- case "plugin::content-manager":
71
- return "Content manager";
72
- case "plugin::content-type-builder":
73
- return "Content types builder";
74
- case "plugin::documentation":
75
- return "Documentation";
76
- case "plugin::email":
77
- return "Email";
78
- case "plugin::i18n":
79
- return "i18n";
80
- case "plugin::upload":
81
- return "Upload";
82
- case "plugin::users-permissions":
83
- return "Users-permissions";
84
- default:
85
- return upperFirst__default.default(pluginSlug.replace("api::", "").replace("plugin::", ""));
86
- }
87
- }
88
- const init$1 = (initialState2, permissions) => {
89
- const collapses = Object.keys(permissions).sort().map((name) => ({ name, isOpen: false }));
90
- return { ...initialState2, collapses };
91
- };
92
- const activeCheckboxWrapperStyles = styledComponents.css`
93
- background: ${(props) => props.theme.colors.primary100};
94
-
95
- #cog {
96
- opacity: 1;
97
- }
98
- `;
99
- const CheckboxWrapper = styledComponents.styled(designSystem.Box)`
100
- display: flex;
101
- justify-content: space-between;
102
- align-items: center;
103
-
104
- #cog {
105
- opacity: 0;
106
- path {
107
- fill: ${(props) => props.theme.colors.primary600};
108
- }
109
- }
110
-
111
- /* Show active style both on hover and when the action is selected */
112
- ${(props) => props.isActive && activeCheckboxWrapperStyles}
113
- &:hover {
114
- ${activeCheckboxWrapperStyles}
115
- }
116
- `;
117
- const Border = styledComponents.styled.div`
118
- flex: 1;
119
- align-self: center;
120
- border-top: 1px solid ${({ theme }) => theme.colors.neutral150};
121
- `;
122
- const SubCategory = ({ subCategory }) => {
123
- const { formatMessage } = reactIntl.useIntl();
124
- const { onChange, onChangeSelectAll, onSelectedAction, selectedAction, modifiedData } = useUsersPermissions();
125
- const currentScopedModifiedData = React.useMemo(() => {
126
- return get__default.default(modifiedData, subCategory.name, {});
127
- }, [modifiedData, subCategory]);
128
- const hasAllActionsSelected = React.useMemo(() => {
129
- return Object.values(currentScopedModifiedData).every((action) => action.enabled === true);
130
- }, [currentScopedModifiedData]);
131
- const hasSomeActionsSelected = React.useMemo(() => {
132
- return Object.values(currentScopedModifiedData).some((action) => action.enabled === true) && !hasAllActionsSelected;
133
- }, [currentScopedModifiedData, hasAllActionsSelected]);
134
- const handleChangeSelectAll = React.useCallback(
135
- ({ target: { name } }) => {
136
- onChangeSelectAll({ target: { name, value: !hasAllActionsSelected } });
137
- },
138
- [hasAllActionsSelected, onChangeSelectAll]
139
- );
140
- const isActionSelected = React.useCallback(
141
- (actionName) => {
142
- return selectedAction === actionName;
143
- },
144
- [selectedAction]
145
- );
146
- return /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Box, { children: [
147
- /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { justifyContent: "space-between", alignItems: "center", children: [
148
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Box, { paddingRight: 4, children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "sigma", textColor: "neutral600", children: subCategory.label }) }),
149
- /* @__PURE__ */ jsxRuntime.jsx(Border, {}),
150
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Box, { paddingLeft: 4, children: /* @__PURE__ */ jsxRuntime.jsx(
151
- designSystem.Checkbox,
152
- {
153
- name: subCategory.name,
154
- checked: hasSomeActionsSelected ? "indeterminate" : hasAllActionsSelected,
155
- onCheckedChange: (value) => handleChangeSelectAll({ target: { name: subCategory.name, value } }),
156
- children: formatMessage({ id: "app.utils.select-all", defaultMessage: "Select all" })
157
- }
158
- ) })
159
- ] }),
160
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Flex, { paddingTop: 6, paddingBottom: 6, children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Root, { gap: 2, style: { flex: 1 }, children: subCategory.actions.map((action) => {
161
- const name = `${action.name}.enabled`;
162
- return /* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Item, { col: 6, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsxRuntime.jsxs(CheckboxWrapper, { isActive: isActionSelected(action.name), padding: 2, hasRadius: true, children: [
163
- /* @__PURE__ */ jsxRuntime.jsx(
164
- designSystem.Checkbox,
165
- {
166
- checked: get__default.default(modifiedData, name, false),
167
- name,
168
- onCheckedChange: (value) => onChange({ target: { name, value } }),
169
- children: action.label
170
- }
171
- ),
172
- /* @__PURE__ */ jsxRuntime.jsxs(
173
- "button",
174
- {
175
- type: "button",
176
- onClick: () => onSelectedAction(action.name),
177
- style: { display: "inline-flex", alignItems: "center" },
178
- children: [
179
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.VisuallyHidden, { tag: "span", children: formatMessage(
180
- {
181
- id: "app.utils.show-bound-route",
182
- defaultMessage: "Show bound route for {route}"
183
- },
184
- {
185
- route: action.name
186
- }
187
- ) }),
188
- /* @__PURE__ */ jsxRuntime.jsx(icons.Cog, { id: "cog" })
189
- ]
190
- }
191
- )
192
- ] }) }, action.name);
193
- }) }) })
194
- ] });
195
- };
196
- SubCategory.propTypes = {
197
- subCategory: PropTypes__default.default.object.isRequired
198
- };
199
- const PermissionRow = ({ name, permissions }) => {
200
- const subCategories = React.useMemo(() => {
201
- return sortBy__default.default(
202
- Object.values(permissions.controllers).reduce((acc, curr, index2) => {
203
- const currentName = `${name}.controllers.${Object.keys(permissions.controllers)[index2]}`;
204
- const actions = sortBy__default.default(
205
- Object.keys(curr).reduce((acc2, current) => {
206
- return [
207
- ...acc2,
208
- {
209
- ...curr[current],
210
- label: current,
211
- name: `${currentName}.${current}`
212
- }
213
- ];
214
- }, []),
215
- "label"
216
- );
217
- return [
218
- ...acc,
219
- {
220
- actions,
221
- label: Object.keys(permissions.controllers)[index2],
222
- name: currentName
223
- }
224
- ];
225
- }, []),
226
- "label"
227
- );
228
- }, [name, permissions]);
229
- return /* @__PURE__ */ jsxRuntime.jsx(designSystem.Box, { padding: 6, children: subCategories.map((subCategory) => /* @__PURE__ */ jsxRuntime.jsx(SubCategory, { subCategory }, subCategory.name)) });
230
- };
231
- PermissionRow.propTypes = {
232
- name: PropTypes__default.default.string.isRequired,
233
- permissions: PropTypes__default.default.object.isRequired
234
- };
235
- const initialState$1 = {
236
- collapses: []
237
- };
238
- const reducer$1 = (state, action) => (
239
- // eslint-disable-next-line consistent-return
240
- createNextState2.produce(state, (draftState) => {
241
- switch (action.type) {
242
- case "TOGGLE_COLLAPSE": {
243
- draftState.collapses = state.collapses.map((collapse, index2) => {
244
- if (index2 === action.index) {
245
- return { ...collapse, isOpen: !collapse.isOpen };
246
- }
247
- return { ...collapse, isOpen: false };
248
- });
249
- break;
250
- }
251
- default:
252
- return draftState;
253
- }
254
- })
255
- );
256
- const Permissions = () => {
257
- const { modifiedData } = useUsersPermissions();
258
- const { formatMessage } = reactIntl.useIntl();
259
- const [{ collapses }] = React.useReducer(reducer$1, initialState$1, (state) => init$1(state, modifiedData));
260
- return /* @__PURE__ */ jsxRuntime.jsx(designSystem.Accordion.Root, { size: "M", children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Flex, { direction: "column", alignItems: "stretch", gap: 1, children: collapses.map((collapse, index2) => /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Accordion.Item, { value: collapse.name, children: [
261
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Accordion.Header, { variant: index2 % 2 === 0 ? "secondary" : void 0, children: /* @__PURE__ */ jsxRuntime.jsx(
262
- designSystem.Accordion.Trigger,
263
- {
264
- caretPosition: "right",
265
- description: formatMessage(
266
- {
267
- id: "users-permissions.Plugin.permissions.plugins.description",
268
- defaultMessage: "Define all allowed actions for the {name} plugin."
269
- },
270
- { name: collapse.name }
271
- ),
272
- children: formatPluginName(collapse.name)
273
- }
274
- ) }),
275
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Accordion.Content, { children: /* @__PURE__ */ jsxRuntime.jsx(PermissionRow, { permissions: modifiedData[collapse.name], name: collapse.name }) })
276
- ] }, collapse.name)) }) });
277
- };
278
- const getMethodColor = (verb) => {
279
- switch (verb) {
280
- case "POST": {
281
- return {
282
- text: "success600",
283
- border: "success200",
284
- background: "success100"
285
- };
286
- }
287
- case "GET": {
288
- return {
289
- text: "secondary600",
290
- border: "secondary200",
291
- background: "secondary100"
292
- };
293
- }
294
- case "PUT": {
295
- return {
296
- text: "warning600",
297
- border: "warning200",
298
- background: "warning100"
299
- };
300
- }
301
- case "DELETE": {
302
- return {
303
- text: "danger600",
304
- border: "danger200",
305
- background: "danger100"
306
- };
307
- }
308
- default: {
309
- return {
310
- text: "neutral600",
311
- border: "neutral200",
312
- background: "neutral100"
313
- };
314
- }
315
- }
316
- };
317
- const MethodBox = styledComponents.styled(designSystem.Box)`
318
- margin: -1px;
319
- border-radius: ${({ theme }) => theme.spaces[1]} 0 0 ${({ theme }) => theme.spaces[1]};
320
- `;
321
- function BoundRoute({ route }) {
322
- const { formatMessage } = reactIntl.useIntl();
323
- const { method, handler: title, path } = route;
324
- const formattedRoute = path ? tail__default.default(path.split("/")) : [];
325
- const [controller = "", action = ""] = title ? title.split(".") : [];
326
- const colors = getMethodColor(route.method);
327
- return /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { direction: "column", alignItems: "stretch", gap: 2, children: [
328
- /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Typography, { variant: "delta", tag: "h3", children: [
329
- formatMessage({
330
- id: "users-permissions.BoundRoute.title",
331
- defaultMessage: "Bound route to"
332
- }),
333
- " ",
334
- /* @__PURE__ */ jsxRuntime.jsx("span", { children: controller }),
335
- /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Typography, { variant: "delta", textColor: "primary600", children: [
336
- ".",
337
- action
338
- ] })
339
- ] }),
340
- /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { hasRadius: true, background: "neutral0", borderColor: "neutral200", gap: 0, children: [
341
- /* @__PURE__ */ jsxRuntime.jsx(MethodBox, { background: colors.background, borderColor: colors.border, padding: 2, children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { fontWeight: "bold", textColor: colors.text, children: method }) }),
342
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Box, { paddingLeft: 2, paddingRight: 2, children: map__default.default(formattedRoute, (value) => /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Typography, { textColor: value.includes(":") ? "neutral600" : "neutral900", children: [
343
- "/",
344
- value
345
- ] }, value)) })
346
- ] })
347
- ] });
348
- }
349
- BoundRoute.defaultProps = {
350
- route: {
351
- handler: "Nocontroller.error",
352
- method: "GET",
353
- path: "/there-is-no-path"
354
- }
355
- };
356
- BoundRoute.propTypes = {
357
- route: PropTypes__default.default.shape({
358
- handler: PropTypes__default.default.string,
359
- method: PropTypes__default.default.string,
360
- path: PropTypes__default.default.string
361
- })
362
- };
363
- const Policies = () => {
364
- const { formatMessage } = reactIntl.useIntl();
365
- const { selectedAction, routes } = useUsersPermissions();
366
- const path = without__default.default(selectedAction.split("."), "controllers");
367
- const controllerRoutes = get__default.default(routes, path[0]);
368
- const pathResolved = path.slice(1).join(".");
369
- const displayedRoutes = isEmpty__default.default(controllerRoutes) ? [] : controllerRoutes.filter((o) => o.handler.endsWith(pathResolved));
370
- return /* @__PURE__ */ jsxRuntime.jsx(
371
- designSystem.Grid.Item,
372
- {
373
- col: 5,
374
- background: "neutral150",
375
- paddingTop: 6,
376
- paddingBottom: 6,
377
- paddingLeft: 7,
378
- paddingRight: 7,
379
- style: { minHeight: "100%" },
380
- direction: "column",
381
- alignItems: "stretch",
382
- children: selectedAction ? /* @__PURE__ */ jsxRuntime.jsx(designSystem.Flex, { direction: "column", alignItems: "stretch", gap: 2, children: displayedRoutes.map((route, key) => (
383
- // eslint-disable-next-line react/no-array-index-key
384
- /* @__PURE__ */ jsxRuntime.jsx(BoundRoute, { route }, key)
385
- )) }) : /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { direction: "column", alignItems: "stretch", gap: 2, children: [
386
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "delta", tag: "h3", children: formatMessage({
387
- id: "users-permissions.Policies.header.title",
388
- defaultMessage: "Advanced settings"
389
- }) }),
390
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { tag: "p", textColor: "neutral600", children: formatMessage({
391
- id: "users-permissions.Policies.header.hint",
392
- defaultMessage: "Select the application's actions or the plugin's actions and click on the cog icon to display the bound route"
393
- }) })
394
- ] })
395
- }
396
- );
397
- };
398
- const init = (state, permissions, routes) => {
399
- return {
400
- ...state,
401
- initialData: permissions,
402
- modifiedData: permissions,
403
- routes
404
- };
405
- };
406
- const initialState = {
407
- initialData: {},
408
- modifiedData: {},
409
- routes: {},
410
- selectedAction: "",
411
- policies: []
412
- };
413
- const reducer = (state, action) => createNextState2.produce(state, (draftState) => {
414
- switch (action.type) {
415
- case "ON_CHANGE": {
416
- const keysLength = action.keys.length;
417
- const isChangingCheckbox = action.keys[keysLength - 1] === "enabled";
418
- if (action.value && isChangingCheckbox) {
419
- const selectedAction = take__default.default(action.keys, keysLength - 1).join(".");
420
- draftState.selectedAction = selectedAction;
421
- }
422
- set__default.default(draftState, ["modifiedData", ...action.keys], action.value);
423
- break;
424
- }
425
- case "ON_CHANGE_SELECT_ALL": {
426
- const pathToValue = ["modifiedData", ...action.keys];
427
- const oldValues = get__default.default(state, pathToValue, {});
428
- const updatedValues = Object.keys(oldValues).reduce((acc, current) => {
429
- acc[current] = { ...oldValues[current], enabled: action.value };
430
- return acc;
431
- }, {});
432
- set__default.default(draftState, pathToValue, updatedValues);
433
- break;
434
- }
435
- case "ON_RESET": {
436
- draftState.modifiedData = state.initialData;
437
- break;
438
- }
439
- case "ON_SUBMIT_SUCCEEDED": {
440
- draftState.initialData = state.modifiedData;
441
- break;
442
- }
443
- case "SELECT_ACTION": {
444
- const { actionToSelect } = action;
445
- draftState.selectedAction = actionToSelect === state.selectedAction ? "" : actionToSelect;
446
- break;
447
- }
448
- default:
449
- return draftState;
450
- }
451
- });
452
- const UsersPermissions = React.forwardRef(({ permissions, routes }, ref) => {
453
- const { formatMessage } = reactIntl.useIntl();
454
- const [state, dispatch] = React.useReducer(
455
- reducer,
456
- initialState,
457
- (state2) => init(state2, permissions, routes)
458
- );
459
- React.useImperativeHandle(ref, () => ({
460
- getPermissions() {
461
- return {
462
- permissions: state.modifiedData
463
- };
464
- },
465
- resetForm() {
466
- dispatch({ type: "ON_RESET" });
467
- },
468
- setFormAfterSubmit() {
469
- dispatch({ type: "ON_SUBMIT_SUCCEEDED" });
470
- }
471
- }));
472
- const handleChange = ({ target: { name, value } }) => dispatch({
473
- type: "ON_CHANGE",
474
- keys: name.split("."),
475
- value: value === "empty__string_value" ? "" : value
476
- });
477
- const handleChangeSelectAll = ({ target: { name, value } }) => dispatch({
478
- type: "ON_CHANGE_SELECT_ALL",
479
- keys: name.split("."),
480
- value
481
- });
482
- const handleSelectedAction = (actionToSelect) => dispatch({
483
- type: "SELECT_ACTION",
484
- actionToSelect
485
- });
486
- const providerValue = {
487
- ...state,
488
- onChange: handleChange,
489
- onChangeSelectAll: handleChangeSelectAll,
490
- onSelectedAction: handleSelectedAction
491
- };
492
- return /* @__PURE__ */ jsxRuntime.jsx(UsersPermissionsProvider, { value: providerValue, children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Grid.Root, { gap: 0, shadow: "filterShadow", hasRadius: true, background: "neutral0", children: [
493
- /* @__PURE__ */ jsxRuntime.jsx(
494
- designSystem.Grid.Item,
495
- {
496
- col: 7,
497
- paddingTop: 6,
498
- paddingBottom: 6,
499
- paddingLeft: 7,
500
- paddingRight: 7,
501
- direction: "column",
502
- alignItems: "stretch",
503
- children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { direction: "column", alignItems: "stretch", gap: 6, children: [
504
- /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { direction: "column", alignItems: "stretch", gap: 2, children: [
505
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "delta", tag: "h2", children: formatMessage({
506
- id: index.getTrad("Plugins.header.title"),
507
- defaultMessage: "Permissions"
508
- }) }),
509
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { tag: "p", textColor: "neutral600", children: formatMessage({
510
- id: index.getTrad("Plugins.header.description"),
511
- defaultMessage: "Only actions bound by a route are listed below."
512
- }) })
513
- ] }),
514
- /* @__PURE__ */ jsxRuntime.jsx(Permissions, {})
515
- ] })
516
- }
517
- ),
518
- /* @__PURE__ */ jsxRuntime.jsx(Policies, {})
519
- ] }) });
520
- });
521
- UsersPermissions.propTypes = {
522
- permissions: PropTypes__default.default.object.isRequired,
523
- routes: PropTypes__default.default.object.isRequired
524
- };
525
- const UsersPermissions$1 = React.memo(UsersPermissions);
526
- const createRoleSchema = yup__namespace.object().shape({
527
- name: yup__namespace.string().required(admin.translatedErrors.required.id),
528
- description: yup__namespace.string().required(admin.translatedErrors.required.id)
529
- });
530
- const cleanPermissions = (permissions) => Object.keys(permissions).reduce((acc, current) => {
531
- const currentPermission = permissions[current].controllers;
532
- const cleanedControllers = Object.keys(currentPermission).reduce((acc2, curr) => {
533
- if (isEmpty__default.default(currentPermission[curr])) {
534
- return acc2;
535
- }
536
- acc2[curr] = currentPermission[curr];
537
- return acc2;
538
- }, {});
539
- if (isEmpty__default.default(cleanedControllers)) {
540
- return acc;
541
- }
542
- acc[current] = { controllers: cleanedControllers };
543
- return acc;
544
- }, {});
545
- const usePlugins = () => {
546
- const { toggleNotification } = admin.useNotification();
547
- const { get: get2 } = admin.useFetchClient();
548
- const { formatAPIError } = admin.useAPIErrorHandler(index.getTrad);
549
- const [
550
- {
551
- data: permissions,
552
- isLoading: isLoadingPermissions,
553
- error: permissionsError,
554
- refetch: refetchPermissions
555
- },
556
- { data: routes, isLoading: isLoadingRoutes, error: routesError, refetch: refetchRoutes }
557
- ] = reactQuery.useQueries([
558
- {
559
- queryKey: ["users-permissions", "permissions"],
560
- async queryFn() {
561
- const {
562
- data: { permissions: permissions2 }
563
- } = await get2(`/users-permissions/permissions`);
564
- return permissions2;
565
- }
566
- },
567
- {
568
- queryKey: ["users-permissions", "routes"],
569
- async queryFn() {
570
- const {
571
- data: { routes: routes2 }
572
- } = await get2(`/users-permissions/routes`);
573
- return routes2;
574
- }
575
- }
576
- ]);
577
- const refetchQueries = async () => {
578
- await Promise.all([refetchPermissions(), refetchRoutes()]);
579
- };
580
- React.useEffect(() => {
581
- if (permissionsError) {
582
- toggleNotification({
583
- type: "danger",
584
- message: formatAPIError(permissionsError)
585
- });
586
- }
587
- }, [toggleNotification, permissionsError, formatAPIError]);
588
- React.useEffect(() => {
589
- if (routesError) {
590
- toggleNotification({
591
- type: "danger",
592
- message: formatAPIError(routesError)
593
- });
594
- }
595
- }, [toggleNotification, routesError, formatAPIError]);
596
- const isLoading = isLoadingPermissions || isLoadingRoutes;
597
- return {
598
- // TODO: these return values need to be memoized, otherwise
599
- // they will create infinite rendering loops when used as
600
- // effect dependencies
601
- permissions: permissions ? cleanPermissions(permissions) : {},
602
- routes: routes ?? {},
603
- getData: refetchQueries,
604
- isLoading
605
- };
606
- };
607
- const CreatePage = () => {
608
- const { formatMessage } = reactIntl.useIntl();
609
- const { toggleNotification } = admin.useNotification();
610
- const navigate = reactRouterDom.useNavigate();
611
- const { isLoading: isLoadingPlugins, permissions, routes } = usePlugins();
612
- const { trackUsage } = admin.useTracking();
613
- const permissionsRef = React__namespace.useRef();
614
- const { post } = admin.useFetchClient();
615
- const mutation = reactQuery.useMutation((body) => post(`/users-permissions/roles`, body), {
616
- onError() {
617
- toggleNotification({
618
- type: "danger",
619
- message: formatMessage({
620
- id: "notification.error",
621
- defaultMessage: "An error occurred"
622
- })
623
- });
624
- },
625
- onSuccess() {
626
- trackUsage("didCreateRole");
627
- toggleNotification({
628
- type: "success",
629
- message: formatMessage({
630
- id: index.getTrad("Settings.roles.created"),
631
- defaultMessage: "Role created"
632
- })
633
- });
634
- navigate(-1);
635
- }
636
- });
637
- const handleCreateRoleSubmit = async (data) => {
638
- const permissions2 = permissionsRef.current.getPermissions();
639
- await mutation.mutate({ ...data, ...permissions2, users: [] });
640
- };
641
- return /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Main, { children: [
642
- /* @__PURE__ */ jsxRuntime.jsx(admin.Page.Title, { children: formatMessage(
643
- { id: "Settings.PageTitle", defaultMessage: "Settings - {name}" },
644
- { name: "Roles" }
645
- ) }),
646
- /* @__PURE__ */ jsxRuntime.jsx(
647
- formik.Formik,
648
- {
649
- enableReinitialize: true,
650
- initialValues: { name: "", description: "" },
651
- onSubmit: handleCreateRoleSubmit,
652
- validationSchema: createRoleSchema,
653
- children: ({ handleSubmit, values, handleChange, errors }) => /* @__PURE__ */ jsxRuntime.jsxs(formik.Form, { noValidate: true, onSubmit: handleSubmit, children: [
654
- /* @__PURE__ */ jsxRuntime.jsx(
655
- admin.Layouts.Header,
656
- {
657
- primaryAction: !isLoadingPlugins && /* @__PURE__ */ jsxRuntime.jsx(designSystem.Button, { type: "submit", loading: mutation.isLoading, startIcon: /* @__PURE__ */ jsxRuntime.jsx(icons.Check, {}), children: formatMessage({
658
- id: "global.save",
659
- defaultMessage: "Save"
660
- }) }),
661
- title: formatMessage({
662
- id: "Settings.roles.create.title",
663
- defaultMessage: "Create a role"
664
- }),
665
- subtitle: formatMessage({
666
- id: "Settings.roles.create.description",
667
- defaultMessage: "Define the rights given to the role"
668
- })
669
- }
670
- ),
671
- /* @__PURE__ */ jsxRuntime.jsx(admin.Layouts.Content, { children: /* @__PURE__ */ jsxRuntime.jsxs(
672
- designSystem.Flex,
673
- {
674
- background: "neutral0",
675
- direction: "column",
676
- alignItems: "stretch",
677
- gap: 7,
678
- hasRadius: true,
679
- paddingTop: 6,
680
- paddingBottom: 6,
681
- paddingLeft: 7,
682
- paddingRight: 7,
683
- shadow: "filterShadow",
684
- children: [
685
- /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { direction: "column", alignItems: "stretch", children: [
686
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "delta", tag: "h2", children: formatMessage({
687
- id: index.getTrad("EditPage.form.roles"),
688
- defaultMessage: "Role details"
689
- }) }),
690
- /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Grid.Root, { gap: 4, children: [
691
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Item, { col: 6, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsxRuntime.jsxs(
692
- designSystem.Field.Root,
693
- {
694
- name: "name",
695
- error: errors?.name ? formatMessage({ id: errors.name, defaultMessage: "Name is required" }) : false,
696
- required: true,
697
- children: [
698
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: formatMessage({
699
- id: "global.name",
700
- defaultMessage: "Name"
701
- }) }),
702
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.TextInput, { value: values.name || "", onChange: handleChange }),
703
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Error, {})
704
- ]
705
- }
706
- ) }),
707
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Item, { col: 6, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsxRuntime.jsxs(
708
- designSystem.Field.Root,
709
- {
710
- name: "description",
711
- error: errors?.description ? formatMessage({
712
- id: errors.description,
713
- defaultMessage: "Description is required"
714
- }) : false,
715
- required: true,
716
- children: [
717
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: formatMessage({
718
- id: "global.description",
719
- defaultMessage: "Description"
720
- }) }),
721
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Textarea, { value: values.description || "", onChange: handleChange }),
722
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Error, {})
723
- ]
724
- }
725
- ) })
726
- ] })
727
- ] }),
728
- !isLoadingPlugins && /* @__PURE__ */ jsxRuntime.jsx(
729
- UsersPermissions$1,
730
- {
731
- ref: permissionsRef,
732
- permissions,
733
- routes
734
- }
735
- )
736
- ]
737
- }
738
- ) })
739
- ] })
740
- }
741
- )
742
- ] });
743
- };
744
- const ProtectedRolesCreatePage = () => /* @__PURE__ */ jsxRuntime.jsx(admin.Page.Protect, { permissions: index.PERMISSIONS.createRole, children: /* @__PURE__ */ jsxRuntime.jsx(CreatePage, {}) });
745
- const EditPage = () => {
746
- const { formatMessage } = reactIntl.useIntl();
747
- const { toggleNotification } = admin.useNotification();
748
- const {
749
- params: { id }
750
- } = reactRouterDom.useMatch(`/settings/users-permissions/roles/:id`);
751
- const { get: get2 } = admin.useFetchClient();
752
- const { isLoading: isLoadingPlugins, routes } = usePlugins();
753
- const {
754
- data: role,
755
- isLoading: isLoadingRole,
756
- refetch: refetchRole
757
- } = reactQuery.useQuery(["users-permissions", "role", id], async () => {
758
- const {
759
- data: { role: role2 }
760
- } = await get2(`/users-permissions/roles/${id}`);
761
- return role2;
762
- });
763
- const permissionsRef = React__namespace.useRef();
764
- const { put } = admin.useFetchClient();
765
- const { formatAPIError } = admin.useAPIErrorHandler();
766
- const mutation = reactQuery.useMutation((body) => put(`/users-permissions/roles/${id}`, body), {
767
- onError(error) {
768
- toggleNotification({
769
- type: "danger",
770
- message: formatAPIError(error)
771
- });
772
- },
773
- async onSuccess() {
774
- toggleNotification({
775
- type: "success",
776
- message: formatMessage({
777
- id: index.getTrad("Settings.roles.created"),
778
- defaultMessage: "Role edited"
779
- })
780
- });
781
- await refetchRole();
782
- }
783
- });
784
- const handleEditRoleSubmit = async (data) => {
785
- const permissions = permissionsRef.current.getPermissions();
786
- await mutation.mutate({ ...data, ...permissions, users: [] });
787
- };
788
- if (isLoadingRole) {
789
- return /* @__PURE__ */ jsxRuntime.jsx(admin.Page.Loading, {});
790
- }
791
- return /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Main, { children: [
792
- /* @__PURE__ */ jsxRuntime.jsx(admin.Page.Title, { children: formatMessage(
793
- { id: "Settings.PageTitle", defaultMessage: "Settings - {name}" },
794
- { name: "Roles" }
795
- ) }),
796
- /* @__PURE__ */ jsxRuntime.jsx(
797
- formik.Formik,
798
- {
799
- enableReinitialize: true,
800
- initialValues: { name: role.name, description: role.description },
801
- onSubmit: handleEditRoleSubmit,
802
- validationSchema: createRoleSchema,
803
- children: ({ handleSubmit, values, handleChange, errors }) => /* @__PURE__ */ jsxRuntime.jsxs(formik.Form, { noValidate: true, onSubmit: handleSubmit, children: [
804
- /* @__PURE__ */ jsxRuntime.jsx(
805
- admin.Layouts.Header,
806
- {
807
- primaryAction: !isLoadingPlugins ? /* @__PURE__ */ jsxRuntime.jsx(
808
- designSystem.Button,
809
- {
810
- disabled: role.code === "strapi-super-admin",
811
- type: "submit",
812
- loading: mutation.isLoading,
813
- startIcon: /* @__PURE__ */ jsxRuntime.jsx(icons.Check, {}),
814
- children: formatMessage({
815
- id: "global.save",
816
- defaultMessage: "Save"
817
- })
818
- }
819
- ) : null,
820
- title: role.name,
821
- subtitle: role.description,
822
- navigationAction: /* @__PURE__ */ jsxRuntime.jsx(admin.BackButton, {})
823
- }
824
- ),
825
- /* @__PURE__ */ jsxRuntime.jsx(admin.Layouts.Content, { children: /* @__PURE__ */ jsxRuntime.jsxs(
826
- designSystem.Flex,
827
- {
828
- background: "neutral0",
829
- direction: "column",
830
- alignItems: "stretch",
831
- gap: 7,
832
- hasRadius: true,
833
- paddingTop: 6,
834
- paddingBottom: 6,
835
- paddingLeft: 7,
836
- paddingRight: 7,
837
- shadow: "filterShadow",
838
- children: [
839
- /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { direction: "column", alignItems: "stretch", gap: 4, children: [
840
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "delta", tag: "h2", children: formatMessage({
841
- id: index.getTrad("EditPage.form.roles"),
842
- defaultMessage: "Role details"
843
- }) }),
844
- /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Grid.Root, { gap: 4, children: [
845
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Item, { col: 6, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsxRuntime.jsxs(
846
- designSystem.Field.Root,
847
- {
848
- name: "name",
849
- error: errors?.name ? formatMessage({
850
- id: errors.name,
851
- defaultMessage: "Name is required"
852
- }) : false,
853
- required: true,
854
- children: [
855
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: formatMessage({
856
- id: "global.name",
857
- defaultMessage: "Name"
858
- }) }),
859
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.TextInput, { value: values.name || "", onChange: handleChange }),
860
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Error, {})
861
- ]
862
- }
863
- ) }),
864
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Grid.Item, { col: 6, direction: "column", alignItems: "stretch", children: /* @__PURE__ */ jsxRuntime.jsxs(
865
- designSystem.Field.Root,
866
- {
867
- name: "description",
868
- error: errors?.description ? formatMessage({
869
- id: errors.description,
870
- defaultMessage: "Description is required"
871
- }) : false,
872
- required: true,
873
- children: [
874
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Label, { children: formatMessage({
875
- id: "global.description",
876
- defaultMessage: "Description"
877
- }) }),
878
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Textarea, { value: values.description || "", onChange: handleChange }),
879
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Field.Error, {})
880
- ]
881
- }
882
- ) })
883
- ] })
884
- ] }),
885
- !isLoadingPlugins && /* @__PURE__ */ jsxRuntime.jsx(
886
- UsersPermissions$1,
887
- {
888
- ref: permissionsRef,
889
- permissions: role.permissions,
890
- routes
891
- }
892
- )
893
- ]
894
- }
895
- ) })
896
- ] })
897
- }
898
- )
899
- ] });
900
- };
901
- const ProtectedRolesEditPage = () => /* @__PURE__ */ jsxRuntime.jsx(admin.Page.Protect, { permissions: index.PERMISSIONS.updateRole, children: /* @__PURE__ */ jsxRuntime.jsx(EditPage, {}) });
902
- const EditLink = styledComponents.styled(designSystem.Link)`
903
- align-items: center;
904
- height: 3.2rem;
905
- width: 3.2rem;
906
- display: flex;
907
- justify-content: center;
908
- padding: ${({ theme }) => `${theme.spaces[2]}`};
909
-
910
- svg {
911
- height: 1.6rem;
912
- width: 1.6rem;
913
-
914
- path {
915
- fill: ${({ theme }) => theme.colors.neutral500};
916
- }
917
- }
918
-
919
- &:hover,
920
- &:focus {
921
- svg {
922
- path {
923
- fill: ${({ theme }) => theme.colors.neutral800};
924
- }
925
- }
926
- }
927
- `;
928
- const TableBody = ({ sortedRoles, canDelete, canUpdate, setRoleToDelete, onDelete }) => {
929
- const { formatMessage } = reactIntl.useIntl();
930
- const navigate = reactRouterDom.useNavigate();
931
- const [showConfirmDelete, setShowConfirmDelete] = onDelete;
932
- const checkCanDeleteRole = (role) => canDelete && !["public", "authenticated"].includes(role.type);
933
- const handleClickDelete = (id) => {
934
- setRoleToDelete(id);
935
- setShowConfirmDelete(!showConfirmDelete);
936
- };
937
- return /* @__PURE__ */ jsxRuntime.jsx(designSystem.Tbody, { children: sortedRoles?.map((role) => /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Tr, { onClick: () => navigate(role.id.toString()), children: [
938
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { width: "20%", children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { children: role.name }) }),
939
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { width: "50%", children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { children: role.description }) }),
940
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { width: "30%", children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { children: formatMessage(
941
- {
942
- id: "Roles.RoleRow.user-count",
943
- defaultMessage: "{number, plural, =0 {# user} one {# user} other {# users}}"
944
- },
945
- { number: role.nb_users }
946
- ) }) }),
947
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Td, { children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Flex, { justifyContent: "end", onClick: (e) => e.stopPropagation(), children: [
948
- canUpdate ? /* @__PURE__ */ jsxRuntime.jsx(
949
- EditLink,
950
- {
951
- tag: reactRouterDom.NavLink,
952
- to: role.id.toString(),
953
- "aria-label": formatMessage(
954
- { id: "app.component.table.edit", defaultMessage: "Edit {target}" },
955
- { target: `${role.name}` }
956
- ),
957
- children: /* @__PURE__ */ jsxRuntime.jsx(icons.Pencil, {})
958
- }
959
- ) : null,
960
- checkCanDeleteRole(role) && /* @__PURE__ */ jsxRuntime.jsx(
961
- designSystem.IconButton,
962
- {
963
- onClick: () => handleClickDelete(role.id.toString()),
964
- variant: "ghost",
965
- label: formatMessage(
966
- { id: "global.delete-target", defaultMessage: "Delete {target}" },
967
- { target: `${role.name}` }
968
- ),
969
- children: /* @__PURE__ */ jsxRuntime.jsx(icons.Trash, {})
970
- }
971
- )
972
- ] }) })
973
- ] }, role.name)) });
974
- };
975
- TableBody.defaultProps = {
976
- canDelete: false,
977
- canUpdate: false
978
- };
979
- TableBody.propTypes = {
980
- onDelete: PropTypes__default.default.array.isRequired,
981
- setRoleToDelete: PropTypes__default.default.func.isRequired,
982
- sortedRoles: PropTypes__default.default.array.isRequired,
983
- canDelete: PropTypes__default.default.bool,
984
- canUpdate: PropTypes__default.default.bool
985
- };
986
- const RolesListPage = () => {
987
- const { trackUsage } = admin.useTracking();
988
- const { formatMessage, locale } = reactIntl.useIntl();
989
- const { toggleNotification } = admin.useNotification();
990
- const { notifyStatus } = designSystem.useNotifyAT();
991
- const [{ query }] = admin.useQueryParams();
992
- const _q = query?._q || "";
993
- const [showConfirmDelete, setShowConfirmDelete] = React.useState(false);
994
- const [roleToDelete, setRoleToDelete] = React.useState();
995
- const { del, get: get2 } = admin.useFetchClient();
996
- const {
997
- isLoading: isLoadingForPermissions,
998
- allowedActions: { canRead, canDelete, canCreate, canUpdate }
999
- } = admin.useRBAC({
1000
- create: index.PERMISSIONS.createRole,
1001
- read: index.PERMISSIONS.readRoles,
1002
- update: index.PERMISSIONS.updateRole,
1003
- delete: index.PERMISSIONS.deleteRole
1004
- });
1005
- const {
1006
- isLoading: isLoadingForData,
1007
- data: { roles },
1008
- isFetching,
1009
- refetch
1010
- } = reactQuery.useQuery("get-roles", () => fetchData(toggleNotification, formatMessage, notifyStatus), {
1011
- initialData: {},
1012
- enabled: canRead
1013
- });
1014
- const { contains } = designSystem.useFilter(locale, {
1015
- sensitivity: "base"
1016
- });
1017
- const formatter = designSystem.useCollator(locale, {
1018
- sensitivity: "base"
1019
- });
1020
- const isLoading = isLoadingForData || isFetching || isLoadingForPermissions;
1021
- const handleShowConfirmDelete = () => {
1022
- setShowConfirmDelete(!showConfirmDelete);
1023
- };
1024
- const deleteData = async (id, formatMessage2, toggleNotification2) => {
1025
- try {
1026
- await del(`/users-permissions/roles/${id}`);
1027
- } catch (error) {
1028
- toggleNotification2({
1029
- type: "danger",
1030
- message: formatMessage2({ id: "notification.error", defaultMessage: "An error occured" })
1031
- });
1032
- }
1033
- };
1034
- const fetchData = async (toggleNotification2, formatMessage2, notifyStatus2) => {
1035
- try {
1036
- const { data } = await get2("/users-permissions/roles");
1037
- notifyStatus2("The roles have loaded successfully");
1038
- return data;
1039
- } catch (err) {
1040
- toggleNotification2({
1041
- type: "danger",
1042
- message: formatMessage2({ id: "notification.error", defaultMessage: "An error occurred" })
1043
- });
1044
- throw new Error(err);
1045
- }
1046
- };
1047
- const emptyLayout = {
1048
- roles: {
1049
- id: index.getTrad("Roles.empty"),
1050
- defaultMessage: "You don't have any roles yet."
1051
- },
1052
- search: {
1053
- id: index.getTrad("Roles.empty.search"),
1054
- defaultMessage: "No roles match the search."
1055
- }
1056
- };
1057
- const pageTitle = formatMessage({
1058
- id: "global.roles",
1059
- defaultMessage: "Roles"
1060
- });
1061
- const deleteMutation = reactQuery.useMutation((id) => deleteData(id, formatMessage, toggleNotification), {
1062
- async onSuccess() {
1063
- await refetch();
1064
- }
1065
- });
1066
- const handleConfirmDelete = async () => {
1067
- await deleteMutation.mutateAsync(roleToDelete);
1068
- setShowConfirmDelete(!showConfirmDelete);
1069
- };
1070
- const sortedRoles = (roles || []).filter((role) => contains(role.name, _q) || contains(role.description, _q)).sort(
1071
- (a, b) => formatter.compare(a.name, b.name) || formatter.compare(a.description, b.description)
1072
- );
1073
- const emptyContent = _q && !sortedRoles.length ? "search" : "roles";
1074
- const colCount = 4;
1075
- const rowCount = (roles?.length || 0) + 1;
1076
- if (isLoading) {
1077
- return /* @__PURE__ */ jsxRuntime.jsx(admin.Page.Loading, {});
1078
- }
1079
- return /* @__PURE__ */ jsxRuntime.jsxs(admin.Layouts.Root, { children: [
1080
- /* @__PURE__ */ jsxRuntime.jsx(admin.Page.Title, { children: formatMessage(
1081
- { id: "Settings.PageTitle", defaultMessage: "Settings - {name}" },
1082
- { name: pageTitle }
1083
- ) }),
1084
- /* @__PURE__ */ jsxRuntime.jsxs(admin.Page.Main, { children: [
1085
- /* @__PURE__ */ jsxRuntime.jsx(
1086
- admin.Layouts.Header,
1087
- {
1088
- title: formatMessage({
1089
- id: "global.roles",
1090
- defaultMessage: "Roles"
1091
- }),
1092
- subtitle: formatMessage({
1093
- id: "Settings.roles.list.description",
1094
- defaultMessage: "List of roles"
1095
- }),
1096
- primaryAction: canCreate ? /* @__PURE__ */ jsxRuntime.jsx(
1097
- designSystem.LinkButton,
1098
- {
1099
- to: "new",
1100
- tag: reactRouterDom.NavLink,
1101
- onClick: () => trackUsage("willCreateRole"),
1102
- startIcon: /* @__PURE__ */ jsxRuntime.jsx(icons.Plus, {}),
1103
- size: "S",
1104
- children: formatMessage({
1105
- id: index.getTrad("List.button.roles"),
1106
- defaultMessage: "Add new role"
1107
- })
1108
- }
1109
- ) : null
1110
- }
1111
- ),
1112
- /* @__PURE__ */ jsxRuntime.jsx(
1113
- admin.Layouts.Action,
1114
- {
1115
- startActions: /* @__PURE__ */ jsxRuntime.jsx(
1116
- admin.SearchInput,
1117
- {
1118
- label: formatMessage({
1119
- id: "app.component.search.label",
1120
- defaultMessage: "Search"
1121
- })
1122
- }
1123
- )
1124
- }
1125
- ),
1126
- /* @__PURE__ */ jsxRuntime.jsxs(admin.Layouts.Content, { children: [
1127
- !canRead && /* @__PURE__ */ jsxRuntime.jsx(admin.Page.NoPermissions, {}),
1128
- canRead && sortedRoles && sortedRoles?.length ? /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Table, { colCount, rowCount, children: [
1129
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Thead, { children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Tr, { children: [
1130
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Th, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "sigma", textColor: "neutral600", children: formatMessage({ id: "global.name", defaultMessage: "Name" }) }) }),
1131
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Th, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "sigma", textColor: "neutral600", children: formatMessage({
1132
- id: "global.description",
1133
- defaultMessage: "Description"
1134
- }) }) }),
1135
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Th, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "sigma", textColor: "neutral600", children: formatMessage({
1136
- id: "global.users",
1137
- defaultMessage: "Users"
1138
- }) }) }),
1139
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Th, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.VisuallyHidden, { children: formatMessage({
1140
- id: "global.actions",
1141
- defaultMessage: "Actions"
1142
- }) }) })
1143
- ] }) }),
1144
- /* @__PURE__ */ jsxRuntime.jsx(
1145
- TableBody,
1146
- {
1147
- sortedRoles,
1148
- canDelete,
1149
- canUpdate,
1150
- permissions: index.PERMISSIONS,
1151
- setRoleToDelete,
1152
- onDelete: [showConfirmDelete, setShowConfirmDelete]
1153
- }
1154
- )
1155
- ] }) : /* @__PURE__ */ jsxRuntime.jsx(designSystem.EmptyStateLayout, { content: formatMessage(emptyLayout[emptyContent]) })
1156
- ] }),
1157
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.Dialog.Root, { open: showConfirmDelete, onOpenChange: handleShowConfirmDelete, children: /* @__PURE__ */ jsxRuntime.jsx(admin.ConfirmDialog, { onConfirm: handleConfirmDelete }) })
1158
- ] })
1159
- ] });
1160
- };
1161
- const ProtectedRolesListPage = () => {
1162
- return /* @__PURE__ */ jsxRuntime.jsx(admin.Page.Protect, { permissions: index.PERMISSIONS.accessRoles, children: /* @__PURE__ */ jsxRuntime.jsx(RolesListPage, {}) });
1163
- };
1164
- const Roles = () => {
1165
- return /* @__PURE__ */ jsxRuntime.jsx(admin.Page.Protect, { permissions: index.PERMISSIONS.accessRoles, children: /* @__PURE__ */ jsxRuntime.jsxs(reactRouterDom.Routes, { children: [
1166
- /* @__PURE__ */ jsxRuntime.jsx(reactRouterDom.Route, { index: true, element: /* @__PURE__ */ jsxRuntime.jsx(ProtectedRolesListPage, {}) }),
1167
- /* @__PURE__ */ jsxRuntime.jsx(reactRouterDom.Route, { path: "new", element: /* @__PURE__ */ jsxRuntime.jsx(ProtectedRolesCreatePage, {}) }),
1168
- /* @__PURE__ */ jsxRuntime.jsx(reactRouterDom.Route, { path: ":id", element: /* @__PURE__ */ jsxRuntime.jsx(ProtectedRolesEditPage, {}) })
1169
- ] }) });
1170
- };
1171
- exports.default = Roles;
1172
- //# sourceMappingURL=index-DruWuFWL.js.map