@webbio/strapi-plugin-page-builder 0.12.2-platform → 0.12.4-platform

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 (172) hide show
  1. package/README.md +166 -166
  2. package/admin/src/api/collection-type.ts +111 -111
  3. package/admin/src/api/entity-relation.ts +42 -42
  4. package/admin/src/api/has-page-relation.ts +37 -37
  5. package/admin/src/api/has-platform-relation.ts +40 -40
  6. package/admin/src/api/page-type-relation.ts +41 -41
  7. package/admin/src/api/platform-page-types.ts +45 -45
  8. package/admin/src/api/platform-relation.ts +42 -42
  9. package/admin/src/api/platform.ts +35 -35
  10. package/admin/src/api/search-filtered-entity.ts +114 -114
  11. package/admin/src/api/template.ts +39 -39
  12. package/admin/src/components/Combobox/index.tsx +83 -83
  13. package/admin/src/components/Combobox/react-select-custom-styles.tsx +121 -121
  14. package/admin/src/components/Combobox/styles.ts +46 -46
  15. package/admin/src/components/ConfirmModal/index.tsx +90 -90
  16. package/admin/src/components/EditView/CollectionTypeSearch/index.tsx +127 -127
  17. package/admin/src/components/EditView/CollectionTypeSettings/CreatePageButton/index.tsx +149 -149
  18. package/admin/src/components/EditView/CollectionTypeSettings/CreatePageButton/styles.ts +19 -19
  19. package/admin/src/components/EditView/CollectionTypeSettings/index.tsx +82 -82
  20. package/admin/src/components/EditView/Details/index.tsx +48 -48
  21. package/admin/src/components/EditView/Details/styles.ts +51 -51
  22. package/admin/src/components/EditView/PageSettings/index.tsx +124 -124
  23. package/admin/src/components/EditView/Platform/platform-select.tsx +30 -30
  24. package/admin/src/components/EditView/Template/TemplateConfirmModal/index.tsx +36 -36
  25. package/admin/src/components/EditView/Template/TemplateSelect/index.tsx +70 -70
  26. package/admin/src/components/EditView/Template/TemplateSelect/use-template-modules.ts +41 -41
  27. package/admin/src/components/EditView/index.tsx +35 -35
  28. package/admin/src/components/EditView/page-type-select.tsx +32 -32
  29. package/admin/src/components/EditView/wrapper.tsx +41 -41
  30. package/admin/src/components/GlobalPlatformSelect/index.tsx +40 -40
  31. package/admin/src/components/GlobalPlatformSelect/styles.ts +27 -27
  32. package/admin/src/components/Initializer/index.tsx +24 -24
  33. package/admin/src/components/PageFilters/PageTypeFilter/index.tsx +39 -39
  34. package/admin/src/components/PageFilters/PlatformFilter/index.tsx +32 -32
  35. package/admin/src/components/PageFilters/filters.tsx +189 -189
  36. package/admin/src/components/PageFilters/index.tsx +35 -35
  37. package/admin/src/components/PageTypeEditView/TemplatePlatformSelect/index.tsx +76 -76
  38. package/admin/src/components/PageTypeEditView/index.tsx +53 -53
  39. package/admin/src/components/PlatformFilteredSelectField/InputIcon/index.tsx +23 -23
  40. package/admin/src/components/PlatformFilteredSelectField/Multi/index.tsx +210 -210
  41. package/admin/src/components/PlatformFilteredSelectField/Single/index.tsx +197 -197
  42. package/admin/src/components/PlatformFilteredSelectField/hooks/useRelationLoad.tsx +128 -128
  43. package/admin/src/components/PlatformFilteredSelectField/index.tsx +85 -85
  44. package/admin/src/components/PlatformFilteredSelectField/styles.tsx +77 -77
  45. package/admin/src/components/PlatformFilteredSelectField/utils/get-translations.ts +3 -3
  46. package/admin/src/components/PlatformFilteredSelectField/utils/relation-helper.ts +147 -147
  47. package/admin/src/components/PluginIcon/index.tsx +94 -94
  48. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/components/Relations/RelationInput.tsx +689 -689
  49. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/components/Relations/RelationInputDataManager.tsx +6 -6
  50. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/components/Relations/useRelation.ts +170 -170
  51. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/components/Relations/utils/getRelationLink.ts +5 -5
  52. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/components/Relations/utils/normalizeRelations.ts +52 -52
  53. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/constants/attributes.ts +3 -3
  54. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/hooks/useDragAndDrop.ts +253 -253
  55. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/hooks/useKeyboardDragAndDrop.ts +96 -96
  56. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/hooks/usePrev.ts +11 -11
  57. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/utils/dragAndDrop.ts +8 -8
  58. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/utils/paths.ts +29 -29
  59. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/utils/refs.ts +19 -19
  60. package/admin/src/components/StrapiCore/admin/admin/src/content-manager/utils/translations.ts +3 -3
  61. package/admin/src/components/StrapiCore/content-manager/shared/contracts/collection-types.ts +300 -300
  62. package/admin/src/components/StrapiCore/content-manager/shared/contracts/components.ts +72 -72
  63. package/admin/src/components/StrapiCore/content-manager/shared/contracts/content-types.ts +116 -116
  64. package/admin/src/components/StrapiCore/content-manager/shared/contracts/index.ts +8 -8
  65. package/admin/src/components/StrapiCore/content-manager/shared/contracts/init.ts +22 -22
  66. package/admin/src/components/StrapiCore/content-manager/shared/contracts/relations.ts +80 -80
  67. package/admin/src/components/StrapiCore/content-manager/shared/contracts/review-workflows.ts +88 -88
  68. package/admin/src/components/StrapiCore/content-manager/shared/contracts/single-types.ts +112 -112
  69. package/admin/src/components/StrapiCore/content-manager/shared/contracts/uid.ts +48 -48
  70. package/admin/src/components/StrapiCore/content-manager/shared/index.ts +1 -1
  71. package/admin/src/constants.ts +3 -3
  72. package/admin/src/index.tsx +101 -101
  73. package/admin/src/middlewares/index.tsx +37 -37
  74. package/admin/src/pages/app/index.tsx +14 -14
  75. package/admin/src/pluginId.ts +5 -5
  76. package/admin/src/translations/en.json +9 -9
  77. package/admin/src/translations/nl.json +9 -9
  78. package/admin/src/utils/findDomElement.ts +6 -6
  79. package/admin/src/utils/findElementParent.ts +20 -20
  80. package/admin/src/utils/getObjectFromFormName.ts +42 -42
  81. package/admin/src/utils/getRequestUrl.ts +11 -11
  82. package/admin/src/utils/getTrad.ts +5 -5
  83. package/admin/src/utils/hooks/useDebounce.ts +17 -17
  84. package/admin/src/utils/hooks/useDefaultPlatformFromLocalStorage.ts +61 -61
  85. package/admin/src/utils/hooks/useGetLocaleFromUrl.ts +9 -9
  86. package/admin/src/utils/hooks/useHideOverviewFilterTags.ts +34 -34
  87. package/admin/src/utils/hooks/usePlatformFormData.ts +64 -64
  88. package/admin/src/utils/hooks/usePrevious.ts +12 -12
  89. package/admin/src/utils/sanitizeModules.ts +93 -93
  90. package/custom.d.ts +6 -6
  91. package/dist/package.json +1 -1
  92. package/dist/server/bootstrap/collection-type-lifecycles.js +1 -1
  93. package/dist/server/bootstrap.js +1 -1
  94. package/dist/server/graphql/page-by-path.js +20 -17
  95. package/dist/server/graphql/page-by-slug.js +9 -9
  96. package/dist/server/graphql/pages-by-uid.js +5 -5
  97. package/dist/server/services/private-content/graphql/index.js +27 -27
  98. package/dist/server/services/private-content/graphql/types/index.js +74 -74
  99. package/dist/server/utils/graphql.js +18 -18
  100. package/dist/tsconfig.server.tsbuildinfo +1 -1
  101. package/package.json +78 -78
  102. package/server/bootstrap/collection-type-lifecycles.ts +47 -47
  103. package/server/bootstrap/permissions.ts +161 -161
  104. package/server/bootstrap.ts +261 -261
  105. package/server/config/index.ts +4 -4
  106. package/server/content-types/index.ts +7 -7
  107. package/server/content-types/user-category/schema.json +23 -23
  108. package/server/controllers/collection-types.ts +32 -32
  109. package/server/controllers/index.ts +19 -19
  110. package/server/controllers/page-type.ts +18 -18
  111. package/server/controllers/page.ts +9 -9
  112. package/server/controllers/platform.ts +21 -21
  113. package/server/controllers/private-content.ts +17 -17
  114. package/server/controllers/sitemap.ts +32 -32
  115. package/server/controllers/template.ts +16 -16
  116. package/server/controllers/user-category.ts +3 -3
  117. package/server/destroy.ts +5 -5
  118. package/server/graphql/index.ts +9 -9
  119. package/server/graphql/page-by-path.ts +135 -132
  120. package/server/graphql/page-type.ts +67 -67
  121. package/server/graphql/pages-by-uid.ts +89 -89
  122. package/server/index.ts +23 -23
  123. package/server/middlewares/index.ts +1 -1
  124. package/server/policies/index.ts +5 -5
  125. package/server/policies/isAuthorizedPage.ts +11 -11
  126. package/server/register.ts +22 -22
  127. package/server/routes/index.ts +115 -115
  128. package/server/routes/user-category.ts +3 -3
  129. package/server/schema/page-end.json +96 -96
  130. package/server/schema/page-start.json +87 -87
  131. package/server/schema/page-type-end.json +53 -53
  132. package/server/schema/page-type-start.json +38 -38
  133. package/server/schema/platform-start.json +21 -21
  134. package/server/schema/template-end.json +40 -40
  135. package/server/schema/template-start.json +35 -35
  136. package/server/services/builder.ts +232 -232
  137. package/server/services/collection-types.ts +95 -95
  138. package/server/services/email.ts +127 -127
  139. package/server/services/index.ts +23 -23
  140. package/server/services/page-type.ts +30 -30
  141. package/server/services/page.ts +24 -24
  142. package/server/services/platform.ts +30 -30
  143. package/server/services/private-content/components/admin-email.json +22 -22
  144. package/server/services/private-content/components/email.json +22 -22
  145. package/server/services/private-content/components/platform-email.json +30 -30
  146. package/server/services/private-content/constants/index.ts +13 -13
  147. package/server/services/private-content/graphql/index.ts +88 -88
  148. package/server/services/private-content/graphql/resolvers/findOnePage.ts +40 -40
  149. package/server/services/private-content/graphql/resolvers/findPage.ts +45 -45
  150. package/server/services/private-content/graphql/resolvers/forgot-password.ts +34 -34
  151. package/server/services/private-content/graphql/resolvers/login.ts +56 -56
  152. package/server/services/private-content/graphql/resolvers/register.ts +78 -78
  153. package/server/services/private-content/graphql/resolvers/reset-password.ts +44 -44
  154. package/server/services/private-content/graphql/types/index.ts +96 -96
  155. package/server/services/private-content/index.ts +95 -95
  156. package/server/services/private-content/mail-template/txtMail.email.template.text.ts +6 -6
  157. package/server/services/private-content/page.ts +20 -20
  158. package/server/services/private-content/platform.ts +19 -19
  159. package/server/services/private-content/schemas/index.ts +28 -28
  160. package/server/services/private-content/user.ts +197 -197
  161. package/server/services/sitemap.ts +83 -83
  162. package/server/services/template.ts +13 -13
  163. package/server/services/user-category.ts +3 -3
  164. package/server/utils/filter-underscore-arguments.ts +12 -12
  165. package/server/utils/reload-strapi-on-load.ts +13 -13
  166. package/server/utils/strapi.ts +50 -50
  167. package/shared/utils/constants.ts +8 -8
  168. package/shared/utils/sleep.ts +1 -1
  169. package/strapi-admin.js +3 -3
  170. package/strapi-server.js +3 -3
  171. package/tsconfig.json +20 -20
  172. package/tsconfig.server.json +25 -25
