@webbio/strapi-plugin-page-builder 0.12.2-platform → 0.12.3-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.js +1 -1
  93. package/dist/server/graphql/page-by-path.js +20 -17
  94. package/dist/server/graphql/pages-by-uid.js +5 -5
  95. package/dist/server/services/private-content/graphql/index.js +27 -27
  96. package/dist/server/services/private-content/graphql/types/index.js +74 -74
  97. package/dist/tsconfig.server.tsbuildinfo +1 -1
  98. package/package.json +78 -78
  99. package/server/bootstrap/collection-type-lifecycles.ts +47 -47
  100. package/server/bootstrap/permissions.ts +161 -161
  101. package/server/bootstrap.ts +261 -261
  102. package/server/config/index.ts +4 -4
  103. package/server/content-types/index.ts +7 -7
  104. package/server/content-types/user-category/schema.json +23 -23
  105. package/server/controllers/collection-types.ts +32 -32
  106. package/server/controllers/index.ts +19 -19
  107. package/server/controllers/page-type.ts +18 -18
  108. package/server/controllers/page.ts +9 -9
  109. package/server/controllers/platform.ts +21 -21
  110. package/server/controllers/private-content.ts +17 -17
  111. package/server/controllers/sitemap.ts +32 -32
  112. package/server/controllers/template.ts +16 -16
  113. package/server/controllers/user-category.ts +3 -3
  114. package/server/destroy.ts +5 -5
  115. package/server/graphql/index.ts +9 -9
  116. package/server/graphql/page-by-path.ts +135 -132
  117. package/server/graphql/page-type.ts +67 -67
  118. package/server/graphql/pages-by-uid.ts +89 -89
  119. package/server/index.ts +23 -23
  120. package/server/middlewares/index.ts +1 -1
  121. package/server/policies/index.ts +5 -5
  122. package/server/policies/isAuthorizedPage.ts +11 -11
  123. package/server/register.ts +22 -22
  124. package/server/routes/index.ts +115 -115
  125. package/server/routes/user-category.ts +3 -3
  126. package/server/schema/page-end.json +96 -96
  127. package/server/schema/page-start.json +87 -87
  128. package/server/schema/page-type-end.json +53 -53
  129. package/server/schema/page-type-start.json +38 -38
  130. package/server/schema/platform-start.json +21 -21
  131. package/server/schema/template-end.json +40 -40
  132. package/server/schema/template-start.json +35 -35
  133. package/server/services/builder.ts +232 -232
  134. package/server/services/collection-types.ts +95 -95
  135. package/server/services/email.ts +127 -127
  136. package/server/services/index.ts +23 -23
  137. package/server/services/page-type.ts +30 -30
  138. package/server/services/page.ts +24 -24
  139. package/server/services/platform.ts +30 -30
  140. package/server/services/private-content/components/admin-email.json +22 -22
  141. package/server/services/private-content/components/email.json +22 -22
  142. package/server/services/private-content/components/platform-email.json +30 -30
  143. package/server/services/private-content/constants/index.ts +13 -13
  144. package/server/services/private-content/graphql/index.ts +88 -88
  145. package/server/services/private-content/graphql/resolvers/findOnePage.ts +40 -40
  146. package/server/services/private-content/graphql/resolvers/findPage.ts +45 -45
  147. package/server/services/private-content/graphql/resolvers/forgot-password.ts +34 -34
  148. package/server/services/private-content/graphql/resolvers/login.ts +56 -56
  149. package/server/services/private-content/graphql/resolvers/register.ts +78 -78
  150. package/server/services/private-content/graphql/resolvers/reset-password.ts +44 -44
  151. package/server/services/private-content/graphql/types/index.ts +96 -96
  152. package/server/services/private-content/index.ts +95 -95
  153. package/server/services/private-content/mail-template/txtMail.email.template.text.ts +6 -6
  154. package/server/services/private-content/page.ts +20 -20
  155. package/server/services/private-content/platform.ts +19 -19
  156. package/server/services/private-content/schemas/index.ts +28 -28
  157. package/server/services/private-content/user.ts +197 -197
  158. package/server/services/sitemap.ts +83 -83
  159. package/server/services/template.ts +13 -13
  160. package/server/services/user-category.ts +3 -3
  161. package/server/utils/filter-underscore-arguments.ts +12 -12
  162. package/server/utils/reload-strapi-on-load.ts +13 -13
  163. package/server/utils/strapi.ts +50 -50
  164. package/shared/utils/constants.ts +8 -8
  165. package/shared/utils/sleep.ts +1 -1
  166. package/strapi-admin.js +3 -3
  167. package/strapi-server.js +3 -3
  168. package/tsconfig.json +20 -20
  169. package/tsconfig.server.json +25 -25
  170. package/dist/server/graphql/page-by-slug.js +0 -89
  171. package/dist/server/utils/graphql.js +0 -100
  172. package/dist/server/utils/paginationValidation.js +0 -31
