strapi-plugin-navigation 2.0.11 → 2.1.0-beta.1

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 (268) hide show
  1. package/README.md +254 -41
  2. package/admin/src/components/Alert/styles.d.ts +2 -0
  3. package/admin/src/components/Alert/styles.js +14 -0
  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 +34 -53
  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 +169 -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/useNavigationConfig.d.ts +10 -0
  39. package/admin/src/hooks/useNavigationConfig.js +52 -56
  40. package/admin/src/index.d.ts +14 -0
  41. package/admin/src/index.js +92 -76
  42. package/admin/src/pages/App/index.d.ts +3 -0
  43. package/admin/src/pages/App/index.js +43 -31
  44. package/admin/src/pages/DataManagerProvider/actions.d.ts +19 -0
  45. package/admin/src/pages/DataManagerProvider/actions.js +22 -26
  46. package/admin/src/pages/DataManagerProvider/index.d.ts +12 -0
  47. package/admin/src/pages/DataManagerProvider/index.js +280 -300
  48. package/admin/src/pages/DataManagerProvider/init.d.ts +3 -0
  49. package/admin/src/pages/DataManagerProvider/init.js +5 -3
  50. package/admin/src/pages/DataManagerProvider/reducer.d.ts +19 -0
  51. package/admin/src/pages/DataManagerProvider/reducer.js +119 -121
  52. package/admin/src/pages/SettingsPage/components/DisableI18nModal/index.d.ts +24 -0
  53. package/admin/src/pages/SettingsPage/components/DisableI18nModal/index.js +88 -0
  54. package/admin/src/pages/SettingsPage/index.d.ts +3 -0
  55. package/admin/src/pages/SettingsPage/index.js +242 -317
  56. package/admin/src/pages/SettingsPage/utils/functions.d.ts +5 -0
  57. package/admin/src/pages/SettingsPage/utils/functions.js +3 -8
  58. package/admin/src/pages/View/components/I18nCopyNavigationItems/index.d.ts +20 -0
  59. package/admin/src/pages/View/components/I18nCopyNavigationItems/index.js +60 -0
  60. package/admin/src/pages/View/components/NavigationContentHeader/index.d.ts +6 -0
  61. package/admin/src/pages/View/components/NavigationContentHeader/index.js +13 -17
  62. package/admin/src/pages/View/components/NavigationHeader/index.d.ts +12 -0
  63. package/admin/src/pages/View/components/NavigationHeader/index.js +74 -65
  64. package/admin/src/pages/View/components/NavigationHeader/styles.d.ts +2 -0
  65. package/admin/src/pages/View/components/NavigationHeader/styles.js +10 -5
  66. package/admin/src/pages/View/components/NavigationItemForm/index.d.ts +51 -0
  67. package/admin/src/pages/View/components/NavigationItemForm/index.js +322 -454
  68. package/admin/src/pages/View/components/NavigationItemForm/utils/form.d.ts +45 -0
  69. package/admin/src/pages/View/components/NavigationItemForm/utils/form.js +81 -52
  70. package/admin/src/pages/View/components/NavigationItemPopup/NavigationItemPopupFooter.d.ts +23 -0
  71. package/admin/src/pages/View/components/NavigationItemPopup/NavigationItemPopupFooter.js +24 -34
  72. package/admin/src/pages/View/components/NavigationItemPopup/NavigationItemPopupHeader.d.ts +4 -0
  73. package/admin/src/pages/View/components/NavigationItemPopup/NavigationItemPopupHeader.js +16 -16
  74. package/admin/src/pages/View/components/NavigationItemPopup/index.d.ts +27 -0
  75. package/admin/src/pages/View/components/NavigationItemPopup/index.js +59 -108
  76. package/admin/src/pages/View/index.d.ts +4 -0
  77. package/admin/src/pages/View/index.js +229 -304
  78. package/admin/src/pages/View/utils/enums.d.ts +9 -0
  79. package/admin/src/pages/View/utils/enums.js +11 -8
  80. package/admin/src/pages/View/utils/form.d.ts +2 -0
  81. package/admin/src/pages/View/utils/form.js +15 -12
  82. package/admin/src/pages/View/utils/index.d.ts +2 -0
  83. package/admin/src/pages/View/utils/index.js +11 -3
  84. package/admin/src/pages/View/utils/parsers.d.ts +44 -0
  85. package/admin/src/pages/View/utils/parsers.js +231 -277
  86. package/admin/src/permissions.d.ts +12 -0
  87. package/admin/src/permissions.js +11 -7
  88. package/admin/src/pluginId.d.ts +3 -0
  89. package/admin/src/pluginId.js +2 -2
  90. package/admin/src/translations/en.json +126 -102
  91. package/admin/src/translations/fr.json +44 -44
  92. package/admin/src/translations/index.d.ts +12 -0
  93. package/admin/src/translations/index.js +17 -11
  94. package/admin/src/utils/api.d.ts +8 -0
  95. package/admin/src/utils/api.js +54 -50
  96. package/admin/src/utils/getTrad.d.ts +3 -0
  97. package/admin/src/utils/getTrad.js +9 -5
  98. package/admin/src/utils/index.d.ts +5 -0
  99. package/admin/src/utils/index.js +21 -15
  100. package/package.json +19 -17
  101. package/permissions.d.ts +9 -0
  102. package/permissions.js +5 -4
  103. package/server/bootstrap/index.d.ts +4 -0
  104. package/server/bootstrap/index.js +41 -0
  105. package/server/config/index.d.ts +5 -0
  106. package/server/config/index.js +33 -9
  107. package/server/config/setupStrategy.d.ts +3 -0
  108. package/server/config/setupStrategy.js +38 -0
  109. package/server/content-types/audience/index.d.ts +27 -0
  110. package/server/content-types/audience/index.js +9 -8
  111. package/server/content-types/audience/schema.d.ts +25 -0
  112. package/server/content-types/audience/schema.js +26 -0
  113. package/server/content-types/index.d.ts +255 -0
  114. package/server/content-types/index.js +15 -12
  115. package/server/content-types/navigation/index.d.ts +64 -0
  116. package/server/content-types/navigation/index.js +11 -8
  117. package/server/content-types/navigation/lifecycle.d.ts +9 -0
  118. package/server/content-types/navigation/lifecycle.js +8 -12
  119. package/server/content-types/navigation/schema.d.ts +55 -0
  120. package/server/content-types/navigation/schema.js +56 -0
  121. package/server/content-types/navigation-item/index.d.ts +112 -0
  122. package/server/content-types/navigation-item/index.js +11 -8
  123. package/server/content-types/navigation-item/lifecycle.d.ts +16 -0
  124. package/server/content-types/navigation-item/lifecycle.js +28 -32
  125. package/server/content-types/navigation-item/schema.d.ts +97 -0
  126. package/server/content-types/navigation-item/schema.js +102 -0
  127. package/server/content-types/navigations-items-related/index.d.ts +56 -0
  128. package/server/content-types/navigations-items-related/index.js +11 -8
  129. package/server/content-types/navigations-items-related/lifecycle.d.ts +8 -0
  130. package/server/content-types/navigations-items-related/lifecycle.js +20 -17
  131. package/server/content-types/navigations-items-related/schema.d.ts +49 -0
  132. package/server/content-types/navigations-items-related/schema.js +50 -0
  133. package/server/controllers/admin.d.ts +4 -0
  134. package/server/controllers/admin.js +77 -0
  135. package/server/controllers/client.d.ts +4 -0
  136. package/server/controllers/client.js +34 -0
  137. package/server/controllers/index.d.ts +4 -0
  138. package/server/controllers/index.js +12 -6
  139. package/server/destroy.d.ts +3 -0
  140. package/server/destroy.js +5 -0
  141. package/server/graphql/config.d.ts +4 -0
  142. package/server/graphql/config.js +28 -0
  143. package/server/graphql/index.d.ts +2 -0
  144. package/server/graphql/index.js +18 -22
  145. package/server/graphql/queries/index.d.ts +3 -0
  146. package/server/graphql/queries/index.js +15 -15
  147. package/server/graphql/queries/render-navigation-child.d.ts +15 -0
  148. package/server/graphql/queries/render-navigation-child.js +24 -15
  149. package/server/graphql/queries/render-navigation.d.ts +23 -0
  150. package/server/graphql/queries/render-navigation.js +29 -15
  151. package/server/graphql/resolvers-config.d.ts +10 -0
  152. package/server/graphql/resolvers-config.js +5 -3
  153. package/server/graphql/setupStrategy.d.ts +3 -0
  154. package/server/graphql/setupStrategy.js +15 -0
  155. package/server/graphql/types/content-types-name-fields.d.ts +6 -0
  156. package/server/graphql/types/content-types-name-fields.js +13 -9
  157. package/server/graphql/types/content-types.d.ts +5 -0
  158. package/server/graphql/types/content-types.js +17 -15
  159. package/server/graphql/types/create-navigation-item.d.ts +5 -0
  160. package/server/graphql/types/create-navigation-item.js +18 -16
  161. package/server/graphql/types/create-navigation-related.d.ts +5 -0
  162. package/server/graphql/types/create-navigation-related.js +9 -7
  163. package/server/graphql/types/create-navigation.d.ts +5 -0
  164. package/server/graphql/types/create-navigation.js +8 -6
  165. package/server/graphql/types/index.d.ts +3 -0
  166. package/server/graphql/types/index.js +15 -13
  167. package/server/graphql/types/navigation-config.d.ts +5 -0
  168. package/server/graphql/types/navigation-config.js +10 -8
  169. package/server/graphql/types/navigation-details.d.ts +5 -0
  170. package/server/graphql/types/navigation-details.js +11 -9
  171. package/server/graphql/types/navigation-item-related-data.d.ts +5 -0
  172. package/server/graphql/types/navigation-item-related-data.js +9 -0
  173. package/server/graphql/types/navigation-item-related.d.ts +7 -0
  174. package/server/graphql/types/navigation-item-related.js +25 -0
  175. package/server/graphql/types/navigation-item.d.ts +5 -0
  176. package/server/graphql/types/navigation-item.js +28 -29
  177. package/server/graphql/types/navigation-render-type.d.ts +5 -0
  178. package/server/graphql/types/navigation-render-type.js +7 -4
  179. package/server/graphql/types/navigation.d.ts +5 -0
  180. package/server/graphql/types/navigation.js +10 -8
  181. package/server/i18n/constant.d.ts +2 -0
  182. package/server/i18n/constant.js +5 -0
  183. package/server/i18n/errors.d.ts +7 -0
  184. package/server/i18n/errors.js +14 -0
  185. package/server/i18n/graphQLEnhancers.d.ts +10 -0
  186. package/server/i18n/graphQLEnhancers.js +9 -0
  187. package/server/i18n/index.d.ts +8 -0
  188. package/server/i18n/index.js +23 -0
  189. package/server/i18n/navigationSetupStrategy.d.ts +3 -0
  190. package/server/i18n/navigationSetupStrategy.js +119 -0
  191. package/server/i18n/serviceEnhancers.d.ts +12 -0
  192. package/server/i18n/serviceEnhancers.js +117 -0
  193. package/server/i18n/types.d.ts +54 -0
  194. package/server/i18n/types.js +3 -0
  195. package/server/i18n/utils.d.ts +12 -0
  196. package/server/i18n/utils.js +29 -0
  197. package/server/index.d.ts +273 -0
  198. package/server/index.js +26 -0
  199. package/server/navigation/index.d.ts +2 -0
  200. package/server/navigation/index.js +18 -0
  201. package/server/navigation/setupStrategy.d.ts +3 -0
  202. package/server/navigation/setupStrategy.js +37 -0
  203. package/server/register/index.d.ts +3 -0
  204. package/server/register/index.js +4 -0
  205. package/server/routes/admin.d.ts +4 -0
  206. package/server/routes/admin.js +72 -61
  207. package/server/routes/client.d.ts +4 -0
  208. package/server/routes/client.js +25 -21
  209. package/server/routes/index.d.ts +6 -0
  210. package/server/routes/index.js +13 -4
  211. package/server/services/admin.d.ts +5 -0
  212. package/server/services/admin.js +183 -0
  213. package/server/services/client.d.ts +5 -0
  214. package/server/services/client.js +249 -0
  215. package/server/services/common.d.ts +5 -0
  216. package/server/services/common.js +313 -0
  217. package/server/services/index.d.ts +7 -0
  218. package/server/services/index.js +14 -6
  219. package/server/utils/constant.d.ts +27 -0
  220. package/server/utils/constant.js +24 -0
  221. package/server/utils/functions.d.ts +138 -0
  222. package/server/utils/functions.js +224 -0
  223. package/server/utils/index.d.ts +3 -0
  224. package/server/utils/index.js +19 -0
  225. package/strapi-admin.d.ts +3 -0
  226. package/strapi-admin.js +8 -1
  227. package/strapi-server.d.ts +273 -0
  228. package/strapi-server.js +6 -17
  229. package/tsconfig.tsbuildinfo +1 -0
  230. package/types/bootstrap.d.ts +13 -0
  231. package/types/bootstrap.js +3 -0
  232. package/types/config.d.ts +21 -0
  233. package/types/config.js +3 -0
  234. package/types/contentTypes.d.ts +85 -0
  235. package/types/contentTypes.js +3 -0
  236. package/types/controllers.d.ts +35 -0
  237. package/types/controllers.js +5 -0
  238. package/types/graphQL.d.ts +3 -0
  239. package/types/graphQL.js +3 -0
  240. package/types/i18n.d.ts +9 -0
  241. package/types/i18n.js +3 -0
  242. package/types/index.d.ts +9 -0
  243. package/types/index.js +25 -0
  244. package/types/services.d.ts +68 -0
  245. package/types/services.js +3 -0
  246. package/types/utils.d.ts +58 -0
  247. package/types/utils.js +26 -0
  248. package/utils/InvalidParamNavigationError.d.ts +4 -0
  249. package/utils/InvalidParamNavigationError.js +11 -0
  250. package/utils/NavigationError.d.ts +5 -0
  251. package/utils/NavigationError.js +7 -7
  252. package/__mocks__/pages.settings.json +0 -25
  253. package/__mocks__/strapi.js +0 -207
  254. package/jest.config.js +0 -14
  255. package/server/bootstrap.js +0 -52
  256. package/server/config.js +0 -9
  257. package/server/content-types/audience/lifecycle.js +0 -8
  258. package/server/content-types/audience/schema.json +0 -23
  259. package/server/content-types/navigation/schema.json +0 -45
  260. package/server/content-types/navigation-item/schema.json +0 -99
  261. package/server/content-types/navigations-items-related/schema.json +0 -47
  262. package/server/controllers/navigation.js +0 -105
  263. package/server/graphql/types/navigation-related.js +0 -25
  264. package/server/services/__tests__/functions.test.js +0 -48
  265. package/server/services/__tests__/navigation.test.js +0 -91
  266. package/server/services/navigation.js +0 -788
  267. package/server/services/utils/constant.js +0 -21
  268. package/server/services/utils/functions.js +0 -226
