strapi-plugin-navigation 2.0.12 → 2.1.0-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (268) hide show
  1. package/README.md +260 -41
  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 +162 -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 +335 -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 +21 -0
  150. package/server/graphql/queries/render-navigation.js +31 -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 +10 -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
@@ -0,0 +1,45 @@
1
+ export namespace form {
2
+ const fieldsToDisable: never[];
3
+ const fieldsToOmit: never[];
4
+ function schema(isSingleSelected: any): import("yup/lib/object").OptionalObjectSchema<{
5
+ title: yup.StringSchema<string | undefined, Record<string, any>, string | undefined>;
6
+ uiRouterKey: import("yup/lib/string").RequiredStringSchema<string | undefined, Record<string, any>>;
7
+ type: import("yup/lib/string").RequiredStringSchema<string | undefined, Record<string, any>>;
8
+ path: yup.StringSchema<string | undefined, Record<string, any>, string | undefined>;
9
+ externalPath: yup.StringSchema<string | undefined, Record<string, any>, string | undefined>;
10
+ menuAttached: yup.BooleanSchema<boolean | undefined, Record<string, any>, boolean | undefined>;
11
+ relatedType: import("yup/lib/mixed").MixedSchema<any, Record<string, any>, any>;
12
+ related: import("yup/lib/mixed").MixedSchema<any, Record<string, any>, any>;
13
+ }, Record<string, any>, import("yup/lib/object").TypeOfShape<{
14
+ title: yup.StringSchema<string | undefined, Record<string, any>, string | undefined>;
15
+ uiRouterKey: import("yup/lib/string").RequiredStringSchema<string | undefined, Record<string, any>>;
16
+ type: import("yup/lib/string").RequiredStringSchema<string | undefined, Record<string, any>>;
17
+ path: yup.StringSchema<string | undefined, Record<string, any>, string | undefined>;
18
+ externalPath: yup.StringSchema<string | undefined, Record<string, any>, string | undefined>;
19
+ menuAttached: yup.BooleanSchema<boolean | undefined, Record<string, any>, boolean | undefined>;
20
+ relatedType: import("yup/lib/mixed").MixedSchema<any, Record<string, any>, any>;
21
+ related: import("yup/lib/mixed").MixedSchema<any, Record<string, any>, any>;
22
+ }>>;
23
+ function schema(isSingleSelected: any): import("yup/lib/object").OptionalObjectSchema<{
24
+ title: yup.StringSchema<string | undefined, Record<string, any>, string | undefined>;
25
+ uiRouterKey: import("yup/lib/string").RequiredStringSchema<string | undefined, Record<string, any>>;
26
+ type: import("yup/lib/string").RequiredStringSchema<string | undefined, Record<string, any>>;
27
+ path: yup.StringSchema<string | undefined, Record<string, any>, string | undefined>;
28
+ externalPath: yup.StringSchema<string | undefined, Record<string, any>, string | undefined>;
29
+ menuAttached: yup.BooleanSchema<boolean | undefined, Record<string, any>, boolean | undefined>;
30
+ relatedType: import("yup/lib/mixed").MixedSchema<any, Record<string, any>, any>;
31
+ related: import("yup/lib/mixed").MixedSchema<any, Record<string, any>, any>;
32
+ }, Record<string, any>, import("yup/lib/object").TypeOfShape<{
33
+ title: yup.StringSchema<string | undefined, Record<string, any>, string | undefined>;
34
+ uiRouterKey: import("yup/lib/string").RequiredStringSchema<string | undefined, Record<string, any>>;
35
+ type: import("yup/lib/string").RequiredStringSchema<string | undefined, Record<string, any>>;
36
+ path: yup.StringSchema<string | undefined, Record<string, any>, string | undefined>;
37
+ externalPath: yup.StringSchema<string | undefined, Record<string, any>, string | undefined>;
38
+ menuAttached: yup.BooleanSchema<boolean | undefined, Record<string, any>, boolean | undefined>;
39
+ relatedType: import("yup/lib/mixed").MixedSchema<any, Record<string, any>, any>;
40
+ related: import("yup/lib/mixed").MixedSchema<any, Record<string, any>, any>;
41
+ }>>;
42
+ const inputsPrefix: string;
43
+ }
44
+ import * as yup from "yup";
45
+ //# sourceMappingURL=form.d.ts.map
@@ -1,54 +1,83 @@
1
- import * as yup from "yup";
2
- import { isNil } from "lodash";
3
- import { translatedErrors } from "@strapi/helper-plugin";
4
- import { navigationItemType } from "../../../utils/enums";
5
- import pluginId from "../../../../../pluginId";
6
-
7
- export const form = {
8
- fieldsToDisable: [],
9
- fieldsToOmit: [],
10
- schema(isSingleSelected) {
11
- return yup.object({
12
- title: yup.string()
13
- .when('type', {
14
- is: val => val === navigationItemType.EXTERNAL,
15
- then: yup.string()
16
- .required(translatedErrors.required),
17
- otherwise: yup.string().notRequired(),
18
- }),
19
- uiRouterKey: yup.string().required(translatedErrors.required),
20
- type: yup.string().required(translatedErrors.required),
21
- path: yup.string()
22
- .when('type', {
23
- is: val => val === navigationItemType.INTERNAL || isNil(val),
24
- then: yup.string().required(translatedErrors.required),
25
- otherwise: yup.string().notRequired(),
26
- }),
27
- externalPath: yup.string()
28
- .when('type', {
29
- is: val => val === navigationItemType.EXTERNAL,
30
- then: yup.string()
31
- .required(translatedErrors.required)
32
- .matches(/(#.*)|(https?:\/\/(?:www\.|(?!www))[a-zA-Z0-9][a-zA-Z0-9-]+[a-zA-Z0-9]\.[^\s]{2,}|www\.[a-zA-Z0-9][a-zA-Z0-9-]+[a-zA-Z0-9]\.[^\s]{2,}|https?:\/\/(?:www\.|(?!www))[a-zA-Z0-9]+\.[^\s]{2,}|www\.[a-zA-Z0-9]+\.[^\s]{2,})/, {
33
- excludeEmptyString: true,
34
- message: `${pluginId}.popup.item.form.externalPath.validation.type`,
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.form = void 0;
30
+ const yup = __importStar(require("yup"));
31
+ const lodash_1 = require("lodash");
32
+ const helper_plugin_1 = require("@strapi/helper-plugin");
33
+ const enums_1 = require("../../../utils/enums");
34
+ const pluginId_1 = __importDefault(require("../../../../../pluginId"));
35
+ exports.form = {
36
+ fieldsToDisable: [],
37
+ fieldsToOmit: [],
38
+ schema(isSingleSelected) {
39
+ return yup.object({
40
+ title: yup.string()
41
+ .when('type', {
42
+ is: val => val === enums_1.navigationItemType.EXTERNAL,
43
+ then: yup.string()
44
+ .required(helper_plugin_1.translatedErrors.required),
45
+ otherwise: yup.string().notRequired(),
46
+ }),
47
+ uiRouterKey: yup.string().required(helper_plugin_1.translatedErrors.required),
48
+ type: yup.string().required(helper_plugin_1.translatedErrors.required),
49
+ path: yup.string()
50
+ .when('type', {
51
+ is: val => val === enums_1.navigationItemType.INTERNAL || (0, lodash_1.isNil)(val),
52
+ then: yup.string().required(helper_plugin_1.translatedErrors.required),
53
+ otherwise: yup.string().notRequired(),
54
+ }),
55
+ externalPath: yup.string()
56
+ .when('type', {
57
+ is: val => val === enums_1.navigationItemType.EXTERNAL,
58
+ then: yup.string()
59
+ .required(helper_plugin_1.translatedErrors.required)
60
+ .matches(/(#.*)|(https?:\/\/(?:www\.|(?!www))[a-zA-Z0-9][a-zA-Z0-9-]+[a-zA-Z0-9]\.[^\s]{2,}|www\.[a-zA-Z0-9][a-zA-Z0-9-]+[a-zA-Z0-9]\.[^\s]{2,}|https?:\/\/(?:www\.|(?!www))[a-zA-Z0-9]+\.[^\s]{2,}|www\.[a-zA-Z0-9]+\.[^\s]{2,})/, {
61
+ excludeEmptyString: true,
62
+ message: `${pluginId_1.default}.popup.item.form.externalPath.validation.type`,
63
+ }),
64
+ otherwise: yup.string().notRequired(),
65
+ }),
66
+ menuAttached: yup.boolean(),
67
+ relatedType: yup.mixed()
68
+ .when('type', {
69
+ is: val => val === enums_1.navigationItemType.INTERNAL || (0, lodash_1.isNil)(val),
70
+ then: isSingleSelected ? yup.mixed().notRequired() : yup.mixed().required(helper_plugin_1.translatedErrors.required),
71
+ otherwise: yup.mixed().notRequired(),
72
+ }),
73
+ related: yup.mixed()
74
+ .when('type', {
75
+ is: val => val === enums_1.navigationItemType.INTERNAL || (0, lodash_1.isNil)(val),
76
+ then: isSingleSelected ? yup.mixed().notRequired() : yup.mixed().required(helper_plugin_1.translatedErrors.required),
77
+ otherwise: yup.mixed().notRequired(),
35
78
  }),
36
- otherwise: yup.string().notRequired(),
37
- }),
38
- menuAttached: yup.boolean(),
39
- relatedType: yup.mixed()
40
- .when('type', {
41
- is: val => val === navigationItemType.INTERNAL || isNil(val),
42
- then: isSingleSelected ? yup.mixed().notRequired() : yup.mixed().required(translatedErrors.required),
43
- otherwise: yup.mixed().notRequired(),
44
- }),
45
- related: yup.mixed()
46
- .when('type', {
47
- is: val => val === navigationItemType.INTERNAL || isNil(val),
48
- then: isSingleSelected ? yup.mixed().notRequired() : yup.mixed().required(translatedErrors.required),
49
- otherwise: yup.mixed().notRequired(),
50
- }),
51
- });
52
- },
53
- inputsPrefix: '',
79
+ });
80
+ },
81
+ inputsPrefix: '',
54
82
  };
83
+ //# sourceMappingURL=form.js.map
@@ -0,0 +1,23 @@
1
+ export function NavigationItemPopupFooter({ handleCancel, handleSubmit, submitDisabled, formViewId }: {
2
+ handleCancel: any;
3
+ handleSubmit: any;
4
+ submitDisabled: any;
5
+ formViewId: any;
6
+ }): JSX.Element;
7
+ export namespace NavigationItemPopupFooter {
8
+ namespace defaultProps {
9
+ const onValidate: undefined;
10
+ const submitDisabled: boolean;
11
+ const formViewId: undefined;
12
+ }
13
+ namespace propTypes {
14
+ export const handleCancel: PropTypes.Validator<(...args: any[]) => any>;
15
+ export const handleSubmit: PropTypes.Requireable<(...args: any[]) => any>;
16
+ const submitDisabled_1: PropTypes.Requireable<boolean>;
17
+ export { submitDisabled_1 as submitDisabled };
18
+ const formViewId_1: PropTypes.Requireable<object>;
19
+ export { formViewId_1 as formViewId };
20
+ }
21
+ }
22
+ import PropTypes from "prop-types";
23
+ //# sourceMappingURL=NavigationItemPopupFooter.d.ts.map
@@ -1,37 +1,27 @@
1
- import React from 'react';
2
- import PropTypes from 'prop-types';
3
-
4
- import { Button } from '@strapi/design-system/Button';
5
- import { ModalFooter } from '@strapi/design-system/ModalLayout';
6
- import { getMessage } from '../../../../utils';
7
-
8
- export const NavigationItemPopupFooter = ({ handleCancel, handleSubmit, submitDisabled, formViewId }) => {
9
-
10
- return (
11
- <ModalFooter
12
- startActions={
13
- <Button onClick={handleCancel} variant="tertiary">
14
- {getMessage('popup.item.form.button.cancel')}
15
- </Button>
16
- }
17
- endActions={
18
- <Button onClick={handleSubmit} disabled={submitDisabled}>
19
- {getMessage(`popup.item.form.button.save`)}
20
- </Button>
21
- }
22
- />
23
- );
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
24
4
  };
25
-
26
- NavigationItemPopupFooter.defaultProps = {
27
- onValidate: undefined,
28
- submitDisabled: false,
29
- formViewId: undefined,
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.NavigationItemPopupFooter = void 0;
7
+ const react_1 = __importDefault(require("react"));
8
+ const prop_types_1 = __importDefault(require("prop-types"));
9
+ const Button_1 = require("@strapi/design-system/Button");
10
+ const ModalLayout_1 = require("@strapi/design-system/ModalLayout");
11
+ const utils_1 = require("../../../../utils");
12
+ const NavigationItemPopupFooter = ({ handleCancel, handleSubmit, submitDisabled, formViewId }) => {
13
+ return (react_1.default.createElement(ModalLayout_1.ModalFooter, { startActions: react_1.default.createElement(Button_1.Button, { onClick: handleCancel, variant: "tertiary" }, (0, utils_1.getMessage)('popup.item.form.button.cancel')), endActions: react_1.default.createElement(Button_1.Button, { onClick: handleSubmit, disabled: submitDisabled }, (0, utils_1.getMessage)(`popup.item.form.button.save`)) }));
30
14
  };
31
-
32
- NavigationItemPopupFooter.propTypes = {
33
- handleCancel: PropTypes.func.isRequired,
34
- handleSubmit: PropTypes.func,
35
- submitDisabled: PropTypes.bool,
36
- formViewId: PropTypes.object,
15
+ exports.NavigationItemPopupFooter = NavigationItemPopupFooter;
16
+ exports.NavigationItemPopupFooter.defaultProps = {
17
+ onValidate: undefined,
18
+ submitDisabled: false,
19
+ formViewId: undefined,
37
20
  };
21
+ exports.NavigationItemPopupFooter.propTypes = {
22
+ handleCancel: prop_types_1.default.func.isRequired,
23
+ handleSubmit: prop_types_1.default.func,
24
+ submitDisabled: prop_types_1.default.bool,
25
+ formViewId: prop_types_1.default.object,
26
+ };
27
+ //# sourceMappingURL=NavigationItemPopupFooter.js.map
@@ -0,0 +1,4 @@
1
+ export function NavigationItemPopupHeader({ isNewItem }: {
2
+ isNewItem: any;
3
+ }): JSX.Element;
4
+ //# sourceMappingURL=NavigationItemPopupHeader.d.ts.map
@@ -1,16 +1,16 @@
1
-
2
-
3
- import React from 'react';
4
- import { Typography } from '@strapi/design-system/Typography';
5
- import { ModalHeader } from '@strapi/design-system/ModalLayout';
6
- import { getMessage } from '../../../../utils';
7
-
8
- export const NavigationItemPopupHeader = ({isNewItem}) => {
9
- return (
10
- <ModalHeader>
11
- <Typography variant="omega" fontWeight="bold" textColor="neutral800" as="h2" id="asset-dialog-title">
12
- {getMessage(`popup.item.header.${isNewItem ? 'new' : 'edit'}`)}
13
- </Typography>
14
- </ModalHeader>
15
- );
16
- };
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.NavigationItemPopupHeader = void 0;
7
+ const react_1 = __importDefault(require("react"));
8
+ const Typography_1 = require("@strapi/design-system/Typography");
9
+ const ModalLayout_1 = require("@strapi/design-system/ModalLayout");
10
+ const utils_1 = require("../../../../utils");
11
+ const NavigationItemPopupHeader = ({ isNewItem }) => {
12
+ return (react_1.default.createElement(ModalLayout_1.ModalHeader, null,
13
+ react_1.default.createElement(Typography_1.Typography, { variant: "omega", fontWeight: "bold", textColor: "neutral800", as: "h2", id: "asset-dialog-title" }, (0, utils_1.getMessage)(`popup.item.header.${isNewItem ? 'new' : 'edit'}`))));
14
+ };
15
+ exports.NavigationItemPopupHeader = NavigationItemPopupHeader;
16
+ //# sourceMappingURL=NavigationItemPopupHeader.js.map
@@ -0,0 +1,27 @@
1
+ export default NavigationItemPopUp;
2
+ declare function NavigationItemPopUp({ isOpen, isLoading, data, config, onSubmit, onClose, usedContentTypeItems, getContentTypeItems, usedContentTypesData, locale, }: {
3
+ isOpen: any;
4
+ isLoading: any;
5
+ data: any;
6
+ config?: {} | undefined;
7
+ onSubmit: any;
8
+ onClose: any;
9
+ usedContentTypeItems: any;
10
+ getContentTypeItems: any;
11
+ usedContentTypesData: any;
12
+ locale: any;
13
+ }): JSX.Element;
14
+ declare namespace NavigationItemPopUp {
15
+ namespace propTypes {
16
+ const data: PropTypes.Validator<object>;
17
+ const config: PropTypes.Validator<object>;
18
+ const isOpen: PropTypes.Requireable<boolean>;
19
+ const isLoading: PropTypes.Requireable<boolean>;
20
+ const onSubmit: PropTypes.Validator<(...args: any[]) => any>;
21
+ const onClose: PropTypes.Validator<(...args: any[]) => any>;
22
+ const getContentTypeItems: PropTypes.Validator<(...args: any[]) => any>;
23
+ const locale: PropTypes.Requireable<string>;
24
+ }
25
+ }
26
+ import PropTypes from "prop-types";
27
+ //# sourceMappingURL=index.d.ts.map
@@ -1,112 +1,63 @@
1
- /**
2
- *
3
- * NavigationItemPopUp
4
- *
5
- */
6
-
7
- import React from 'react';
8
- import PropTypes from 'prop-types';
9
- import { find } from 'lodash';
10
-
11
- //Design System
12
- import { ModalLayout } from '@strapi/design-system/ModalLayout';
13
-
14
- import NavigationItemForm from '../NavigationItemForm';
15
- import { extractRelatedItemLabel, isRelationCorrect, isRelationPublished } from '../../utils/parsers';
16
- import { navigationItemType } from '../../utils/enums';
17
- import { NavigationItemPopupHeader } from './NavigationItemPopupHeader';
18
- import { getMessage } from '../../../../utils';
19
-
20
- const NavigationItemPopUp = ({
21
- isOpen,
22
- isLoading,
23
- data,
24
- config = {},
25
- onSubmit,
26
- onClose,
27
- usedContentTypeItems,
28
- getContentTypeItems,
29
- usedContentTypesData,
30
- }) => {
31
-
32
-
33
- const handleOnSubmit = (payload) => {
34
- onSubmit(payload);
35
- };
36
-
37
- const { related, relatedType } = data;
38
- const {
39
- availableAudience = [],
40
- additionalFields,
41
- contentTypes,
42
- contentTypeItems,
43
- contentTypesNameFields = {},
44
- } = config;
45
-
46
-
47
- const appendLabelPublicationStatus = (label = '', item = {}, isCollection = false) => {
48
- const appendix = isRelationPublished({
49
- relatedRef: item,
50
- type: item.isSingle ? navigationItemType.INTERNAL : item.type,
51
- isCollection,
52
- }) ? '' : `[${getMessage('notification.navigation.item.relation.status.draft')}] `.toUpperCase();
53
- return `${appendix}${label}`;
54
- };
55
-
56
- const relatedTypeItem = find(contentTypes, item => item.uid === relatedType);
57
- const prepareFormData = data => {
58
- const relatedItem = find(contentTypeItems, item => item.id === related);
59
- return {
60
- ...data,
61
- type: isRelationCorrect(data) ? data.type : undefined,
62
- related: related && isRelationCorrect(data) ? {
63
- value: related,
64
- label: appendLabelPublicationStatus(
65
- extractRelatedItemLabel({
66
- ...relatedItem,
67
- __collectionUid: relatedType,
68
- }, contentTypesNameFields, config),
69
- relatedItem,
70
- ),
71
- } : undefined,
72
- relatedType: relatedType && isRelationCorrect(data) ? {
73
- value: relatedType,
74
- label: appendLabelPublicationStatus(relatedTypeItem.label || relatedTypeItem.name, relatedTypeItem, true),
75
- } : undefined,
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 prop_types_1 = __importDefault(require("prop-types"));
8
+ const lodash_1 = require("lodash");
9
+ const ModalLayout_1 = require("@strapi/design-system/ModalLayout");
10
+ const NavigationItemForm_1 = __importDefault(require("../NavigationItemForm"));
11
+ const parsers_1 = require("../../utils/parsers");
12
+ const enums_1 = require("../../utils/enums");
13
+ const NavigationItemPopupHeader_1 = require("./NavigationItemPopupHeader");
14
+ const utils_1 = require("../../../../utils");
15
+ const NavigationItemPopUp = ({ isOpen, isLoading, data, config = {}, onSubmit, onClose, usedContentTypeItems, getContentTypeItems, usedContentTypesData, locale, }) => {
16
+ const handleOnSubmit = (payload) => {
17
+ onSubmit(payload);
18
+ };
19
+ const { related, relatedType } = data;
20
+ const { availableAudience = [], additionalFields, contentTypes, contentTypeItems, contentTypesNameFields = {}, } = config;
21
+ const appendLabelPublicationStatus = (label = '', item = {}, isCollection = false) => {
22
+ const appendix = (0, parsers_1.isRelationPublished)({
23
+ relatedRef: item,
24
+ type: item.isSingle ? enums_1.navigationItemType.INTERNAL : item.type,
25
+ isCollection,
26
+ }) ? '' : `[${(0, utils_1.getMessage)('notification.navigation.item.relation.status.draft')}] `.toUpperCase();
27
+ return `${appendix}${label}`;
28
+ };
29
+ const relatedTypeItem = (0, lodash_1.find)(contentTypes, item => item.uid === relatedType);
30
+ const prepareFormData = data => {
31
+ const relatedItem = (0, lodash_1.find)(contentTypeItems, item => item.id === related);
32
+ return {
33
+ ...data,
34
+ type: (0, parsers_1.isRelationCorrect)(data) ? data.type : undefined,
35
+ related: related && (0, parsers_1.isRelationCorrect)(data) ? {
36
+ value: related,
37
+ label: appendLabelPublicationStatus((0, parsers_1.extractRelatedItemLabel)({
38
+ ...relatedItem,
39
+ __collectionUid: relatedType,
40
+ }, contentTypesNameFields, config), relatedItem),
41
+ } : undefined,
42
+ relatedType: relatedType && (0, parsers_1.isRelationCorrect)(data) ? {
43
+ value: relatedType,
44
+ label: appendLabelPublicationStatus(relatedTypeItem.label || relatedTypeItem.name, relatedTypeItem, true),
45
+ } : undefined,
46
+ };
76
47
  };
77
- };
78
-
79
- return (
80
- <ModalLayout labelledBy="condition-modal-breadcrumbs" onClose={onClose} isOpen={isOpen}>
81
- <NavigationItemPopupHeader isNewItem={!data.viewId}/>
82
- <NavigationItemForm
83
- data={prepareFormData(data)}
84
- isLoading={isLoading}
85
- additionalFields={additionalFields}
86
- contentTypesNameFields={contentTypesNameFields}
87
- availableAudience={availableAudience}
88
- contentTypes={contentTypes}
89
- contentTypeEntities={contentTypeItems}
90
- usedContentTypeEntities={usedContentTypeItems}
91
- getContentTypeEntities={getContentTypeItems}
92
- usedContentTypesData={usedContentTypesData}
93
- onSubmit={handleOnSubmit}
94
- onCancel={onClose}
95
- appendLabelPublicationStatus={appendLabelPublicationStatus}
96
- />
97
- </ModalLayout>
98
-
99
- );
48
+ return (react_1.default.createElement(ModalLayout_1.ModalLayout, { labelledBy: "condition-modal-breadcrumbs", onClose: onClose, isOpen: isOpen },
49
+ react_1.default.createElement(NavigationItemPopupHeader_1.NavigationItemPopupHeader, { isNewItem: !data.viewId }),
50
+ react_1.default.createElement(NavigationItemForm_1.default, { data: prepareFormData(data), isLoading: isLoading, additionalFields: additionalFields, contentTypesNameFields: contentTypesNameFields, availableAudience: availableAudience, contentTypes: contentTypes, contentTypeEntities: contentTypeItems, usedContentTypeEntities: usedContentTypeItems, getContentTypeEntities: getContentTypeItems, usedContentTypesData: usedContentTypesData, onSubmit: handleOnSubmit, onCancel: onClose, appendLabelPublicationStatus: appendLabelPublicationStatus, locale: locale })));
100
51
  };
101
-
102
52
  NavigationItemPopUp.propTypes = {
103
- data: PropTypes.object.isRequired,
104
- config: PropTypes.object.isRequired,
105
- isOpen: PropTypes.bool,
106
- isLoading: PropTypes.bool,
107
- onSubmit: PropTypes.func.isRequired,
108
- onClose: PropTypes.func.isRequired,
109
- getContentTypeItems: PropTypes.func.isRequired,
53
+ data: prop_types_1.default.object.isRequired,
54
+ config: prop_types_1.default.object.isRequired,
55
+ isOpen: prop_types_1.default.bool,
56
+ isLoading: prop_types_1.default.bool,
57
+ onSubmit: prop_types_1.default.func.isRequired,
58
+ onClose: prop_types_1.default.func.isRequired,
59
+ getContentTypeItems: prop_types_1.default.func.isRequired,
60
+ locale: prop_types_1.default.string
110
61
  };
111
-
112
- export default NavigationItemPopUp;
62
+ exports.default = NavigationItemPopUp;
63
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,4 @@
1
+ declare var _default: React.MemoExoticComponent<() => JSX.Element>;
2
+ export default _default;
3
+ import React from "react";
4
+ //# sourceMappingURL=index.d.ts.map