@@ -1,27 +1,27 @@
1
- import styled, { css } from 'styled-components';
2
-
3
- const Wrapper = styled.div<{ small?: boolean }>`
4
- ${({ theme, small }) => {
5
- return css`
6
- width: ${small ? '72px' : '224px'};
7
- &:hover {
8
- width: 224px;
9
- transition: ${small ? 'width 0.15s ease-in-out' : 'none'};
10
- }
11
- display: flex;
12
- flex-direction: column;
13
- gap: 4px;
14
- position: fixed;
15
- top: 64px;
16
- left: 0;
17
- z-index: 4;
18
- padding: 0 8px 0 12px;
19
- `;
20
- }}
21
- `;
22
-
23
- const GlobalPlatformSelectStyles = {
24
- Wrapper
25
- };
26
-
27
- export default GlobalPlatformSelectStyles;
1
+ import styled, { css } from 'styled-components';
2
+
3
+ const Wrapper = styled.div<{ small?: boolean }>`
4
+ ${({ theme, small }) => {
5
+ return css`
6
+ width: ${small ? '72px' : '224px'};
7
+ &:hover {
8
+ width: 224px;
9
+ transition: ${small ? 'width 0.15s ease-in-out' : 'none'};
10
+ }
11
+ display: flex;
12
+ flex-direction: column;
13
+ gap: 4px;
14
+ position: fixed;
15
+ top: 64px;
16
+ left: 0;
17
+ z-index: 4;
18
+ padding: 0 8px 0 12px;
19
+ `;
20
+ }}
21
+ `;
22
+
23
+ const GlobalPlatformSelectStyles = {
24
+ Wrapper
25
+ };
26
+
27
+ export default GlobalPlatformSelectStyles;
@@ -1,24 +1,24 @@
1
- /**
2
- *
3
- * Initializer
4
- *
5
- */
6
-
7
- import { useEffect, useRef } from 'react';
8
- import pluginId from '../../pluginId';
9
-
10
- type InitializerProps = {
11
- setPlugin: (id: string) => void;
12
- };
13
-
14
- const Initializer = ({ setPlugin }: InitializerProps) => {
15
- const ref = useRef(setPlugin);
16
-
17
- useEffect(() => {
18
- ref.current(pluginId);
19
- }, []);
20
-
21
- return null;
22
- };
23
-
24
- export default Initializer;
1
+ /**
2
+ *
3
+ * Initializer
4
+ *
5
+ */
6
+
7
+ import { useEffect, useRef } from 'react';
8
+ import pluginId from '../../pluginId';
9
+
10
+ type InitializerProps = {
11
+ setPlugin: (id: string) => void;
12
+ };
13
+
14
+ const Initializer = ({ setPlugin }: InitializerProps) => {
15
+ const ref = useRef(setPlugin);
16
+
17
+ useEffect(() => {
18
+ ref.current(pluginId);
19
+ }, []);
20
+
21
+ return null;
22
+ };
23
+
24
+ export default Initializer;
@@ -1,39 +1,39 @@
1
- import React from 'react';
2
-
3
- import { SingleSelectOption, SingleSelect } from '@strapi/design-system';
4
-
5
- import { PageType } from '../../../api/platform-page-types';
6
- import { PAGE_TYPE_NO_FILTER } from '../../../constants';
7
- import { PAGE_TYPE_PAGE } from '../../../../../shared/utils/constants';
8
-
9
- interface Props {
10
- onChange: (pageTypeUId: string) => void;
11
- selectedPageTypeUid?: string;
12
- pageTypes?: PageType[];
13
- }
14
-
15
- const PageTypeFilter = ({ onChange, pageTypes, selectedPageTypeUid }: Props) => {
16
- return (
17
- <SingleSelect
18
- placeholder="Pagina types"
19
- onChange={onChange}
20
- size="S"
21
- value={selectedPageTypeUid}
22
- disabled={(pageTypes?.length || 0) === 0}
23
- >
24
- <SingleSelectOption key={PAGE_TYPE_NO_FILTER} value={PAGE_TYPE_NO_FILTER}>
25
- Alle pagina types
26
- </SingleSelectOption>
27
- <SingleSelectOption key={PAGE_TYPE_PAGE} value={PAGE_TYPE_PAGE}>
28
- Pagina
29
- </SingleSelectOption>
30
- {pageTypes?.map((pageType) => (
31
- <SingleSelectOption key={pageType.uid} value={pageType.uid}>
32
- {pageType.title || pageType.uid}
33
- </SingleSelectOption>
34
- ))}
35
- </SingleSelect>
36
- );
37
- };
38
-
39
- export default PageTypeFilter;
1
+ import React from 'react';
2
+
3
+ import { SingleSelectOption, SingleSelect } from '@strapi/design-system';
4
+
5
+ import { PageType } from '../../../api/platform-page-types';
6
+ import { PAGE_TYPE_NO_FILTER } from '../../../constants';
7
+ import { PAGE_TYPE_PAGE } from '../../../../../shared/utils/constants';
8
+
9
+ interface Props {
10
+ onChange: (pageTypeUId: string) => void;
11
+ selectedPageTypeUid?: string;
12
+ pageTypes?: PageType[];
13
+ }
14
+
15
+ const PageTypeFilter = ({ onChange, pageTypes, selectedPageTypeUid }: Props) => {
16
+ return (
17
+ <SingleSelect
18
+ placeholder="Pagina types"
19
+ onChange={onChange}
20
+ size="S"
21
+ value={selectedPageTypeUid}
22
+ disabled={(pageTypes?.length || 0) === 0}
23
+ >
24
+ <SingleSelectOption key={PAGE_TYPE_NO_FILTER} value={PAGE_TYPE_NO_FILTER}>
25
+ Alle pagina types
26
+ </SingleSelectOption>
27
+ <SingleSelectOption key={PAGE_TYPE_PAGE} value={PAGE_TYPE_PAGE}>
28
+ Pagina
29
+ </SingleSelectOption>
30
+ {pageTypes?.map((pageType) => (
31
+ <SingleSelectOption key={pageType.uid} value={pageType.uid}>
32
+ {pageType.title || pageType.uid}
33
+ </SingleSelectOption>
34
+ ))}
35
+ </SingleSelect>
36
+ );
37
+ };
38
+
39
+ export default PageTypeFilter;
@@ -1,32 +1,32 @@
1
- import React from 'react';
2
-
3
- import { SingleSelectOption, SingleSelect } from '@strapi/design-system';
4
- import { Platform } from '../../../api/platform';
5
-
6
- interface Props {
7
- onChange?: (platform: Platform) => void;
8
- selectedPlatform?: Platform;
9
- platforms?: Platform[];
10
- }
11
-
12
- const PlatformFilter = ({ onChange, platforms, selectedPlatform }: Props) => {
13
- const handleChange = (platformId?: string) => {
14
- const foundPlatform = platforms?.find((platform) => platform?.id === Number(platformId));
15
-
16
- if (foundPlatform) {
17
- onChange?.(foundPlatform);
18
- }
19
- };
20
-
21
- return (
22
- <SingleSelect placeholder="Selecteer platform" onChange={handleChange} size="S" value={selectedPlatform?.id}>
23
- {platforms?.map((platform: Platform) => (
24
- <SingleSelectOption key={platform?.id} value={platform?.id}>
25
- {platform?.title}
26
- </SingleSelectOption>
27
- ))}
28
- </SingleSelect>
29
- );
30
- };
31
-
32
- export default PlatformFilter;
1
+ import React from 'react';
2
+
3
+ import { SingleSelectOption, SingleSelect } from '@strapi/design-system';
4
+ import { Platform } from '../../../api/platform';
5
+
6
+ interface Props {
7
+ onChange?: (platform: Platform) => void;
8
+ selectedPlatform?: Platform;
9
+ platforms?: Platform[];
10
+ }
11
+
12
+ const PlatformFilter = ({ onChange, platforms, selectedPlatform }: Props) => {
13
+ const handleChange = (platformId?: string) => {
14
+ const foundPlatform = platforms?.find((platform) => platform?.id === Number(platformId));
15
+
16
+ if (foundPlatform) {
17
+ onChange?.(foundPlatform);
18
+ }
19
+ };
20
+
21
+ return (
22
+ <SingleSelect placeholder="Selecteer platform" onChange={handleChange} size="S" value={selectedPlatform?.id}>
23
+ {platforms?.map((platform: Platform) => (
24
+ <SingleSelectOption key={platform?.id} value={platform?.id}>
25
+ {platform?.title}
26
+ </SingleSelectOption>
27
+ ))}
28
+ </SingleSelect>
29
+ );
30
+ };
31
+
32
+ export default PlatformFilter;
@@ -1,189 +1,189 @@
1
- import { useEffect, useMemo } from 'react';
2
- import set from 'lodash/set';
3
-
4
- import { Stack } from '@strapi/design-system';
5
- import { useQueryParams } from '@strapi/helper-plugin';
6
-
7
- import PageTypeFilter from './PageTypeFilter';
8
- import { PAGE_TYPE_PAGE, PLATFORM } from '../../../../shared/utils/constants';
9
- import { Platform, useGetPlatforms } from '../../api/platform';
10
- import { PAGE_TYPE, PAGE_TYPE_NO_FILTER, PLATFORM_NO_FILTER } from '../../constants';
11
- import { PageType } from '../../api/platform-page-types';
12
- import { useGetPageTypesForPlatform } from '../../api/platform-page-types';
13
- import { useDefaultPlatformFromLocalStorage } from '../../utils/hooks/useDefaultPlatformFromLocalStorage';
14
- import { useHideOverviewFilterTags } from '../../utils/hooks/useHideOverviewFilterTags';
15
-
16
- interface PageFiltersProps {
17
- hidePageType?: boolean;
18
- }
19
-
20
- const PageFilters = ({ hidePageType }: PageFiltersProps) => {
21
- const [{ query }, setQuery] = useQueryParams() as any;
22
- const { selectedPlatform: globalSelectedPlatform } = useDefaultPlatformFromLocalStorage();
23
- useHideOverviewFilterTags();
24
- const { data: platforms } = useGetPlatforms({});
25
-
26
- const { data: pageTypesForPlatform } = useGetPageTypesForPlatform({
27
- id: globalSelectedPlatform?.id
28
- });
29
-
30
- const selectedPageTypeUid = useMemo(
31
- () => getPageTypeFromQuery(query, pageTypesForPlatform),
32
- [query, platforms, globalSelectedPlatform, pageTypesForPlatform]
33
- );
34
-
35
- const handleFilterChange = (
36
- filters: Record<string, any>,
37
- filterCategory: string,
38
- filterCategoryToRemove?: string
39
- ) => {
40
- const currentFilters = query.filters?.$and ? query.filters : { ...query.filters, $and: [] };
41
- const filterIndex = currentFilters.$and.findIndex(
42
- (x?: Record<string, any>) => Object.keys(x || {})?.[0] === filterCategory
43
- );
44
-
45
- if (filterIndex > -1) {
46
- set(currentFilters, `$and[${filterIndex}]`, filters); // If the filter in this category already exists, replace it
47
- } else {
48
- currentFilters.$and.push(filters);
49
- }
50
-
51
- const removedFilters = removeFiltersFromQuery({ filters: currentFilters }, filterCategoryToRemove);
52
-
53
- setQuery({
54
- page: 1,
55
- filters: removedFilters
56
- });
57
- };
58
-
59
- const removeFilters = (filterCategory: string) => {
60
- const filters = removeFiltersFromQuery(query, filterCategory);
61
-
62
- setQuery({
63
- page: 1,
64
- filters
65
- });
66
- };
67
-
68
- const handlePlatformSelect = (platformTitle: string) => {
69
- if (platformTitle === PLATFORM_NO_FILTER) {
70
- removeFilters(PLATFORM);
71
- return;
72
- }
73
-
74
- handleFilterChange(getPlatformQueryFilter(platformTitle), PLATFORM, PAGE_TYPE);
75
- };
76
-
77
- const handlePageTypeSelect = (pageType: string) => {
78
- if (pageType === PAGE_TYPE_NO_FILTER) {
79
- removeFilters(PAGE_TYPE);
80
- return;
81
- }
82
-
83
- if (pageType === PAGE_TYPE_PAGE) {
84
- handleFilterChange(nullPageTypeQueryFilter, PAGE_TYPE);
85
- return;
86
- }
87
-
88
- handleFilterChange(getPageTypeQueryFilter(pageType), PAGE_TYPE);
89
- };
90
-
91
- useEffect(() => {
92
- const selectedPlatformFromQuery = getPlatformFromQuery(query, platforms);
93
- if (globalSelectedPlatform?.title && globalSelectedPlatform.title !== selectedPlatformFromQuery) {
94
- handlePlatformSelect(globalSelectedPlatform.title);
95
- }
96
- }, [query, platforms, globalSelectedPlatform]);
97
-
98
- return (
99
- <Stack horizontal spacing={2}>
100
- {!hidePageType && (
101
- <PageTypeFilter
102
- onChange={handlePageTypeSelect}
103
- pageTypes={pageTypesForPlatform}
104
- selectedPageTypeUid={selectedPageTypeUid}
105
- />
106
- )}
107
- </Stack>
108
- );
109
- };
110
-
111
- export default PageFilters;
112
-
113
- const getPageTypeFromQuery = (query: Record<string, any>, pageTypes?: PageType[]) => {
114
- const pageTypeFromQuery = query?.filters?.$and?.find(
115
- (x?: Record<string, any>) => Object.keys(x || {})?.[0] === PAGE_TYPE
116
- )?.pageType;
117
-
118
- if (pageTypeFromQuery?.uid?.$null === 'true') {
119
- return PAGE_TYPE_PAGE;
120
- }
121
-
122
- if (pageTypeFromQuery?.uid?.$eq) {
123
- const matchingPageType = pageTypes?.find((pageType: any) => pageType?.uid === pageTypeFromQuery.uid.$eq);
124
-
125
- if (matchingPageType) {
126
- return matchingPageType.uid;
127
- }
128
- }
129
-
130
- return PAGE_TYPE_NO_FILTER;
131
- };
132
-
133
- const getPlatformFromQuery = (query: Record<string, any>, platforms?: Platform[]): string | undefined => {
134
- const platformFromQuery = query?.filters?.$and?.find(
135
- (x?: Record<string, any>) => Object.keys(x || {})?.[0] === PLATFORM
136
- )?.platform;
137
-
138
- if (platformFromQuery?.title?.$null === 'true') {
139
- return PLATFORM_NO_FILTER;
140
- }
141
-
142
- if (platformFromQuery?.title?.$eq) {
143
- const matchingPageType = platforms?.find((platforms: Platform) => platforms?.title === platformFromQuery.title.$eq);
144
-
145
- if (matchingPageType) {
146
- return matchingPageType.title;
147
- }
148
- }
149
-
150
- return PLATFORM_NO_FILTER;
151
- };
152
-
153
- const getPlatformQueryFilter = (platform: string) => ({
154
- platform: {
155
- title: {
156
- $eq: platform
157
- }
158
- }
159
- });
160
-
161
- const getPageTypeQueryFilter = (pageType: string) => ({
162
- pageType: {
163
- uid: {
164
- $eq: pageType
165
- }
166
- }
167
- });
168
-
169
- const nullPageTypeQueryFilter = {
170
- pageType: {
171
- uid: {
172
- $null: true
173
- }
174
- }
175
- };
176
-
177
- const removeFiltersFromQuery = (query: Record<string, any>, filterCategory?: string) => {
178
- const newAndFilters = query.filters?.$and?.filter(
179
- (x?: Record<string, any>) => Object.keys(x || {})?.[0] !== filterCategory
180
- );
181
-
182
- const filters = { ...query.filters, $and: newAndFilters };
183
-
184
- if (newAndFilters && newAndFilters.length === 0) {
185
- delete filters.$and;
186
- }
187
-
188
- return filters;
189
- };
1
+ import { useEffect, useMemo } from 'react';
2
+ import set from 'lodash/set';
3
+
4
+ import { Stack } from '@strapi/design-system';
5
+ import { useQueryParams } from '@strapi/helper-plugin';
6
+
7
+ import PageTypeFilter from './PageTypeFilter';
8
+ import { PAGE_TYPE_PAGE, PLATFORM } from '../../../../shared/utils/constants';
9
+ import { Platform, useGetPlatforms } from '../../api/platform';
10
+ import { PAGE_TYPE, PAGE_TYPE_NO_FILTER, PLATFORM_NO_FILTER } from '../../constants';
11
+ import { PageType } from '../../api/platform-page-types';
12
+ import { useGetPageTypesForPlatform } from '../../api/platform-page-types';
13
+ import { useDefaultPlatformFromLocalStorage } from '../../utils/hooks/useDefaultPlatformFromLocalStorage';
14
+ import { useHideOverviewFilterTags } from '../../utils/hooks/useHideOverviewFilterTags';
15
+
16
+ interface PageFiltersProps {
17
+ hidePageType?: boolean;
18
+ }
19
+
20
+ const PageFilters = ({ hidePageType }: PageFiltersProps) => {
21
+ const [{ query }, setQuery] = useQueryParams() as any;
22
+ const { selectedPlatform: globalSelectedPlatform } = useDefaultPlatformFromLocalStorage();
23
+ useHideOverviewFilterTags();
24
+ const { data: platforms } = useGetPlatforms({});
25
+
26
+ const { data: pageTypesForPlatform } = useGetPageTypesForPlatform({
27
+ id: globalSelectedPlatform?.id
28
+ });
29
+
30
+ const selectedPageTypeUid = useMemo(
31
+ () => getPageTypeFromQuery(query, pageTypesForPlatform),
32
+ [query, platforms, globalSelectedPlatform, pageTypesForPlatform]
33
+ );
34
+
35
+ const handleFilterChange = (
36
+ filters: Record<string, any>,
37
+ filterCategory: string,
38
+ filterCategoryToRemove?: string
39
+ ) => {
40
+ const currentFilters = query.filters?.$and ? query.filters : { ...query.filters, $and: [] };
41
+ const filterIndex = currentFilters.$and.findIndex(
42
+ (x?: Record<string, any>) => Object.keys(x || {})?.[0] === filterCategory
43
+ );
44
+
45
+ if (filterIndex > -1) {
46
+ set(currentFilters, `$and[${filterIndex}]`, filters); // If the filter in this category already exists, replace it
47
+ } else {
48
+ currentFilters.$and.push(filters);
49
+ }
50
+
51
+ const removedFilters = removeFiltersFromQuery({ filters: currentFilters }, filterCategoryToRemove);
52
+
53
+ setQuery({
54
+ page: 1,
55
+ filters: removedFilters
56
+ });
57
+ };
58
+
59
+ const removeFilters = (filterCategory: string) => {
60
+ const filters = removeFiltersFromQuery(query, filterCategory);
61
+
62
+ setQuery({
63
+ page: 1,
64
+ filters
65
+ });
66
+ };
67
+
68
+ const handlePlatformSelect = (platformTitle: string) => {
69
+ if (platformTitle === PLATFORM_NO_FILTER) {
70
+ removeFilters(PLATFORM);
71
+ return;
72
+ }
73
+
74
+ handleFilterChange(getPlatformQueryFilter(platformTitle), PLATFORM, PAGE_TYPE);
75
+ };
76
+
77
+ const handlePageTypeSelect = (pageType: string) => {
78
+ if (pageType === PAGE_TYPE_NO_FILTER) {
79
+ removeFilters(PAGE_TYPE);
80
+ return;
81
+ }
82
+
83
+ if (pageType === PAGE_TYPE_PAGE) {
84
+ handleFilterChange(nullPageTypeQueryFilter, PAGE_TYPE);
85
+ return;
86
+ }
87
+
88
+ handleFilterChange(getPageTypeQueryFilter(pageType), PAGE_TYPE);
89
+ };
90
+
91
+ useEffect(() => {
92
+ const selectedPlatformFromQuery = getPlatformFromQuery(query, platforms);
93
+ if (globalSelectedPlatform?.title && globalSelectedPlatform.title !== selectedPlatformFromQuery) {
94
+ handlePlatformSelect(globalSelectedPlatform.title);
95
+ }
96
+ }, [query, platforms, globalSelectedPlatform]);
97
+
98
+ return (
99
+ <Stack horizontal spacing={2}>
100
+ {!hidePageType && (
101
+ <PageTypeFilter
102
+ onChange={handlePageTypeSelect}
103
+ pageTypes={pageTypesForPlatform}
104
+ selectedPageTypeUid={selectedPageTypeUid}
105
+ />
106
+ )}
107
+ </Stack>
108
+ );
109
+ };
110
+
111
+ export default PageFilters;
112
+
113
+ const getPageTypeFromQuery = (query: Record<string, any>, pageTypes?: PageType[]) => {
114
+ const pageTypeFromQuery = query?.filters?.$and?.find(
115
+ (x?: Record<string, any>) => Object.keys(x || {})?.[0] === PAGE_TYPE
116
+ )?.pageType;
117
+
118
+ if (pageTypeFromQuery?.uid?.$null === 'true') {
119
+ return PAGE_TYPE_PAGE;
120
+ }
121
+
122
+ if (pageTypeFromQuery?.uid?.$eq) {
123
+ const matchingPageType = pageTypes?.find((pageType: any) => pageType?.uid === pageTypeFromQuery.uid.$eq);
124
+
125
+ if (matchingPageType) {
126
+ return matchingPageType.uid;
127
+ }
128
+ }
129
+
130
+ return PAGE_TYPE_NO_FILTER;
131
+ };
132
+
133
+ const getPlatformFromQuery = (query: Record<string, any>, platforms?: Platform[]): string | undefined => {
134
+ const platformFromQuery = query?.filters?.$and?.find(
135
+ (x?: Record<string, any>) => Object.keys(x || {})?.[0] === PLATFORM
136
+ )?.platform;
137
+
138
+ if (platformFromQuery?.title?.$null === 'true') {
139
+ return PLATFORM_NO_FILTER;
140
+ }
141
+
142
+ if (platformFromQuery?.title?.$eq) {
143
+ const matchingPageType = platforms?.find((platforms: Platform) => platforms?.title === platformFromQuery.title.$eq);
144
+
145
+ if (matchingPageType) {
146
+ return matchingPageType.title;
147
+ }
148
+ }
149
+
150
+ return PLATFORM_NO_FILTER;
151
+ };
152
+
153
+ const getPlatformQueryFilter = (platform: string) => ({
154
+ platform: {
155
+ title: {
156
+ $eq: platform
157
+ }
158
+ }
159
+ });
160
+
161
+ const getPageTypeQueryFilter = (pageType: string) => ({
162
+ pageType: {
163
+ uid: {
164
+ $eq: pageType
165
+ }
166
+ }
167
+ });
168
+
169
+ const nullPageTypeQueryFilter = {
170
+ pageType: {
171
+ uid: {
172
+ $null: true
173
+ }
174
+ }
175
+ };
176
+
177
+ const removeFiltersFromQuery = (query: Record<string, any>, filterCategory?: string) => {
178
+ const newAndFilters = query.filters?.$and?.filter(
179
+ (x?: Record<string, any>) => Object.keys(x || {})?.[0] !== filterCategory
180
+ );
181
+
182
+ const filters = { ...query.filters, $and: newAndFilters };
183
+
184
+ if (newAndFilters && newAndFilters.length === 0) {
185
+ delete filters.$and;
186
+ }
187
+
188
+ return filters;
189
+ };