@@ -1,127 +1,127 @@
1
- import React, { useEffect, useState } from 'react';
2
- import { useSelector } from 'react-redux';
3
- import debounce from 'lodash/debounce';
4
- import { OptionProps, SingleValue, components } from 'react-select';
5
- import { useCMEditViewDataManager, useFetchClient } from '@strapi/helper-plugin';
6
-
7
- import { Combobox, IReactSelectValue } from '../../Combobox';
8
- import { getSearchEntities } from '../../../api/collection-type';
9
- import { usePrevious } from '../../../utils/hooks/usePrevious';
10
- import { useGetLocaleFromUrl } from '../../../utils/hooks/useGetLocaleFromUrl';
11
-
12
- const SEARCH_DEBOUNCE_MS = 150;
13
- const PAGE = 1;
14
-
15
- interface Props {
16
- uid: string;
17
- platformTitle?: string;
18
- }
19
-
20
- export const CollectionTypeSearch = ({ uid, platformTitle }: Props) => {
21
- const fetchClient = useFetchClient();
22
- const form = useCMEditViewDataManager() as any;
23
- const { locales } = useSelector((state: any) => state.i18n_locales);
24
- const urlLocale = useGetLocaleFromUrl();
25
- const defaultLocale = locales.find((locale: any) => locale.isDefault);
26
- const selectedLocale = form.initialData?.locale ?? urlLocale ?? defaultLocale.code;
27
- const prevUid = usePrevious(uid);
28
- const prevPlatformTitle = usePrevious(platformTitle);
29
-
30
- const [selected, setSelected] = useState<SingleValue<IReactSelectValue | null>>(
31
- getInitialSelectItem(form.initialData?.collectionTypeId, form.initialData?.collectionTypeTitle)
32
- );
33
-
34
- const isPagePageType = !uid;
35
- const searchEntitiesIsEnabled = !isPagePageType;
36
-
37
- useEffect(() => {
38
- if (form.isCreatingEntry) {
39
- setSelected(null);
40
- }
41
- }, []);
42
-
43
- const getItems = async (inputValue?: string, platformTitle?: string): Promise<IReactSelectValue[]> => {
44
- const searchEntities = await getSearchEntities({
45
- fetchClient,
46
- page: PAGE,
47
- locale: selectedLocale,
48
- uid,
49
- searchQuery: inputValue,
50
- currentCollectionTypeId: form.initialData?.collectionTypeId,
51
- currentPageId: form.initialData?.id,
52
- platformTitle
53
- });
54
-
55
- return searchEntities.results.map((x) => ({
56
- value: String(x.id),
57
- label: x.title,
58
- isDisabled: x.hasPages && !x.isCurrentSelected,
59
- initialSelected: x.isCurrentSelected
60
- }));
61
- };
62
-
63
- const setCollectionTypeId = (item?: SingleValue<IReactSelectValue>) => {
64
- form.onChange({
65
- target: {
66
- name: 'collectionTypeId',
67
- value: item?.value || null
68
- },
69
- shouldSetInitialValue: true
70
- });
71
- setSelected(item || null);
72
- };
73
-
74
- const handleChange = (item?: SingleValue<IReactSelectValue>) => {
75
- setCollectionTypeId(item);
76
- };
77
-
78
- useEffect(() => {
79
- if ((prevUid !== null && prevUid !== uid) || (prevPlatformTitle !== null && prevPlatformTitle !== platformTitle)) {
80
- setSelected(null);
81
- }
82
- }, [uid, platformTitle]);
83
-
84
- const debouncedFetch = debounce((searchTerm, callback, selectedPlatformTitle?: string) => {
85
- promiseOptions(searchTerm, selectedPlatformTitle).then((result) => {
86
- return callback(result || []);
87
- });
88
- }, SEARCH_DEBOUNCE_MS);
89
-
90
- const promiseOptions = (inputValue: string, selectedPlatformTitle?: string): Promise<IReactSelectValue[]> =>
91
- new Promise<IReactSelectValue[]>((resolve) => {
92
- resolve(getItems(inputValue, selectedPlatformTitle));
93
- });
94
-
95
- return (
96
- <Combobox
97
- key={`rerenderOnUidOrPlatformChange-${uid}-${platformTitle}`}
98
- id="collectionTypeSearch"
99
- label="Link"
100
- loadOptions={(i, c) => debouncedFetch(i, c, platformTitle)}
101
- cacheOptions
102
- onChange={handleChange}
103
- customOption={CustomOption}
104
- value={selected}
105
- defaultOptions={searchEntitiesIsEnabled}
106
- />
107
- );
108
- };
109
-
110
- const CustomOption = (props: OptionProps<IReactSelectValue, false>) => {
111
- return (
112
- <components.Option {...props}>
113
- <span>{props.children}</span>
114
- {props.isDisabled && <span>Entiteit heeft al een pagina</span>}
115
- {props.data.initialSelected && <span>Oorspronkelijk gekoppeld</span>}
116
- </components.Option>
117
- );
118
- };
119
-
120
- const getInitialSelectItem = (id?: string, title?: string): SingleValue<IReactSelectValue | null> =>
121
- id
122
- ? {
123
- value: String(id),
124
- label: title ?? '',
125
- initialSelected: true
126
- }
127
- : null;
1
+ import React, { useEffect, useState } from 'react';
2
+ import { useSelector } from 'react-redux';
3
+ import debounce from 'lodash/debounce';
4
+ import { OptionProps, SingleValue, components } from 'react-select';
5
+ import { useCMEditViewDataManager, useFetchClient } from '@strapi/helper-plugin';
6
+
7
+ import { Combobox, IReactSelectValue } from '../../Combobox';
8
+ import { getSearchEntities } from '../../../api/collection-type';
9
+ import { usePrevious } from '../../../utils/hooks/usePrevious';
10
+ import { useGetLocaleFromUrl } from '../../../utils/hooks/useGetLocaleFromUrl';
11
+
12
+ const SEARCH_DEBOUNCE_MS = 150;
13
+ const PAGE = 1;
14
+
15
+ interface Props {
16
+ uid: string;
17
+ platformTitle?: string;
18
+ }
19
+
20
+ export const CollectionTypeSearch = ({ uid, platformTitle }: Props) => {
21
+ const fetchClient = useFetchClient();
22
+ const form = useCMEditViewDataManager() as any;
23
+ const { locales } = useSelector((state: any) => state.i18n_locales);
24
+ const urlLocale = useGetLocaleFromUrl();
25
+ const defaultLocale = locales.find((locale: any) => locale.isDefault);
26
+ const selectedLocale = form.initialData?.locale ?? urlLocale ?? defaultLocale.code;
27
+ const prevUid = usePrevious(uid);
28
+ const prevPlatformTitle = usePrevious(platformTitle);
29
+
30
+ const [selected, setSelected] = useState<SingleValue<IReactSelectValue | null>>(
31
+ getInitialSelectItem(form.initialData?.collectionTypeId, form.initialData?.collectionTypeTitle)
32
+ );
33
+
34
+ const isPagePageType = !uid;
35
+ const searchEntitiesIsEnabled = !isPagePageType;
36
+
37
+ useEffect(() => {
38
+ if (form.isCreatingEntry) {
39
+ setSelected(null);
40
+ }
41
+ }, []);
42
+
43
+ const getItems = async (inputValue?: string, platformTitle?: string): Promise<IReactSelectValue[]> => {
44
+ const searchEntities = await getSearchEntities({
45
+ fetchClient,
46
+ page: PAGE,
47
+ locale: selectedLocale,
48
+ uid,
49
+ searchQuery: inputValue,
50
+ currentCollectionTypeId: form.initialData?.collectionTypeId,
51
+ currentPageId: form.initialData?.id,
52
+ platformTitle
53
+ });
54
+
55
+ return searchEntities.results.map((x) => ({
56
+ value: String(x.id),
57
+ label: x.title,
58
+ isDisabled: x.hasPages && !x.isCurrentSelected,
59
+ initialSelected: x.isCurrentSelected
60
+ }));
61
+ };
62
+
63
+ const setCollectionTypeId = (item?: SingleValue<IReactSelectValue>) => {
64
+ form.onChange({
65
+ target: {
66
+ name: 'collectionTypeId',
67
+ value: item?.value || null
68
+ },
69
+ shouldSetInitialValue: true
70
+ });
71
+ setSelected(item || null);
72
+ };
73
+
74
+ const handleChange = (item?: SingleValue<IReactSelectValue>) => {
75
+ setCollectionTypeId(item);
76
+ };
77
+
78
+ useEffect(() => {
79
+ if ((prevUid !== null && prevUid !== uid) || (prevPlatformTitle !== null && prevPlatformTitle !== platformTitle)) {
80
+ setSelected(null);
81
+ }
82
+ }, [uid, platformTitle]);
83
+
84
+ const debouncedFetch = debounce((searchTerm, callback, selectedPlatformTitle?: string) => {
85
+ promiseOptions(searchTerm, selectedPlatformTitle).then((result) => {
86
+ return callback(result || []);
87
+ });
88
+ }, SEARCH_DEBOUNCE_MS);
89
+
90
+ const promiseOptions = (inputValue: string, selectedPlatformTitle?: string): Promise<IReactSelectValue[]> =>
91
+ new Promise<IReactSelectValue[]>((resolve) => {
92
+ resolve(getItems(inputValue, selectedPlatformTitle));
93
+ });
94
+
95
+ return (
96
+ <Combobox
97
+ key={`rerenderOnUidOrPlatformChange-${uid}-${platformTitle}`}
98
+ id="collectionTypeSearch"
99
+ label="Link"
100
+ loadOptions={(i, c) => debouncedFetch(i, c, platformTitle)}
101
+ cacheOptions
102
+ onChange={handleChange}
103
+ customOption={CustomOption}
104
+ value={selected}
105
+ defaultOptions={searchEntitiesIsEnabled}
106
+ />
107
+ );
108
+ };
109
+
110
+ const CustomOption = (props: OptionProps<IReactSelectValue, false>) => {
111
+ return (
112
+ <components.Option {...props}>
113
+ <span>{props.children}</span>
114
+ {props.isDisabled && <span>Entiteit heeft al een pagina</span>}
115
+ {props.data.initialSelected && <span>Oorspronkelijk gekoppeld</span>}
116
+ </components.Option>
117
+ );
118
+ };
119
+
120
+ const getInitialSelectItem = (id?: string, title?: string): SingleValue<IReactSelectValue | null> =>
121
+ id
122
+ ? {
123
+ value: String(id),
124
+ label: title ?? '',
125
+ initialSelected: true
126
+ }
127
+ : null;
@@ -1,149 +1,149 @@
1
- import React, { useState } from 'react';
2
- import slugify from 'slugify';
3
- import { useSelector } from 'react-redux';
4
- import { useHistory } from 'react-router-dom';
5
-
6
- import { Plus } from '@strapi/icons';
7
- import { useFetchClient, useCMEditViewDataManager } from '@strapi/helper-plugin';
8
-
9
- import getRequestUrl from '../../../../utils/getRequestUrl';
10
- import { sanitizeModules } from '../../../../utils/sanitizeModules';
11
- import { PAGE_UID } from '../../../../../../shared/utils/constants';
12
- import { IGetTranslationPageLinks } from '../../../../../../server/controllers/collection-types';
13
- import { usePlatformFormData } from '../../../../utils/hooks/usePlatformFormData';
14
-
15
- import S from './styles';
16
- import { Platform } from '../../../../api/platform';
17
-
18
- interface ICreatePageButtonProps {
19
- selectedPlatform: Platform;
20
- onCreatedPage?: (page: Record<string, any>) => void;
21
- }
22
-
23
- export const CreatePageButton = ({ selectedPlatform, onCreatedPage }: ICreatePageButtonProps) => {
24
- const history = useHistory();
25
- const form = (useCMEditViewDataManager() || {}) as Record<string, any>;
26
-
27
- const { layout, initialData } = form;
28
-
29
- const { locales } = useSelector((state: any) => state.i18n_locales);
30
-
31
- const { post, get, put } = useFetchClient();
32
- const url = `/content-manager/collectionType/${PAGE_UID}/create`;
33
-
34
- const handleCreatePage = async (e: React.MouseEvent<HTMLAnchorElement>) => {
35
- e.preventDefault();
36
-
37
- try {
38
- const pageTypeUrl = getRequestUrl(`/page-types/${layout.uid}/${selectedPlatform.id}`);
39
- const { data: pageType } = await get(pageTypeUrl);
40
- const mappedLocalizations = (initialData?.localizations || []).map((x: any) => x?.id).join(',');
41
- const linkedPages: { data: IGetTranslationPageLinks[] } = await get(
42
- getRequestUrl(`/collection-types-page-links/${layout.uid}/${mappedLocalizations}`)
43
- );
44
- const createLocalizedPage = !linkedPages?.data?.find((x) => x.locale === initialData?.locale);
45
- const defaultLocale = locales.find((locale: any) => locale.isDefault);
46
- const locale = initialData?.locale || defaultLocale?.code;
47
-
48
- if (!locale) {
49
- throw new Error('No locale found');
50
- }
51
-
52
- // Get data inside template
53
- let templateData: Record<string, any> | undefined;
54
-
55
- if (pageType?.template?.id) {
56
- templateData = await get(getRequestUrl(`/template/${pageType.template.id}`));
57
- }
58
-
59
- const modules = sanitizeModules(templateData?.data?.modules || [], false);
60
-
61
- const newPage = await createNewPage({
62
- title: initialData?.title,
63
- modules,
64
- post,
65
- locale,
66
- pageTypeId: pageType.id,
67
- platformId: selectedPlatform.id,
68
- parentId: pageType?.defaultParent?.id,
69
- collectionTypeId: initialData.id,
70
- layoutUid: layout.uid,
71
- relatedEntityId: createLocalizedPage ? linkedPages.data?.[0]?.id : undefined
72
- });
73
-
74
- if (newPage?.id) {
75
- onCreatedPage?.(newPage);
76
- await put(`/content-manager/collection-types/${layout.uid}/${initialData.id}`, {
77
- hasPage: false
78
- });
79
-
80
- history.push(`/content-manager/collectionType/${PAGE_UID}/${newPage.id}?plugins[i18n][locale]=${locale}`);
81
- }
82
- } catch (error) {
83
- console.error(error);
84
- }
85
- };
86
-
87
- return (
88
- <S.CreateButton to={url} onClick={handleCreatePage} size="S" variant="secondary" startIcon={<Plus />} width="100%">
89
- Maak een pagina aan
90
- </S.CreateButton>
91
- );
92
- };
93
-
94
- interface ICreateNewPageProps {
95
- title?: string;
96
- locale: string;
97
- collectionTypeId: number;
98
- layoutUid: string;
99
- modules?: Record<string, any>[];
100
- post: any;
101
- pageTypeId: number;
102
- platformId: number;
103
- relatedEntityId?: number;
104
- parentId?: number;
105
- }
106
-
107
- const createNewPage = async ({
108
- title,
109
- post,
110
- locale,
111
- collectionTypeId,
112
- layoutUid,
113
- modules,
114
- pageTypeId,
115
- platformId,
116
- relatedEntityId,
117
- parentId
118
- }: ICreateNewPageProps) => {
119
- // Including locale in url is neccesary.
120
- const relatedEntityIdQuery = relatedEntityId ? `&plugins[i18n][relatedEntityId]=${relatedEntityId}` : '';
121
- const url = `/content-manager/collection-types/${PAGE_UID}?plugins[i18n][locale]=${locale}${relatedEntityIdQuery}`;
122
- const slugData = title
123
- ? {
124
- slug: slugify(title, {
125
- lower: true,
126
- trim: true
127
- })
128
- }
129
- : {};
130
-
131
- const { data: page } = await post(url, {
132
- ...slugData,
133
- title,
134
- locale,
135
- pageType: { connect: [{ id: pageTypeId }] },
136
- platform: { connect: [{ id: platformId }] },
137
- ...(parentId && { parent: { connect: [{ id: parentId }] } }),
138
- collectionTypeData: {
139
- id: collectionTypeId,
140
- __type: layoutUid,
141
- __pivot: {
142
- field: 'page'
143
- }
144
- },
145
- modules
146
- });
147
-
148
- return page;
149
- };
1
+ import React, { useState } from 'react';
2
+ import slugify from 'slugify';
3
+ import { useSelector } from 'react-redux';
4
+ import { useHistory } from 'react-router-dom';
5
+
6
+ import { Plus } from '@strapi/icons';
7
+ import { useFetchClient, useCMEditViewDataManager } from '@strapi/helper-plugin';
8
+
9
+ import getRequestUrl from '../../../../utils/getRequestUrl';
10
+ import { sanitizeModules } from '../../../../utils/sanitizeModules';
11
+ import { PAGE_UID } from '../../../../../../shared/utils/constants';
12
+ import { IGetTranslationPageLinks } from '../../../../../../server/controllers/collection-types';
13
+ import { usePlatformFormData } from '../../../../utils/hooks/usePlatformFormData';
14
+
15
+ import S from './styles';
16
+ import { Platform } from '../../../../api/platform';
17
+
18
+ interface ICreatePageButtonProps {
19
+ selectedPlatform: Platform;
20
+ onCreatedPage?: (page: Record<string, any>) => void;
21
+ }
22
+
23
+ export const CreatePageButton = ({ selectedPlatform, onCreatedPage }: ICreatePageButtonProps) => {
24
+ const history = useHistory();
25
+ const form = (useCMEditViewDataManager() || {}) as Record<string, any>;
26
+
27
+ const { layout, initialData } = form;
28
+
29
+ const { locales } = useSelector((state: any) => state.i18n_locales);
30
+
31
+ const { post, get, put } = useFetchClient();
32
+ const url = `/content-manager/collectionType/${PAGE_UID}/create`;
33
+
34
+ const handleCreatePage = async (e: React.MouseEvent<HTMLAnchorElement>) => {
35
+ e.preventDefault();
36
+
37
+ try {
38
+ const pageTypeUrl = getRequestUrl(`/page-types/${layout.uid}/${selectedPlatform.id}`);
39
+ const { data: pageType } = await get(pageTypeUrl);
40
+ const mappedLocalizations = (initialData?.localizations || []).map((x: any) => x?.id).join(',');
41
+ const linkedPages: { data: IGetTranslationPageLinks[] } = await get(
42
+ getRequestUrl(`/collection-types-page-links/${layout.uid}/${mappedLocalizations}`)
43
+ );
44
+ const createLocalizedPage = !linkedPages?.data?.find((x) => x.locale === initialData?.locale);
45
+ const defaultLocale = locales.find((locale: any) => locale.isDefault);
46
+ const locale = initialData?.locale || defaultLocale?.code;
47
+
48
+ if (!locale) {
49
+ throw new Error('No locale found');
50
+ }
51
+
52
+ // Get data inside template
53
+ let templateData: Record<string, any> | undefined;
54
+
55
+ if (pageType?.template?.id) {
56
+ templateData = await get(getRequestUrl(`/template/${pageType.template.id}`));
57
+ }
58
+
59
+ const modules = sanitizeModules(templateData?.data?.modules || [], false);
60
+
61
+ const newPage = await createNewPage({
62
+ title: initialData?.title,
63
+ modules,
64
+ post,
65
+ locale,
66
+ pageTypeId: pageType.id,
67
+ platformId: selectedPlatform.id,
68
+ parentId: pageType?.defaultParent?.id,
69
+ collectionTypeId: initialData.id,
70
+ layoutUid: layout.uid,
71
+ relatedEntityId: createLocalizedPage ? linkedPages.data?.[0]?.id : undefined
72
+ });
73
+
74
+ if (newPage?.id) {
75
+ onCreatedPage?.(newPage);
76
+ await put(`/content-manager/collection-types/${layout.uid}/${initialData.id}`, {
77
+ hasPage: false
78
+ });
79
+
80
+ history.push(`/content-manager/collectionType/${PAGE_UID}/${newPage.id}?plugins[i18n][locale]=${locale}`);
81
+ }
82
+ } catch (error) {
83
+ console.error(error);
84
+ }
85
+ };
86
+
87
+ return (
88
+ <S.CreateButton to={url} onClick={handleCreatePage} size="S" variant="secondary" startIcon={<Plus />} width="100%">
89
+ Maak een pagina aan
90
+ </S.CreateButton>
91
+ );
92
+ };
93
+
94
+ interface ICreateNewPageProps {
95
+ title?: string;
96
+ locale: string;
97
+ collectionTypeId: number;
98
+ layoutUid: string;
99
+ modules?: Record<string, any>[];
100
+ post: any;
101
+ pageTypeId: number;
102
+ platformId: number;
103
+ relatedEntityId?: number;
104
+ parentId?: number;
105
+ }
106
+
107
+ const createNewPage = async ({
108
+ title,
109
+ post,
110
+ locale,
111
+ collectionTypeId,
112
+ layoutUid,
113
+ modules,
114
+ pageTypeId,
115
+ platformId,
116
+ relatedEntityId,
117
+ parentId
118
+ }: ICreateNewPageProps) => {
119
+ // Including locale in url is neccesary.
120
+ const relatedEntityIdQuery = relatedEntityId ? `&plugins[i18n][relatedEntityId]=${relatedEntityId}` : '';
121
+ const url = `/content-manager/collection-types/${PAGE_UID}?plugins[i18n][locale]=${locale}${relatedEntityIdQuery}`;
122
+ const slugData = title
123
+ ? {
124
+ slug: slugify(title, {
125
+ lower: true,
126
+ trim: true
127
+ })
128
+ }
129
+ : {};
130
+
131
+ const { data: page } = await post(url, {
132
+ ...slugData,
133
+ title,
134
+ locale,
135
+ pageType: { connect: [{ id: pageTypeId }] },
136
+ platform: { connect: [{ id: platformId }] },
137
+ ...(parentId && { parent: { connect: [{ id: parentId }] } }),
138
+ collectionTypeData: {
139
+ id: collectionTypeId,
140
+ __type: layoutUid,
141
+ __pivot: {
142
+ field: 'page'
143
+ }
144
+ },
145
+ modules
146
+ });
147
+
148
+ return page;
149
+ };
@@ -1,19 +1,19 @@
1
- import styled, { css } from 'styled-components';
2
-
3
- import { Button } from '@strapi/design-system';
4
-
5
- const CreateButton = styled(Button)`
6
- ${({ _theme }) => css`
7
- text-decoration: none;
8
-
9
- > div {
10
- display: flex;
11
- }
12
- `}
13
- `;
14
-
15
- const CreatePageButtonStyles = {
16
- CreateButton
17
- };
18
-
19
- export default CreatePageButtonStyles;
1
+ import styled, { css } from 'styled-components';
2
+
3
+ import { Button } from '@strapi/design-system';
4
+
5
+ const CreateButton = styled(Button)`
6
+ ${({ _theme }) => css`
7
+ text-decoration: none;
8
+
9
+ > div {
10
+ display: flex;
11
+ }
12
+ `}
13
+ `;
14
+
15
+ const CreatePageButtonStyles = {
16
+ CreateButton
17
+ };
18
+
19
+ export default CreatePageButtonStyles;