strapi-plugin-navigation 2.0.13 → 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 +98 -26
  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 +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 -335
  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 -278
  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 -104
  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 -791
  267. package/server/services/utils/constant.js +0 -21
  268. package/server/services/utils/functions.js +0 -226
@@ -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
@@ -0,0 +1,20 @@
1
+ import React, { VFC } from "react";
2
+ interface ConfirmEffect {
3
+ (source: string): void;
4
+ }
5
+ interface CancelEffect {
6
+ (): void;
7
+ }
8
+ interface Props {
9
+ onConfirm: ConfirmEffect;
10
+ onCancel: CancelEffect;
11
+ }
12
+ export declare const I18nCopyNavigationItemsModal: VFC<Props>;
13
+ export declare const useI18nCopyNavigationItemsModal: (onConfirm: ConfirmEffect) => {
14
+ setI18nCopyModalOpened: React.Dispatch<React.SetStateAction<boolean>>;
15
+ setI18nCopySourceLocale: React.Dispatch<React.SetStateAction<string | undefined>>;
16
+ i18nCopyItemsModal: JSX.Element | null;
17
+ i18nCopySourceLocale: string | undefined;
18
+ };
19
+ export {};
20
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1,60 @@
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]; } };
7
+ }
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
+ exports.useI18nCopyNavigationItemsModal = exports.I18nCopyNavigationItemsModal = void 0;
30
+ const react_1 = __importStar(require("react"));
31
+ const ConfirmationDialog_1 = __importDefault(require("../../../../components/ConfirmationDialog"));
32
+ const utils_1 = require("../../../../utils");
33
+ const refreshIcon = react_1.default.createElement(react_1.default.Fragment, null);
34
+ const I18nCopyNavigationItemsModal = ({ onConfirm, onCancel, }) => {
35
+ return (react_1.default.createElement(ConfirmationDialog_1.default, { isVisible: true, header: (0, utils_1.getMessage)("pages.view.actions.i18nCopyItems.confirmation.header"), labelConfirm: (0, utils_1.getMessage)("pages.view.actions.i18nCopyItems.confirmation.confirm"), iconConfirm: refreshIcon, mainIcon: refreshIcon, onConfirm: onConfirm, onCancel: onCancel }, (0, utils_1.getMessage)("pages.view.actions.i18nCopyItems.confirmation.content")));
36
+ };
37
+ exports.I18nCopyNavigationItemsModal = I18nCopyNavigationItemsModal;
38
+ const useI18nCopyNavigationItemsModal = (onConfirm) => {
39
+ const [isOpened, setIsOpened] = (0, react_1.useState)(false);
40
+ const [sourceLocale, setSourceLocale] = (0, react_1.useState)(undefined);
41
+ const onCancel = (0, react_1.useCallback)(() => {
42
+ setIsOpened(false);
43
+ }, [setIsOpened]);
44
+ const onConfirmWithModalClose = (0, react_1.useCallback)(() => {
45
+ if (!sourceLocale) {
46
+ return;
47
+ }
48
+ onConfirm(sourceLocale);
49
+ setIsOpened(false);
50
+ }, [onConfirm, sourceLocale]);
51
+ const modal = (0, react_1.useMemo)(() => isOpened ? (react_1.default.createElement(exports.I18nCopyNavigationItemsModal, { onConfirm: onConfirmWithModalClose, onCancel: onCancel })) : null, [isOpened, onConfirmWithModalClose, onCancel]);
52
+ return (0, react_1.useMemo)(() => ({
53
+ setI18nCopyModalOpened: setIsOpened,
54
+ setI18nCopySourceLocale: setSourceLocale,
55
+ i18nCopyItemsModal: modal,
56
+ i18nCopySourceLocale: sourceLocale,
57
+ }), [setSourceLocale, setIsOpened, modal, sourceLocale]);
58
+ };
59
+ exports.useI18nCopyNavigationItemsModal = useI18nCopyNavigationItemsModal;
60
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,6 @@
1
+ export default NavigationContentHeader;
2
+ declare function NavigationContentHeader({ startActions, endActions }: {
3
+ startActions: any;
4
+ endActions: any;
5
+ }): JSX.Element;
6
+ //# sourceMappingURL=index.d.ts.map
@@ -1,18 +1,14 @@
1
- import React from 'react';
2
-
3
- import { Flex } from '@strapi/design-system/Flex';
4
-
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ const Flex_1 = require("@strapi/design-system/Flex");
5
8
  const NavigationContentHeader = ({ startActions, endActions }) => {
6
- return (
7
- <Flex justifyContent="space-between" width="100%">
8
- <Flex alignItems="space-between">
9
- {startActions}
10
- </Flex>
11
- <Flex alignItems="space-between">
12
- {endActions}
13
- </Flex>
14
- </Flex>
15
- );
16
- }
17
-
18
- export default NavigationContentHeader;
9
+ return (react_1.default.createElement(Flex_1.Flex, { justifyContent: "space-between", width: "100%" },
10
+ react_1.default.createElement(Flex_1.Flex, { alignItems: "space-between" }, startActions),
11
+ react_1.default.createElement(Flex_1.Flex, { alignItems: "space-between" }, endActions)));
12
+ };
13
+ exports.default = NavigationContentHeader;
14
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,12 @@
1
+ export default NavigationHeader;
2
+ declare function NavigationHeader({ activeNavigation, availableNavigations, structureHasErrors, structureHasChanged, handleChangeSelection, handleLocalizationSelection, handleSave, config, }: {
3
+ activeNavigation: any;
4
+ availableNavigations: any;
5
+ structureHasErrors: any;
6
+ structureHasChanged: any;
7
+ handleChangeSelection: any;
8
+ handleLocalizationSelection: any;
9
+ handleSave: any;
10
+ config: any;
11
+ }): JSX.Element;
12
+ //# sourceMappingURL=index.d.ts.map
@@ -1,66 +1,75 @@
1
- import React from 'react';
2
- import { useIntl } from 'react-intl';
3
- import { HeaderLayout } from '@strapi/design-system/Layout';
4
- import { Stack } from '@strapi/design-system/Stack';
5
- import { Button } from '@strapi/design-system/Button';
6
- import Check from '@strapi/icons/Check';
7
- import More from '@strapi/icons/More';
8
- import { getTrad } from '../../../../translations';
9
- import { MoreButton } from './styles';
10
- import { Select, Option } from '@strapi/design-system/Select';
11
- import { Box } from '@strapi/design-system/Box'
12
-
13
- const NavigationHeader = ({
14
- activeNavigation,
15
- availableNavigations,
16
- structureHasErrors,
17
- structureHasChanged,
18
- handleChangeSelection,
19
- handleSave,
20
- }) => {
21
- const { formatMessage } = useIntl();
22
- return (
23
- <HeaderLayout
24
- primaryAction={
25
- <Stack horizontal spacing={2}>
26
- <Box width="10vw">
27
- <Select
28
- type="select"
29
- placeholder={'Change navigation'}
30
- name={`navigationSelect`}
31
- onChange={handleChangeSelection}
32
- value={activeNavigation?.id}
33
- size="S"
34
- style={null}
35
- >
36
- {availableNavigations.map(({ id, name }) => <Option key={id} value={id}>{name}</Option>)}
37
- </Select >
38
- </Box>
39
- <Button
40
- onClick={handleSave}
41
- startIcon={<Check />}
42
- disabled={structureHasErrors || !structureHasChanged}
43
- type="submit"
44
- >
45
- {formatMessage(getTrad('submit.cta.save'))}
46
- </Button>
47
- {/* <MoreButton
48
- id="more"
49
- label="More"
50
- icon={<More />}
51
- /> */}
52
- </Stack>
53
- }
54
- title={formatMessage({
55
- id: getTrad('header.title'),
56
- defaultMessage: 'UI Navigation',
57
- })}
58
- subtitle={formatMessage({
59
- id: getTrad('header.description'),
60
- defaultMessage: 'Define your portal navigation',
61
- })}
62
- />
63
- );
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]; } };
7
+ }
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;
64
24
  };
