strapi-plugin-navigation 2.0.13 → 2.1.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 (288) hide show
  1. package/README.md +105 -27
  2. package/admin/src/components/Alert/styles.d.ts +2 -0
  3. package/admin/src/components/Alert/styles.js +10 -4
  4. package/admin/src/components/CollapseButton/index.d.ts +7 -0
  5. package/admin/src/components/CollapseButton/index.js +21 -22
  6. package/admin/src/components/ConfirmationDialog/index.d.ts +28 -0
  7. package/admin/src/components/ConfirmationDialog/index.js +32 -54
  8. package/admin/src/components/EmptyView/index.d.ts +3 -0
  9. package/admin/src/components/EmptyView/index.js +9 -7
  10. package/admin/src/components/Item/ItemCardBadge/index.d.ts +3 -0
  11. package/admin/src/components/Item/ItemCardBadge/index.js +11 -7
  12. package/admin/src/components/Item/ItemCardHeader/Wrapper.d.ts +3 -0
  13. package/admin/src/components/Item/ItemCardHeader/Wrapper.js +10 -6
  14. package/admin/src/components/Item/ItemCardHeader/index.d.ts +12 -0
  15. package/admin/src/components/Item/ItemCardHeader/index.js +33 -52
  16. package/admin/src/components/Item/ItemCardRemovedOverlay/index.d.ts +2 -0
  17. package/admin/src/components/Item/ItemCardRemovedOverlay/index.js +10 -4
  18. package/admin/src/components/Item/Wrapper.d.ts +3 -0
  19. package/admin/src/components/Item/Wrapper.js +10 -6
  20. package/admin/src/components/Item/index.d.ts +31 -0
  21. package/admin/src/components/Item/index.js +163 -242
  22. package/admin/src/components/NavigationItemList/Wrapper.d.ts +3 -0
  23. package/admin/src/components/NavigationItemList/Wrapper.js +9 -5
  24. package/admin/src/components/NavigationItemList/index.d.ts +35 -0
  25. package/admin/src/components/NavigationItemList/index.js +28 -66
  26. package/admin/src/components/RestartAlert/index.d.ts +3 -0
  27. package/admin/src/components/RestartAlert/index.js +10 -5
  28. package/admin/src/components/Search/index.d.ts +6 -0
  29. package/admin/src/components/Search/index.js +57 -46
  30. package/admin/src/components/icons/navigation.d.ts +6 -0
  31. package/admin/src/components/icons/navigation.js +11 -13
  32. package/admin/src/contexts/DataManagerContext.d.ts +3 -0
  33. package/admin/src/contexts/DataManagerContext.js +6 -5
  34. package/admin/src/hooks/useAllContentTypes.d.ts +6 -0
  35. package/admin/src/hooks/useAllContentTypes.js +10 -11
  36. package/admin/src/hooks/useDataManager.d.ts +3 -0
  37. package/admin/src/hooks/useDataManager.js +10 -6
  38. package/admin/src/hooks/useI18nCopyNavigationItemsModal.d.ts +9 -0
  39. package/admin/src/hooks/useI18nCopyNavigationItemsModal.js +51 -0
  40. package/admin/src/hooks/useNavigationConfig.d.ts +10 -0
  41. package/admin/src/hooks/useNavigationConfig.js +52 -56
  42. package/admin/src/hooks/useNavigationManager.d.ts +7 -0
  43. package/admin/src/hooks/useNavigationManager.js +41 -0
  44. package/admin/src/index.d.ts +14 -0
  45. package/admin/src/index.js +92 -76
  46. package/admin/src/pages/App/index.d.ts +3 -0
  47. package/admin/src/pages/App/index.js +43 -31
  48. package/admin/src/pages/DataManagerProvider/actions.d.ts +19 -0
  49. package/admin/src/pages/DataManagerProvider/actions.js +22 -26
  50. package/admin/src/pages/DataManagerProvider/index.d.ts +12 -0
  51. package/admin/src/pages/DataManagerProvider/index.js +316 -298
  52. package/admin/src/pages/DataManagerProvider/init.d.ts +3 -0
  53. package/admin/src/pages/DataManagerProvider/init.js +5 -3
  54. package/admin/src/pages/DataManagerProvider/reducer.d.ts +19 -0
  55. package/admin/src/pages/DataManagerProvider/reducer.js +119 -121
  56. package/admin/src/pages/SettingsPage/components/DisableI18nModal/index.d.ts +24 -0
  57. package/admin/src/pages/SettingsPage/components/DisableI18nModal/index.js +88 -0
  58. package/admin/src/pages/SettingsPage/index.d.ts +3 -0
  59. package/admin/src/pages/SettingsPage/index.js +242 -335
  60. package/admin/src/pages/SettingsPage/utils/functions.d.ts +5 -0
  61. package/admin/src/pages/SettingsPage/utils/functions.js +3 -8
  62. package/admin/src/pages/View/components/I18nCopyNavigationItems/index.d.ts +14 -0
  63. package/admin/src/pages/View/components/I18nCopyNavigationItems/index.js +15 -0
  64. package/admin/src/pages/View/components/NavigationContentHeader/index.d.ts +6 -0
  65. package/admin/src/pages/View/components/NavigationContentHeader/index.js +13 -17
  66. package/admin/src/pages/View/components/NavigationHeader/index.d.ts +12 -0
  67. package/admin/src/pages/View/components/NavigationHeader/index.js +79 -65
  68. package/admin/src/pages/View/components/NavigationHeader/styles.d.ts +2 -0
  69. package/admin/src/pages/View/components/NavigationHeader/styles.js +10 -5
  70. package/admin/src/pages/View/components/NavigationItemForm/index.d.ts +57 -0
  71. package/admin/src/pages/View/components/NavigationItemForm/index.js +416 -453
  72. package/admin/src/pages/View/components/NavigationItemForm/utils/form.d.ts +45 -0
  73. package/admin/src/pages/View/components/NavigationItemForm/utils/form.js +84 -52
  74. package/admin/src/pages/View/components/NavigationItemPopup/NavigationItemPopupFooter.d.ts +23 -0
  75. package/admin/src/pages/View/components/NavigationItemPopup/NavigationItemPopupFooter.js +24 -34
  76. package/admin/src/pages/View/components/NavigationItemPopup/NavigationItemPopupHeader.d.ts +4 -0
  77. package/admin/src/pages/View/components/NavigationItemPopup/NavigationItemPopupHeader.js +16 -16
  78. package/admin/src/pages/View/components/NavigationItemPopup/index.d.ts +30 -0
  79. package/admin/src/pages/View/components/NavigationItemPopup/index.js +85 -108
  80. package/admin/src/pages/View/components/NavigationManager/Create/index.d.ts +9 -0
  81. package/admin/src/pages/View/components/NavigationManager/Create/index.js +57 -0
  82. package/admin/src/pages/View/components/NavigationManager/Delete/index.d.ts +8 -0
  83. package/admin/src/pages/View/components/NavigationManager/Delete/index.js +28 -0
  84. package/admin/src/pages/View/components/NavigationManager/Edit/index.d.ts +8 -0
  85. package/admin/src/pages/View/components/NavigationManager/Edit/index.js +54 -0
  86. package/admin/src/pages/View/components/NavigationManager/Error/index.d.ts +8 -0
  87. package/admin/src/pages/View/components/NavigationManager/Error/index.js +53 -0
  88. package/admin/src/pages/View/components/NavigationManager/Form/index.d.ts +19 -0
  89. package/admin/src/pages/View/components/NavigationManager/Form/index.js +98 -0
  90. package/admin/src/pages/View/components/NavigationManager/List/index.d.ts +8 -0
  91. package/admin/src/pages/View/components/NavigationManager/List/index.js +138 -0
  92. package/admin/src/pages/View/components/NavigationManager/index.d.ts +10 -0
  93. package/admin/src/pages/View/components/NavigationManager/index.js +189 -0
  94. package/admin/src/pages/View/components/NavigationManager/types.d.ts +53 -0
  95. package/admin/src/pages/View/components/NavigationManager/types.js +3 -0
  96. package/admin/src/pages/View/index.d.ts +4 -0
  97. package/admin/src/pages/View/index.js +231 -304
  98. package/admin/src/pages/View/utils/enums.d.ts +9 -0
  99. package/admin/src/pages/View/utils/enums.js +11 -8
  100. package/admin/src/pages/View/utils/form.d.ts +2 -0
  101. package/admin/src/pages/View/utils/form.js +15 -12
  102. package/admin/src/pages/View/utils/index.d.ts +2 -0
  103. package/admin/src/pages/View/utils/index.js +11 -3
  104. package/admin/src/pages/View/utils/parsers.d.ts +49 -0
  105. package/admin/src/pages/View/utils/parsers.js +239 -278
  106. package/admin/src/permissions.d.ts +12 -0
  107. package/admin/src/permissions.js +11 -7
  108. package/admin/src/pluginId.d.ts +3 -0
  109. package/admin/src/pluginId.js +2 -2
  110. package/admin/src/translations/en.json +157 -104
  111. package/admin/src/translations/fr.json +44 -44
  112. package/admin/src/translations/index.d.ts +12 -0
  113. package/admin/src/translations/index.js +17 -11
  114. package/admin/src/utils/api.d.ts +8 -0
  115. package/admin/src/utils/api.js +54 -50
  116. package/admin/src/utils/getTrad.d.ts +3 -0
  117. package/admin/src/utils/getTrad.js +9 -5
  118. package/admin/src/utils/index.d.ts +18 -0
  119. package/admin/src/utils/index.js +36 -15
  120. package/package.json +20 -19
  121. package/permissions.d.ts +9 -0
  122. package/permissions.js +5 -4
  123. package/server/bootstrap/index.d.ts +4 -0
  124. package/server/bootstrap/index.js +41 -0
  125. package/server/config/index.d.ts +5 -0
  126. package/server/config/index.js +33 -9
  127. package/server/config/setupStrategy.d.ts +3 -0
  128. package/server/config/setupStrategy.js +38 -0
  129. package/server/content-types/audience/index.d.ts +27 -0
  130. package/server/content-types/audience/index.js +9 -8
  131. package/server/content-types/audience/schema.d.ts +25 -0
  132. package/server/content-types/audience/schema.js +26 -0
  133. package/server/content-types/index.d.ts +255 -0
  134. package/server/content-types/index.js +15 -12
  135. package/server/content-types/navigation/index.d.ts +64 -0
  136. package/server/content-types/navigation/index.js +11 -8
  137. package/server/content-types/navigation/lifecycle.d.ts +9 -0
  138. package/server/content-types/navigation/lifecycle.js +8 -12
  139. package/server/content-types/navigation/schema.d.ts +55 -0
  140. package/server/content-types/navigation/schema.js +56 -0
  141. package/server/content-types/navigation-item/index.d.ts +112 -0
  142. package/server/content-types/navigation-item/index.js +11 -8
  143. package/server/content-types/navigation-item/lifecycle.d.ts +16 -0
  144. package/server/content-types/navigation-item/lifecycle.js +28 -32
  145. package/server/content-types/navigation-item/schema.d.ts +97 -0
  146. package/server/content-types/navigation-item/schema.js +102 -0
  147. package/server/content-types/navigations-items-related/index.d.ts +56 -0
  148. package/server/content-types/navigations-items-related/index.js +11 -8
  149. package/server/content-types/navigations-items-related/lifecycle.d.ts +8 -0
  150. package/server/content-types/navigations-items-related/lifecycle.js +20 -17
  151. package/server/content-types/navigations-items-related/schema.d.ts +49 -0
  152. package/server/content-types/navigations-items-related/schema.js +50 -0
  153. package/server/controllers/admin.d.ts +4 -0
  154. package/server/controllers/admin.js +130 -0
  155. package/server/controllers/client.d.ts +4 -0
  156. package/server/controllers/client.js +57 -0
  157. package/server/controllers/index.d.ts +4 -0
  158. package/server/controllers/index.js +12 -6
  159. package/server/destroy.d.ts +3 -0
  160. package/server/destroy.js +5 -0
  161. package/server/graphql/config.d.ts +4 -0
  162. package/server/graphql/config.js +28 -0
  163. package/server/graphql/index.d.ts +2 -0
  164. package/server/graphql/index.js +18 -22
  165. package/server/graphql/queries/index.d.ts +3 -0
  166. package/server/graphql/queries/index.js +15 -15
  167. package/server/graphql/queries/render-navigation-child.d.ts +15 -0
  168. package/server/graphql/queries/render-navigation-child.js +24 -15
  169. package/server/graphql/queries/render-navigation.d.ts +21 -0
  170. package/server/graphql/queries/render-navigation.js +31 -15
  171. package/server/graphql/resolvers-config.d.ts +10 -0
  172. package/server/graphql/resolvers-config.js +5 -3
  173. package/server/graphql/setupStrategy.d.ts +3 -0
  174. package/server/graphql/setupStrategy.js +15 -0
  175. package/server/graphql/types/content-types-name-fields.d.ts +6 -0
  176. package/server/graphql/types/content-types-name-fields.js +13 -9
  177. package/server/graphql/types/content-types.d.ts +5 -0
  178. package/server/graphql/types/content-types.js +17 -15
  179. package/server/graphql/types/create-navigation-item.d.ts +5 -0
  180. package/server/graphql/types/create-navigation-item.js +18 -16
  181. package/server/graphql/types/create-navigation-related.d.ts +5 -0
  182. package/server/graphql/types/create-navigation-related.js +9 -7
  183. package/server/graphql/types/create-navigation.d.ts +5 -0
  184. package/server/graphql/types/create-navigation.js +8 -6
  185. package/server/graphql/types/index.d.ts +3 -0
  186. package/server/graphql/types/index.js +15 -13
  187. package/server/graphql/types/navigation-config.d.ts +5 -0
  188. package/server/graphql/types/navigation-config.js +10 -8
  189. package/server/graphql/types/navigation-details.d.ts +5 -0
  190. package/server/graphql/types/navigation-details.js +11 -9
  191. package/server/graphql/types/navigation-item-related-data.d.ts +5 -0
  192. package/server/graphql/types/navigation-item-related-data.js +9 -0
  193. package/server/graphql/types/navigation-item-related.d.ts +7 -0
  194. package/server/graphql/types/navigation-item-related.js +25 -0
  195. package/server/graphql/types/navigation-item.d.ts +5 -0
  196. package/server/graphql/types/navigation-item.js +28 -29
  197. package/server/graphql/types/navigation-render-type.d.ts +5 -0
  198. package/server/graphql/types/navigation-render-type.js +7 -4
  199. package/server/graphql/types/navigation.d.ts +5 -0
  200. package/server/graphql/types/navigation.js +10 -8
  201. package/server/i18n/constant.d.ts +2 -0
  202. package/server/i18n/constant.js +5 -0
  203. package/server/i18n/errors.d.ts +7 -0
  204. package/server/i18n/errors.js +14 -0
  205. package/server/i18n/graphQLEnhancers.d.ts +10 -0
  206. package/server/i18n/graphQLEnhancers.js +10 -0
  207. package/server/i18n/index.d.ts +8 -0
  208. package/server/i18n/index.js +23 -0
  209. package/server/i18n/navigationSetupStrategy.d.ts +3 -0
  210. package/server/i18n/navigationSetupStrategy.js +119 -0
  211. package/server/i18n/serviceEnhancers.d.ts +13 -0
  212. package/server/i18n/serviceEnhancers.js +156 -0
  213. package/server/i18n/types.d.ts +60 -0
  214. package/server/i18n/types.js +3 -0
  215. package/server/i18n/utils.d.ts +12 -0
  216. package/server/i18n/utils.js +29 -0
  217. package/server/index.d.ts +273 -0
  218. package/server/index.js +26 -0
  219. package/server/navigation/index.d.ts +2 -0
  220. package/server/navigation/index.js +18 -0
  221. package/server/navigation/setupStrategy.d.ts +3 -0
  222. package/server/navigation/setupStrategy.js +39 -0
  223. package/server/register/index.d.ts +3 -0
  224. package/server/register/index.js +4 -0
  225. package/server/routes/admin.d.ts +4 -0
  226. package/server/routes/admin.js +82 -61
  227. package/server/routes/client.d.ts +4 -0
  228. package/server/routes/client.js +25 -21
  229. package/server/routes/index.d.ts +6 -0
  230. package/server/routes/index.js +13 -4
  231. package/server/services/admin.d.ts +5 -0
  232. package/server/services/admin.js +238 -0
  233. package/server/services/client.d.ts +5 -0
  234. package/server/services/client.js +249 -0
  235. package/server/services/common.d.ts +5 -0
  236. package/server/services/common.js +313 -0
  237. package/server/services/index.d.ts +7 -0
  238. package/server/services/index.js +14 -6
  239. package/server/utils/constant.d.ts +27 -0
  240. package/server/utils/constant.js +24 -0
  241. package/server/utils/functions.d.ts +139 -0
  242. package/server/utils/functions.js +226 -0
  243. package/server/utils/index.d.ts +3 -0
  244. package/server/utils/index.js +19 -0
  245. package/strapi-admin.d.ts +3 -0
  246. package/strapi-admin.js +8 -1
  247. package/strapi-server.d.ts +273 -0
  248. package/strapi-server.js +6 -17
  249. package/tsconfig.tsbuildinfo +1 -0
  250. package/types/bootstrap.d.ts +13 -0
  251. package/types/bootstrap.js +3 -0
  252. package/types/config.d.ts +21 -0
  253. package/types/config.js +3 -0
  254. package/types/contentTypes.d.ts +85 -0
  255. package/types/contentTypes.js +3 -0
  256. package/types/controllers.d.ts +48 -0
  257. package/types/controllers.js +5 -0
  258. package/types/graphQL.d.ts +3 -0
  259. package/types/graphQL.js +3 -0
  260. package/types/i18n.d.ts +9 -0
  261. package/types/i18n.js +3 -0
  262. package/types/index.d.ts +9 -0
  263. package/types/index.js +25 -0
  264. package/types/services.d.ts +74 -0
  265. package/types/services.js +3 -0
  266. package/types/utils.d.ts +62 -0
  267. package/types/utils.js +27 -0
  268. package/utils/InvalidParamNavigationError.d.ts +4 -0
  269. package/utils/InvalidParamNavigationError.js +8 -0
  270. package/utils/NavigationError.d.ts +5 -0
  271. package/utils/NavigationError.js +7 -7
  272. package/__mocks__/pages.settings.json +0 -25
  273. package/__mocks__/strapi.js +0 -207
  274. package/jest.config.js +0 -14
  275. package/server/bootstrap.js +0 -52
  276. package/server/config.js +0 -9
  277. package/server/content-types/audience/lifecycle.js +0 -8
  278. package/server/content-types/audience/schema.json +0 -23
  279. package/server/content-types/navigation/schema.json +0 -45
  280. package/server/content-types/navigation-item/schema.json +0 -99
  281. package/server/content-types/navigations-items-related/schema.json +0 -47
  282. package/server/controllers/navigation.js +0 -105
  283. package/server/graphql/types/navigation-related.js +0 -25
  284. package/server/services/__tests__/functions.test.js +0 -48
  285. package/server/services/__tests__/navigation.test.js +0 -91
  286. package/server/services/navigation.js +0 -791
  287. package/server/services/utils/constant.js +0 -21
  288. package/server/services/utils/functions.js +0 -226
