@strapi/admin 4.15.0-alpha.0 → 4.15.0

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 (472) hide show
  1. package/.eslintrc.js +4 -1
  2. package/admin/.eslintrc.js +28 -0
  3. package/admin/custom.d.ts +28 -0
  4. package/admin/src/StrapiApp.js +27 -28
  5. package/admin/src/components/AuthenticatedApp.tsx +187 -0
  6. package/admin/src/components/ConfigurationProvider.tsx +68 -0
  7. package/admin/src/components/{DragLayer/DragLayer.js → DragLayer.tsx} +18 -10
  8. package/admin/src/components/GuidedTour/Homepage.tsx +111 -0
  9. package/admin/src/components/GuidedTour/Modal.tsx +303 -0
  10. package/admin/src/components/GuidedTour/Ornaments.tsx +74 -0
  11. package/admin/src/components/GuidedTour/Provider.tsx +253 -0
  12. package/admin/src/components/GuidedTour/{layout.js → constants.ts} +13 -3
  13. package/admin/src/components/LanguageProvider.tsx +130 -0
  14. package/admin/src/components/{LeftMenu/index.js → LeftMenu.tsx} +23 -18
  15. package/admin/src/components/{NpsSurvey/index.js → NpsSurvey.tsx} +68 -21
  16. package/admin/src/components/PluginsInitializer.tsx +124 -0
  17. package/admin/src/components/PrivateRoute.tsx +42 -0
  18. package/admin/src/components/Providers.tsx +125 -0
  19. package/admin/src/components/RBACProvider.tsx +124 -0
  20. package/admin/src/components/Theme.tsx +41 -0
  21. package/admin/src/components/ThemeToggleProvider.tsx +64 -0
  22. package/admin/src/components/{UnauthenticatedLogo/index.js → UnauthenticatedLogo.tsx} +3 -5
  23. package/admin/src/components/{LocalesProvider/__mocks__/useLocalesProvider.js → __mocks__/LanguageProvider.ts} +3 -1
  24. package/admin/src/{constants.js → constants.ts} +48 -0
  25. package/admin/src/content-manager/components/BlocksEditor/BlocksInput/index.js +68 -9
  26. package/admin/src/content-manager/components/BlocksEditor/Toolbar/index.js +433 -202
  27. package/admin/src/content-manager/components/BlocksEditor/hooks/useBlocksStore.js +463 -135
  28. package/admin/src/content-manager/components/BlocksEditor/hooks/useModifiersStore.js +23 -6
  29. package/admin/src/content-manager/components/BlocksEditor/index.js +97 -20
  30. package/admin/src/content-manager/components/BlocksEditor/plugins/index.js +4 -0
  31. package/admin/src/content-manager/components/BlocksEditor/plugins/withLinks.js +61 -0
  32. package/admin/src/content-manager/components/BlocksEditor/plugins/withStrapiSchema.js +33 -0
  33. package/admin/src/content-manager/components/BlocksEditor/utils/links.js +90 -0
  34. package/admin/src/content-manager/components/InputUID/index.js +1 -1
  35. package/admin/src/content-manager/hooks/useAllowedAttributes.js +9 -1
  36. package/admin/src/content-manager/pages/App/selectors.js +1 -1
  37. package/admin/src/content-manager/pages/App/useContentManagerInitData.js +3 -1
  38. package/admin/src/content-manager/pages/EditSettingsView/index.js +1 -0
  39. package/admin/src/content-manager/pages/EditSettingsView/utils/createPossibleMainFieldsForModelsAndComponents.js +1 -0
  40. package/admin/src/content-manager/pages/EditView/selectors.js +1 -1
  41. package/admin/src/content-manager/pages/EditViewLayoutManager/index.js +3 -1
  42. package/admin/src/content-manager/pages/ListSettingsView/constants.js +1 -0
  43. package/admin/src/content-manager/pages/ListView/components/Body/index.js +53 -56
  44. package/admin/src/content-manager/pages/ListView/components/BulkActionButtons/SelectedEntriesModal/index.js +5 -3
  45. package/admin/src/content-manager/pages/ListView/components/TableRows/index.js +1 -1
  46. package/admin/src/content-manager/pages/ListView/index.js +35 -51
  47. package/admin/src/content-manager/pages/ListView/selectors.js +1 -1
  48. package/admin/src/content-manager/utils/checkIfAttributeIsDisplayable.js +1 -1
  49. package/admin/src/content-manager/utils/schema.js +2 -2
  50. package/admin/src/contexts/admin.ts +19 -0
  51. package/admin/src/contexts/apiTokenPermissions.tsx +64 -0
  52. package/admin/src/contexts/configuration.ts +25 -0
  53. package/admin/src/contexts/themeToggle.ts +18 -0
  54. package/admin/src/core/store/configure.ts +91 -0
  55. package/admin/src/core/store/hooks.ts +15 -0
  56. package/admin/src/hooks/{useConfigurations/__mocks__/index.js → __mocks__/useConfigurations.ts} +4 -2
  57. package/admin/src/hooks/index.js +0 -8
  58. package/admin/src/hooks/{useAdminRoles/index.js → useAdminRoles.ts} +26 -10
  59. package/admin/src/hooks/useAdminUsers.ts +64 -0
  60. package/admin/src/hooks/useConfiguration.ts +5 -0
  61. package/admin/src/hooks/{useContentTypes/useContentTypes.js → useContentTypes.ts} +39 -16
  62. package/admin/src/hooks/useDebounce.ts +17 -0
  63. package/admin/src/hooks/{useEnterprise/useEnterprise.js → useEnterprise.ts} +15 -5
  64. package/admin/src/hooks/useLicenseLimitNotification.ts +3 -0
  65. package/admin/src/hooks/useMenu.ts +153 -0
  66. package/admin/src/hooks/useSettingsForm/index.js +14 -2
  67. package/admin/src/hooks/useSettingsMenu/constants.js +39 -0
  68. package/admin/src/hooks/useThemeToggle.ts +9 -0
  69. package/admin/src/index.js +7 -6
  70. package/admin/src/layouts/{AppLayout/index.js → AppLayout.tsx} +7 -10
  71. package/admin/src/layouts/UnauthenticatedLayout.tsx +77 -0
  72. package/admin/src/pages/Admin/index.js +15 -8
  73. package/admin/src/pages/App/index.js +13 -8
  74. package/admin/src/pages/App/selectors.js +1 -1
  75. package/admin/src/pages/AuthPage/components/ForgotPassword/index.js +3 -2
  76. package/admin/src/pages/AuthPage/components/ForgotPasswordSuccess/index.js +3 -2
  77. package/admin/src/pages/AuthPage/components/Login/BaseLogin.js +1 -1
  78. package/admin/src/pages/AuthPage/components/Login/index.js +1 -1
  79. package/admin/src/pages/AuthPage/components/Oops/index.js +3 -2
  80. package/admin/src/pages/AuthPage/components/Register/index.js +30 -35
  81. package/admin/src/pages/AuthPage/components/ResetPassword/index.js +3 -2
  82. package/admin/src/pages/AuthPage/index.js +4 -5
  83. package/admin/src/pages/HomePage/index.js +6 -3
  84. package/admin/src/pages/{InternalErrorPage/index.js → InternalErrorPage.tsx} +10 -6
  85. package/admin/src/pages/MarketplacePage/components/NpmPackageCard/index.js +0 -2
  86. package/admin/src/pages/MarketplacePage/hooks/__mocks__/useNavigatorOnline.ts +1 -0
  87. package/admin/src/{hooks/useNavigatorOnLine/index.js → pages/MarketplacePage/hooks/useNavigatorOnline.ts} +4 -6
  88. package/admin/src/pages/MarketplacePage/index.js +3 -3
  89. package/admin/src/pages/{NotFoundPage/index.js → NotFoundPage.tsx} +9 -7
  90. package/admin/src/pages/ProfilePage/components/Preferences/index.js +23 -9
  91. package/admin/src/pages/ProfilePage/index.js +4 -4
  92. package/admin/src/pages/SettingsPage/components/SettingsNav/index.js +20 -0
  93. package/admin/src/pages/SettingsPage/components/Tokens/Regenerate/index.js +1 -1
  94. package/admin/src/pages/SettingsPage/components/Tokens/Table/index.js +119 -87
  95. package/admin/src/pages/SettingsPage/constants.js +33 -0
  96. package/admin/src/{hooks/useRegenerate/index.js → pages/SettingsPage/hooks/useRegenerate.ts} +13 -7
  97. package/admin/src/pages/SettingsPage/index.js +2 -2
  98. package/admin/src/pages/SettingsPage/pages/ApiTokens/EditView/components/ActionBoundRoutes/index.js +1 -1
  99. package/admin/src/pages/SettingsPage/pages/ApiTokens/EditView/components/CollapsableContentType/index.js +1 -1
  100. package/admin/src/pages/SettingsPage/pages/ApiTokens/EditView/components/Permissions/index.js +1 -1
  101. package/admin/src/pages/SettingsPage/pages/ApiTokens/EditView/components/Regenerate/index.js +1 -1
  102. package/admin/src/pages/SettingsPage/pages/ApiTokens/EditView/index.js +2 -2
  103. package/admin/src/pages/SettingsPage/pages/ApplicationInfosPage/components/CustomizationInfos/index.js +2 -2
  104. package/admin/src/pages/SettingsPage/pages/ApplicationInfosPage/index.js +2 -2
  105. package/admin/src/pages/SettingsPage/pages/AuditLogs/SalesPage.js +50 -0
  106. package/admin/src/pages/SettingsPage/pages/ReviewWorkflows/SalesPage.js +53 -0
  107. package/admin/src/pages/SettingsPage/pages/Roles/CreatePage/index.js +1 -1
  108. package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/ConditionsModal/index.js +1 -1
  109. package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/ContentTypeCollapse/Collapse/index.js +1 -1
  110. package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/ContentTypeCollapse/CollapsePropertyMatrix/ActionRow/index.js +1 -1
  111. package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/ContentTypeCollapse/CollapsePropertyMatrix/SubActionRow/index.js +1 -1
  112. package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/GlobalActions/index.js +1 -1
  113. package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/PermissionsDataManagerProvider/index.js +1 -1
  114. package/admin/src/pages/SettingsPage/pages/Roles/EditPage/components/PluginsAndSettings/SubCategory/index.js +1 -1
  115. package/admin/src/pages/SettingsPage/pages/Roles/EditPage/hooks/usePermissionsDataManager.ts +28 -0
  116. package/admin/src/pages/SettingsPage/pages/Roles/EditPage/index.js +1 -1
  117. package/admin/src/{hooks/useAdminRolePermissions/index.js → pages/SettingsPage/pages/Roles/hooks/useAdminRolePermissions.ts} +13 -6
  118. package/admin/src/pages/SettingsPage/pages/SingleSignOn/SalesPage.js +53 -0
  119. package/admin/src/pages/SettingsPage/pages/TransferTokens/EditView/index.js +1 -1
  120. package/admin/src/pages/SettingsPage/pages/TransferTokens/ListView/index.js +3 -5
  121. package/admin/src/pages/SettingsPage/pages/Users/EditPage/index.js +2 -1
  122. package/admin/src/pages/SettingsPage/pages/Users/ListPage/DynamicTable/TableRows/index.js +1 -1
  123. package/admin/src/pages/{UseCasePage/index.js → UseCasePage.tsx} +10 -12
  124. package/admin/src/shared/hooks/index.js +0 -1
  125. package/admin/src/shared/hooks/useInjectionZone/index.js +2 -2
  126. package/admin/src/translations/en.json +13 -0
  127. package/admin/src/types/adminAPI.ts +29 -0
  128. package/admin/src/utils/createRoute.tsx +54 -0
  129. package/admin/src/utils/formatAPIErrors.ts +18 -0
  130. package/admin/src/utils/getFullName.ts +3 -0
  131. package/admin/src/utils/{uniqueAdminHash.js → hashAdminUserEmail.ts} +6 -3
  132. package/admin/src/utils/makeUniqueRoutes.ts +11 -0
  133. package/admin/tsconfig.build.json +4 -0
  134. package/admin/tsconfig.json +11 -0
  135. package/build/0cd5f8915b265d5b1856.png +0 -0
  136. package/build/1049.ecc10c97.chunk.js +1 -0
  137. package/build/1217.96155682.chunk.js +35 -0
  138. package/build/1227.947ceaf9.chunk.js +1 -0
  139. package/build/1306.2699df52.chunk.js +79 -0
  140. package/build/135.ad267b59.chunk.js +1 -0
  141. package/build/1386.eabd8a1e.chunk.js +7 -0
  142. package/build/1727.b49f0713.chunk.js +1 -0
  143. package/build/1835.eaa696ba.chunk.js +1 -0
  144. package/build/19eb2dfcf2603eb55733.png +0 -0
  145. package/build/2325.d705b39a.chunk.js +1 -0
  146. package/build/2379.7ce8e110.chunk.js +1 -0
  147. package/build/2395.acb961a8.chunk.js +26 -0
  148. package/build/2421.79e5b3d0.chunk.js +1 -0
  149. package/build/267.073a3bcb.chunk.js +1 -0
  150. package/build/27d16aefee06412db90a.png +0 -0
  151. package/build/2801.4711ea5a.chunk.js +1 -0
  152. package/build/2878.145ebf7c.chunk.js +1 -0
  153. package/build/2950.216f2e89.chunk.js +1 -0
  154. package/build/2953.284a63c0.chunk.js +1 -0
  155. package/build/3019.fde2e1be.chunk.js +181 -0
  156. package/build/3100.2ba4df95.chunk.js +1 -0
  157. package/build/311.cb0884bb.chunk.js +1 -0
  158. package/build/3460.8644e608.chunk.js +146 -0
  159. package/build/3483.db8c1520.chunk.js +1 -0
  160. package/build/3911.488fbde3.chunk.js +95 -0
  161. package/build/4174.49cedb6a.chunk.js +1 -0
  162. package/build/4429.7f044dc7.chunk.js +1 -0
  163. package/build/4555.c883d697.chunk.js +1 -0
  164. package/build/4663.b906cc10.chunk.js +1 -0
  165. package/build/4732.149f5f8f.chunk.js +1 -0
  166. package/build/4916.480053a6.chunk.js +1 -0
  167. package/build/4996.d285c30b.chunk.js +1 -0
  168. package/build/502.f536f78b.chunk.js +1 -0
  169. package/build/570.2f3b4c56.chunk.js +1 -0
  170. package/build/5858.493b31ec.chunk.js +1 -0
  171. package/build/6158.c3c13c20.chunk.js +1 -0
  172. package/build/6345.334e7678.chunk.js +1 -0
  173. package/build/6453.4160b5b7.chunk.js +1 -0
  174. package/build/7030.b98dcedf.chunk.js +1 -0
  175. package/build/70674f63fc3904c20de0.svg +7 -0
  176. package/build/7448.6fd14dd3.chunk.js +1 -0
  177. package/build/7464.579564ac.chunk.js +1 -0
  178. package/build/7735.9e7c9fdd.chunk.js +10 -0
  179. package/build/78.dcc6df5c.chunk.js +1 -0
  180. package/build/7811.fdbe09af.chunk.js +103 -0
  181. package/build/782.7243b183.chunk.js +1 -0
  182. package/build/7849.2a500ed8.chunk.js +1 -0
  183. package/build/7897.63ba0a00.chunk.js +6 -0
  184. package/build/7e9af4fb7e723fcebf1f.svg +48 -0
  185. package/build/8162.7d1100a0.chunk.js +1 -0
  186. package/build/8276.9abe4679.chunk.js +26 -0
  187. package/build/8773.ee67141c.chunk.js +48 -0
  188. package/build/8980.f0045cc1.chunk.js +1 -0
  189. package/build/9077.2cc01ac8.chunk.js +105 -0
  190. package/build/9153.42c1428a.chunk.js +1 -0
  191. package/build/918.54414509.chunk.js +1 -0
  192. package/build/9218.b2d367f8.chunk.js +1 -0
  193. package/build/9285.5f174057.chunk.js +1 -0
  194. package/build/9547.62987774.chunk.js +1 -0
  195. package/build/9754.b4e73779.chunk.js +1 -0
  196. package/build/9d5d788027e86620c234.svg +5 -0
  197. package/build/Admin-authenticatedApp.059dc48f.chunk.js +79 -0
  198. package/build/Admin_InternalErrorPage.06eeef20.chunk.js +1 -0
  199. package/build/Admin_homePage.56b9eb3f.chunk.js +81 -0
  200. package/build/Admin_marketplace.d693a435.chunk.js +44 -0
  201. package/build/Admin_pluginsPage.ae2c872a.chunk.js +6 -0
  202. package/build/Admin_profilePage.89099d5b.chunk.js +13 -0
  203. package/build/Admin_settingsPage.88c45586.chunk.js +12 -0
  204. package/build/Upload_ConfigureTheView.44f28145.chunk.js +1 -0
  205. package/build/admin-app.990e112f.chunk.js +69 -0
  206. package/build/admin-edit-roles-page.4e1eb4a9.chunk.js +267 -0
  207. package/build/admin-edit-users.5b91404e.chunk.js +10 -0
  208. package/build/admin-roles-list.89dd94fe.chunk.js +22 -0
  209. package/build/admin-users.7be4fc5f.chunk.js +11 -0
  210. package/build/api-tokens-create-page.571920e5.chunk.js +1 -0
  211. package/build/api-tokens-edit-page.cbdc81b1.chunk.js +1 -0
  212. package/build/api-tokens-list-page.de0c49e8.chunk.js +16 -0
  213. package/build/ar-json.74e40bc7.chunk.js +1 -0
  214. package/build/audit-logs-sales-page.2955db88.chunk.js +1 -0
  215. package/build/audit-logs-settings-page.b0cb5164.chunk.js +1 -0
  216. package/build/bb3108f7fd1e6179bde1.svg +1 -0
  217. package/build/bb4d0d527bdfb161bc5a.svg +1 -0
  218. package/build/ca-json.fc6001d3.chunk.js +1 -0
  219. package/build/content-manager.de7ae330.chunk.js +1241 -0
  220. package/build/content-type-builder-list-view.6c8d3213.chunk.js +211 -0
  221. package/build/content-type-builder-translation-ar-json.3e808e2f.chunk.js +1 -0
  222. package/build/content-type-builder-translation-cs-json.1ef9e106.chunk.js +1 -0
  223. package/build/content-type-builder-translation-de-json.63fcff7b.chunk.js +1 -0
  224. package/build/content-type-builder-translation-dk-json.fd626b67.chunk.js +1 -0
  225. package/build/content-type-builder-translation-en-json.74d80f18.chunk.js +1 -0
  226. package/build/content-type-builder-translation-es-json.a4a361a9.chunk.js +1 -0
  227. package/build/content-type-builder-translation-fr-json.499c3a46.chunk.js +1 -0
  228. package/build/content-type-builder-translation-id-json.65255f93.chunk.js +1 -0
  229. package/build/content-type-builder-translation-it-json.e268ab74.chunk.js +1 -0
  230. package/build/content-type-builder-translation-ja-json.9be0d5b2.chunk.js +1 -0
  231. package/build/content-type-builder-translation-ko-json.04cb309d.chunk.js +1 -0
  232. package/build/content-type-builder-translation-ms-json.f6b743b9.chunk.js +1 -0
  233. package/build/content-type-builder-translation-nl-json.997fe8cc.chunk.js +1 -0
  234. package/build/content-type-builder-translation-pl-json.634f638b.chunk.js +1 -0
  235. package/build/content-type-builder-translation-pt-BR-json.6a95dc71.chunk.js +1 -0
  236. package/build/content-type-builder-translation-pt-json.ddb44f8c.chunk.js +1 -0
  237. package/build/content-type-builder-translation-ru-json.3af65503.chunk.js +1 -0
  238. package/build/content-type-builder-translation-sk-json.c6078082.chunk.js +1 -0
  239. package/build/content-type-builder-translation-sv-json.a6df2462.chunk.js +1 -0
  240. package/build/content-type-builder-translation-th-json.122277cc.chunk.js +1 -0
  241. package/build/content-type-builder-translation-tr-json.41f44f77.chunk.js +1 -0
  242. package/build/content-type-builder-translation-uk-json.e1315acd.chunk.js +1 -0
  243. package/build/content-type-builder-translation-zh-Hans-json.6ff57db6.chunk.js +1 -0
  244. package/build/content-type-builder-translation-zh-json.3532b962.chunk.js +1 -0
  245. package/build/content-type-builder.0bc97051.chunk.js +136 -0
  246. package/build/cs-json.4b44411c.chunk.js +1 -0
  247. package/build/de-json.e72545cf.chunk.js +1 -0
  248. package/build/dk-json.e77140ef.chunk.js +1 -0
  249. package/build/email-settings-page.07712efc.chunk.js +11 -0
  250. package/build/en-json.5b907f67.chunk.js +1 -0
  251. package/build/es-json.b1f2284b.chunk.js +1 -0
  252. package/build/eu-json.63d0a898.chunk.js +1 -0
  253. package/build/fr-json.33c6428b.chunk.js +1 -0
  254. package/build/gu-json.7efe8cc2.chunk.js +1 -0
  255. package/build/he-json.3cf0b48a.chunk.js +1 -0
  256. package/build/hi-json.0d633692.chunk.js +1 -0
  257. package/build/highlight.js.28a1547e.chunk.js +85 -0
  258. package/build/hu-json.c74b6a1e.chunk.js +1 -0
  259. package/build/i18n-settings-page.5c34f012.chunk.js +9 -0
  260. package/build/i18n-translation-de-json.362384a6.chunk.js +1 -0
  261. package/build/i18n-translation-dk-json.89401417.chunk.js +1 -0
  262. package/build/i18n-translation-en-json.1ec7becf.chunk.js +1 -0
  263. package/build/i18n-translation-es-json.87b494d1.chunk.js +1 -0
  264. package/build/i18n-translation-fr-json.57ddc77e.chunk.js +1 -0
  265. package/build/i18n-translation-ko-json.ef4f9471.chunk.js +1 -0
  266. package/build/i18n-translation-pl-json.dfac513d.chunk.js +1 -0
  267. package/build/i18n-translation-ru-json.a3dbc125.chunk.js +1 -0
  268. package/build/i18n-translation-tr-json.3bfc812f.chunk.js +1 -0
  269. package/build/i18n-translation-zh-Hans-json.757ce62d.chunk.js +1 -0
  270. package/build/i18n-translation-zh-json.bef2dc07.chunk.js +1 -0
  271. package/build/id-json.41e07c46.chunk.js +1 -0
  272. package/build/index.html +1 -0
  273. package/build/it-json.bfe27ed8.chunk.js +1 -0
  274. package/build/ja-json.e1959a1c.chunk.js +1 -0
  275. package/build/ko-json.ce5d6d94.chunk.js +1 -0
  276. package/build/main.f84563f1.js +2665 -0
  277. package/build/ml-json.940d7ace.chunk.js +1 -0
  278. package/build/ms-json.0eddffd9.chunk.js +1 -0
  279. package/build/nl-json.fe38f0fb.chunk.js +1 -0
  280. package/build/no-json.19a2dbfa.chunk.js +1 -0
  281. package/build/pl-json.d55e8e78.chunk.js +1 -0
  282. package/build/pt-BR-json.ae0a0d2e.chunk.js +1 -0
  283. package/build/pt-json.ee554a41.chunk.js +1 -0
  284. package/build/review-workflows-sales-page.f46a8f00.chunk.js +1 -0
  285. package/build/review-workflows-settings-create-view.d0544fb0.chunk.js +1 -0
  286. package/build/review-workflows-settings-edit-view.aabf49ef.chunk.js +1 -0
  287. package/build/review-workflows-settings-list-view.8b0525ab.chunk.js +56 -0
  288. package/build/ru-json.1c976644.chunk.js +1 -0
  289. package/build/runtime~main.270fd45f.js +2 -0
  290. package/build/sa-json.2c03ef4e.chunk.js +1 -0
  291. package/build/sk-json.b41847e8.chunk.js +1 -0
  292. package/build/sso-sales-page.ef22e469.chunk.js +1 -0
  293. package/build/sso-settings-page.21e16ae4.chunk.js +1 -0
  294. package/build/sv-json.568cb7ae.chunk.js +1 -0
  295. package/build/th-json.5f659396.chunk.js +1 -0
  296. package/build/tr-json.c9f22432.chunk.js +1 -0
  297. package/build/transfer-tokens-create-page.3366204d.chunk.js +1 -0
  298. package/build/transfer-tokens-edit-page.15cf0f73.chunk.js +1 -0
  299. package/build/transfer-tokens-list-page.0bc0e682.chunk.js +16 -0
  300. package/build/uk-json.b7e38370.chunk.js +1 -0
  301. package/build/upload-settings.1319dca0.chunk.js +14 -0
  302. package/build/upload-translation-ca-json.57954414.chunk.js +1 -0
  303. package/build/upload-translation-de-json.420c943b.chunk.js +1 -0
  304. package/build/upload-translation-dk-json.bbb2fa05.chunk.js +1 -0
  305. package/build/upload-translation-en-json.8b7573ce.chunk.js +1 -0
  306. package/build/upload-translation-es-json.ba2eb03a.chunk.js +1 -0
  307. package/build/upload-translation-fr-json.baab9911.chunk.js +1 -0
  308. package/build/upload-translation-he-json.0a830937.chunk.js +1 -0
  309. package/build/upload-translation-it-json.e87d7966.chunk.js +1 -0
  310. package/build/upload-translation-ja-json.44b88e7a.chunk.js +1 -0
  311. package/build/upload-translation-ko-json.a52eab64.chunk.js +1 -0
  312. package/build/upload-translation-ms-json.74f6d746.chunk.js +1 -0
  313. package/build/upload-translation-pl-json.426f31c9.chunk.js +1 -0
  314. package/build/upload-translation-pt-BR-json.d1704f0b.chunk.js +1 -0
  315. package/build/upload-translation-pt-json.6b937fdf.chunk.js +1 -0
  316. package/build/upload-translation-ru-json.675f6b93.chunk.js +1 -0
  317. package/build/upload-translation-sk-json.483a18f6.chunk.js +1 -0
  318. package/build/upload-translation-th-json.98d35574.chunk.js +1 -0
  319. package/build/upload-translation-tr-json.74117e5c.chunk.js +1 -0
  320. package/build/upload-translation-uk-json.9950466a.chunk.js +1 -0
  321. package/build/upload-translation-zh-Hans-json.db163b6b.chunk.js +1 -0
  322. package/build/upload-translation-zh-json.e1dd6eb2.chunk.js +1 -0
  323. package/build/upload.1ced11be.chunk.js +58 -0
  324. package/build/users-advanced-settings-page.8e657084.chunk.js +9 -0
  325. package/build/users-email-settings-page.e57745e5.chunk.js +9 -0
  326. package/build/users-permissions-translation-ar-json.7d87d54d.chunk.js +1 -0
  327. package/build/users-permissions-translation-cs-json.7e23424a.chunk.js +1 -0
  328. package/build/users-permissions-translation-de-json.a6fb670f.chunk.js +1 -0
  329. package/build/users-permissions-translation-dk-json.60e50f48.chunk.js +1 -0
  330. package/build/users-permissions-translation-en-json.4b302272.chunk.js +1 -0
  331. package/build/users-permissions-translation-es-json.35007573.chunk.js +1 -0
  332. package/build/users-permissions-translation-fr-json.7e55bbbb.chunk.js +1 -0
  333. package/build/users-permissions-translation-id-json.a5a0fb59.chunk.js +1 -0
  334. package/build/users-permissions-translation-it-json.0705465d.chunk.js +1 -0
  335. package/build/users-permissions-translation-ja-json.891fe76e.chunk.js +1 -0
  336. package/build/users-permissions-translation-ko-json.357d7a33.chunk.js +1 -0
  337. package/build/users-permissions-translation-ms-json.c83f87c4.chunk.js +1 -0
  338. package/build/users-permissions-translation-nl-json.c9f92a3c.chunk.js +1 -0
  339. package/build/users-permissions-translation-pl-json.0a7287d1.chunk.js +1 -0
  340. package/build/users-permissions-translation-pt-BR-json.1b6d2920.chunk.js +1 -0
  341. package/build/users-permissions-translation-pt-json.a7eda429.chunk.js +1 -0
  342. package/build/users-permissions-translation-ru-json.8e883c67.chunk.js +1 -0
  343. package/build/users-permissions-translation-sk-json.7f37180f.chunk.js +1 -0
  344. package/build/users-permissions-translation-sv-json.17187818.chunk.js +1 -0
  345. package/build/users-permissions-translation-th-json.1e9c0247.chunk.js +1 -0
  346. package/build/users-permissions-translation-tr-json.2bd7ff98.chunk.js +1 -0
  347. package/build/users-permissions-translation-uk-json.6a0a1572.chunk.js +1 -0
  348. package/build/users-permissions-translation-vi-json.6722a8a2.chunk.js +1 -0
  349. package/build/users-permissions-translation-zh-Hans-json.8d82c809.chunk.js +1 -0
  350. package/build/users-permissions-translation-zh-json.7978eaa6.chunk.js +1 -0
  351. package/build/users-providers-settings-page.55796d13.chunk.js +14 -0
  352. package/build/users-roles-settings-page.57079245.chunk.js +55 -0
  353. package/build/vi-json.ee4c5537.chunk.js +1 -0
  354. package/build/webhook-edit-page.3a28b2e7.chunk.js +33 -0
  355. package/build/webhook-list-page.ee80767b.chunk.js +63 -0
  356. package/build/zh-Hans-json.97efd015.chunk.js +1 -0
  357. package/build/zh-json.bfc2e036.chunk.js +1 -0
  358. package/ee/admin/hooks/{useLicenseLimitNotification.js → useLicenseLimitNotification.ts} +4 -4
  359. package/ee/admin/pages/AuthPage/components/Login/index.js +1 -1
  360. package/ee/admin/pages/AuthPage/components/Providers/index.js +3 -2
  361. package/ee/admin/pages/SettingsPage/pages/ReviewWorkflows/selectors.js +1 -1
  362. package/ee/admin/pages/SettingsPage/pages/Users/ListPage/index.js +1 -3
  363. package/ee/server/bootstrap.js +1 -1
  364. package/ee/server/controllers/admin.js +1 -1
  365. package/ee/server/controllers/user.js +1 -1
  366. package/ee/server/destroy.js +1 -1
  367. package/ee/server/register.js +1 -1
  368. package/ee/server/routes/utils.js +1 -1
  369. package/ee/server/services/audit-logs.js +1 -1
  370. package/ee/server/services/passport/sso.js +1 -1
  371. package/ee/server/services/passport.js +1 -1
  372. package/ee/server/services/seat-enforcement.js +1 -1
  373. package/ee/server/utils/sso-lock.js +1 -1
  374. package/ee/server/validation/role.js +1 -1
  375. package/ee/server/validation/user.js +1 -1
  376. package/jest.config.front.js +4 -0
  377. package/package.json +28 -22
  378. package/scripts/build.js +6 -2
  379. package/server/controllers/admin.js +4 -3
  380. package/shared/entities.ts +33 -0
  381. package/shared/permissions.ts +52 -0
  382. package/shared/schema.ts +9 -0
  383. package/webpack.config.js +1 -0
  384. package/admin/src/components/AuthenticatedApp/index.js +0 -120
  385. package/admin/src/components/AuthenticatedApp/utils/api.js +0 -85
  386. package/admin/src/components/AuthenticatedApp/utils/checkLatestStrapiVersion.js +0 -11
  387. package/admin/src/components/ConfigurationsProvider/index.js +0 -66
  388. package/admin/src/components/ConfigurationsProvider/reducer.js +0 -29
  389. package/admin/src/components/DragLayer/index.js +0 -1
  390. package/admin/src/components/GlobalStyle/index.js +0 -9
  391. package/admin/src/components/GuidedTour/Homepage/components/Step.js +0 -61
  392. package/admin/src/components/GuidedTour/Homepage/components/Stepper.js +0 -61
  393. package/admin/src/components/GuidedTour/Homepage/index.js +0 -71
  394. package/admin/src/components/GuidedTour/Modal/components/Content.js +0 -66
  395. package/admin/src/components/GuidedTour/Modal/components/Modal.js +0 -72
  396. package/admin/src/components/GuidedTour/Modal/components/StepNumberWithPadding.js +0 -26
  397. package/admin/src/components/GuidedTour/Modal/components/Stepper.js +0 -118
  398. package/admin/src/components/GuidedTour/Modal/index.js +0 -94
  399. package/admin/src/components/GuidedTour/Modal/reducer.js +0 -29
  400. package/admin/src/components/GuidedTour/Stepper/StepLine.js +0 -29
  401. package/admin/src/components/GuidedTour/Stepper/StepNumber.js +0 -71
  402. package/admin/src/components/GuidedTour/constants.js +0 -3
  403. package/admin/src/components/GuidedTour/index.js +0 -102
  404. package/admin/src/components/GuidedTour/init.js +0 -37
  405. package/admin/src/components/GuidedTour/reducer.js +0 -50
  406. package/admin/src/components/GuidedTour/utils/arePreviousSectionsDone.js +0 -13
  407. package/admin/src/components/GuidedTour/utils/arePreviousStepsDone.js +0 -12
  408. package/admin/src/components/GuidedTour/utils/isGuidedTourCompleted.js +0 -6
  409. package/admin/src/components/GuidedTour/utils/persistStateToLocaleStorage.js +0 -34
  410. package/admin/src/components/LanguageProvider/index.js +0 -54
  411. package/admin/src/components/LanguageProvider/init.js +0 -13
  412. package/admin/src/components/LanguageProvider/reducer.js +0 -30
  413. package/admin/src/components/LanguageProvider/utils/localStorageKey.js +0 -3
  414. package/admin/src/components/LocalesProvider/context.js +0 -5
  415. package/admin/src/components/LocalesProvider/index.js +0 -21
  416. package/admin/src/components/LocalesProvider/useLocalesProvider.js +0 -11
  417. package/admin/src/components/NpsSurvey/hooks/useNpsSurveySettings.js +0 -17
  418. package/admin/src/components/PluginsInitializer/index.js +0 -68
  419. package/admin/src/components/PluginsInitializer/init.js +0 -11
  420. package/admin/src/components/PluginsInitializer/reducer.js +0 -22
  421. package/admin/src/components/PrivateRoute/index.js +0 -46
  422. package/admin/src/components/Providers/index.js +0 -156
  423. package/admin/src/components/RBACProvider/actions.js +0 -10
  424. package/admin/src/components/RBACProvider/constants.js +0 -2
  425. package/admin/src/components/RBACProvider/index.js +0 -39
  426. package/admin/src/components/RBACProvider/reducer.js +0 -51
  427. package/admin/src/components/Theme/index.js +0 -26
  428. package/admin/src/components/ThemeToggleProvider/index.js +0 -79
  429. package/admin/src/contexts/Admin/index.js +0 -5
  430. package/admin/src/contexts/ApiTokenPermissions/index.js +0 -25
  431. package/admin/src/contexts/Configurations/index.js +0 -5
  432. package/admin/src/contexts/MarketPlace/index.js +0 -18
  433. package/admin/src/contexts/PermisssionsDataManagerContext/index.js +0 -5
  434. package/admin/src/contexts/ThemeToggle/index.js +0 -5
  435. package/admin/src/contexts/index.js +0 -4
  436. package/admin/src/core/store/configureStore.js +0 -47
  437. package/admin/src/exposedHooks.js +0 -27
  438. package/admin/src/hooks/useAdminRoles/__mocks__/index.js +0 -5
  439. package/admin/src/hooks/useAdminUsers/index.js +0 -1
  440. package/admin/src/hooks/useAdminUsers/useAdminUsers.js +0 -47
  441. package/admin/src/hooks/useConfigurations/index.js +0 -11
  442. package/admin/src/hooks/useContentTypes/index.js +0 -1
  443. package/admin/src/hooks/useDebounce/index.js +0 -19
  444. package/admin/src/hooks/useEnterprise/index.js +0 -1
  445. package/admin/src/hooks/useLicenseLimitNotification/index.js +0 -5
  446. package/admin/src/hooks/useMenu/index.js +0 -86
  447. package/admin/src/hooks/useMenu/utils/checkPermissions.js +0 -13
  448. package/admin/src/hooks/useMenu/utils/getGeneralLinks.js +0 -31
  449. package/admin/src/hooks/useMenu/utils/getPluginSectionLinks.js +0 -17
  450. package/admin/src/hooks/usePermissionsDataManager/index.js +0 -7
  451. package/admin/src/hooks/useReleaseNotification/index.js +0 -31
  452. package/admin/src/hooks/useReleaseNotification/utils/api.js +0 -20
  453. package/admin/src/hooks/useReleaseNotification/utils/checkLatestStrapiVersion.js +0 -11
  454. package/admin/src/hooks/useThemeToggle/index.js +0 -11
  455. package/admin/src/injectionZones.js +0 -25
  456. package/admin/src/layouts/UnauthenticatedLayout/LocaleToggle/index.js +0 -29
  457. package/admin/src/layouts/UnauthenticatedLayout/index.js +0 -55
  458. package/admin/src/reducers.js +0 -23
  459. package/admin/src/shared/hooks/useAdminProvider/index.js +0 -11
  460. package/admin/src/tsconfig.json +0 -10
  461. package/admin/src/utils/checkFormValidity.js +0 -15
  462. package/admin/src/utils/createRoute.js +0 -47
  463. package/admin/src/utils/formatAPIErrors.js +0 -17
  464. package/admin/src/utils/getAttributesToDisplay.js +0 -19
  465. package/admin/src/utils/getExistingActions.js +0 -32
  466. package/admin/src/utils/getFullName.js +0 -9
  467. package/admin/src/utils/index.js +0 -9
  468. package/admin/src/utils/makeUniqueRoutes.js +0 -6
  469. package/admin/src/utils/sortLinks.js +0 -5
  470. /package/admin/src/hooks/{useAdminUsers/__mocks__/index.js → __mocks__/useAdminUsers.ts} +0 -0
  471. /package/admin/src/hooks/{useContentTypes/__mocks__/index.js → __mocks__/useContentTypes.ts} +0 -0
  472. /package/admin/src/{hooks/useAdminRolePermissions/__mocks__/index.js → pages/SettingsPage/pages/Roles/hooks/__mocks__/useAdminRolePermissions.ts} +0 -0