65
-
66
- export default NavigationHeader;
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 react_intl_1 = require("react-intl");
31
+ const Layout_1 = require("@strapi/design-system/Layout");
32
+ const Stack_1 = require("@strapi/design-system/Stack");
33
+ const Button_1 = require("@strapi/design-system/Button");
34
+ const Check_1 = __importDefault(require("@strapi/icons/Check"));
35
+ const translations_1 = require("../../../../translations");
36
+ const Select_1 = require("@strapi/design-system/Select");
37
+ const Box_1 = require("@strapi/design-system/Box");
38
+ const Grid_1 = require("@strapi/design-system/Grid");
39
+ const lodash_1 = require("lodash");
40
+ const submitIcon = react_1.default.createElement(Check_1.default, null);
41
+ const pickDefaultLocaleNavigation = ({ activeNavigation, config }) => config.i18nEnabled
42
+ ? activeNavigation
43
+ ? activeNavigation.localeCode === config.defaultLocale
44
+ ? activeNavigation
45
+ : activeNavigation?.localizations.find(({ localeCode }) => localeCode === config.defaultLocale)
46
+ : null
47
+ : activeNavigation;
48
+ const NavigationHeader = ({ activeNavigation, availableNavigations, structureHasErrors, structureHasChanged, handleChangeSelection, handleLocalizationSelection, handleSave, config, }) => {
49
+ const { formatMessage } = (0, react_intl_1.useIntl)();
50
+ const allLocaleVersions = (0, react_1.useMemo)(() => activeNavigation?.localizations.length && config.i18nEnabled
51
+ ? (0, lodash_1.uniqBy)([activeNavigation, ...(activeNavigation.localizations ?? [])].sort((a, b) => a.localeCode.localeCompare(b.localeCode)), 'id')
52
+ : [], [activeNavigation, config]);
53
+ const hasLocalizations = config.i18nEnabled && allLocaleVersions.length;
54
+ const passedActiveNavigation = pickDefaultLocaleNavigation({ activeNavigation, config });
55
+ return (react_1.default.createElement(Layout_1.HeaderLayout, { primaryAction: react_1.default.createElement(Stack_1.Stack, { horizontal: true, size: 2 },
56
+ react_1.default.createElement(Box_1.Box, { width: "20vw", marginRight: "8px" },
57
+ react_1.default.createElement(Grid_1.Grid, { gap: 4 },
58
+ !hasLocalizations ? (react_1.default.createElement(Grid_1.GridItem, { col: 3 })) : null,
59
+ react_1.default.createElement(Grid_1.GridItem, { col: 6 },
60
+ react_1.default.createElement(Select_1.Select, { type: "select", placeholder: "Change navigation", name: "navigationSelect", onChange: handleChangeSelection, value: passedActiveNavigation?.id, size: "S", style: null }, availableNavigations.map(({ id, name }) => react_1.default.createElement(Select_1.Option, { key: id, value: id }, name)))),
61
+ hasLocalizations
62
+ ? react_1.default.createElement(Grid_1.GridItem, { col: 3 },
63
+ react_1.default.createElement(Select_1.Select, { type: "select", placeholder: formatMessage((0, translations_1.getTrad)('pages.main.header.localization.select.placeholder')), name: "navigationLocalizationSelect", onChange: handleLocalizationSelection, value: activeNavigation?.id, size: "S" }, allLocaleVersions.map(({ id, localeCode }) => react_1.default.createElement(Select_1.Option, { key: id, value: id }, localeCode))))
64
+ : null,
65
+ react_1.default.createElement(Grid_1.GridItem, { col: "3" },
66
+ react_1.default.createElement(Button_1.Button, { onClick: handleSave, startIcon: submitIcon, disabled: structureHasErrors || !structureHasChanged, type: "submit" }, formatMessage((0, translations_1.getTrad)('submit.cta.save'))))))), title: formatMessage({
67
+ id: (0, translations_1.getTrad)('header.title'),
68
+ defaultMessage: 'UI Navigation',
69
+ }), subtitle: formatMessage({
70
+ id: (0, translations_1.getTrad)('header.description'),
71
+ defaultMessage: 'Define your portal navigation',
72
+ }) }));
73
+ };
74
+ exports.default = NavigationHeader;
75
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,2 @@
1
+ export const MoreButton: any;
2
+ //# sourceMappingURL=styles.d.ts.map
@@ -1,7 +1,12 @@
1
- import styled from 'styled-components';
2
- import { IconButton } from '@strapi/design-system/IconButton';
3
-
4
- export const MoreButton = styled(IconButton)`
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.MoreButton = void 0;
7
+ const styled_components_1 = __importDefault(require("styled-components"));
8
+ const IconButton_1 = require("@strapi/design-system/IconButton");
9
+ exports.MoreButton = (0, styled_components_1.default)(IconButton_1.IconButton) `
5
10
  margin: ${({ theme }) => `0 ${theme.spaces[2]}`};