@@ -1,337 +1,244 @@
1
- import React, { useState } from 'react';
2
- import { Formik } from 'formik';
3
- import { isEmpty, capitalize, isEqual, orderBy } from 'lodash';
4
-
5
- import {
6
- CheckPermissions,
7
- LoadingIndicatorPage,
8
- Form,
9
- useOverlayBlocker,
10
- useAutoReloadOverlayBlocker,
11
- SettingsPageTitle,
12
- } from '@strapi/helper-plugin';
13
- import { Main } from '@strapi/design-system/Main';
14
- import { ContentLayout, HeaderLayout } from '@strapi/design-system/Layout';
15
- import { Accordion, AccordionToggle, AccordionContent, AccordionGroup } from '@strapi/design-system/Accordion';
16
- import { Button } from '@strapi/design-system/Button';
17
- import { Box } from '@strapi/design-system/Box';
18
- import { Stack } from '@strapi/design-system/Stack';
19
- import { Typography } from '@strapi/design-system/Typography';
20
- import { Grid, GridItem } from '@strapi/design-system/Grid';
21
- import { ToggleInput } from '@strapi/design-system/ToggleInput';
22
- import { NumberInput } from '@strapi/design-system/NumberInput';
23
- import { Select, Option } from '@strapi/design-system/Select';
24
- import { Tooltip } from '@strapi/design-system/Tooltip';
25
- import { Check, Refresh, Play, Information, ExclamationMarkCircle } from '@strapi/icons';
26
-
27
- import permissions from '../../permissions';
28
- import useNavigationConfig from '../../hooks/useNavigationConfig';
29
- import useAllContentTypes from '../../hooks/useAllContentTypes';
30
- import { navigationItemAdditionalFields } from '../View/utils/enums';
31
- import ConfirmationDialog from '../../components/ConfirmationDialog';
32
- import RestartAlert from '../../components/RestartAlert';
33
- import { getMessage } from '../../utils';
34
- import { isContentTypeEligible, resolveGlobalLikeId } from './utils/functions';
35
- import { PermanentAlert } from '../../components/Alert/styles';
36
-
37
- const SettingsPage = () => {
38
- const { lockApp, unlockApp } = useOverlayBlocker();
39
- const { lockAppWithAutoreload, unlockAppWithAutoreload } = useAutoReloadOverlayBlocker();
40
- const [isRestorePopupOpen, setIsRestorePopupOpen] = useState(false);
41
- const [isRestartRequired, setIsRestartRequired] = useState(false);
42
- const [contentTypeExpanded, setContentTypeExpanded] = useState(undefined);
43
- const { data: navigationConfigData, isLoading: isConfigLoading, err: configErr, submitMutation, restoreMutation, restartMutation } = useNavigationConfig();
44
- const { data: allContentTypesData, isLoading: isContentTypesLoading, err: contentTypesErr } = useAllContentTypes();
45
- const isLoading = isConfigLoading || isContentTypesLoading;
46
- const isError = configErr || contentTypesErr;
47
- const boxDefaultProps = {
48
- background: "neutral0",
49
- hasRadius: true,
50
- shadow: "filterShadow",
51
- padding: 6,
52
- };
53
-
54
- const preparePayload = ({ selectedContentTypes, nameFields, audienceFieldChecked, allowedLevels, populate }) => ({
55
- contentTypes: selectedContentTypes,
56
- contentTypesNameFields: nameFields,
57
- contentTypesPopulate: populate,
58
- additionalFields: audienceFieldChecked ? [navigationItemAdditionalFields.AUDIENCE] : [],
59
- allowedLevels: allowedLevels,
60
- gql: {
61
- navigationItemRelated: selectedContentTypes.map(uid => resolveGlobalLikeId(uid)),
62
- }
63
- });
64
-
65
- const onSave = async (form) => {
66
- lockApp();
67
- const payload = preparePayload(form);
68
- await submitMutation({ body: payload });
69
- const isContentTypesChanged = !isEqual(payload.contentTypes, navigationConfigData.contentTypes);
70
- if (isContentTypesChanged && navigationConfigData.isGQLPluginEnabled) {
71
- setIsRestartRequired(true);
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
72
7
  }
73
- unlockApp();
74
- }
75
-
76
- const onPopupClose = async (isConfirmed) => {
77
- setIsRestorePopupOpen(false);
78
- if (isConfirmed) {
79
- lockApp();
80
- await restoreMutation();
81
- unlockApp();
82
- setIsRestartRequired(true);
83
- }
84
- }
85
-
86
- const handleRestart = async () => {
87
- lockAppWithAutoreload();
88
- await restartMutation();
89
- setIsRestartRequired(false);
90
- unlockAppWithAutoreload();
91
- };
92
- const handleRestartDiscard = () => setIsRestartRequired(false);
93
- const handleSetContentTypeExpanded = key => setContentTypeExpanded(key === contentTypeExpanded ? undefined : key);
94
-
95
- const prepareNameFieldFor = (uid, current, value) => ({
96
- ...current,
97
- [uid]: value && !isEmpty(value) ? [...value] : undefined,
98
- });
99
-
100
- if (isLoading || isError) {
101
- return (
102
- <>
103
- <SettingsPageTitle
104
- name={getMessage('Settings.email.plugin.title', 'Configuration')}
105
- />
106
- <LoadingIndicatorPage>
107
- Fetching plugin config...
108
- </LoadingIndicatorPage>
109
- </>
110
- )
111
- }
112
-
113
- const configContentTypes = navigationConfigData?.contentTypes || [];
114
-
115
- const allContentTypes = !isLoading && Object.values(allContentTypesData).filter(({ uid }) => isContentTypeEligible(uid, {
116
- allowedContentTypes: navigationConfigData?.allowedContentTypes,
117
- restrictedContentTypes: navigationConfigData?.restrictedContentTypes,
118
- })).map(ct => {
119
- const type = configContentTypes.find(_ => _.uid === ct.uid);
120
- if (type) {
121
- const { available, isSingle } = type;
122
- return {
123
- ...ct,
124
- available,
125
- isSingle,
126
- };
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ const react_1 = __importStar(require("react"));
30
+ const formik_1 = require("formik");
31
+ const lodash_1 = require("lodash");
32
+ const helper_plugin_1 = require("@strapi/helper-plugin");
33
+ const Main_1 = require("@strapi/design-system/Main");
34
+ const Layout_1 = require("@strapi/design-system/Layout");
35
+ const Accordion_1 = require("@strapi/design-system/Accordion");
36
+ const Button_1 = require("@strapi/design-system/Button");
37
+ const Box_1 = require("@strapi/design-system/Box");
38
+ const Stack_1 = require("@strapi/design-system/Stack");
39
+ const Typography_1 = require("@strapi/design-system/Typography");
40
+ const Grid_1 = require("@strapi/design-system/Grid");
41
+ const ToggleInput_1 = require("@strapi/design-system/ToggleInput");
42
+ const NumberInput_1 = require("@strapi/design-system/NumberInput");
43
+ const Select_1 = require("@strapi/design-system/Select");
44
+ const Tooltip_1 = require("@strapi/design-system/Tooltip");
45
+ const icons_1 = require("@strapi/icons");
46
+ const permissions_1 = __importDefault(require("../../permissions"));
47
+ const useNavigationConfig_1 = __importDefault(require("../../hooks/useNavigationConfig"));
48
+ const useAllContentTypes_1 = __importDefault(require("../../hooks/useAllContentTypes"));
49
+ const enums_1 = require("../View/utils/enums");
50
+ const ConfirmationDialog_1 = __importDefault(require("../../components/ConfirmationDialog"));
51
+ const RestartAlert_1 = __importDefault(require("../../components/RestartAlert"));
52
+ const utils_1 = require("../../utils");
53
+ const functions_1 = require("./utils/functions");
54
+ const styles_1 = require("../../components/Alert/styles");
55
+ const DisableI18nModal_1 = require("./components/DisableI18nModal");
56
+ const RESTART_NOT_REQUIRED = { required: false };
57
+ const RESTART_REQUIRED = { required: true, reasons: [] };
58
+ const SettingsPage = () => {
59
+ const { lockApp, unlockApp } = (0, helper_plugin_1.useOverlayBlocker)();
60
+ const { lockAppWithAutoreload, unlockAppWithAutoreload } = (0, helper_plugin_1.useAutoReloadOverlayBlocker)();
61
+ const [isRestorePopupOpen, setIsRestorePopupOpen] = (0, react_1.useState)(false);
62
+ const [restartStatus, setRestartStatus] = (0, react_1.useState)(RESTART_NOT_REQUIRED);
63
+ const [contentTypeExpanded, setContentTypeExpanded] = (0, react_1.useState)(undefined);
64
+ const [pruneObsoleteI18nNavigations, setPruneObsoleteI18nNavigations] = (0, react_1.useState)(false);
65
+ const { disableI18nModal, setDisableI18nModalOpened, setI18nModalOnCancel, } = (0, DisableI18nModal_1.useDisableI18nModal)(({ pruneNavigations }) => {
66
+ setPruneObsoleteI18nNavigations(pruneNavigations);
67
+ });
68
+ const { data: navigationConfigData, isLoading: isConfigLoading, err: configErr, submitMutation, restoreMutation, restartMutation } = (0, useNavigationConfig_1.default)();
69
+ const { data: allContentTypesData, isLoading: isContentTypesLoading, err: contentTypesErr } = (0, useAllContentTypes_1.default)();
70
+ const isLoading = isConfigLoading || isContentTypesLoading;
71
+ const isError = configErr || contentTypesErr;
72
+ const boxDefaultProps = {
73
+ background: "neutral0",
74
+ hasRadius: true,
75
+ shadow: "filterShadow",
76
+ padding: 6,
77
+ };
78
+ const preparePayload = ({ form: { selectedContentTypes, nameFields, audienceFieldChecked, allowedLevels, i18nEnabled }, pruneObsoleteI18nNavigations }) => ({
79
+ i18nEnabled,
80
+ allowedLevels,
81
+ pruneObsoleteI18nNavigations,
82
+ contentTypes: selectedContentTypes,
83
+ contentTypesNameFields: nameFields,
84
+ contentTypesPopulate: populate,
85
+ additionalFields: audienceFieldChecked ? [enums_1.navigationItemAdditionalFields.AUDIENCE] : [],
86
+ gql: {
87
+ navigationItemRelated: selectedContentTypes.map(uid => (0, functions_1.resolveGlobalLikeId)(uid)),
88
+ }
89
+ });
90
+ const onSave = async (form) => {
91
+ lockApp();
92
+ const payload = preparePayload({ form, pruneObsoleteI18nNavigations });
93
+ await submitMutation({ body: payload });
94
+ const isContentTypesChanged = !(0, lodash_1.isEqual)(payload.contentTypes, navigationConfigData.contentTypes);
95
+ const isI18nChanged = !(0, lodash_1.isEqual)(payload.i18nEnabled, navigationConfigData.i18nEnabled);
96
+ const restartReasons = [];
97
+ if (isI18nChanged) {
98
+ restartReasons.push('I18N');
99
+ }
100
+ if (isContentTypesChanged && navigationConfigData.isGQLPluginEnabled) {
101
+ restartReasons.push('GRAPH_QL');
102
+ }
103
+ if (pruneObsoleteI18nNavigations) {
104
+ restartReasons.push('I18N_NAVIGATIONS_PRUNE');
105
+ }
106
+ if (restartReasons.length) {
107
+ setRestartStatus({
108
+ ...RESTART_REQUIRED,
109
+ reasons: restartReasons,
110
+ });
111
+ }
112
+ setDisableI18nModalOpened(false);
113
+ setPruneObsoleteI18nNavigations(false);
114
+ unlockApp();
115
+ };
116
+ const onPopupClose = async (isConfirmed) => {
117
+ setIsRestorePopupOpen(false);
118
+ if (isConfirmed) {
119
+ lockApp();
120
+ await restoreMutation();
121
+ unlockApp();
122
+ setRestartStatus(RESTART_REQUIRED);
123
+ }
124
+ };
125
+ const handleRestart = async () => {
126
+ lockAppWithAutoreload();
127
+ await restartMutation();
128
+ setRestartStatus(RESTART_NOT_REQUIRED);
129
+ unlockAppWithAutoreload();
130
+ };
131
+ const handleRestartDiscard = () => setRestartStatus(RESTART_NOT_REQUIRED);
132
+ const handleSetContentTypeExpanded = key => setContentTypeExpanded(key === contentTypeExpanded ? undefined : key);
133
+ const prepareNameFieldFor = (uid, current, value) => ({
134
+ ...current,
135
+ [uid]: value && !(0, lodash_1.isEmpty)(value) ? [...value] : undefined,
136
+ });
137
+ if (isLoading || isError) {
138
+ return (react_1.default.createElement(react_1.default.Fragment, null,
139
+ react_1.default.createElement(helper_plugin_1.SettingsPageTitle, { name: (0, utils_1.getMessage)('Settings.email.plugin.title', 'Configuration') }),
140
+ react_1.default.createElement(helper_plugin_1.LoadingIndicatorPage, null, "Fetching plugin config...")));
127
141
  }
128
- return ct;
129
- });
130
- const selectedContentTypes = configContentTypes.map(item => item.uid);
131
- const audienceFieldChecked = navigationConfigData?.additionalFields.includes(navigationItemAdditionalFields.AUDIENCE);
132
- const allowedLevels = navigationConfigData?.allowedLevels || 2;
133
- const nameFields = navigationConfigData?.contentTypesNameFields || {}
134
- const populate = navigationConfigData?.contentTypesPopulate || {}
135
-
136
- return (
137
- <>
138
- <SettingsPageTitle
139
- name={getMessage('Settings.email.plugin.title', 'Configuration')}
140
- />
141
- <Main labelledBy="title">
142
- <Formik
143
- initialValues={{
144
- selectedContentTypes,
145
- audienceFieldChecked,
146
- allowedLevels,
147
- nameFields,
148
- populate,
149
- }}
150
- onSubmit={onSave}
151
- >
152
- {({ handleSubmit, setFieldValue, values }) => (
153
- <Form noValidate onSubmit={handleSubmit}>
154
- <HeaderLayout
155
- title={getMessage('pages.settings.header.title')}
156
- subtitle={getMessage('pages.settings.header.description')}
157
- primaryAction={
158
- <CheckPermissions permissions={permissions.access}>
159
- <Button type="submit" startIcon={<Check />} disabled={isRestartRequired}>
160
- {getMessage('pages.settings.actions.submit')}
161
- </Button>
162
- </CheckPermissions>
163
- }
164
- />
165
- <ContentLayout>
166
- <Stack spacing={7}>
167
- {isRestartRequired && (
168
- <RestartAlert
169
- closeLabel={getMessage('pages.settings.actions.restart.alert.cancel')}
170
- title={getMessage('pages.settings.actions.restart.alert.title')}
171
- action={<Box><Button onClick={handleRestart} startIcon={<Play />}>{getMessage('pages.settings.actions.restart')}</Button></Box>}
172
- onClose={handleRestartDiscard}>
173
- {getMessage('pages.settings.actions.restart.alert.description')}
174
- </RestartAlert>)}
175
- <Box {...boxDefaultProps} >
176
- <Stack spacing={4}>
177
- <Typography variant="delta" as="h2">
178
- {getMessage('pages.settings.general.title')}
179
- </Typography>
180
- <Grid gap={4}>
181
- <GridItem col={12} s={12} xs={12}>
182
- <Select
183
- name="selectedContentTypes"
184
- label={getMessage('pages.settings.form.contentTypes.label')}
185
- placeholder={getMessage('pages.settings.form.contentTypes.placeholder')}
186
- hint={getMessage('pages.settings.form.contentTypes.hint')}
187
- onClear={() => setFieldValue('selectedContentTypes', [], false)}
188
- value={values.selectedContentTypes}
189
- onChange={(value) => setFieldValue('selectedContentTypes', value, false)}
190
- multi
191
- withTags
192
- disabled={isRestartRequired}
193
- >
194
- {allContentTypes.map((item) => <Option key={item.uid} value={item.uid}>{item.info.displayName}</Option>)}
195
- </Select>
196
- </GridItem>
197
- {!isEmpty(values.selectedContentTypes) && (
198
- <GridItem col={12}>
199
- <AccordionGroup
200
- label={getMessage('pages.settings.form.contentTypesSettings.label')}
201
- labelAction={<Tooltip description={getMessage('pages.settings.form.contentTypesSettings.tooltip')}>
202
- <Information aria-hidden={true} />
203
- </Tooltip>}>
204
- {orderBy(values.selectedContentTypes).map(uid => {
205
- const { attributes, info: { displayName }, available, isSingle } = allContentTypes.find(item => item.uid == uid);
206
- const stringAttributes = Object.keys(attributes).filter(_ => attributes[_].type === 'string');
207
- const relationAttributes = Object.keys(attributes).filter(_ => attributes[_].type === 'relation');
208
- const key = `collectionSettings-${uid}`;
209
- return (<Accordion
210
- expanded={contentTypeExpanded === key}
211
- toggle={() => handleSetContentTypeExpanded(key)}
212
- key={key}
213
- id={key}
214
- size="S">
215
- <AccordionToggle title={displayName} togglePosition="left" startIcon={(isSingle && !available) && (<ExclamationMarkCircle aria-hidden={true} />)} />
216
- <AccordionContent>
217
- <Box padding={6}>
218
- <Stack spacing={4}>
219
- { (isSingle && !available) && (
220
- <PermanentAlert title={getMessage('pages.settings.form.contentTypesSettings.initializationWarning.title')} variant="danger" onClose={(e) => e.preventDefault()}>
221
- { getMessage('pages.settings.form.contentTypesSettings.initializationWarning.content') }
222
- </PermanentAlert>)}
223
- <Select
224
- name={`collectionSettings-${uid}-entryLabel`}
225
- label={getMessage('pages.settings.form.nameField.label')}
226
- hint={getMessage(`pages.settings.form.populate.${isEmpty(stringAttributes) ? 'empty' : 'hint'}`)}
227
- placeholder={getMessage('pages.settings.form.nameField.placeholder')}
228
- onClear={() => null}
229
- value={values.nameFields[uid] || []}
230
- onChange={(value) => setFieldValue('nameFields', prepareNameFieldFor(uid, values.nameFields, value))}
231
- multi
232
- withTags
233
- disabled={isRestartRequired || isEmpty(stringAttributes)}
234
- >
235
- {stringAttributes.map(key =>
236
- (<Option key={uid + key} value={key}>{capitalize(key.split('_').join(' '))}</Option>))}
237
- </Select>
238
- <Select
239
- name={`collectionSettings-${uid}-populate`}
240
- label={getMessage('pages.settings.form.populate.label')}
241
- hint={getMessage(`pages.settings.form.populate.${isEmpty(relationAttributes) ? 'empty' : 'hint'}`)}
242
- placeholder={getMessage('pages.settings.form.populate.placeholder')}
243
- onClear={() => null}
244
- value={values.populate[uid] || []}
245
- onChange={(value) => setFieldValue('populate', prepareNameFieldFor(uid, values.populate, value))}
246
- multi
247
- withTags
248
- disabled={isRestartRequired || isEmpty(relationAttributes)}
249
- >
250
- {relationAttributes.map(key =>
251
- (<Option key={uid + key} value={key}>{capitalize(key.split('_').join(' '))}</Option>))}
252
- </Select>
253
- </Stack>
254
- </Box>
255
-
256
- </AccordionContent>
257
- </Accordion>);
258
- })}
259
- </AccordionGroup>
260
- </GridItem>)}
261
- </Grid>
262
- </Stack>
263
- </Box>
264
- <Box {...boxDefaultProps} >
265
- <Stack spacing={4}>
266
- <Typography variant="delta" as="h2">
267
- {getMessage('pages.settings.additional.title')}
268
- </Typography>
269
- <Grid gap={4}>
270
- <GridItem col={3} s={6} xs={12}>
271
- <NumberInput
272
- name="allowedLevels"
273
- label={getMessage('pages.settings.form.allowedLevels.label')}
274
- placeholder={getMessage('pages.settings.form.allowedLevels.placeholder')}
275
- hint={getMessage('pages.settings.form.allowedLevels.hint')}
276
- onValueChange={(value) => setFieldValue('allowedLevels', value, false)}
277
- value={values.allowedLevels}
278
- disabled={isRestartRequired}
279
- />
280
- </GridItem>
281
- <GridItem col={6} s={12} xs={12}>
282
- <ToggleInput
283
- name="audienceFieldChecked"
284
- label={getMessage('pages.settings.form.audience.label')}
285
- hint={getMessage('pages.settings.form.audience.hint')}
286
- checked={values.audienceFieldChecked}
287
- onChange={({ target: { checked } }) => setFieldValue('audienceFieldChecked', checked, false)}
288
- onLabel="Enabled"
289
- offLabel="Disabled"
290
- disabled={isRestartRequired}
291
- />
292
- </GridItem>
293
- </Grid>
294
- </Stack>
295
- </Box>
296
- <Box {...boxDefaultProps} >
297
- <Stack spacing={4}>
298
- <Typography variant="delta" as="h2">
299
- {getMessage('pages.settings.restoring.title')}
300
- </Typography>
301
- <Grid gap={4}>
302
- <GridItem col={12} s={12} xs={12}>
303
- <Typography>
304
- {getMessage('pages.settings.actions.restore.description')}
305
- </Typography>
306
- </GridItem>
307
- <GridItem col={6} s={12} xs={12}>
308
- <CheckPermissions permissions={permissions.access}>
309
- <Button variant="danger-light" startIcon={<Refresh />} onClick={() => setIsRestorePopupOpen(true)}>
310
- {getMessage('pages.settings.actions.restore')}
311
- </Button>
312
- </CheckPermissions>
313
- <ConfirmationDialog
314
- isVisible={isRestorePopupOpen}
315
- header={getMessage('pages.settings.actions.restore.confirmation.header')}
316
- labelConfirm={getMessage('pages.settings.actions.restore.confirmation.confirm')}
317
- iconConfirm={<Refresh />}
318
- onConfirm={() => onPopupClose(true)}
319
- onCancel={() => onPopupClose(false)}>
320
- {getMessage('pages.settings.actions.restore.confirmation.description')}
321
- </ConfirmationDialog>
322
- </GridItem>
323
- </Grid>
324
- </Stack>
325
- </Box>
326
- </Stack>
327
- </ContentLayout>
328
- </Form>
329
- )}
330
- </Formik>
331
- </Main>
332
- </>
333
- );
334
- }
335
-
336
-
337
- export default SettingsPage;
142
+ const configContentTypes = navigationConfigData?.contentTypes || [];
143
+ const allContentTypes = !isLoading && Object.values(allContentTypesData).filter(({ uid }) => (0, functions_1.isContentTypeEligible)(uid, {
144
+ allowedContentTypes: navigationConfigData?.allowedContentTypes,
145
+ restrictedContentTypes: navigationConfigData?.restrictedContentTypes,
146
+ })).map(ct => {
147
+ const type = configContentTypes.find(_ => _.uid === ct.uid);
148
+ if (type) {
149
+ const { available, isSingle } = type;
150
+ return {
151
+ ...ct,
152
+ available,
153
+ isSingle,
154
+ };
155
+ }
156
+ return ct;
157
+ });
158
+ const selectedContentTypes = configContentTypes.map(item => item.uid);
159
+ const audienceFieldChecked = navigationConfigData?.additionalFields.includes(enums_1.navigationItemAdditionalFields.AUDIENCE);
160
+ const allowedLevels = navigationConfigData?.allowedLevels || 2;
161
+ const nameFields = navigationConfigData?.contentTypesNameFields || {};
162
+ const populate = navigationConfigData?.contentTypesPopulate || {};
163
+ const i18nEnabled = navigationConfigData?.i18nEnabled ?? false;
164
+ const isI18NPluginEnabled = navigationConfigData?.isI18NPluginEnabled;
165
+ const defaultLocale = navigationConfigData?.defaultLocale;
166
+ return (react_1.default.createElement(react_1.default.Fragment, null,
167
+ react_1.default.createElement(helper_plugin_1.SettingsPageTitle, { name: (0, utils_1.getMessage)('Settings.email.plugin.title', 'Configuration') }),
168
+ react_1.default.createElement(Main_1.Main, { labelledBy: "title" },
169
+ react_1.default.createElement(formik_1.Formik, { initialValues: {
170
+ selectedContentTypes,
171
+ audienceFieldChecked,
172
+ allowedLevels,
173
+ nameFields,
174
+ populate,
175
+ i18nEnabled,
176
+ }, onSubmit: onSave }, ({ handleSubmit, setFieldValue, values }) => (react_1.default.createElement(helper_plugin_1.Form, { noValidate: true, onSubmit: handleSubmit },
177
+ react_1.default.createElement(Layout_1.HeaderLayout, { title: (0, utils_1.getMessage)('pages.settings.header.title'), subtitle: (0, utils_1.getMessage)('pages.settings.header.description'), primaryAction: react_1.default.createElement(helper_plugin_1.CheckPermissions, { permissions: permissions_1.default.access },
178
+ react_1.default.createElement(Button_1.Button, { type: "submit", startIcon: react_1.default.createElement(icons_1.Check, null), disabled: restartStatus.required }, (0, utils_1.getMessage)('pages.settings.actions.submit'))) }),
179
+ react_1.default.createElement(Layout_1.ContentLayout, null,
180
+ react_1.default.createElement(Stack_1.Stack, { spacing: 7 },
181
+ restartStatus.required && (react_1.default.createElement(RestartAlert_1.default, { closeLabel: (0, utils_1.getMessage)('pages.settings.actions.restart.alert.cancel'), title: (0, utils_1.getMessage)('pages.settings.actions.restart.alert.title'), action: react_1.default.createElement(Box_1.Box, null,
182
+ react_1.default.createElement(Button_1.Button, { onClick: handleRestart, startIcon: react_1.default.createElement(icons_1.Play, null) }, (0, utils_1.getMessage)('pages.settings.actions.restart'))), onClose: handleRestartDiscard },
183
+ react_1.default.createElement(react_1.default.Fragment, null,
184
+ react_1.default.createElement(Box_1.Box, { paddingBottom: 1 }, (0, utils_1.getMessage)('pages.settings.actions.restart.alert.description')),
185
+ restartStatus.reasons.map((reason, i) => react_1.default.createElement(Box_1.Box, { paddingBottom: 1, key: i, children: (0, utils_1.getMessage)(`pages.settings.actions.restart.alert.reason.${reason}`) }))))),
186
+ react_1.default.createElement(Box_1.Box, { ...boxDefaultProps },
187
+ react_1.default.createElement(Stack_1.Stack, { size: 4 },
188
+ react_1.default.createElement(Typography_1.Typography, { variant: "delta", as: "h2" }, (0, utils_1.getMessage)('pages.settings.general.title')),
189
+ react_1.default.createElement(Grid_1.Grid, { gap: 4 },
190
+ react_1.default.createElement(Grid_1.GridItem, { col: 12, s: 12, xs: 12 },
191
+ react_1.default.createElement(Select_1.Select, { name: "selectedContentTypes", label: (0, utils_1.getMessage)('pages.settings.form.contentTypes.label'), placeholder: (0, utils_1.getMessage)('pages.settings.form.contentTypes.placeholder'), hint: (0, utils_1.getMessage)('pages.settings.form.contentTypes.hint'), onClear: () => setFieldValue('selectedContentTypes', [], false), value: values.selectedContentTypes, onChange: (value) => setFieldValue('selectedContentTypes', value, false), multi: true, withTags: true, disabled: restartStatus.required }, allContentTypes.map((item) => react_1.default.createElement(Select_1.Option, { key: item.uid, value: item.uid }, item.info.displayName)))),
192
+ !(0, lodash_1.isEmpty)(values.selectedContentTypes) && (react_1.default.createElement(Grid_1.GridItem, { col: 12 },
193
+ react_1.default.createElement(Accordion_1.AccordionGroup, { label: (0, utils_1.getMessage)('pages.settings.form.contentTypesSettings.label'), labelAction: react_1.default.createElement(Tooltip_1.Tooltip, { description: (0, utils_1.getMessage)('pages.settings.form.contentTypesSettings.tooltip') },
194
+ react_1.default.createElement(icons_1.Information, { "aria-hidden": true })) }, (0, lodash_1.orderBy)(values.selectedContentTypes).map(uid => {
195
+ const { attributes, info: { displayName }, available, isSingle } = allContentTypes.find(item => item.uid == uid);
196
+ const stringAttributes = Object.keys(attributes).filter(_ => attributes[_].type === 'string');
197
+ const relationAttributes = Object.keys(attributes).filter(_ => attributes[_].type === 'relation');
198
+ const key = `collectionSettings-${uid}`;
199
+ return (react_1.default.createElement(Accordion_1.Accordion, { expanded: contentTypeExpanded === key, toggle: () => handleSetContentTypeExpanded(key), key: key, id: key, size: "S" },
200
+ react_1.default.createElement(Accordion_1.AccordionToggle, { title: displayName, togglePosition: "left", startIcon: (isSingle && !available) && (react_1.default.createElement(icons_1.ExclamationMarkCircle, { "aria-hidden": true })) }),
201
+ react_1.default.createElement(Accordion_1.AccordionContent, null,
202
+ react_1.default.createElement(Box_1.Box, { padding: 6 },
203
+ react_1.default.createElement(Stack_1.Stack, { size: 4 },
204
+ (isSingle && !available) && (react_1.default.createElement(styles_1.PermanentAlert, { title: (0, utils_1.getMessage)('pages.settings.form.contentTypesSettings.initializationWarning.title'), variant: "danger", onClose: (e) => e.preventDefault() }, (0, utils_1.getMessage)('pages.settings.form.contentTypesSettings.initializationWarning.content'))),
205
+ react_1.default.createElement(Select_1.Select, { name: `collectionSettings-${uid}-entryLabel`, label: (0, utils_1.getMessage)('pages.settings.form.nameField.label'), hint: (0, utils_1.getMessage)(`pages.settings.form.populate.${(0, lodash_1.isEmpty)(stringAttributes) ? 'empty' : 'hint'}`), placeholder: (0, utils_1.getMessage)('pages.settings.form.nameField.placeholder'), onClear: () => null, value: values.nameFields[uid] || [], onChange: (value) => setFieldValue('nameFields', prepareNameFieldFor(uid, values.nameFields, value)), multi: true, withTags: true, disabled: restartStatus.required || (0, lodash_1.isEmpty)(stringAttributes) }, stringAttributes.map(key => (react_1.default.createElement(Select_1.Option, { key: uid + key, value: key }, (0, lodash_1.capitalize)(key.split('_').join(' ')))))),
206
+ react_1.default.createElement(Select_1.Select, { name: `collectionSettings-${uid}-populate`, label: (0, utils_1.getMessage)('pages.settings.form.populate.label'), hint: (0, utils_1.getMessage)(`pages.settings.form.populate.${(0, lodash_1.isEmpty)(relationAttributes) ? 'empty' : 'hint'}`), placeholder: (0, utils_1.getMessage)('pages.settings.form.populate.placeholder'), onClear: () => null, value: values.populate[uid] || [], onChange: (value) => setFieldValue('populate', prepareNameFieldFor(uid, values.populate, value)), multi: true, withTags: true, disabled: restartStatus.required || (0, lodash_1.isEmpty)(relationAttributes) }, relationAttributes.map(key => (react_1.default.createElement(Select_1.Option, { key: uid + key, value: key }, (0, lodash_1.capitalize)(key.split('_').join(' ')))))))))));
207
+ }))))))),
208
+ react_1.default.createElement(Box_1.Box, { ...boxDefaultProps },
209
+ react_1.default.createElement(Stack_1.Stack, { size: 4 },
210
+ react_1.default.createElement(Typography_1.Typography, { variant: "delta", as: "h2" }, (0, utils_1.getMessage)('pages.settings.additional.title')),
211
+ react_1.default.createElement(Grid_1.Grid, { gap: 4 },
212
+ react_1.default.createElement(Grid_1.GridItem, { col: 3, s: 6, xs: 12 },
213
+ react_1.default.createElement(NumberInput_1.NumberInput, { name: "allowedLevels", label: (0, utils_1.getMessage)('pages.settings.form.allowedLevels.label'), placeholder: (0, utils_1.getMessage)('pages.settings.form.allowedLevels.placeholder'), hint: (0, utils_1.getMessage)('pages.settings.form.allowedLevels.hint'), onValueChange: (value) => setFieldValue('allowedLevels', value, false), value: values.allowedLevels, disabled: restartStatus.required })),
214
+ react_1.default.createElement(Grid_1.GridItem, { col: 4, s: 12, xs: 12 },
215
+ react_1.default.createElement(ToggleInput_1.ToggleInput, { name: "audienceFieldChecked", label: (0, utils_1.getMessage)('pages.settings.form.audience.label'), hint: (0, utils_1.getMessage)('pages.settings.form.audience.hint'), checked: values.audienceFieldChecked, onChange: ({ target: { checked } }) => setFieldValue('audienceFieldChecked', checked, false), onLabel: "Enabled", offLabel: "Disabled", disabled: restartStatus.required })),
216
+ isI18NPluginEnabled && (react_1.default.createElement(Grid_1.GridItem, { col: 4, s: 12, xs: 12 },
217
+ react_1.default.createElement(ToggleInput_1.ToggleInput, { name: "i18nEnabled", label: (0, utils_1.getMessage)('pages.settings.form.i18n.label'), hint: defaultLocale
218
+ ? (0, utils_1.getMessage)('pages.settings.form.i18n.hint')
219
+ : (0, utils_1.getMessage)('pages.settings.form.i18n.hint.missingDefaultLocale'), checked: values.i18nEnabled, onChange: ({ target: { checked } }) => {
220
+ setFieldValue('i18nEnabled', checked, false);
221
+ if (checked) {
222
+ setPruneObsoleteI18nNavigations(false);
223
+ }
224
+ else {
225
+ setDisableI18nModalOpened(true);
226
+ setI18nModalOnCancel(() => () => {
227
+ setFieldValue('i18nEnabled', true);
228
+ });
229
+ }
230
+ }, onLabel: "Enabled", offLabel: "Disabled", disabled: restartStatus.required || !defaultLocale })))))),
231
+ react_1.default.createElement(Box_1.Box, { ...boxDefaultProps },
232
+ react_1.default.createElement(Stack_1.Stack, { size: 4 },
233
+ react_1.default.createElement(Typography_1.Typography, { variant: "delta", as: "h2" }, (0, utils_1.getMessage)('pages.settings.restoring.title')),
234
+ react_1.default.createElement(Grid_1.Grid, { gap: 4 },
235
+ react_1.default.createElement(Grid_1.GridItem, { col: 12, s: 12, xs: 12 },
236
+ react_1.default.createElement(Typography_1.Typography, null, (0, utils_1.getMessage)('pages.settings.actions.restore.description'))),
237
+ react_1.default.createElement(Grid_1.GridItem, { col: 6, s: 12, xs: 12 },
238
+ react_1.default.createElement(helper_plugin_1.CheckPermissions, { permissions: permissions_1.default.access },
239
+ react_1.default.createElement(Button_1.Button, { variant: "danger-light", startIcon: react_1.default.createElement(icons_1.Refresh, null), onClick: () => setIsRestorePopupOpen(true) }, (0, utils_1.getMessage)('pages.settings.actions.restore'))),
240
+ react_1.default.createElement(ConfirmationDialog_1.default, { isVisible: isRestorePopupOpen, header: (0, utils_1.getMessage)('pages.settings.actions.restore.confirmation.header'), labelConfirm: (0, utils_1.getMessage)('pages.settings.actions.restore.confirmation.confirm'), iconConfirm: react_1.default.createElement(icons_1.Refresh, null), onConfirm: () => onPopupClose(true), onCancel: () => onPopupClose(false) }, (0, utils_1.getMessage)('pages.settings.actions.restore.confirmation.description')),
241
+ disableI18nModal))))))))))));
242
+ };
243
+ exports.default = SettingsPage;
244
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,5 @@
1
+ export function resolveGlobalLikeId(uid?: string): any;
2
+ export function resolveGlobalLikeId(uid?: string): any;
3
+ export function isContentTypeEligible(uid?: string, config?: {}): boolean | "";
4
+ export function isContentTypeEligible(uid?: string, config?: {}): boolean | "";
5
+ //# sourceMappingURL=functions.d.ts.map