@strapi/admin 4.6.0-beta.0 → 4.6.0-beta.2

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 (524) hide show
  1. package/.browserslistrc +3 -0
  2. package/admin/src/components/AuthenticatedApp/index.js +13 -2
  3. package/admin/src/components/GlobalStyle/index.js +0 -11
  4. package/admin/src/components/GuidedTour/Modal/components/Content.js +7 -2
  5. package/admin/src/components/LeftMenu/index.js +8 -4
  6. package/admin/src/components/Notifications/Notification/index.js +25 -3
  7. package/admin/src/components/Notifications/reducer.js +1 -0
  8. package/admin/src/content-manager/components/ComponentIcon/ComponentIcon.js +49 -0
  9. package/admin/src/content-manager/components/ComponentIcon/index.js +1 -0
  10. package/admin/src/content-manager/components/DragLayer/ComponentDragPreview.js +2 -16
  11. package/admin/src/content-manager/components/DragLayer/RelationDragPreview.js +9 -7
  12. package/admin/src/content-manager/components/DragLayer/index.js +1 -1
  13. package/admin/src/content-manager/components/DynamicTable/CellContent/RelationMultiple/index.js +4 -0
  14. package/admin/src/content-manager/components/DynamicZone/components/ComponentCard.js +17 -31
  15. package/admin/src/content-manager/components/DynamicZone/components/ComponentCategory.js +2 -2
  16. package/admin/src/content-manager/components/DynamicZone/components/DynamicComponent.js +1 -3
  17. package/admin/src/content-manager/components/EditViewDataManagerProvider/index.js +5 -6
  18. package/admin/src/content-manager/components/EditViewDataManagerProvider/reducer.js +49 -8
  19. package/admin/src/content-manager/components/EditViewDataManagerProvider/utils/cleanData.js +18 -6
  20. package/admin/src/content-manager/components/EditViewDataManagerProvider/utils/findLeafByPathAndReplace.js +2 -1
  21. package/admin/src/content-manager/components/EditViewDataManagerProvider/utils/schema.js +2 -1
  22. package/admin/src/content-manager/components/FieldComponent/index.js +6 -4
  23. package/admin/src/content-manager/components/InputJSON/FieldWrapper.js +10 -2
  24. package/admin/src/content-manager/components/InputJSON/Label.js +2 -18
  25. package/admin/src/content-manager/components/InputJSON/index.js +7 -3
  26. package/admin/src/content-manager/components/RelationInput/RelationInput.js +14 -25
  27. package/admin/src/content-manager/components/RelationInput/components/RelationItem.js +8 -1
  28. package/admin/src/content-manager/components/RelationInput/components/RelationList.js +10 -6
  29. package/admin/src/content-manager/components/RelationInput/index.js +1 -0
  30. package/admin/src/content-manager/components/RelationInputDataManager/RelationInputDataManager.js +17 -6
  31. package/admin/src/content-manager/components/RelationInputDataManager/utils/select.js +5 -5
  32. package/admin/src/content-manager/components/RepeatableComponent/index.js +19 -26
  33. package/admin/src/content-manager/hooks/useCallbackRef.js +23 -0
  34. package/admin/src/content-manager/hooks/useDragAndDrop.js +26 -12
  35. package/admin/src/content-manager/hooks/useKeyboardDragAndDrop.js +10 -2
  36. package/admin/src/content-manager/hooks/useRelation/useRelation.js +9 -6
  37. package/admin/src/content-manager/pages/App/LeftMenu/index.js +5 -7
  38. package/admin/src/content-manager/pages/EditSettingsView/components/DynamicZoneList.js +18 -38
  39. package/admin/src/content-manager/pages/EditView/Header/index.js +1 -1
  40. package/admin/src/content-manager/pages/ListSettingsView/index.js +3 -5
  41. package/admin/src/content-manager/utils/getMaxTempKey.js +4 -2
  42. package/admin/src/content-manager/utils/paths.js +37 -0
  43. package/admin/src/hooks/index.js +0 -1
  44. package/admin/src/hooks/useSettingsMenu/init.js +7 -0
  45. package/admin/src/pages/Admin/Onboarding/index.js +42 -44
  46. package/admin/src/pages/App/index.js +20 -12
  47. package/admin/src/pages/AuthPage/components/Register/index.js +1 -1
  48. package/admin/src/pages/AuthPage/components/ResetPassword/index.js +1 -1
  49. package/admin/src/pages/ProfilePage/index.js +1 -1
  50. package/admin/src/pages/SettingsPage/pages/ApiTokens/EditView/index.js +2 -3
  51. package/admin/src/pages/SettingsPage/pages/AuditLogs/ListView/Modal/ActionBody.js +111 -0
  52. package/admin/src/pages/SettingsPage/pages/AuditLogs/ListView/Modal/ActionItem.js +22 -0
  53. package/admin/src/pages/SettingsPage/pages/AuditLogs/ListView/Modal/index.js +52 -0
  54. package/admin/src/pages/SettingsPage/pages/AuditLogs/ListView/PaginationFooter/index.js +35 -0
  55. package/admin/src/pages/SettingsPage/pages/AuditLogs/ListView/TableRows/index.js +88 -0
  56. package/admin/src/pages/SettingsPage/pages/AuditLogs/ListView/hooks/useFormatTimeStamp.js +24 -0
  57. package/admin/src/pages/SettingsPage/pages/AuditLogs/ListView/index.js +98 -0
  58. package/admin/src/pages/SettingsPage/pages/AuditLogs/ListView/utils/getActionTypesDefaultMessages.js +33 -0
  59. package/admin/src/pages/SettingsPage/pages/AuditLogs/ListView/utils/tableHeaders.js +38 -0
  60. package/admin/src/pages/SettingsPage/pages/AuditLogs/ProtectedListPage/index.js +12 -0
  61. package/admin/src/pages/SettingsPage/utils/defaultRoutes.js +11 -0
  62. package/admin/src/permissions/defaultPermissions.js +4 -0
  63. package/admin/src/translations/ca.json +2 -3
  64. package/admin/src/translations/dk.json +2 -2
  65. package/admin/src/translations/en.json +43 -1
  66. package/admin/src/translations/es.json +2 -2
  67. package/admin/src/translations/fr.json +2 -2
  68. package/admin/src/translations/hu.json +197 -2
  69. package/admin/src/translations/ja.json +2 -2
  70. package/admin/src/translations/nl.json +2 -2
  71. package/admin/src/translations/sk.json +274 -52
  72. package/admin/src/translations/tr.json +485 -5
  73. package/admin/src/translations/zh-Hans.json +1 -1
  74. package/admin/src/translations/zh.json +11 -3
  75. package/admin/src/utils/index.js +1 -0
  76. package/admin/src/utils/uniqueAdminHash.js +22 -0
  77. package/build/2235.746d3cf7.chunk.js +106 -0
  78. package/build/2598.01c96bd5.chunk.js +159 -0
  79. package/build/2743.692b1f21.chunk.js +42 -0
  80. package/build/3557.e7115160.chunk.js +169 -0
  81. package/build/4318.87affaf2.chunk.js +30 -0
  82. package/build/4958.1979bbf5.chunk.js +276 -0
  83. package/build/5015.f5e15fdb.chunk.js +6 -0
  84. package/build/5052.c2eacff2.chunk.js +65 -0
  85. package/build/7295.4e2dfbbb.chunk.js +114 -0
  86. package/build/805.da20168c.chunk.js +138 -0
  87. package/build/8633.6f546066.chunk.js +1 -0
  88. package/build/874.be41e4b3.chunk.js +104 -0
  89. package/build/9707.a07db355.chunk.js +101 -0
  90. package/build/Admin-authenticatedApp.9933974c.chunk.js +75 -0
  91. package/build/Admin_InternalErrorPage.157152a8.chunk.js +1 -0
  92. package/build/Admin_homePage.045bb0c8.chunk.js +77 -0
  93. package/build/Admin_marketplace.bf3ac090.chunk.js +26 -0
  94. package/build/Admin_pluginsPage.d2a9a619.chunk.js +6 -0
  95. package/build/Admin_profilePage.5e830ceb.chunk.js +15 -0
  96. package/build/Admin_settingsPage.53fa00a4.chunk.js +178 -0
  97. package/build/Upload_ConfigureTheView.9bdf41b5.chunk.js +1 -0
  98. package/build/admin-app.8ed108ca.chunk.js +112 -0
  99. package/build/admin-audit-logs.68f833bf.chunk.js +1 -0
  100. package/build/admin-edit-roles-page.32bfe5ea.chunk.js +1 -0
  101. package/build/admin-edit-users.795f155c.chunk.js +10 -0
  102. package/build/admin-users.cbd9bcf7.chunk.js +11 -0
  103. package/build/api-tokens-create-page.0e686c30.chunk.js +1 -0
  104. package/build/api-tokens-edit-page.d6c7487b.chunk.js +1 -0
  105. package/build/api-tokens-list-page.a55e427c.chunk.js +16 -0
  106. package/build/ar-json.932794f7.chunk.js +1 -0
  107. package/build/ca-json.f6a0f472.chunk.js +1 -0
  108. package/build/codemirror-addon-closebrackets.71aa4bbd.chunk.js +2 -0
  109. package/build/codemirror-addon-lint-js.405f70fb.chunk.js +1 -0
  110. package/build/codemirror-addon-lint.8487ad3d.chunk.js +1 -0
  111. package/build/codemirror-addon-mark-selection.1928c849.chunk.js +1 -0
  112. package/build/{codemirror-css.4e2bbed3.chunk.js → codemirror-css.359a2a4b.chunk.js} +2 -3
  113. package/build/codemirror-javacript.af237b68.chunk.js +1 -0
  114. package/build/codemirror-theme.2fe63a16.chunk.js +33 -0
  115. package/build/content-manager.ad929a94.chunk.js +1174 -0
  116. package/build/content-type-builder-list-view.3048854d.chunk.js +198 -0
  117. package/build/content-type-builder-translation-ar-json.56d8fcf4.chunk.js +1 -0
  118. package/build/content-type-builder-translation-cs-json.a5b299ca.chunk.js +1 -0
  119. package/build/content-type-builder-translation-de-json.29df67b8.chunk.js +1 -0
  120. package/build/content-type-builder-translation-dk-json.e22d2527.chunk.js +1 -0
  121. package/build/content-type-builder-translation-en-json.08e28f4e.chunk.js +1 -0
  122. package/build/content-type-builder-translation-es-json.1044b252.chunk.js +1 -0
  123. package/build/content-type-builder-translation-fr-json.2183e6b3.chunk.js +1 -0
  124. package/build/content-type-builder-translation-id-json.ba3e8891.chunk.js +1 -0
  125. package/build/content-type-builder-translation-it-json.d4661201.chunk.js +1 -0
  126. package/build/content-type-builder-translation-ja-json.9be0d5b2.chunk.js +1 -0
  127. package/build/content-type-builder-translation-ko-json.57ff7f51.chunk.js +1 -0
  128. package/build/content-type-builder-translation-ms-json.2d29c1e0.chunk.js +1 -0
  129. package/build/content-type-builder-translation-nl-json.40bbc562.chunk.js +1 -0
  130. package/build/content-type-builder-translation-pl-json.a057b51e.chunk.js +1 -0
  131. package/build/content-type-builder-translation-pt-BR-json.446df9da.chunk.js +1 -0
  132. package/build/content-type-builder-translation-pt-json.ddb44f8c.chunk.js +1 -0
  133. package/build/content-type-builder-translation-ru-json.8c51843e.chunk.js +1 -0
  134. package/build/content-type-builder-translation-sk-json.626c9493.chunk.js +1 -0
  135. package/build/content-type-builder-translation-sv-json.af6ecca1.chunk.js +1 -0
  136. package/build/content-type-builder-translation-th-json.6fe3ed55.chunk.js +1 -0
  137. package/build/content-type-builder-translation-tr-json.da83a07e.chunk.js +1 -0
  138. package/build/content-type-builder-translation-uk-json.c4524247.chunk.js +1 -0
  139. package/build/content-type-builder-translation-zh-Hans-json.52a30266.chunk.js +1 -0
  140. package/build/content-type-builder-translation-zh-json.42f94cb3.chunk.js +1 -0
  141. package/build/content-type-builder.4edd1c22.chunk.js +127 -0
  142. package/build/cs-json.79879fb6.chunk.js +1 -0
  143. package/build/de-json.30e1f35b.chunk.js +1 -0
  144. package/build/dk-json.e6d9ffa4.chunk.js +1 -0
  145. package/build/email-settings-page.7c9e6c5e.chunk.js +15 -0
  146. package/build/email-translation-ar-json.88304564.chunk.js +1 -0
  147. package/build/email-translation-cs-json.6eaeec6a.chunk.js +1 -0
  148. package/build/email-translation-de-json.1b334230.chunk.js +1 -0
  149. package/build/email-translation-dk-json.85402492.chunk.js +1 -0
  150. package/build/email-translation-en-json.4211d4d0.chunk.js +1 -0
  151. package/build/email-translation-es-json.0b6b1006.chunk.js +1 -0
  152. package/build/email-translation-fr-json.78be2787.chunk.js +1 -0
  153. package/build/email-translation-id-json.c97239fe.chunk.js +1 -0
  154. package/build/email-translation-it-json.a2ed8c78.chunk.js +1 -0
  155. package/build/email-translation-ja-json.63eebd02.chunk.js +1 -0
  156. package/build/email-translation-ko-json.4de49b23.chunk.js +1 -0
  157. package/build/email-translation-ms-json.7390477e.chunk.js +1 -0
  158. package/build/email-translation-nl-json.377bdd9f.chunk.js +1 -0
  159. package/build/email-translation-pl-json.97d0db97.chunk.js +1 -0
  160. package/build/email-translation-pt-BR-json.81cca553.chunk.js +1 -0
  161. package/build/email-translation-pt-json.2a2a0643.chunk.js +1 -0
  162. package/build/email-translation-ru-json.6bce37dd.chunk.js +1 -0
  163. package/build/email-translation-sk-json.53da2fcd.chunk.js +1 -0
  164. package/build/email-translation-th-json.660fa9a8.chunk.js +1 -0
  165. package/build/email-translation-tr-json.e6c0f8fc.chunk.js +1 -0
  166. package/build/email-translation-uk-json.bd1fb6bf.chunk.js +1 -0
  167. package/build/email-translation-vi-json.9fb7e6d7.chunk.js +1 -0
  168. package/build/email-translation-zh-Hans-json.c6841563.chunk.js +1 -0
  169. package/build/email-translation-zh-json.7a2232ea.chunk.js +1 -0
  170. package/build/en-json.d65a13ef.chunk.js +1 -0
  171. package/build/es-json.e275481d.chunk.js +1 -0
  172. package/build/fr-json.78545ef8.chunk.js +1 -0
  173. package/build/gu-json.676518f2.chunk.js +1 -0
  174. package/build/he-json.ad22e8cc.chunk.js +1 -0
  175. package/build/hi-json.19b51c09.chunk.js +1 -0
  176. package/build/highlight.js.26ef649f.chunk.js +85 -0
  177. package/build/hu-json.f947088f.chunk.js +1 -0
  178. package/build/i18n-settings-page.fbccdf12.chunk.js +1 -0
  179. package/build/i18n-translation-de-json.dc876c08.chunk.js +1 -0
  180. package/build/i18n-translation-dk-json.49aaf933.chunk.js +1 -0
  181. package/build/i18n-translation-en-json.ac9ebc1b.chunk.js +1 -0
  182. package/build/i18n-translation-es-json.57072ed3.chunk.js +1 -0
  183. package/build/i18n-translation-fr-json.84733f34.chunk.js +1 -0
  184. package/build/i18n-translation-ko-json.fc73fe20.chunk.js +1 -0
  185. package/build/i18n-translation-pl-json.16e5df90.chunk.js +1 -0
  186. package/build/i18n-translation-tr-json.cb39c048.chunk.js +1 -0
  187. package/build/i18n-translation-zh-Hans-json.2cf82d2d.chunk.js +1 -0
  188. package/build/i18n-translation-zh-json.ed1d272e.chunk.js +1 -0
  189. package/build/id-json.504daa84.chunk.js +1 -0
  190. package/build/index.html +1 -1
  191. package/build/it-json.2fd90f4d.chunk.js +1 -0
  192. package/build/ja-json.c9f12d0b.chunk.js +1 -0
  193. package/build/ko-json.ef463065.chunk.js +1 -0
  194. package/build/main.6bbf9950.js +4417 -0
  195. package/build/ml-json.490f666c.chunk.js +1 -0
  196. package/build/ms-json.db87d8d3.chunk.js +1 -0
  197. package/build/nl-json.c416295a.chunk.js +1 -0
  198. package/build/no-json.1a2258ba.chunk.js +1 -0
  199. package/build/pl-json.8cf0c871.chunk.js +1 -0
  200. package/build/pt-BR-json.51fab8d0.chunk.js +1 -0
  201. package/build/pt-json.62927d1e.chunk.js +1 -0
  202. package/build/ru-json.3b411a39.chunk.js +1 -0
  203. package/build/runtime~main.c2bf62af.js +2 -0
  204. package/build/sa-json.f3fa5407.chunk.js +1 -0
  205. package/build/sk-json.9ec60d9f.chunk.js +1 -0
  206. package/build/sso-settings-page.4031de9e.chunk.js +41 -0
  207. package/build/sv-json.c6b0c237.chunk.js +1 -0
  208. package/build/th-json.6e68155c.chunk.js +1 -0
  209. package/build/tr-json.9f41dc08.chunk.js +1 -0
  210. package/build/uk-json.b2fcd567.chunk.js +1 -0
  211. package/build/upload-settings.657790fd.chunk.js +89 -0
  212. package/build/upload-translation-ca-json.57954414.chunk.js +1 -0
  213. package/build/upload-translation-de-json.420c943b.chunk.js +1 -0
  214. package/build/upload-translation-dk-json.bbb2fa05.chunk.js +1 -0
  215. package/build/upload-translation-en-json.8b7573ce.chunk.js +1 -0
  216. package/build/upload-translation-es-json.ba2eb03a.chunk.js +1 -0
  217. package/build/upload-translation-fr-json.84429734.chunk.js +1 -0
  218. package/build/upload-translation-he-json.0a830937.chunk.js +1 -0
  219. package/build/upload-translation-it-json.e87d7966.chunk.js +1 -0
  220. package/build/upload-translation-ja-json.44b88e7a.chunk.js +1 -0
  221. package/build/upload-translation-ko-json.a52eab64.chunk.js +1 -0
  222. package/build/upload-translation-ms-json.74f6d746.chunk.js +1 -0
  223. package/build/upload-translation-pl-json.426f31c9.chunk.js +1 -0
  224. package/build/upload-translation-pt-BR-json.d1704f0b.chunk.js +1 -0
  225. package/build/upload-translation-pt-json.6b937fdf.chunk.js +1 -0
  226. package/build/upload-translation-ru-json.675f6b93.chunk.js +1 -0
  227. package/build/upload-translation-sk-json.483a18f6.chunk.js +1 -0
  228. package/build/upload-translation-th-json.3847dae0.chunk.js +1 -0
  229. package/build/upload-translation-tr-json.74117e5c.chunk.js +1 -0
  230. package/build/upload-translation-uk-json.9950466a.chunk.js +1 -0
  231. package/build/upload-translation-zh-Hans-json.3da5cf56.chunk.js +1 -0
  232. package/build/upload-translation-zh-json.e1dd6eb2.chunk.js +1 -0
  233. package/build/upload.608a9856.chunk.js +38 -0
  234. package/build/users-advanced-settings-page.e3ab865f.chunk.js +13 -0
  235. package/build/users-email-settings-page.57adf9b7.chunk.js +28 -0
  236. package/build/users-permissions-translation-ar-json.7d87d54d.chunk.js +1 -0
  237. package/build/users-permissions-translation-cs-json.7e23424a.chunk.js +1 -0
  238. package/build/users-permissions-translation-de-json.a6fb670f.chunk.js +1 -0
  239. package/build/users-permissions-translation-dk-json.60e50f48.chunk.js +1 -0
  240. package/build/users-permissions-translation-en-json.4b302272.chunk.js +1 -0
  241. package/build/users-permissions-translation-es-json.35007573.chunk.js +1 -0
  242. package/build/users-permissions-translation-fr-json.7e55bbbb.chunk.js +1 -0
  243. package/build/users-permissions-translation-id-json.a5a0fb59.chunk.js +1 -0
  244. package/build/users-permissions-translation-it-json.0705465d.chunk.js +1 -0
  245. package/build/users-permissions-translation-ja-json.891fe76e.chunk.js +1 -0
  246. package/build/users-permissions-translation-ko-json.357d7a33.chunk.js +1 -0
  247. package/build/users-permissions-translation-ms-json.c83f87c4.chunk.js +1 -0
  248. package/build/users-permissions-translation-nl-json.c9f92a3c.chunk.js +1 -0
  249. package/build/users-permissions-translation-pl-json.0a7287d1.chunk.js +1 -0
  250. package/build/users-permissions-translation-pt-BR-json.1b6d2920.chunk.js +1 -0
  251. package/build/users-permissions-translation-pt-json.a7eda429.chunk.js +1 -0
  252. package/build/users-permissions-translation-ru-json.20e177db.chunk.js +1 -0
  253. package/build/users-permissions-translation-sk-json.7f37180f.chunk.js +1 -0
  254. package/build/users-permissions-translation-sv-json.17187818.chunk.js +1 -0
  255. package/build/users-permissions-translation-th-json.1e9c0247.chunk.js +1 -0
  256. package/build/users-permissions-translation-tr-json.2bd7ff98.chunk.js +1 -0
  257. package/build/users-permissions-translation-uk-json.6a0a1572.chunk.js +1 -0
  258. package/build/users-permissions-translation-vi-json.6722a8a2.chunk.js +1 -0
  259. package/build/users-permissions-translation-zh-Hans-json.0b31c705.chunk.js +1 -0
  260. package/build/users-permissions-translation-zh-json.7978eaa6.chunk.js +1 -0
  261. package/build/users-providers-settings-page.7d1fb45c.chunk.js +1 -0
  262. package/build/users-roles-settings-page.ad28ab42.chunk.js +30 -0
  263. package/build/vi-json.f08d7d03.chunk.js +1 -0
  264. package/build/webhook-edit-page.1dd6d040.chunk.js +75 -0
  265. package/build/webhook-list-page.98afa3ea.chunk.js +42 -0
  266. package/build/zh-Hans-json.9c0eac99.chunk.js +1 -0
  267. package/build/zh-json.f88f563d.chunk.js +1 -0
  268. package/ee/server/bootstrap.js +6 -20
  269. package/ee/server/config/admin-actions.js +32 -0
  270. package/ee/server/controllers/audit-logs.js +24 -0
  271. package/ee/server/controllers/authentication/middlewares.js +2 -1
  272. package/ee/server/controllers/index.js +1 -0
  273. package/ee/server/destroy.js +12 -0
  274. package/ee/server/index.js +2 -0
  275. package/ee/server/register.js +15 -0
  276. package/ee/server/routes/features-routes.js +20 -0
  277. package/ee/server/services/audit-logs.js +135 -0
  278. package/ee/server/services/passport/provider-registry.js +1 -1
  279. package/ee/server/validation/audit-logs.js +18 -0
  280. package/package.json +21 -17
  281. package/server/controllers/admin.js +2 -0
  282. package/server/controllers/authentication.js +8 -1
  283. package/server/index.js +2 -0
  284. package/server/middlewares/index.js +7 -0
  285. package/server/middlewares/rateLimit.js +43 -0
  286. package/server/register.js +9 -0
  287. package/server/routes/admin.js +1 -1
  288. package/server/routes/authentication.js +12 -1
  289. package/server/routes/roles.js +0 -8
  290. package/server/services/metrics.js +5 -2
  291. package/server/services/permission/queries.js +12 -3
  292. package/server/services/role.js +12 -2
  293. package/server/services/user.js +23 -3
  294. package/webpack.alias.js +0 -2
  295. package/webpack.config.js +7 -4
  296. package/admin/src/content-manager/components/BackHeader/index.js +0 -8
  297. package/admin/src/content-manager/components/Block/components.js +0 -28
  298. package/admin/src/content-manager/components/Block/index.js +0 -43
  299. package/admin/src/content-manager/components/Container/index.js +0 -7
  300. package/admin/src/content-manager/components/CustomInputCheckbox/components.js +0 -77
  301. package/admin/src/content-manager/components/CustomInputCheckbox/index.js +0 -53
  302. package/admin/src/content-manager/components/DynamicComponentCard/Wrapper.js +0 -63
  303. package/admin/src/content-manager/components/FilterOptionsCTA/index.js +0 -14
  304. package/admin/src/content-manager/components/FormTitle/index.js +0 -22
  305. package/admin/src/content-manager/components/FormWrapper/index.js +0 -20
  306. package/admin/src/content-manager/components/InputJSON/FieldError.js +0 -38
  307. package/admin/src/content-manager/components/LayoutTitle/index.js +0 -19
  308. package/admin/src/content-manager/components/PlusButton/index.js +0 -52
  309. package/admin/src/content-manager/components/PreviewCarret/components.js +0 -27
  310. package/admin/src/content-manager/components/PreviewCarret/index.js +0 -22
  311. package/admin/src/content-manager/components/SectionTitle/Title.js +0 -11
  312. package/admin/src/content-manager/components/SectionTitle/index.js +0 -26
  313. package/admin/src/hooks/useFetchClient/index.js +0 -23
  314. package/admin/src/utils/fetchClient.js +0 -45
  315. package/admin/src/utils/getFetchClient.js +0 -10
  316. package/build/1551f4f60c37af51121f.woff2 +0 -0
  317. package/build/1e59d2330b4c6deb84b3.ttf +0 -0
  318. package/build/20fd1704ea223900efa9.woff2 +0 -0
  319. package/build/2285773e6b4b172f07d9.woff +0 -0
  320. package/build/23f19bb08961f37aaf69.eot +0 -0
  321. package/build/2f517e09eb2ca6650ff5.svg +0 -3717
  322. package/build/4306.df40a798.chunk.js +0 -98
  323. package/build/4318.80bdf035.chunk.js +0 -30
  324. package/build/4689f52cc96215721344.svg +0 -801
  325. package/build/491974d108fe4002b2aa.ttf +0 -0
  326. package/build/5015.f080b64e.chunk.js +0 -6
  327. package/build/504.9aeff724.chunk.js +0 -758
  328. package/build/5057.195a59ff.chunk.js +0 -65
  329. package/build/527940b104eb2ea366c8.ttf +0 -0
  330. package/build/77206a6bb316fa0aded5.eot +0 -0
  331. package/build/7a3337626410ca2f4071.woff2 +0 -0
  332. package/build/7a8b4f130182d19a2d7c.svg +0 -5034
  333. package/build/805.e991a370.chunk.js +0 -138
  334. package/build/8176.b19bc128.chunk.js +0 -145
  335. package/build/8186.55910742.chunk.js +0 -169
  336. package/build/8633.59223842.chunk.js +0 -1
  337. package/build/8881.c693411a.chunk.js +0 -245
  338. package/build/8b43027f47b20503057d.eot +0 -0
  339. package/build/9161.4a0ab137.chunk.js +0 -2119
  340. package/build/9279.6290c87a.chunk.js +0 -117
  341. package/build/9707.a0cc4ad8.chunk.js +0 -70
  342. package/build/9bbb245e67a133f6e486.eot +0 -0
  343. package/build/Admin-authenticatedApp.f9e74dc0.chunk.js +0 -80
  344. package/build/Admin_InternalErrorPage.e0317a5e.chunk.js +0 -1
  345. package/build/Admin_homePage.8945f71a.chunk.js +0 -77
  346. package/build/Admin_marketplace.ed754a4a.chunk.js +0 -26
  347. package/build/Admin_pluginsPage.3c872de7.chunk.js +0 -6
  348. package/build/Admin_profilePage.c07bdf08.chunk.js +0 -15
  349. package/build/Admin_settingsPage.50a8765b.chunk.js +0 -178
  350. package/build/admin-app.2861b6d2.chunk.js +0 -112
  351. package/build/admin-edit-roles-page.f407538c.chunk.js +0 -1
  352. package/build/admin-edit-users.85231e4c.chunk.js +0 -10
  353. package/build/admin-users.a2707644.chunk.js +0 -11
  354. package/build/api-tokens-create-page.dd4ddfcb.chunk.js +0 -1
  355. package/build/api-tokens-edit-page.821c5a6c.chunk.js +0 -1
  356. package/build/api-tokens-list-page.700e575f.chunk.js +0 -16
  357. package/build/ar-json.3489463d.chunk.js +0 -1
  358. package/build/bb58e57c48a3e911f15f.woff +0 -0
  359. package/build/be9ee23c0c6390141475.ttf +0 -0
  360. package/build/c1e38fd9e0e74ba58f7a.svg +0 -2671
  361. package/build/ca-json.07ae0f2c.chunk.js +0 -1
  362. package/build/codemirror-addon-closebrackets.c0f97916.chunk.js +0 -2
  363. package/build/codemirror-addon-lint-js.7c35dcb0.chunk.js +0 -1
  364. package/build/codemirror-addon-lint.505ff1d4.chunk.js +0 -1
  365. package/build/codemirror-addon-mark-selection.653e904d.chunk.js +0 -1
  366. package/build/codemirror-javacript.41bdefda.chunk.js +0 -1
  367. package/build/codemirror-theme.a82cae4e.chunk.js +0 -34
  368. package/build/content-manager.ee948f75.chunk.js +0 -1186
  369. package/build/content-type-builder-list-view.4412efc3.chunk.js +0 -201
  370. package/build/content-type-builder-translation-ar-json.142327af.chunk.js +0 -1
  371. package/build/content-type-builder-translation-cs-json.4aafb972.chunk.js +0 -1
  372. package/build/content-type-builder-translation-de-json.0d7696b9.chunk.js +0 -1
  373. package/build/content-type-builder-translation-dk-json.4729f055.chunk.js +0 -1
  374. package/build/content-type-builder-translation-en-json.f985c9c4.chunk.js +0 -1
  375. package/build/content-type-builder-translation-es-json.333cf47f.chunk.js +0 -1
  376. package/build/content-type-builder-translation-fr-json.aa6eeea8.chunk.js +0 -1
  377. package/build/content-type-builder-translation-id-json.7c00a32a.chunk.js +0 -1
  378. package/build/content-type-builder-translation-it-json.a906b389.chunk.js +0 -1
  379. package/build/content-type-builder-translation-ja-json.87f71930.chunk.js +0 -1
  380. package/build/content-type-builder-translation-ko-json.51201b12.chunk.js +0 -1
  381. package/build/content-type-builder-translation-ms-json.963a1a01.chunk.js +0 -1
  382. package/build/content-type-builder-translation-nl-json.c46c8f30.chunk.js +0 -1
  383. package/build/content-type-builder-translation-pl-json.4a42349b.chunk.js +0 -1
  384. package/build/content-type-builder-translation-pt-BR-json.6fe3b8d1.chunk.js +0 -1
  385. package/build/content-type-builder-translation-pt-json.96a31576.chunk.js +0 -1
  386. package/build/content-type-builder-translation-ru-json.cf8d7c5c.chunk.js +0 -1
  387. package/build/content-type-builder-translation-sk-json.3a6defe0.chunk.js +0 -1
  388. package/build/content-type-builder-translation-sv-json.6deff030.chunk.js +0 -1
  389. package/build/content-type-builder-translation-th-json.c96a2d3f.chunk.js +0 -1
  390. package/build/content-type-builder-translation-tr-json.2e52bc60.chunk.js +0 -1
  391. package/build/content-type-builder-translation-uk-json.d8c0b6dd.chunk.js +0 -1
  392. package/build/content-type-builder-translation-zh-Hans-json.92a27f59.chunk.js +0 -1
  393. package/build/content-type-builder-translation-zh-json.3b0afd31.chunk.js +0 -1
  394. package/build/content-type-builder.b132b5f4.chunk.js +0 -145
  395. package/build/cropper-css.12fe038c.chunk.js +0 -306
  396. package/build/cs-json.ce49da5c.chunk.js +0 -1
  397. package/build/d878b0a6a1144760244f.woff2 +0 -0
  398. package/build/de-json.6b3e1894.chunk.js +0 -1
  399. package/build/dk-json.144c6a8e.chunk.js +0 -1
  400. package/build/eeccf4f66002c6f2ba24.woff +0 -0
  401. package/build/email-settings-page.db0d98d1.chunk.js +0 -15
  402. package/build/email-translation-ar-json.c624512d.chunk.js +0 -1
  403. package/build/email-translation-cs-json.cb18caab.chunk.js +0 -1
  404. package/build/email-translation-de-json.54743260.chunk.js +0 -1
  405. package/build/email-translation-dk-json.f323fe4e.chunk.js +0 -1
  406. package/build/email-translation-en-json.ebad8943.chunk.js +0 -1
  407. package/build/email-translation-es-json.9021417d.chunk.js +0 -1
  408. package/build/email-translation-fr-json.9f125db0.chunk.js +0 -1
  409. package/build/email-translation-id-json.3bcae5f5.chunk.js +0 -1
  410. package/build/email-translation-it-json.6ffd1774.chunk.js +0 -1
  411. package/build/email-translation-ja-json.72b3f73c.chunk.js +0 -1
  412. package/build/email-translation-ko-json.e61d4e7a.chunk.js +0 -1
  413. package/build/email-translation-ms-json.b2b11e05.chunk.js +0 -1
  414. package/build/email-translation-nl-json.5349635f.chunk.js +0 -1
  415. package/build/email-translation-pl-json.a03bcf98.chunk.js +0 -1
  416. package/build/email-translation-pt-BR-json.2c98ab20.chunk.js +0 -1
  417. package/build/email-translation-pt-json.159505ab.chunk.js +0 -1
  418. package/build/email-translation-ru-json.d508cf3e.chunk.js +0 -1
  419. package/build/email-translation-sk-json.fa1fd4b3.chunk.js +0 -1
  420. package/build/email-translation-th-json.989cfecc.chunk.js +0 -1
  421. package/build/email-translation-tr-json.87f2feb3.chunk.js +0 -1
  422. package/build/email-translation-uk-json.0396a803.chunk.js +0 -1
  423. package/build/email-translation-vi-json.c0d8c414.chunk.js +0 -1
  424. package/build/email-translation-zh-Hans-json.8172da08.chunk.js +0 -1
  425. package/build/email-translation-zh-json.62b1c6fe.chunk.js +0 -1
  426. package/build/en-json.4a56dca7.chunk.js +0 -1
  427. package/build/es-json.6d123a82.chunk.js +0 -1
  428. package/build/f691f37e57f04c152e23.woff +0 -0
  429. package/build/fontawesome-css-all.15068c6e.chunk.js +0 -4618
  430. package/build/fontawesome-css.418f40da.chunk.js +0 -6
  431. package/build/fontawesome-js.252cc5f3.chunk.js +0 -7
  432. package/build/fr-json.28ab54cb.chunk.js +0 -1
  433. package/build/gu-json.9a50ea64.chunk.js +0 -1
  434. package/build/he-json.72f18790.chunk.js +0 -1
  435. package/build/hi-json.0301b7ba.chunk.js +0 -1
  436. package/build/highlight.js.af2de364.chunk.js +0 -86
  437. package/build/hu-json.c4b641bb.chunk.js +0 -1
  438. package/build/i18n-settings-page.195d42fe.chunk.js +0 -1
  439. package/build/i18n-translation-de-json.92534555.chunk.js +0 -1
  440. package/build/i18n-translation-dk-json.54f410ca.chunk.js +0 -1
  441. package/build/i18n-translation-en-json.760250ae.chunk.js +0 -1
  442. package/build/i18n-translation-es-json.488206ae.chunk.js +0 -1
  443. package/build/i18n-translation-fr-json.b401aa34.chunk.js +0 -1
  444. package/build/i18n-translation-ko-json.b2d90a83.chunk.js +0 -1
  445. package/build/i18n-translation-pl-json.cea5bf23.chunk.js +0 -1
  446. package/build/i18n-translation-zh-Hans-json.560a98e3.chunk.js +0 -1
  447. package/build/i18n-translation-zh-json.eeebb849.chunk.js +0 -1
  448. package/build/id-json.86035797.chunk.js +0 -1
  449. package/build/it-json.bbdc8993.chunk.js +0 -1
  450. package/build/ja-json.1c9eeeec.chunk.js +0 -1
  451. package/build/ko-json.e1f66398.chunk.js +0 -1
  452. package/build/main.faac89ee.js +0 -2025
  453. package/build/ml-json.963c889f.chunk.js +0 -1
  454. package/build/ms-json.ed51e902.chunk.js +0 -1
  455. package/build/nl-json.26f39180.chunk.js +0 -1
  456. package/build/no-json.a58c28bd.chunk.js +0 -1
  457. package/build/pl-json.249626b3.chunk.js +0 -1
  458. package/build/pt-BR-json.2b72b1d6.chunk.js +0 -1
  459. package/build/pt-json.cd67ba86.chunk.js +0 -1
  460. package/build/ru-json.8830286f.chunk.js +0 -1
  461. package/build/runtime~main.75a15b8e.js +0 -2
  462. package/build/sa-json.44e95991.chunk.js +0 -1
  463. package/build/sk-json.7ba4b330.chunk.js +0 -1
  464. package/build/sso-settings-page.adb12ac3.chunk.js +0 -1
  465. package/build/sv-json.fb1081ff.chunk.js +0 -1
  466. package/build/th-json.a67309b1.chunk.js +0 -1
  467. package/build/tr-json.9c44ea0c.chunk.js +0 -1
  468. package/build/uk-json.c4cd2e24.chunk.js +0 -1
  469. package/build/upload-settings.450cab1a.chunk.js +0 -18
  470. package/build/upload-translation-ca-json.db8ed7ba.chunk.js +0 -1
  471. package/build/upload-translation-de-json.00cbbc08.chunk.js +0 -1
  472. package/build/upload-translation-dk-json.c787a6be.chunk.js +0 -1
  473. package/build/upload-translation-en-json.86da7b0a.chunk.js +0 -1
  474. package/build/upload-translation-es-json.0f90db48.chunk.js +0 -1
  475. package/build/upload-translation-fr-json.e21c0c7a.chunk.js +0 -1
  476. package/build/upload-translation-he-json.4ce77b7b.chunk.js +0 -1
  477. package/build/upload-translation-it-json.5ce11e0b.chunk.js +0 -1
  478. package/build/upload-translation-ja-json.22afae44.chunk.js +0 -1
  479. package/build/upload-translation-ko-json.392002fb.chunk.js +0 -1
  480. package/build/upload-translation-ms-json.0605d6da.chunk.js +0 -1
  481. package/build/upload-translation-pl-json.136eedb6.chunk.js +0 -1
  482. package/build/upload-translation-pt-BR-json.95686cfb.chunk.js +0 -1
  483. package/build/upload-translation-pt-json.5c452b48.chunk.js +0 -1
  484. package/build/upload-translation-ru-json.37bd1546.chunk.js +0 -1
  485. package/build/upload-translation-sk-json.b03d4904.chunk.js +0 -1
  486. package/build/upload-translation-th-json.9e1fda51.chunk.js +0 -1
  487. package/build/upload-translation-uk-json.1328cb3e.chunk.js +0 -1
  488. package/build/upload-translation-zh-Hans-json.37a2981e.chunk.js +0 -1
  489. package/build/upload-translation-zh-json.ac5711de.chunk.js +0 -1
  490. package/build/upload.e2034370.chunk.js +0 -64
  491. package/build/users-advanced-settings-page.0c0b8230.chunk.js +0 -13
  492. package/build/users-email-settings-page.3126ff8c.chunk.js +0 -28
  493. package/build/users-permissions-translation-ar-json.e8123ed2.chunk.js +0 -1
  494. package/build/users-permissions-translation-cs-json.e6649c5f.chunk.js +0 -1
  495. package/build/users-permissions-translation-de-json.c3628843.chunk.js +0 -1
  496. package/build/users-permissions-translation-dk-json.fe39c74b.chunk.js +0 -1
  497. package/build/users-permissions-translation-en-json.765abf48.chunk.js +0 -1
  498. package/build/users-permissions-translation-es-json.1bb9cde2.chunk.js +0 -1
  499. package/build/users-permissions-translation-fr-json.172aa69f.chunk.js +0 -1
  500. package/build/users-permissions-translation-id-json.5aadd143.chunk.js +0 -1
  501. package/build/users-permissions-translation-it-json.7d377480.chunk.js +0 -1
  502. package/build/users-permissions-translation-ja-json.4967badf.chunk.js +0 -1
  503. package/build/users-permissions-translation-ko-json.3be77775.chunk.js +0 -1
  504. package/build/users-permissions-translation-ms-json.ea8a2baf.chunk.js +0 -1
  505. package/build/users-permissions-translation-nl-json.d638c4ce.chunk.js +0 -1
  506. package/build/users-permissions-translation-pl-json.1dbdd4a1.chunk.js +0 -1
  507. package/build/users-permissions-translation-pt-BR-json.f6791a86.chunk.js +0 -1
  508. package/build/users-permissions-translation-pt-json.38afed04.chunk.js +0 -1
  509. package/build/users-permissions-translation-ru-json.319d51ef.chunk.js +0 -1
  510. package/build/users-permissions-translation-sk-json.ba1cd385.chunk.js +0 -1
  511. package/build/users-permissions-translation-sv-json.d5d11648.chunk.js +0 -1
  512. package/build/users-permissions-translation-th-json.68873214.chunk.js +0 -1
  513. package/build/users-permissions-translation-tr-json.cdc49a3c.chunk.js +0 -1
  514. package/build/users-permissions-translation-uk-json.63eaa01c.chunk.js +0 -1
  515. package/build/users-permissions-translation-vi-json.dccc02fc.chunk.js +0 -1
  516. package/build/users-permissions-translation-zh-Hans-json.c3fd301b.chunk.js +0 -1
  517. package/build/users-permissions-translation-zh-json.92f406f9.chunk.js +0 -1
  518. package/build/users-providers-settings-page.b7b602e2.chunk.js +0 -33
  519. package/build/users-roles-settings-page.ce5b582d.chunk.js +0 -30
  520. package/build/vi-json.f7890025.chunk.js +0 -1
  521. package/build/webhook-edit-page.1215a6b7.chunk.js +0 -75
  522. package/build/webhook-list-page.b87821f2.chunk.js +0 -42
  523. package/build/zh-Hans-json.21617c24.chunk.js +0 -1
  524. package/build/zh-json.2ecc6b99.chunk.js +0 -1