6
11
  padding: ${({ theme }) => theme.spaces[2]};
7
12
 
@@ -10,4 +15,4 @@ export const MoreButton = styled(IconButton)`
10
15
  height: ${18 / 16}rem;
11
16
  }
12
17
  `;
13
-
18
+ //# sourceMappingURL=styles.js.map
@@ -0,0 +1,51 @@
1
+ export default NavigationItemForm;
2
+ declare function NavigationItemForm({ isLoading, inputsPrefix, data, contentTypes, contentTypeEntities, usedContentTypeEntities, availableAudience, additionalFields, contentTypesNameFields, onSubmit, onCancel, getContentTypeEntities, usedContentTypesData, appendLabelPublicationStatus, locale, }: {
3
+ isLoading: any;
4
+ inputsPrefix: any;
5
+ data?: {} | undefined;
6
+ contentTypes?: any[] | undefined;
7
+ contentTypeEntities?: any[] | undefined;
8
+ usedContentTypeEntities?: any[] | undefined;
9
+ availableAudience?: any[] | undefined;
10
+ additionalFields?: any[] | undefined;
11
+ contentTypesNameFields?: {} | undefined;
12
+ onSubmit: any;
13
+ onCancel: any;
14
+ getContentTypeEntities: any;
15
+ usedContentTypesData: any;
16
+ appendLabelPublicationStatus?: (() => string) | undefined;
17
+ locale: any;
18
+ }): JSX.Element;
19
+ declare namespace NavigationItemForm {
20
+ namespace defaultProps {
21
+ const fieldsToDisable: never[];
22
+ const formErrors: {};
23
+ const inputsPrefix: string;
24
+ function onSubmit(e: any): any;
25
+ const requestError: null;
26
+ }
27
+ namespace propTypes {
28
+ export const isLoading: PropTypes.Requireable<boolean>;
29
+ const fieldsToDisable_1: PropTypes.Requireable<any[]>;
30
+ export { fieldsToDisable_1 as fieldsToDisable };
31
+ const formErrors_1: PropTypes.Validator<object>;
32
+ export { formErrors_1 as formErrors };
33
+ const inputsPrefix_1: PropTypes.Requireable<string>;
34
+ export { inputsPrefix_1 as inputsPrefix };
35
+ export const data: PropTypes.Validator<object>;
36
+ const onSubmit_1: PropTypes.Requireable<(...args: any[]) => any>;
37
+ export { onSubmit_1 as onSubmit };
38
+ const requestError_1: PropTypes.Requireable<object>;
39
+ export { requestError_1 as requestError };
40
+ export const contentTypes: PropTypes.Requireable<any[]>;
41
+ export const contentTypeEntities: PropTypes.Requireable<any[]>;
42
+ export const usedContentTypeEntities: PropTypes.Requireable<any[]>;
43
+ export const availableAudience: PropTypes.Requireable<any[]>;
44
+ export const additionalFields: PropTypes.Requireable<any[]>;
45
+ export const getContentTypeEntities: PropTypes.Validator<(...args: any[]) => any>;
46
+ export const appendLabelPublicationStatus: PropTypes.Requireable<(...args: any[]) => any>;
47
+ export const onCancel: PropTypes.Requireable<(...args: any[]) => any>;
48
+ }
49
+ }
50
+ import PropTypes from "prop-types";
51
+ //# sourceMappingURL=index.d.ts.map