@@ -4,23 +4,29 @@ import { Typography } from '@strapi/design-system';
4
4
  import { Bold, Italic, Underline, StrikeThrough, Code } from '@strapi/icons';
5
5
  import { Editor } from 'slate';
6
6
  import { useSlate } from 'slate-react';
7
- import styled from 'styled-components';
7
+ import styled, { css } from 'styled-components';
8
8
 
9
- const BoldText = styled(Typography).attrs({ fontWeight: 'bold' })`
9
+ const stylesToInherit = css`
10
10
  font-size: inherit;
11
+ color: inherit;
12
+ line-height: inherit;
13
+ `;
14
+
15
+ const BoldText = styled(Typography).attrs({ fontWeight: 'bold' })`
16
+ ${stylesToInherit}
11
17
  `;
12
18
 
13
19
  const ItalicText = styled(Typography)`
14
20
  font-style: italic;
15
- font-size: inherit;
21
+ ${stylesToInherit}
16
22
  `;
17
23
 
18
24
  const UnderlineText = styled(Typography).attrs({ textDecoration: 'underline' })`
19
- font-size: inherit;
25
+ ${stylesToInherit}
20
26
  `;
21
27
 
22
28
  const StrikeThroughText = styled(Typography).attrs({ textDecoration: 'line-through' })`