@@ -1,319 +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 } 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
-
36
- const SettingsPage = () => {
37
- const { lockApp, unlockApp } = useOverlayBlocker();
38
- const { lockAppWithAutoreload, unlockAppWithAutoreload } = useAutoReloadOverlayBlocker();
39
- const [isRestorePopupOpen, setIsRestorePopupOpen] = useState(false);
40
- const [isRestartRequired, setIsRestartRequired] = useState(false);
41
- const [contentTypeExpanded, setContentTypeExpanded] = useState(undefined);
42
- const { data: navigationConfigData, isLoading: isConfigLoading, err: configErr, submitMutation, restoreMutation, restartMutation } = useNavigationConfig();
43
- const { data: allContentTypesData, isLoading: isContentTypesLoading, err: contentTypesErr } = useAllContentTypes();
44
- const isLoading = isConfigLoading || isContentTypesLoading;
45
- const isError = configErr || contentTypesErr;
46
- const boxDefaultProps = {
47
- background: "neutral0",
48
- hasRadius: true,
49
- shadow: "filterShadow",
50
- padding: 6,
51
- };
52
-
53
- const preparePayload = ({ selectedContentTypes, nameFields, audienceFieldChecked, allowedLevels, populate }) => ({
54
- contentTypes: selectedContentTypes,
55
- contentTypesNameFields: nameFields,
56
- contentTypesPopulate: populate,
57
- additionalFields: audienceFieldChecked ? [navigationItemAdditionalFields.AUDIENCE] : [],
58
- allowedLevels: allowedLevels,
59
- gql: {
60
- navigationItemRelated: selectedContentTypes.map(uid => resolveGlobalLikeId(uid)),
61
- }
62
- });
63
-
64
- const onSave = async (form) => {
65
- lockApp();
66
- const payload = preparePayload(form);
67
- await submitMutation({ body: payload });
68
- const isContentTypesChanged = !isEqual(payload.contentTypes, navigationConfigData.contentTypes);
69
- if (isContentTypesChanged && navigationConfigData.isGQLPluginEnabled) {
70
- 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]; } };
71
7
  }