@@ -12,6 +12,7 @@ import { useKeyboardDragAndDrop } from './useKeyboardDragAndDrop';
12
12
  * item?: object,
13
13
  * onStart?: () => void,
14
14
  * onEnd?: () => void,
15
+ * dropSensitivity?: 'regular' | 'immediate'
15
16
  * } & import('./useKeyboardDragAndDrop').UseKeyboardDragAndDropCallbacks}
16
17
  */
17
18
 
@@ -39,6 +40,7 @@ export const useDragAndDrop = (
39
40
  onDropItem,
40
41
  onCancel,
41
42
  onMoveItem,
43
+ dropSensitivity = 'regular',
42
44
  }
43
45
  ) => {
44
46
  const objectRef = useRef(null);
@@ -62,19 +64,21 @@ export const useDragAndDrop = (
62
64
  return;
63
65
  }
64
66
 
65
- const hoverBoundingRect = objectRef.current.getBoundingClientRect();
66
- const hoverMiddleY = (hoverBoundingRect.bottom - hoverBoundingRect.top) / 2;
67
- const clientOffset = monitor.getClientOffset();
68
- const hoverClientY = clientOffset.y - hoverBoundingRect.top;
67
+ if (dropSensitivity === 'regular') {
68
+ const hoverBoundingRect = objectRef.current.getBoundingClientRect();
69
+ const hoverMiddleY = (hoverBoundingRect.bottom - hoverBoundingRect.top) / 2;
70
+ const clientOffset = monitor.getClientOffset();
71
+ const hoverClientY = clientOffset.y - hoverBoundingRect.top;
69
72
 
70
- // Dragging downwards
71
- if (dragIndex < newInd && hoverClientY < hoverMiddleY) {
72
- return;
73
- }
73
+ // Dragging downwards
74
+ if (dragIndex < newInd && hoverClientY < hoverMiddleY) {
75
+ return;
76
+ }
74
77
 
75
- // Dragging upwards
76
- if (dragIndex > newInd && hoverClientY > hoverMiddleY) {
77
- return;
78
+ // Dragging upwards
79
+ if (dragIndex > newInd && hoverClientY > hoverMiddleY) {
80
+ return;
81
+ }
78
82
  }
79
83
 
80
84
  // Time to actually perform the action
@@ -104,12 +108,22 @@ export const useDragAndDrop = (
104
108
  }
105
109
  },
106
110
  canDrag: active,
111
+ /**
112
+ * This is for useful when the item is in a virtualized list.
113
+ * However, if we don't have an ID then we want the libraries
114
+ * defaults to take care of this.
115
+ */
116
+ isDragging: item.id
117
+ ? (monitor) => {
118
+ return item.id === monitor.getItem().id;
119
+ }
120
+ : undefined,
107
121
  collect: (monitor) => ({
108
122
  isDragging: monitor.isDragging(),
109
123
  }),
110
124
  });