23
- font-size: inherit;
29
+ ${stylesToInherit}
24
30
  `;
25
31
 
26
32
  const InlineCode = styled.code`
@@ -29,6 +35,7 @@ const InlineCode = styled.code`
29
35
  padding: ${({ theme }) => `0 ${theme.spaces[2]}`};
30
36
  font-family: 'SF Mono', SFMono-Regular, ui-monospace, 'DejaVu Sans Mono', Menlo, Consolas,
31
37
  monospace;
38
+ color: inherit;
32
39
  `;
33
40
 
34
41
  /**
@@ -48,14 +55,24 @@ export function useModifiersStore() {
48
55
  const editor = useSlate();
49
56
  const modifiers = Editor.marks(editor);
50
57
 
58
+ /**
59
+ * The default handler for checking if a modifier is active
60
+ *
61
+ * @param {string} name - The name of the modifier to check
62
+ */
51
63
  const baseCheckIsActive = (name) => {
52
64
  if (!modifiers) return false;
53
65
 
54
66
  return Boolean(modifiers[name]);
55
67
  };
56
68
 
69
+ /**
70
+ * The default handler for toggling a modifier
71
+ *
72
+ * @param {string} name - The name of the modifier to toggle
73
+ */
57
74
  const baseHandleToggle = (name) => {
58
- if (modifiers[name]) {
75
+ if (modifiers?.[name]) {
59
76
  Editor.removeMark(editor, name);
60
77
  } else {
61
78
  Editor.addMark(editor, name, true);
@@ -8,33 +8,92 @@ import { withHistory } from 'slate-history';
8
8
  import { Slate, withReact, ReactEditor } from 'slate-react';
9
9
  import styled from 'styled-components';
10
10
 
11
+ import Hint from '../Hint';
12
+
11
13
  import BlocksInput from './BlocksInput';
14
+ import { withLinks, withStrapiSchema } from './plugins';
12
15
  import { BlocksToolbar } from './Toolbar';
13
16
 
14
17
  const TypographyAsterisk = styled(Typography)`
15
18
  line-height: 0;
16
19
  `;
17
20
 
21
+ const LabelAction = styled(Box)`
22
+ svg path {
23
+ fill: ${({ theme }) => theme.colors.neutral500};
24
+ }
25
+ `;
26
+
18
27
  const EditorDivider = styled(Divider)`
19
28
  background: ${({ theme }) => theme.colors.neutral200};
20
29
  `;
21
30
 
22
- const Wrapper = styled(Box)`
23
- width: 100%;
24
- max-height: 512px;
25
- overflow: auto;
26
- padding: ${({ theme }) => `${theme.spaces[3]} ${theme.spaces[4]}`};
27
- font-size: ${({ theme }) => theme.fontSizes[2]};
28
- background-color: ${({ theme }) => theme.colors.neutral0};
29
- color: ${({ theme }) => theme.colors.neutral800};
30
- line-height: ${({ theme }) => theme.lineHeights[6]};
31
- border-radius: ${({ theme }) => theme.borderRadius};
32
- `;
31
+ /**
32
+ * Images are void elements. They handle the rendering of their children instead of Slate.
33
+ * See the Slate documentation for more information:
34
+ * - https://docs.slatejs.org/api/nodes/element#void-vs-not-void
35
+ * - https://docs.slatejs.org/api/nodes/element#rendering-void-elements
36
+ *
37
+ * @param {import('slate').Editor} editor
38
+ */
39
+ const withImages = (editor) => {
40
+ const { isVoid } = editor;
41
+
42
+ editor.isVoid = (element) => {
43
+ return element.type === 'image' ? true : isVoid(element);
44
+ };
45
+
46
+ return editor;
47
+ };
48
+
49
+ /**
50
+ * Forces an update of the Slate editor when the value prop changes from outside of Slate.
51
+ * The root cause is that Slate is not a controlled component: https://github.com/ianstormtaylor/slate/issues/4612
52
+ * Why not use JSON.stringify(value) as the key?
53
+ * Because it would force a rerender of the entire editor every time the user types a character.
54
+ * Why not use the entity id as the key, since it's unique for each locale?
55
+ * Because it would not solve the problem when using the "fill in from other locale" feature
56
+ *
57
+ * @param {import('slate').Descendant[]} value
58
+ * @returns {{
59
+ * key: number,
60
+ * incrementSlateUpdatesCount: () => void
61
+ * }}
62
+ */
63
+ function useResetKey(value) {
64
+ // Keep track how how many times Slate detected a change from a user interaction in the editor
65
+ const slateUpdatesCount = React.useRef(0);
66
+ // Keep track of how many times the value prop was updated, whether from within editor or from outside
67
+ const valueUpdatesCount = React.useRef(0);
68
+ // Use a key to force a rerender of the Slate editor when needed
69
+ const [key, setKey] = React.useState(0);
70
+
71
+ React.useEffect(() => {
72
+ valueUpdatesCount.current += 1;
73
+
74
+ // If the 2 refs are not equal, it means the value was updated from outside
75
+ if (valueUpdatesCount.current !== slateUpdatesCount.current) {
76
+ // So we change the key to force a rerender of the Slate editor,
77
+ // which will pick up the new value through its initialValue prop
78
+ setKey((previousKey) => previousKey + 1);
79
+
80
+ // Then bring the 2 refs back in sync
81
+ slateUpdatesCount.current = valueUpdatesCount.current;
82
+ }
83
+ }, [value]);
84
+
85
+ return { key, incrementSlateUpdatesCount: () => (slateUpdatesCount.current += 1) };
86
+ }
33
87
 
34
88
  const BlocksEditor = React.forwardRef(
35
- ({ intlLabel, name, readOnly, required, error, value, onChange }, ref) => {
89
+ (
90
+ { intlLabel, labelAction, name, disabled, required, error, value, onChange, placeholder, hint },
91
+ ref
92
+ ) => {
36
93
  const { formatMessage } = useIntl();
37
- const [editor] = React.useState(() => withReact(withHistory(createEditor())));
94
+ const [editor] = React.useState(() =>
95
+ withReact(withStrapiSchema(withLinks(withImages(withHistory(createEditor())))))
96
+ );
38
97
 
39
98
  const label = intlLabel.id
40
99
  ? formatMessage(
@@ -43,6 +102,10 @@ const BlocksEditor = React.forwardRef(
43
102
  )
44
103
  : name;
45
104
 
105
+ const formattedPlaceholder = placeholder
106
+ ? formatMessage({ id: placeholder.id, defaultMessage: placeholder.defaultMessage })
107
+ : null;
108
+
46
109
  /** Editable is not able to hold the ref, https://github.com/ianstormtaylor/slate/issues/4082
47
110
  * so with "useImperativeHandle" we can use ReactEditor methods to expose to the parent above
48
111
  * also not passing forwarded ref here, gives console warning.
@@ -57,10 +120,14 @@ const BlocksEditor = React.forwardRef(
57
120
  [editor]
58
121
  );
59
122
 
123
+ const { key, incrementSlateUpdatesCount } = useResetKey(value);
124
+
60
125
  const handleSlateChange = (state) => {
61
126
  const isAstChange = editor.operations.some((op) => op.type !== 'set_selection');
62
127
 
63
128
  if (isAstChange) {
129
+ incrementSlateUpdatesCount();
130
+
64
131
  onChange({
65
132
  target: { name, value: state, type: 'blocks' },
66
133
  });
@@ -75,20 +142,21 @@ const BlocksEditor = React.forwardRef(
75
142
  {label}
76
143
  {required && <TypographyAsterisk textColor="danger600">*</TypographyAsterisk>}
77
144
  </Typography>
145
+ {labelAction && <LabelAction paddingLeft={1}>{labelAction}</LabelAction>}
78
146
  </Flex>
79
147
  <Slate
80
148
  editor={editor}
81
149
  initialValue={value || [{ type: 'paragraph', children: [{ type: 'text', text: '' }] }]}
82
150
  onChange={handleSlateChange}
151
+ key={key}
83
152
  >
84
- <InputWrapper direction="column" alignItems="flex-start">
85
- <BlocksToolbar />
153
+ <InputWrapper direction="column" alignItems="flex-start" height="512px">
154
+ <BlocksToolbar disabled={disabled} />
86
155
  <EditorDivider width="100%" />
87
- <Wrapper>
88
- <BlocksInput readOnly={readOnly} />
89
- </Wrapper>
156
+ <BlocksInput disabled={disabled} placeholder={formattedPlaceholder} />
90
157
  </InputWrapper>
91
158
  </Slate>
159
+ <Hint hint={hint} name={name} error={error} />
92
160
  </Flex>
93
161
  {error && (
94
162
  <Box paddingTop={1}>
@@ -103,10 +171,13 @@ const BlocksEditor = React.forwardRef(
103
171
  );
104
172
 
105
173
  BlocksEditor.defaultProps = {
174
+ labelAction: null,
175
+ disabled: false,
106
176
  required: false,
107
- readOnly: false,
108
177
  error: '',
109
178
  value: null,
179
+ placeholder: null,
180
+ hint: null,
110
181
  };
111
182
 
112
183
  BlocksEditor.propTypes = {
@@ -115,12 +186,18 @@ BlocksEditor.propTypes = {
115
186
  defaultMessage: PropTypes.string.isRequired,
116
187
  values: PropTypes.object,
117
188
  }).isRequired,
189
+ labelAction: PropTypes.element,
118
190
  name: PropTypes.string.isRequired,
119
191
  required: PropTypes.bool,
120
- readOnly: PropTypes.bool,
192
+ disabled: PropTypes.bool,
121
193
  error: PropTypes.string,
122
194
  onChange: PropTypes.func.isRequired,
123
195
  value: PropTypes.array,
196
+ placeholder: PropTypes.shape({
197
+ id: PropTypes.string.isRequired,
198
+ defaultMessage: PropTypes.string.isRequired,
199
+ }),
200
+ hint: PropTypes.oneOfType([PropTypes.string, PropTypes.array]),
124
201
  };
125
202
 
126
203
  export default BlocksEditor;
@@ -0,0 +1,4 @@
1
+ import { withLinks } from './withLinks';
2
+ import { withStrapiSchema } from './withStrapiSchema';
3
+
4
+ export { withLinks, withStrapiSchema };
@@ -0,0 +1,61 @@
1
+ import { Path, Transforms, Range, Point, Editor } from 'slate';
2
+
3
+ const withLinks = (editor) => {
4
+ const { isInline, apply, insertText } = editor;
5
+
6
+ // Links are inline elements, so we need to override the isInline method for slate
7
+ editor.isInline = (element) => {
8
+ return element.type === 'link' ? true : isInline(element);
9
+ };
10
+
11
+ // We keep a track of the last inserted link path
12
+ // So we can show the popover on the link component if that link is the last one inserted
13
+ editor.lastInsertedLinkPath = null;
14
+
15
+ // We intercept the apply method, so everytime we insert a new link, we save its path
16
+ editor.apply = (operation) => {
17
+ if (operation.type === 'insert_node') {
18
+ if (operation.node.type === 'link') {
19
+ editor.lastInsertedLinkPath = operation.path;
20
+ }
21
+ } else if (operation.type === 'move_node') {
22
+ // We need to update the last inserted link path when link is moved
23
+ // If link is the first word in the paragraph we dont need to update the path
24
+ if (Path.hasPrevious(operation.path)) {
25
+ editor.lastInsertedLinkPath = Path.transform(editor.lastInsertedLinkPath, operation);
26
+ }
27
+ }
28
+
29
+ apply(operation);
30
+ };
31
+
32
+ editor.insertText = (text) => {
33
+ // When selection is at the end of a link and user types a space, we want to break the link
34
+ if (Range.isCollapsed(editor.selection) && text === ' ') {
35
+ const linksInSelection = Array.from(
36
+ Editor.nodes(editor, { at: editor.selection, match: (node) => node.type === 'link' })
37
+ );
38
+
39
+ const selectionIsInLink = editor.selection && linksInSelection.length > 0;
40
+ const selectionIsAtEndOfLink =
41
+ selectionIsInLink &&
42
+ Point.equals(editor.selection.anchor, Editor.end(editor, linksInSelection[0][1]));
43
+
44
+ if (selectionIsAtEndOfLink) {
45
+ Transforms.insertNodes(
46
+ editor,
47
+ { text: ' ', type: 'text' },
48
+ { at: Path.next(linksInSelection[0][1]), select: true }
49
+ );
50
+
51
+ return;
52
+ }
53
+ }
54
+
55
+ insertText(text);
56
+ };
57
+
58
+ return editor;
59
+ };
60
+
61
+ export { withLinks };
@@ -0,0 +1,33 @@
1
+ import { Element, Transforms } from 'slate';
2
+
3
+ /**
4
+ * This plugin is used to normalize the Slate document to match the Strapi schema.
5
+ *
6
+ * @param {import('slate').Editor} editor
7
+ */
8
+ const withStrapiSchema = (editor) => {
9
+ const { normalizeNode } = editor;
10
+
11
+ /**
12
+ * On the strapi schema, we want text nodes to have type: text
13
+ * By default, Slate add text nodes without type: text
14
+ * So we add this normalization for the cases when Slate add text nodes automatically
15
+ */
16
+ editor.normalizeNode = (entry) => {
17
+ const [node, path] = entry;
18
+
19
+ if (!Element.isElement(node)) {
20
+ if (node.type !== 'text') {
21
+ Transforms.setNodes(editor, { type: 'text' }, { at: path });
22
+
23
+ return;
24
+ }
25
+ }
26
+
27
+ normalizeNode(entry);
28
+ };
29
+
30
+ return editor;
31
+ };
32
+
33
+ export { withStrapiSchema };
@@ -0,0 +1,90 @@
1
+ import { Transforms, Editor, Element as SlateElement, Node, Range } from 'slate';
2
+
3
+ /**
4
+ *
5
+ * @param {string} url
6
+ * @param {string} protocol
7
+ */
8
+ const addProtocol = (url, protocol = 'https://') => {
9
+ const allowedProtocols = ['http://', 'https://', 'mailto:', 'tel:'];
10
+
11
+ if (allowedProtocols.some((allowedProtocol) => url.startsWith(allowedProtocol))) {
12
+ return url;
13
+ }
14
+
15
+ return `${protocol}${url}`;
16
+ };
17
+
18
+ /**
19
+ *
20
+ * @param {import('slate').Editor} editor
21
+ */
22
+ const removeLink = (editor) => {
23
+ Transforms.unwrapNodes(editor, {
24
+ match: (node) => !Editor.isEditor(node) && SlateElement.isElement(node) && node.type === 'link',
25
+ });
26
+ };
27
+
28
+ /**
29
+ *
30
+ * @param {import('slate').Editor} editor
31
+ * @param {object} link
32
+ * @param {string} link.url
33
+ */
34
+ const insertLink = (editor, { url }) => {
35
+ if (editor.selection) {
36
+ // We want to remove all link on the selection
37
+ const linkNodes = Array.from(
38
+ Editor.nodes(editor, {
39
+ at: editor.selection,
40
+ match: (node) => node.type === 'link',
41
+ })
42
+ );
43
+
44
+ linkNodes.forEach(([, path]) => {
45
+ Transforms.unwrapNodes(editor, { at: path });
46
+ });
47
+
48
+ if (Range.isCollapsed(editor.selection)) {
49
+ const link = { type: 'link', url: url ? addProtocol(url) : '', children: [{ text: url }] };
50
+
51
+ Transforms.insertNodes(editor, link);
52
+ } else {
53
+ Transforms.wrapNodes(
54
+ editor,
55
+ { type: 'link', url: url ? addProtocol(url) : '' },
56
+ { split: true }
57
+ );
58
+ }
59
+ }
60
+ };
61
+
62
+ /**
63
+ *
64
+ * @param {import('slate').Editor} editor
65
+ * @param {object} link
66
+ * @param {string} link.url
67
+ * @param {string} link.text
68
+ */
69
+ const editLink = (editor, { url, text }) => {
70
+ if (editor.selection) {
71
+ const [linkNode, linkPath] = Editor.above(editor, { match: (node) => node.type === 'link' });
72
+
73
+ if (linkNode) {
74
+ Transforms.setNodes(editor, { url: addProtocol(url) }, { at: linkPath });
75
+
76
+ // If link text is different, we remove the old text and insert the new one
77
+ if (text !== '' && text !== Editor.string(editor, linkPath)) {
78
+ const linkNodeChildrens = Array.from(Node.children(editor, linkPath, { reverse: true }));
79
+
80
+ linkNodeChildrens.forEach(([, childPath]) => {
81
+ Transforms.removeNodes(editor, { at: childPath });
82
+ });
83
+
84
+ Transforms.insertNodes(editor, [{ text }], { at: linkPath.concat(0) });
85
+ }
86
+ }
87
+ }
88
+ };
89
+
90
+ export { insertLink, editLink, removeLink };
@@ -12,7 +12,7 @@ import PropTypes from 'prop-types';
12
12
  import { useIntl } from 'react-intl';
13
13
  import { useMutation, useQuery } from 'react-query';
14
14
 
15
- import useDebounce from '../../../hooks/useDebounce';
15
+ import { useDebounce } from '../../../hooks/useDebounce';
16
16
 
17
17
  import { FieldActionWrapper, LoadingWrapper, TextValidation } from './endActionStyle';
18
18
  import UID_REGEX from './regex';
@@ -2,7 +2,15 @@ import { useRBACProvider, findMatchingPermissions } from '@strapi/helper-plugin'
2
2
 
3
3
  import { CREATOR_FIELDS } from '../constants/attributes';
4
4
 
5
- const NOT_ALLOWED_FILTERS = ['json', 'component', 'media', 'richtext', 'dynamiczone', 'password'];
5
+ const NOT_ALLOWED_FILTERS = [
6
+ 'json',
7
+ 'component',
8
+ 'media',
9
+ 'richtext',
10
+ 'dynamiczone',
11
+ 'password',
12
+ 'blocks',
13
+ ];
6
14
  const TIMESTAMPS = ['createdAt', 'updatedAt'];
7
15
 
8
16
  export const useAllowedAttributes = (contentType, slug) => {
@@ -1,4 +1,4 @@
1
- import { createSelector } from 'reselect';
1
+ import { createSelector } from '@reduxjs/toolkit';
2
2
 
3
3
  import { initialState } from './reducer';
4
4
 
@@ -11,13 +11,15 @@ import axios from 'axios';
11
11
  import { useIntl } from 'react-intl';
12
12
  import { useDispatch, useSelector } from 'react-redux';
13
13
 
14
- import { MUTATE_COLLECTION_TYPES_LINKS, MUTATE_SINGLE_TYPES_LINKS } from '../../../exposedHooks';
14
+ import { HOOKS } from '../../../constants';
15
15
  import { getTrad } from '../../utils';
16
16
 
17
17
  import { getInitData, resetInitData, setInitData } from './actions';
18
18
  import { selectAppDomain } from './selectors';
19
19
  import getContentTypeLinks from './utils/getContentTypeLinks';
20
20
 
21
+ const { MUTATE_COLLECTION_TYPES_LINKS, MUTATE_SINGLE_TYPES_LINKS } = HOOKS;
22
+
21
23
  const useContentManagerInitData = () => {
22
24
  const dispatch = useDispatch();
23
25
  const toggleNotification = useNotification();
@@ -73,6 +73,7 @@ const EditSettingsView = ({ mainLayout, components, isContentTypeView, slug, upd
73
73
  'password',
74
74
  'richtext',
75
75
  'timestamp',
76
+ 'blocks',
76
77
  ].includes(type) && !!type
77
78
  );
78
79
  });
@@ -12,6 +12,7 @@ const createPossibleMainFieldsForModelsAndComponents = (array) => {
12
12
  'relation',
13
13
  'text',
14
14
  'richtext',
15
+ 'blocks',
15
16
  ].includes(attributes?.[attr]?.type ?? '');
16
17
  });
17
18
 
@@ -1,4 +1,4 @@
1
- import { createSelector } from 'reselect';
1
+ import { createSelector } from '@reduxjs/toolkit';
2
2
 
3
3
  import { createAttributesLayout, getCustomFieldUidsFromLayout } from './utils';
4
4
 
@@ -4,13 +4,15 @@ import { LoadingIndicatorPage, useQueryParams, useStrapiApp } from '@strapi/help
4
4
  import PropTypes from 'prop-types';
5
5
  import { useDispatch, useSelector } from 'react-redux';
6
6
 
7
- import { MUTATE_EDIT_VIEW_LAYOUT } from '../../../exposedHooks';
7
+ import { HOOKS } from '../../../constants';
8
8
  import { useSyncRbac } from '../../hooks';
9
9
 
10
10
  import { resetProps, setLayout } from './actions';
11
11
  import Permissions from './Permissions';
12
12
  import selectLayout from './selectors';
13
13
 
14
+ const { MUTATE_EDIT_VIEW_LAYOUT } = HOOKS;
15
+
14
16
  const EditViewLayoutManager = ({ layout, ...rest }) => {
15
17
  const currentLayout = useSelector(selectLayout);
16
18
  const dispatch = useDispatch();
@@ -5,4 +5,5 @@ export const EXCLUDED_SORT_ATTRIBUTE_TYPES = [
5
5
  'relation',
6
6
  'component',
7
7
  'json',
8
+ 'blocks',
8
9
  ];