72
- unlockApp();
73
- }
74
-
75
- const onPopupClose = async (isConfirmed) => {
76
- setIsRestorePopupOpen(false);
77
- if (isConfirmed) {
78
- lockApp();
79
- await restoreMutation();
80
- unlockApp();
81
- setIsRestartRequired(true);
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...")));
82
141
  }
83
- }
84
-
85
- const handleRestart = async () => {
86
- lockAppWithAutoreload();
87
- await restartMutation();
88
- setIsRestartRequired(false);
89
- unlockAppWithAutoreload();
90
- };
91
- const handleRestartDiscard = () => setIsRestartRequired(false);
92
- const handleSetContentTypeExpanded = key => setContentTypeExpanded(key === contentTypeExpanded ? undefined : key);
93
-
94
- const prepareNameFieldFor = (uid, current, value) => ({
95
- ...current,
96
- [uid]: value && !isEmpty(value) ? [...value] : undefined,
97
- });
98
-
99
- if (isLoading || isError) {
100
- return (
101
- <>
102
- <SettingsPageTitle
103
- name={getMessage('Settings.email.plugin.title', 'Configuration')}
104
- />
105
- <LoadingIndicatorPage>
106
- Fetching plugin config...
107
- </LoadingIndicatorPage>
108
- </>
109
- )
110
- }
111
-
112
- const allContentTypes = !isLoading && Object.values(allContentTypesData).filter(({ uid }) => isContentTypeEligible(uid, {
113
- allowedContentTypes: navigationConfigData?.allowedContentTypes,
114
- restrictedContentTypes: navigationConfigData?.restrictedContentTypes,
115
- }));
116
- const selectedContentTypes = navigationConfigData?.contentTypes.map(item => item.uid);
117
- const audienceFieldChecked = navigationConfigData?.additionalFields.includes(navigationItemAdditionalFields.AUDIENCE);
118
- const allowedLevels = navigationConfigData?.allowedLevels || 2;
119
- const nameFields = navigationConfigData?.contentTypesNameFields || {}
120
- const populate = navigationConfigData?.contentTypesPopulate || {}
121
-
122
- return (
123
- <>
124
- <SettingsPageTitle
125
- name={getMessage('Settings.email.plugin.title', 'Configuration')}
126
- />
127
- <Main labelledBy="title">
128
- <Formik
129
- initialValues={{
130
- selectedContentTypes,
131
- audienceFieldChecked,
132
- allowedLevels,
133
- nameFields,
134
- populate,
135
- }}
136
- onSubmit={onSave}
137
- >
138
- {({ handleSubmit, setFieldValue, values }) => (
139
- <Form noValidate onSubmit={handleSubmit}>
140
- <HeaderLayout
141
- title={getMessage('pages.settings.header.title')}
142
- subtitle={getMessage('pages.settings.header.description')}
143
- primaryAction={
144
- <CheckPermissions permissions={permissions.access}>
145
- <Button type="submit" startIcon={<Check />} disabled={isRestartRequired}>
146
- {getMessage('pages.settings.actions.submit')}
147
- </Button>
148
- </CheckPermissions>
149
- }
150
- />
151
- <ContentLayout>
152
- <Stack spacing={7}>
153
- {isRestartRequired && (
154
- <RestartAlert
155
- closeLabel={getMessage('pages.settings.actions.restart.alert.cancel')}
156
- title={getMessage('pages.settings.actions.restart.alert.title')}
157
- action={<Box><Button onClick={handleRestart} startIcon={<Play />}>{getMessage('pages.settings.actions.restart')}</Button></Box>}
158
- onClose={handleRestartDiscard}>
159
- {getMessage('pages.settings.actions.restart.alert.description')}
160
- </RestartAlert>)}
161
- <Box {...boxDefaultProps} >
162
- <Stack spacing={4}>
163
- <Typography variant="delta" as="h2">
164
- {getMessage('pages.settings.general.title')}
165
- </Typography>
166
- <Grid gap={4}>
167
- <GridItem col={12} s={12} xs={12}>
168
- <Select
169
- name="selectedContentTypes"
170
- label={getMessage('pages.settings.form.contentTypes.label')}
171
- placeholder={getMessage('pages.settings.form.contentTypes.placeholder')}
172
- hint={getMessage('pages.settings.form.contentTypes.hint')}
173
- onClear={() => setFieldValue('selectedContentTypes', [], false)}
174
- value={values.selectedContentTypes}
175
- onChange={(value) => setFieldValue('selectedContentTypes', value, false)}
176
- multi
177
- withTags
178
- disabled={isRestartRequired}
179
- >
180
- {allContentTypes.map((item) => <Option key={item.uid} value={item.uid}>{item.info.displayName}</Option>)}
181
- </Select>
182
- </GridItem>
183
- {!isEmpty(values.selectedContentTypes) && (
184
- <GridItem col={12}>
185
- <AccordionGroup
186
- label={getMessage('pages.settings.form.contentTypesSettings.label')}
187
- labelAction={<Tooltip description={getMessage('pages.settings.form.contentTypesSettings.tooltip')}>
188
- <Information aria-hidden={true} />
189
- </Tooltip>}>
190
- {orderBy(values.selectedContentTypes).map(uid => {
191
- const { attributes, info: { displayName } } = allContentTypes.find(item => item.uid == uid);
192
- const stringAttributes = Object.keys(attributes).filter(_ => attributes[_].type === 'string');
193
- const relationAttributes = Object.keys(attributes).filter(_ => attributes[_].type === 'relation');
194
- const key = `collectionSettings-${uid}`;
195
- return (<Accordion
196
- expanded={contentTypeExpanded === key}
197
- toggle={() => handleSetContentTypeExpanded(key)}
198
- key={key}
199
- id={key}
200
- size="S">
201
- <AccordionToggle title={displayName} togglePosition="left" />
202
- <AccordionContent>
203
- <Box padding={6}>
204
- <Stack spacing={4}>
205
- <Select
206
- name={`collectionSettings-${uid}-entryLabel`}
207
- label={getMessage('pages.settings.form.nameField.label')}
208
- hint={getMessage(`pages.settings.form.populate.${isEmpty(stringAttributes) ? 'empty' : 'hint'}`)}
209
- placeholder={getMessage('pages.settings.form.nameField.placeholder')}
210
- onClear={() => null}
211
- value={values.nameFields[uid] || []}
212
- onChange={(value) => setFieldValue('nameFields', prepareNameFieldFor(uid, values.nameFields, value))}
213
- multi
214
- withTags
215
- disabled={isRestartRequired || isEmpty(stringAttributes)}
216
- >
217
- {stringAttributes.map(key =>
218
- (<Option key={uid + key} value={key}>{capitalize(key.split('_').join(' '))}</Option>))}
219
- </Select>
220
- <Select
221
- name={`collectionSettings-${uid}-populate`}
222
- label={getMessage('pages.settings.form.populate.label')}
223
- hint={getMessage(`pages.settings.form.populate.${isEmpty(relationAttributes) ? 'empty' : 'hint'}`)}
224
- placeholder={getMessage('pages.settings.form.populate.placeholder')}
225
- onClear={() => null}
226
- value={values.populate[uid] || []}
227
- onChange={(value) => setFieldValue('populate', prepareNameFieldFor(uid, values.populate, value))}
228
- multi
229
- withTags
230
- disabled={isRestartRequired || isEmpty(relationAttributes)}
231
- >
232
- {relationAttributes.map(key =>
233
- (<Option key={uid + key} value={key}>{capitalize(key.split('_').join(' '))}</Option>))}
234
- </Select>
235
- </Stack>
236
- </Box>
237
-
238
- </AccordionContent>
239
- </Accordion>);
240
- })}
241
- </AccordionGroup>
242
- </GridItem>)}
243
- </Grid>
244
- </Stack>
245
- </Box>
246
- <Box {...boxDefaultProps} >
247
- <Stack spacing={4}>
248
- <Typography variant="delta" as="h2">
249
- {getMessage('pages.settings.additional.title')}
250
- </Typography>
251
- <Grid gap={4}>
252
- <GridItem col={3} s={6} xs={12}>
253
- <NumberInput
254
- name="allowedLevels"
255
- label={getMessage('pages.settings.form.allowedLevels.label')}
256
- placeholder={getMessage('pages.settings.form.allowedLevels.placeholder')}
257
- hint={getMessage('pages.settings.form.allowedLevels.hint')}
258
- onValueChange={(value) => setFieldValue('allowedLevels', value, false)}
259
- value={values.allowedLevels}
260
- disabled={isRestartRequired}
261
- />
262
- </GridItem>
263
- <GridItem col={6} s={12} xs={12}>
264
- <ToggleInput
265
- name="audienceFieldChecked"
266
- label={getMessage('pages.settings.form.audience.label')}
267
- hint={getMessage('pages.settings.form.audience.hint')}
268
- checked={values.audienceFieldChecked}
269
- onChange={({ target: { checked } }) => setFieldValue('audienceFieldChecked', checked, false)}
270
- onLabel="Enabled"
271
- offLabel="Disabled"
272
- disabled={isRestartRequired}
273
- />
274
- </GridItem>
275
- </Grid>
276
- </Stack>
277
- </Box>
278
- <Box {...boxDefaultProps} >
279
- <Stack spacing={4}>
280
- <Typography variant="delta" as="h2">
281
- {getMessage('pages.settings.restoring.title')}
282
- </Typography>
283
- <Grid gap={4}>
284
- <GridItem col={12} s={12} xs={12}>
285
- <Typography>
286
- {getMessage('pages.settings.actions.restore.description')}
287
- </Typography>
288
- </GridItem>
289
- <GridItem col={6} s={12} xs={12}>
290
- <CheckPermissions permissions={permissions.access}>
291
- <Button variant="danger-light" startIcon={<Refresh />} onClick={() => setIsRestorePopupOpen(true)}>
292
- {getMessage('pages.settings.actions.restore')}
293
- </Button>
294
- </CheckPermissions>
295
- <ConfirmationDialog
296
- isVisible={isRestorePopupOpen}
297
- header={getMessage('pages.settings.actions.restore.confirmation.header')}
298
- labelConfirm={getMessage('pages.settings.actions.restore.confirmation.confirm')}
299
- iconConfirm={<Refresh />}
300
- onConfirm={() => onPopupClose(true)}
301
- onCancel={() => onPopupClose(false)}>
302
- {getMessage('pages.settings.actions.restore.confirmation.description')}
303
- </ConfirmationDialog>
304
- </GridItem>
305
- </Grid>
306
- </Stack>
307
- </Box>
308
- </Stack>
309
- </ContentLayout>
310
- </Form>
311
- )}
312
- </Formik>
313
- </Main>
314
- </>
315
- );
316
- }
317
-
318
-
319
- 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
@@ -1,30 +1,25 @@
1
1
  'use strict';