111
125
 
112
- const handleKeyDown = useKeyboardDragAndDrop(index, {
126
+ const handleKeyDown = useKeyboardDragAndDrop(active, index, {
113
127
  onGrabItem,
114
128
  onDropItem,
115
129
  onCancel,
@@ -17,9 +17,13 @@ import { useState } from 'react';
17
17
  *
18
18
  * @internal - You should use `useDragAndDrop` instead.
19
19
  *
20
- * @type {(index: number, callbacks: UseKeyboardDragAndDropCallbacks) => (event: React.KeyboardEvent<HTMLButtonElement>) => void}
20
+ * @type {(active: boolean, index: number, callbacks: UseKeyboardDragAndDropCallbacks) => (event: React.KeyboardEvent<HTMLButtonElement>) => void}
21
21
  */
22
- export const useKeyboardDragAndDrop = (index, { onCancel, onDropItem, onGrabItem, onMoveItem }) => {
22
+ export const useKeyboardDragAndDrop = (
23
+ active,
24
+ index,
25
+ { onCancel, onDropItem, onGrabItem, onMoveItem }
26
+ ) => {
23
27
  const [isSelected, setIsSelected] = useState(false);
24
28
  /**
25
29
  * @type {(movement: 'UP' | 'DOWN') => void})}
@@ -64,6 +68,10 @@ export const useKeyboardDragAndDrop = (index, { onCancel, onDropItem, onGrabItem
64
68
  * @type {React.KeyboardEventHandler<HTMLButtonElement>}
65
69
  */
66
70
  const handleKeyDown = (e) => {
71
+ if (!active) {
72
+ return;
73
+ }
74
+
67
75
  if (e.key === 'Tab' && !isSelected) {
68
76
  return;
69
77
  }
@@ -5,9 +5,12 @@ import { axiosInstance } from '../../../core/utils';
5
5
 
6
6
  import { normalizeRelations } from '../../components/RelationInputDataManager/utils';
7
7
 
8
- export const useRelation = (cacheKey, { name, relation, search }) => {
8
+ import { useCallbackRef } from '../useCallbackRef';
9
+
10
+ export const useRelation = (cacheKey, { relation, search }) => {
9
11
  const [searchParams, setSearchParams] = useState({});
10
12
  const [currentPage, setCurrentPage] = useState(0);
13
+
11
14
  /**
12
15
  * This runs in `useInfiniteQuery` to actually fetch the data
13
16
  */
@@ -44,7 +47,7 @@ export const useRelation = (cacheKey, { name, relation, search }) => {
44
47
  }
45
48
  };
46
49
 
47
- const { onLoad: onLoadRelationsCallback, normalizeArguments = {} } = relation;
50
+ const { onLoad: onLoadRelations, normalizeArguments = {} } = relation;
48
51
 
49
52
  const relationsRes = useInfiniteQuery(['relation', cacheKey], fetchRelations, {
50
53
  cacheTime: 0,
@@ -120,19 +123,19 @@ export const useRelation = (cacheKey, { name, relation, search }) => {
120
123
  }
121
124
  }, [pageGoal, currentPage, fetchNextPage, hasNextPage, status]);
122
125
 
126
+ const onLoadRelationsCallback = useCallbackRef(onLoadRelations);
127
+
123
128
  useEffect(() => {
124
129
  if (status === 'success' && data && data.pages?.at(-1)?.results && onLoadRelationsCallback) {
125
130
  // everytime we fetch, we normalize prior to adding to redux
126
131
  const normalizedResults = normalizeRelations(data.pages.at(-1).results, normalizeArguments);
127
132
 
128
133
  // this is loadRelation from EditViewDataManagerProvider
129
- onLoadRelationsCallback({
130
- target: { name, value: normalizedResults },
131
- });
134
+ onLoadRelationsCallback(normalizedResults);
132
135
  }
133
136
 
134
137
  // eslint-disable-next-line react-hooks/exhaustive-deps
135
- }, [status, onLoadRelationsCallback, name, data]);
138
+ }, [status, onLoadRelationsCallback, data]);
136
139
 
137
140
  const searchRes = useInfiniteQuery(
138
141
  ['relation', cacheKey, 'search', JSON.stringify(searchParams)],
@@ -22,7 +22,9 @@ import getTrad from '../../../utils/getTrad';
22
22
  import { makeSelectModelLinks } from '../selectors';
23
23
 
24
24
  const matchByTitle = (links, search) =>
25
- matchSorter(links, toLower(search), { keys: [(item) => toLower(item.title)] });
25
+ search
26
+ ? matchSorter(links, toLower(search), { keys: [(item) => toLower(item.title)] })
27
+ : sortBy(links, (object) => object.title.toLowerCase());
26
28
 
27
29
  const LeftMenu = () => {
28
30
  const [search, setSearch] = useState('');
@@ -52,9 +54,7 @@ const LeftMenu = () => {
52
54
  defaultMessage: 'Collection Types',
53
55
  },
54
56
  searchable: true,
55
- links: sortBy(matchByTitle(intlCollectionTypeLinks, search), (object) =>
56
- object.title.toLowerCase()
57
- ),
57
+ links: matchByTitle(intlCollectionTypeLinks, search),
58
58
  },
59
59
  {
60
60
  id: 'singleTypes',
@@ -63,9 +63,7 @@ const LeftMenu = () => {
63
63
  defaultMessage: 'Single Types',
64
64
  },
65
65
  searchable: true,
66
- links: sortBy(matchByTitle(intlSingleTypeLinks, search), (object) =>
67
- object.title.toLowerCase()
68
- ),
66
+ links: matchByTitle(intlSingleTypeLinks, search),
69
67
  },
70
68
  ];
71
69
 
@@ -1,43 +1,31 @@
1
1
  import React from 'react';
2
- import get from 'lodash/get';
3
- import PropTypes from 'prop-types';
4
- import { Flex } from '@strapi/design-system/Flex';
5
- import { Typography } from '@strapi/design-system/Typography';
6
- import { Box } from '@strapi/design-system/Box';
7
- import { Stack } from '@strapi/design-system/Stack';
8
- import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
9
2
  import styled from 'styled-components';
10
3
  import { Link } from 'react-router-dom';
4
+ import PropTypes from 'prop-types';
5
+ import { Box, Flex, Typography, Stack } from '@strapi/design-system';
6
+
7
+ import { ComponentIcon } from '../../../components/ComponentIcon';
11
8
  import useLayoutDnd from '../../../hooks/useLayoutDnd';
12
9
 
13
- const CustomFlex = styled(Flex)`
14
- border-radius: 50%;
15
- svg {
16
- & > * {
17
- fill: ${({ theme }) => theme.colors.neutral500};
18
- }
19
- width: 12px;
20
- height: 12px;
21
- }
22
- `;
23
10
  const CustomLink = styled(Flex)`
24
11
  text-decoration: none;
12
+
13
+ &:focus,
25
14
  &:hover {
26
15
  ${({ theme }) => `
27
- background: ${theme.colors.primary100};
28
- svg {
29
- & > * {
30
- fill: ${theme.colors.primary600};
31
- }
32
- }
16
+ background-color: ${theme.colors.primary100};
17
+ border-color: ${theme.colors.primary200};
18
+
33
19
  ${Typography} {
34
20
  color: ${theme.colors.primary600};
35
21
  }
36
- ${CustomFlex} {
37
- background: ${theme.colors.primary200};
38
- }
39
- border-color: ${theme.colors.primary200};
40
22
  `}
23
+
24
+ /* > ComponentIcon */
25
+ > div:first-child {
26
+ background: ${({ theme }) => theme.colors.primary200};
27
+ color: ${({ theme }) => theme.colors.primary600};
28
+ }
41
29
  }
42
30
  `;
43
31
 
@@ -61,19 +49,11 @@ const DynamicZoneList = ({ components }) => {
61
49
  as={Link}
62
50
  to={`/content-manager/components/${componentUid}/configurations/edit`}
63
51
  >
64
- <CustomFlex
65
- width={`${32 / 16}rem`}
66
- height={`${32 / 16}rem`}
67
- background="neutral150"
68
- justifyContent="center"
69
- alignItems="center"
70
- padding={2}
71
- >
72
- <FontAwesomeIcon icon={get(componentLayouts, [componentUid, 'info', 'icon'], '')} />
73
- </CustomFlex>
52
+ <ComponentIcon />
53
+
74
54
  <Box paddingTop={1}>
75
55
  <Typography fontSize={1} textColor="neutral600" fontWeight="bold">
76
- {get(componentLayouts, [componentUid, 'info', 'displayName'], '')}
56
+ {componentLayouts?.[componentUid]?.info?.displayName ?? ''}
77
57
  </Typography>
78
58
  </Box>
79
59
  </CustomLink>
@@ -74,7 +74,7 @@ const Header = ({
74
74
  {formatMessage({ id: 'app.utils.publish', defaultMessage: 'Publish' })}
75
75
  </Button>
76
76
  )}
77
- <Button disabled={!didChangeData} isLoading={status === 'submit-pending'} type="submit">
77
+ <Button disabled={!didChangeData} loading={status === 'submit-pending'} type="submit">
78
78
  {formatMessage({
79
79
  id: getTrad('containers.Edit.submit'),
80
80
  defaultMessage: 'Save',
@@ -5,6 +5,7 @@ import isEqual from 'lodash/isEqual';
5
5
  import upperFirst from 'lodash/upperFirst';
6
6
  import pick from 'lodash/pick';
7
7
  import get from 'lodash/get';
8
+ import isEmpty from 'lodash/isEmpty';
8
9
  import { stringify } from 'qs';
9
10
  import { useNotification, useTracking, ConfirmDialog, Link } from '@strapi/helper-plugin';
10
11
  import { useIntl } from 'react-intl';
@@ -35,12 +36,12 @@ const ListSettingsView = ({ layout, slug }) => {
35
36
 
36
37
  const [showWarningSubmit, setWarningSubmit] = useState(false);
37
38
  const toggleWarningSubmit = () => setWarningSubmit((prevState) => !prevState);
38
- const [isModalFormOpen, setIsModalFormOpen] = useState(false);
39
- const toggleModalForm = () => setIsModalFormOpen((prevState) => !prevState);
40
39
  const [reducerState, dispatch] = useReducer(reducer, initialState, () =>
41
40
  init(initialState, layout)
42
41
  );
43
42
  const { fieldToEdit, fieldForm, initialData, modifiedData } = reducerState;
43
+ const isModalFormOpen = !isEmpty(fieldForm);
44
+
44
45
  const { attributes } = layout;
45
46
  const displayedFields = modifiedData.layouts.list;
46
47
 
@@ -110,19 +111,16 @@ const ListSettingsView = ({ layout, slug }) => {
110
111
  type: 'SET_FIELD_TO_EDIT',
111
112
  fieldToEdit,
112
113
  });
113
- toggleModalForm();
114
114
  };
115
115
 
116
116
  const handleCloseModal = () => {
117
117
  dispatch({
118
118
  type: 'UNSET_FIELD_TO_EDIT',
119
119
  });
120
- toggleModalForm();
121
120
  };
122
121
 
123
122
  const handleSubmitFieldEdit = (e) => {
124
123
  e.preventDefault();
125
- toggleModalForm();
126
124
  dispatch({
127
125
  type: 'SUBMIT_FIELD_FORM',
128
126
  });
@@ -3,10 +3,12 @@ const getMaxTempKey = (arr) => {
3
3
  return -1;
4
4
  }
5
5
 
6
- return Math.max.apply(
6
+ const maxTempKey = Math.max.apply(
7
7
  Math,
8
- arr.map((o) => o.__temp_key__ ?? o.id)
8
+ arr.map((o) => o.__temp_key__ ?? 0)
9
9
  );
10
+
11
+ return Number.isNaN(maxTempKey) ? -1 : maxTempKey;
10
12
  };
11
13
 
12
14
  export default getMaxTempKey;
@@ -0,0 +1,37 @@
1
+ /**
2
+ * This file is for all helpers related to `paths` in the CM.
3
+ */
4
+ import { get } from 'lodash';
5
+
6
+ /**
7
+ * This is typically used in circumstances where there are re-orderable pieces e.g. Dynamic Zones
8
+ * or Repeatable fields. It finds the _original_ location of the initial data using `__temp_key__` values
9
+ * which are added to the fields in the `INIT_FORM` reducer to give array data a stable (when you add
10
+ * a new item they wont have a server ID).
11
+ */
12
+ export const getInitialDataPathUsingTempKeys = (initialData, modifiedData) => (currentPath) => {
13
+ const splitPath = currentPath.split('.');
14
+
15
+ return splitPath.reduce((acc, currentValue, index) => {
16
+ const initialDataParent = get(initialData, acc);
17
+ const modifiedDataTempKey = get(modifiedData, [
18
+ ...splitPath.slice(0, index),
19
+ currentValue,
20
+ '__temp_key__',
21
+ ]);
22
+
23
+ if (Array.isArray(initialDataParent) && typeof modifiedDataTempKey === 'number') {
24
+ const initialDataIndex = initialDataParent.findIndex(
25
+ (entry) => entry.__temp_key__ === modifiedDataTempKey
26
+ );
27
+
28
+ acc.push(initialDataIndex.toString());
29
+
30
+ return acc;
31
+ }
32
+
33
+ acc.push(currentValue);
34
+
35
+ return acc;
36
+ }, []);
37
+ };
@@ -10,4 +10,3 @@ export { default as usePermissionsDataManager } from './usePermissionsDataManage
10
10
  export { default as useReleaseNotification } from './useReleaseNotification';
11
11
  export { default as useThemeToggle } from './useThemeToggle';
12
12
  export { default as useRegenerate } from './useRegenerate';
13
- export { default as useFetchClient } from './useFetchClient';
@@ -24,6 +24,13 @@ const init = (initialState, { settings, shouldUpdateStrapi }) => {
24
24
  id: 'permissions',
25
25
  intlLabel: { id: 'Settings.permissions', defaultMessage: 'Administration Panel' },
26
26
  links: [
27
+ {
28
+ intlLabel: { id: 'global.auditLogs', defaultMessage: 'Audit Logs' },
29
+ to: '/settings/audit-logs?pageSize=50&page=1&sort=date:DESC',
30
+ id: 'auditLogs',
31
+ isDisplayed: false,
32
+ permissions: adminPermissions.settings.auditLogs.main,
33
+ },
27
34
  {
28
35
  intlLabel: { id: 'global.roles', defaultMessage: 'Roles' },
29
36
  to: '/settings/roles',
@@ -1,11 +1,10 @@
1
1
  import React, { useState } from 'react';
2
2
  import styled from 'styled-components';
3
3
  import { useIntl } from 'react-intl';
4
- import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
5
- import { faQuestion, faTimes } from '@fortawesome/free-solid-svg-icons';
6
- import { Box } from '@strapi/design-system/Box';
7
- import { Typography } from '@strapi/design-system/Typography';
8
- import { FocusTrap } from '@strapi/design-system/FocusTrap';
4
+ import { Box, Flex, FocusTrap, Typography, Icon, Stack } from '@strapi/design-system';
5
+ import { Book, Cross, Information, Question } from '@strapi/icons';
6
+ import { pxToRem } from '@strapi/helper-plugin';
7
+
9
8
  import { useConfigurations } from '../../../hooks';
10
9
 
11
10
  const OnboardingWrapper = styled(Box)`
@@ -14,52 +13,44 @@ const OnboardingWrapper = styled(Box)`
14
13
  right: ${({ theme }) => theme.spaces[2]};
15
14
  `;
16
15
 
17
- const Button = styled.button`
16
+ const Button = styled(Box)`
18
17
  width: ${({ theme }) => theme.spaces[8]};
19
18
  height: ${({ theme }) => theme.spaces[8]};
20
19
  background: ${({ theme }) => theme.colors.primary600};
21
20
  box-shadow: ${({ theme }) => theme.shadows.tableShadow};
22
21
  border-radius: 50%;
23
- svg {
24
- color: ${({ theme }) => theme.colors.buttonNeutral0};
22
+
23
+ svg path {
24
+ fill: ${({ theme }) => theme.colors.buttonNeutral0};
25
25
  }
26
26
  `;
27
27
 
28
28
  const LinksWrapper = styled(Box)`
29
- position: absolute;
30
29
  bottom: ${({ theme }) => `${theme.spaces[9]}`};
30
+ min-width: ${200 / 16}rem;
31
+ position: absolute;
31
32
  right: 0;
32
- width: ${200 / 16}rem;
33
33
  `;
34
34
 
35
- const StyledLink = styled.a`
36
- display: flex;
37
- align-items: center;
35
+ const StyledLink = styled(Flex)`
38
36
  text-decoration: none;
39
- padding: ${({ theme }) => theme.spaces[2]};
40
- padding-left: ${({ theme }) => theme.spaces[5]};
41
37
 
42
- svg {
43
- color: ${({ theme }) => theme.colors.neutral600};
44
- margin-right: ${({ theme }) => theme.spaces[2]};
38
+ svg path {
39
+ fill: ${({ theme }) => theme.colors.neutral600};
45
40
  }
46
41
 
42
+ &:focus,
47
43
  &:hover {
48
44
  background: ${({ theme }) => theme.colors.neutral100};
49
- color: ${({ theme }) => theme.colors.neutral500};
50
45
 
51
- svg {
52
- color: ${({ theme }) => theme.colors.neutral700};
46
+ svg path {
47
+ fill: ${({ theme }) => theme.colors.neutral700};
53
48
  }
54
49
 
55
50
  ${[Typography]} {
56
51
  color: ${({ theme }) => theme.colors.neutral700};
57
52
  }
58
53
  }
59
-
60
- ${[Typography]} {
61
- color: ${({ theme }) => theme.colors.neutral600};
62
- }
63
54
  `;
64
55
 
65
56
  const Onboarding = () => {
@@ -71,9 +62,9 @@ const Onboarding = () => {
71
62
  return null;
72
63
  }
73
64
 
74
- const staticLinks = [
65
+ const STATIC_LINKS = [
75
66
  {
76
- icon: 'book',
67
+ Icon: <Book />,
77
68
  label: formatMessage({
78
69
  id: 'global.documentation',
79
70
  defaultMessage: 'Documentation',
@@ -81,7 +72,7 @@ const Onboarding = () => {
81
72
  destination: 'https://docs.strapi.io',
82
73
  },
83
74
  {
84
- icon: 'file',
75
+ Icon: <Information />,
85
76
  label: formatMessage({ id: 'app.static.links.cheatsheet', defaultMessage: 'CheatSheet' }),
86
77
  destination: 'https://strapi-showcase.s3-us-west-2.amazonaws.com/CheatSheet.pdf',
87
78
  },
@@ -94,37 +85,44 @@ const Onboarding = () => {
94
85
  return (
95
86
  <OnboardingWrapper as="aside">
96
87
  <Button
88
+ as="button"
97
89
  id="onboarding"
98
- aria-label={formatMessage({
99
- id: 'app.components.Onboarding.help.button',
100
- defaultMessage: 'Help button',
101
- })}
90
+ aria-label={formatMessage(
91
+ isOpen
92
+ ? {
93
+ id: 'app.components.Onboarding.help.button-close',
94
+ defaultMessage: 'Close help menu',
95
+ }
96
+ : {
97
+ id: 'app.components.Onboarding.help.button',
98
+ defaultMessage: 'Open help menu',
99
+ }
100
+ )}
102
101
  onClick={handleClick}
103
102
  >
104
- {!isOpen && <FontAwesomeIcon icon={faQuestion} />}
105
- {isOpen && <FontAwesomeIcon icon={faTimes} />}
103
+ <Icon as={isOpen ? Cross : Question} height={pxToRem(16)} width={pxToRem(16)} />
106
104
  </Button>
107
105
 
108
106
  {/* FIX ME - replace with popover when overflow popover is fixed
109
107
  + when v4 mockups for onboarding component are ready */}
110
108
  {isOpen && (
111
109
  <FocusTrap onEscape={handleClick}>
112
- <LinksWrapper
113
- background="neutral0"
114
- hasRadius
115
- shadow="tableShadow"
116
- paddingBottom={2}
117
- paddingTop={2}
118
- >
119
- {staticLinks.map((link) => (
110
+ <LinksWrapper background="neutral0" hasRadius shadow="tableShadow" padding={2}>
111
+ {STATIC_LINKS.map((link) => (
120
112
  <StyledLink
113
+ as="a"
121
114
  key={link.label}
122
115
  rel="nofollow noreferrer noopener"
123
116
  target="_blank"
124
117
  href={link.destination}
118
+ padding={2}
119
+ hasRadius
120
+ alignItems="center"
125
121
  >
126
- <FontAwesomeIcon icon={link.icon} />
127
- <Typography>{link.label}</Typography>
122
+ <Stack horizontal spacing={2}>
123
+ {link.Icon}
124
+ <Typography color="neutral600">{link.label}</Typography>
125
+ </Stack>
128
126
  </StyledLink>
129
127
  ))}
130
128
  </LinksWrapper>
@@ -14,6 +14,7 @@ import {
14
14
  TrackingProvider,
15
15
  prefixFileUrlWithBackendUrl,
16
16
  useAppInfos,
17
+ useFetchClient,
17
18
  } from '@strapi/helper-plugin';
18
19
  import axios from 'axios';
19
20
  import { SkipToContent } from '@strapi/design-system/Main';
@@ -35,8 +36,12 @@ function App() {
35
36
  const toggleNotification = useNotification();
36
37
  const { updateProjectSettings } = useConfigurations();
37
38
  const { formatMessage } = useIntl();
38
- const [{ isLoading, hasAdmin, uuid }, setState] = useState({ isLoading: true, hasAdmin: false });
39
+ const [{ isLoading, hasAdmin, uuid, deviceId }, setState] = useState({
40
+ isLoading: true,
41
+ hasAdmin: false,
42
+ });
39
43
  const appInfo = useAppInfos();
44
+ const { get } = useFetchClient();
40
45
 
41
46
  const authRoutes = useMemo(() => {
42
47
  return makeUniqueRoutes(
@@ -80,27 +85,29 @@ function App() {
80
85
  } = await axios.get(`${strapi.backendURL}/admin/init`);
81
86
 
82
87
  updateProjectSettings({ menuLogo: prefixFileUrlWithBackendUrl(menuLogo) });
88
+ const deviceId = await getUID();
83
89
 
84
90
  if (uuid) {
85
91
  const {
86
92
  data: { data: properties },
87
- } = await axios.get(`${strapi.backendURL}/admin/telemetry-properties`);
93
+ } = await get(`/admin/telemetry-properties`, {
94
+ // NOTE: needed because the interceptors of the fetchClient redirect to /login when receive a 401 and it would end up in an infinite loop when the user doesn't have a session.
95
+ validateStatus: (status) => status < 500,
96
+ });
88
97
 
89
98
  setTelemetryProperties(properties);
90
99
 
91
100
  try {
92
- const deviceId = await getUID();
93
-
94
- await fetch('https://analytics.strapi.io/track', {
101
+ await fetch('https://analytics.strapi.io/api/v2/track', {
95
102
  method: 'POST',
96
103
  body: JSON.stringify({
104
+ // This event is anonymous
97
105
  event: 'didInitializeAdministration',
98
- uuid,
106
+ userId: '',
99
107
  deviceId,
100
- properties: {
101
- ...properties,
102
- environment: appInfo.currentEnvironment,
103
- },
108
+ eventPropeties: {},
109
+ userProperties: { environment: appInfo.currentEnvironment },
110
+ groupProperties: { ...properties, projectId: uuid },
104
111
  }),
105
112
  headers: {
106
113
  'Content-Type': 'application/json',
@@ -111,7 +118,7 @@ function App() {
111
118
  }
112
119
  }
113
120
 
114
- setState({ isLoading: false, hasAdmin, uuid });
121
+ setState({ isLoading: false, hasAdmin, uuid, deviceId });
115
122
  } catch (err) {
116
123
  toggleNotification({
117
124
  type: 'warning',
@@ -130,8 +137,9 @@ function App() {
130
137
  () => ({
131
138
  uuid,
132
139
  telemetryProperties,
140
+ deviceId,
133
141
  }),
134
- [uuid, telemetryProperties]
142
+ [uuid, telemetryProperties, deviceId]
135
143
  );
136
144
 
137
145
  if (isLoading) {
@@ -268,7 +268,7 @@ const Register = ({ authType, fieldsToDisable, noSignin, onSubmit, schema }) =>
268
268
  required
269
269
  label={formatMessage({
270
270
  id: 'Auth.form.confirmPassword.label',
271
- defaultMessage: 'Confirmation Password',
271
+ defaultMessage: 'Confirm Password',
272
272
  })}
273
273
  type={confirmPasswordShown ? 'text' : 'password'}
274
274
  />
@@ -154,7 +154,7 @@ const ForgotPassword = ({ onSubmit, schema }) => {
154
154
  required
155
155
  label={formatMessage({
156
156
  id: 'Auth.form.confirmPassword.label',
157
- defaultMessage: 'Confirmation Password',
157
+ defaultMessage: 'Confirm Password',
158
158
  })}
159
159
  type={confirmPasswordShown ? 'text' : 'password'}
160
160
  />
@@ -458,7 +458,7 @@ const ProfilePage = () => {
458
458
  href="https://docs.strapi.io/developer-docs/latest/development/admin-customization.html#locales"
459
459
  >
460
460
  {formatMessage({
461
- id: 'Settings.profile.form.section.experience.documentation',
461
+ id: 'Settings.profile.form.section.experience.here',
462
462
  defaultMessage: 'here',
463
463
  })}
464
464
  </DocumentationLink>