2
-
3
2
  const { capitalize } = require("lodash");
4
-
5
3
  const UID_REGEX = /^(?<type>[a-z0-9-]+)\:{2}(?<api>[a-z0-9-]+)\.{1}(?<contentType>[a-z0-9-]+)$/i;
6
-
7
4
  const splitTypeUid = (uid = '') => {
8
5
  return uid.split(UID_REGEX).filter((s) => s && s.length > 0);
9
6
  };
10
-
11
7
  module.exports = {
12
8
  resolveGlobalLikeId(uid = '') {
13
9
  const parse = (str) => str.split('-')
14
10
  .map(_ => capitalize(_))
15
11
  .join('');
16
-
17
12
  const [type, scope, contentTypeName] = splitTypeUid(uid);
18
13
  if (type === 'api') {
19
14
  return parse(contentTypeName);
20
15
  }
21
16
  return `${parse(scope)}${parse(contentTypeName)}`;
22
17
  },
23
-
24
18
  isContentTypeEligible(uid = '', config = {}) {
25
- const { allowedContentTypes = [], restrictedContentTypes = []} = config;
19
+ const { allowedContentTypes = [], restrictedContentTypes = [] } = config;
26
20
  const isOneOfAllowedType = allowedContentTypes.filter(_ => uid.includes(_) || (uid === _)).length > 0;
27
21
  const isNoneOfRestricted = restrictedContentTypes.filter(_ => uid.includes(_) || (uid === _)).length === 0;
28
22
  return uid && isOneOfAllowedType && isNoneOfRestricted;
29
23
  },
30
- }
24
+ };
25
+ //# sourceMappingURL=functions.js.map