@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,37 +1,37 @@
1
- import { useQuery, UseQueryOptions } from 'react-query';
2
-
3
- import { useFetchClient } from '@strapi/helper-plugin';
4
-
5
- import getRequestUrl from '../utils/getRequestUrl';
6
-
7
- type HasPageRelationQueryParams = {
8
- uid: string;
9
- fetchClient?: any;
10
- };
11
-
12
- const QUERY_KEY = 'pageRelation';
13
-
14
- const fetchHasPageRelation = async ({ fetchClient, uid }: HasPageRelationQueryParams): Promise<boolean> => {
15
- try {
16
- if (!uid) {
17
- throw new Error('No uid');
18
- }
19
-
20
- const { get } = fetchClient;
21
- const result = await get(`${getRequestUrl('collection-types')}/${uid}`);
22
-
23
- return Boolean(result?.data?.hasPageRelation);
24
- } catch {
25
- return false;
26
- }
27
- };
28
-
29
- export const useHasPageRelation = (params: HasPageRelationQueryParams, options?: UseQueryOptions<boolean, Error>) => {
30
- const fetchClient = useFetchClient();
31
-
32
- return useQuery<boolean, Error>(
33
- [QUERY_KEY, params?.uid],
34
- () => fetchHasPageRelation({ ...params, fetchClient }),
35
- options
36
- );
37
- };
1
+ import { useQuery, UseQueryOptions } from 'react-query';
2
+
3
+ import { useFetchClient } from '@strapi/helper-plugin';
4
+
5
+ import getRequestUrl from '../utils/getRequestUrl';
6
+
7
+ type HasPageRelationQueryParams = {
8
+ uid: string;
9
+ fetchClient?: any;
10
+ };
11
+
12
+ const QUERY_KEY = 'pageRelation';
13
+
14
+ const fetchHasPageRelation = async ({ fetchClient, uid }: HasPageRelationQueryParams): Promise<boolean> => {
15
+ try {
16
+ if (!uid) {
17
+ throw new Error('No uid');
18
+ }
19
+
20
+ const { get } = fetchClient;
21
+ const result = await get(`${getRequestUrl('collection-types')}/${uid}`);
22
+
23
+ return Boolean(result?.data?.hasPageRelation);
24
+ } catch {
25
+ return false;
26
+ }
27
+ };
28
+
29
+ export const useHasPageRelation = (params: HasPageRelationQueryParams, options?: UseQueryOptions<boolean, Error>) => {
30
+ const fetchClient = useFetchClient();
31
+
32
+ return useQuery<boolean, Error>(
33
+ [QUERY_KEY, params?.uid],
34
+ () => fetchHasPageRelation({ ...params, fetchClient }),
35
+ options
36
+ );
37
+ };
@@ -1,40 +1,40 @@
1
- import { useQuery, UseQueryOptions } from 'react-query';
2
-
3
- import { useFetchClient } from '@strapi/helper-plugin';
4
-
5
- import getRequestUrl from '../utils/getRequestUrl';
6
-
7
- type HasPlatformRelationQueryParams = {
8
- uid: string;
9
- fetchClient?: any;
10
- };
11
-
12
- const QUERY_KEY = 'platformRelation';
13
-
14
- const fetchHasPlatformRelation = async ({ fetchClient, uid }: HasPlatformRelationQueryParams): Promise<boolean> => {
15
- try {
16
- if (!uid) {
17
- throw new Error('No uid');
18
- }
19
-
20
- const { get } = fetchClient;
21
- const result = await get(`${getRequestUrl('collection-types')}/hasPlatform/${uid}`);
22
-
23
- return Boolean(result?.data?.hasPlatformRelation);
24
- } catch {
25
- return false;
26
- }
27
- };
28
-
29
- export const useHasPlatformRelation = (
30
- params: HasPlatformRelationQueryParams,
31
- options?: UseQueryOptions<boolean, Error>
32
- ) => {
33
- const fetchClient = useFetchClient();
34
-
35
- return useQuery<boolean, Error>(
36
- [QUERY_KEY, params?.uid],
37
- () => fetchHasPlatformRelation({ ...params, fetchClient }),
38
- options
39
- );
40
- };
1
+ import { useQuery, UseQueryOptions } from 'react-query';
2
+
3
+ import { useFetchClient } from '@strapi/helper-plugin';
4
+
5
+ import getRequestUrl from '../utils/getRequestUrl';
6
+
7
+ type HasPlatformRelationQueryParams = {
8
+ uid: string;
9
+ fetchClient?: any;
10
+ };
11
+
12
+ const QUERY_KEY = 'platformRelation';
13
+
14
+ const fetchHasPlatformRelation = async ({ fetchClient, uid }: HasPlatformRelationQueryParams): Promise<boolean> => {
15
+ try {
16
+ if (!uid) {
17
+ throw new Error('No uid');
18
+ }
19
+
20
+ const { get } = fetchClient;
21
+ const result = await get(`${getRequestUrl('collection-types')}/hasPlatform/${uid}`);
22
+
23
+ return Boolean(result?.data?.hasPlatformRelation);
24
+ } catch {
25
+ return false;
26
+ }
27
+ };
28
+
29
+ export const useHasPlatformRelation = (
30
+ params: HasPlatformRelationQueryParams,
31
+ options?: UseQueryOptions<boolean, Error>
32
+ ) => {
33
+ const fetchClient = useFetchClient();
34
+
35
+ return useQuery<boolean, Error>(
36
+ [QUERY_KEY, params?.uid],
37
+ () => fetchHasPlatformRelation({ ...params, fetchClient }),
38
+ options
39
+ );
40
+ };
@@ -1,41 +1,41 @@
1
- import { useQuery } from 'react-query';
2
-
3
- import { useFetchClient } from '@strapi/helper-plugin';
4
- import { PageType } from './platform-page-types';
5
-
6
- const QUERY_KEY = 'pageTypeRelations';
7
-
8
- const fetchPageTypeRelation = async ({
9
- fetchClient,
10
- id,
11
- uid
12
- }: Record<string, any> & UseGetPageTypeRelationParams): Promise<PageType | undefined> => {
13
- try {
14
- if (!uid || !id) {
15
- throw new Error('No uid or id');
16
- }
17
-
18
- const { get } = fetchClient;
19
- const result = await get(`/content-manager/relations/${uid}/${id}/pageType?page=1&pageSize=5`);
20
-
21
- return result?.data?.data;
22
- } catch {
23
- return undefined;
24
- }
25
- };
26
-
27
- type UseGetPageTypeRelationParams = {
28
- uid: string;
29
- id: string;
30
- };
31
-
32
- export const useGetPageTypeRelation = (params: Record<string, any> & UseGetPageTypeRelationParams) => {
33
- const fetchClient = useFetchClient();
34
-
35
- return useQuery<PageType | undefined, Error>([QUERY_KEY, params], () =>
36
- fetchPageTypeRelation({
37
- ...params,
38
- fetchClient
39
- })
40
- );
41
- };
1
+ import { useQuery } from 'react-query';
2
+
3
+ import { useFetchClient } from '@strapi/helper-plugin';
4
+ import { PageType } from './platform-page-types';
5
+
6
+ const QUERY_KEY = 'pageTypeRelations';
7
+
8
+ const fetchPageTypeRelation = async ({
9
+ fetchClient,
10
+ id,
11
+ uid
12
+ }: Record<string, any> & UseGetPageTypeRelationParams): Promise<PageType | undefined> => {
13
+ try {
14
+ if (!uid || !id) {
15
+ throw new Error('No uid or id');
16
+ }
17
+
18
+ const { get } = fetchClient;
19
+ const result = await get(`/content-manager/relations/${uid}/${id}/pageType?page=1&pageSize=5`);
20
+
21
+ return result?.data?.data;
22
+ } catch {
23
+ return undefined;
24
+ }
25
+ };
26
+
27
+ type UseGetPageTypeRelationParams = {
28
+ uid: string;
29
+ id: string;
30
+ };
31
+
32
+ export const useGetPageTypeRelation = (params: Record<string, any> & UseGetPageTypeRelationParams) => {
33
+ const fetchClient = useFetchClient();
34
+
35
+ return useQuery<PageType | undefined, Error>([QUERY_KEY, params], () =>
36
+ fetchPageTypeRelation({
37
+ ...params,
38
+ fetchClient
39
+ })
40
+ );
41
+ };
@@ -1,45 +1,45 @@
1
- import { useQuery } from 'react-query';
2
-
3
- import { useFetchClient } from '@strapi/helper-plugin';
4
-
5
- const QUERY_KEY = 'pageTypesForPlatform';
6
-
7
- export type PageType = {
8
- id: number;
9
- uid: string;
10
- title?: string;
11
- };
12
-
13
- const fetchPageTypesForPlatform = async ({ fetchClient, id }: Record<string, any>): Promise<PageType[]> => {
14
- try {
15
- if (!id) {
16
- throw new Error('No id');
17
- }
18
-
19
- const { get } = fetchClient;
20
-
21
- const pageTypesResult = await get(`/content-manager/collection-types/api::page-type.page-type?page=1&pageSize=999`);
22
-
23
- return pageTypesResult?.data?.results
24
- ?.filter((x: Record<string, any>) => x?.platform?.id === id)
25
- ?.map((pageType: Record<string, any>) => ({
26
- id: pageType.id,
27
- uid: pageType.uid,
28
- title: pageType.title,
29
- templateId: pageType?.template?.id
30
- }));
31
- } catch {
32
- return [];
33
- }
34
- };
35
-
36
- export const useGetPageTypesForPlatform = (params: Record<string, any>) => {
37
- const fetchClient = useFetchClient();
38
-
39
- return useQuery<PageType[], Error>([QUERY_KEY, params.id], () =>
40
- fetchPageTypesForPlatform({
41
- ...params,
42
- fetchClient
43
- })
44
- );
45
- };
1
+ import { useQuery } from 'react-query';
2
+
3
+ import { useFetchClient } from '@strapi/helper-plugin';
4
+
5
+ const QUERY_KEY = 'pageTypesForPlatform';
6
+
7
+ export type PageType = {
8
+ id: number;
9
+ uid: string;
10
+ title?: string;
11
+ };
12
+
13
+ const fetchPageTypesForPlatform = async ({ fetchClient, id }: Record<string, any>): Promise<PageType[]> => {
14
+ try {
15
+ if (!id) {
16
+ throw new Error('No id');
17
+ }
18
+
19
+ const { get } = fetchClient;
20
+
21
+ const pageTypesResult = await get(`/content-manager/collection-types/api::page-type.page-type?page=1&pageSize=999`);
22
+
23
+ return pageTypesResult?.data?.results
24
+ ?.filter((x: Record<string, any>) => x?.platform?.id === id)
25
+ ?.map((pageType: Record<string, any>) => ({
26
+ id: pageType.id,
27
+ uid: pageType.uid,
28
+ title: pageType.title,
29
+ templateId: pageType?.template?.id
30
+ }));
31
+ } catch {
32
+ return [];
33
+ }
34
+ };
35
+
36
+ export const useGetPageTypesForPlatform = (params: Record<string, any>) => {
37
+ const fetchClient = useFetchClient();
38
+
39
+ return useQuery<PageType[], Error>([QUERY_KEY, params.id], () =>
40
+ fetchPageTypesForPlatform({
41
+ ...params,
42
+ fetchClient
43
+ })
44
+ );
45
+ };
@@ -1,42 +1,42 @@
1
- import { useQuery } from 'react-query';
2
-
3
- import { useFetchClient } from '@strapi/helper-plugin';
4
-
5
- import { Platform } from './platform';
6
-
7
- const QUERY_KEY = 'platformRelations';
8
-
9
- const fetchPlatformRelation = async ({
10
- fetchClient,
11
- id,
12
- uid
13
- }: Record<string, any> & UseGetPlatformRelationParams): Promise<Platform | undefined> => {
14
- try {
15
- if (!uid || !id) {
16
- throw new Error('No uid or id');
17
- }
18
-
19
- const { get } = fetchClient;
20
- const result = await get(`/content-manager/relations/${uid}/${id}/platform?page=1&pageSize=5`);
21
-
22
- return result?.data?.data;
23
- } catch {
24
- return undefined;
25
- }
26
- };
27
-
28
- type UseGetPlatformRelationParams = {
29
- uid: string;
30
- id: string;
31
- };
32
-
33
- export const useGetPlatformRelation = (params: Record<string, any> & UseGetPlatformRelationParams) => {
34
- const fetchClient = useFetchClient();
35
-
36
- return useQuery<Platform | undefined, Error>([QUERY_KEY, params], () =>
37
- fetchPlatformRelation({
38
- ...params,
39
- fetchClient
40
- })
41
- );
42
- };
1
+ import { useQuery } from 'react-query';
2
+
3
+ import { useFetchClient } from '@strapi/helper-plugin';
4
+
5
+ import { Platform } from './platform';
6
+
7
+ const QUERY_KEY = 'platformRelations';
8
+
9
+ const fetchPlatformRelation = async ({
10
+ fetchClient,
11
+ id,
12
+ uid
13
+ }: Record<string, any> & UseGetPlatformRelationParams): Promise<Platform | undefined> => {
14
+ try {
15
+ if (!uid || !id) {
16
+ throw new Error('No uid or id');
17
+ }
18
+
19
+ const { get } = fetchClient;
20
+ const result = await get(`/content-manager/relations/${uid}/${id}/platform?page=1&pageSize=5`);
21
+
22
+ return result?.data?.data;
23
+ } catch {
24
+ return undefined;
25
+ }
26
+ };
27
+
28
+ type UseGetPlatformRelationParams = {
29
+ uid: string;
30
+ id: string;
31
+ };
32
+
33
+ export const useGetPlatformRelation = (params: Record<string, any> & UseGetPlatformRelationParams) => {
34
+ const fetchClient = useFetchClient();
35
+
36
+ return useQuery<Platform | undefined, Error>([QUERY_KEY, params], () =>
37
+ fetchPlatformRelation({
38
+ ...params,
39
+ fetchClient
40
+ })
41
+ );
42
+ };
@@ -1,35 +1,35 @@
1
- import { useQuery } from 'react-query';
2
-
3
- import { useFetchClient } from '@strapi/helper-plugin';
4
-
5
- export type Platform = {
6
- id: number;
7
- title?: string;
8
- };
9
-
10
- const QUERY_KEY = 'platforms';
11
-
12
- const fetchPlatforms = async ({ fetchClient }: Record<string, any>): Promise<Platform[]> => {
13
- try {
14
- const { get } = fetchClient;
15
- const result = await get('/content-manager/collection-types/api::platform.platform?page=1&pageSize=999');
16
-
17
- return result?.data?.results.map((entity: Record<string, any>) => ({
18
- id: entity.id,
19
- title: entity.title
20
- }));
21
- } catch {
22
- return [];
23
- }
24
- };
25
-
26
- export const useGetPlatforms = (params: Record<string, any>) => {
27
- const fetchClient = useFetchClient();
28
-
29
- return useQuery<Platform[], Error>([QUERY_KEY, params], () =>
30
- fetchPlatforms({
31
- ...params,
32
- fetchClient
33
- })
34
- );
35
- };
1
+ import { useQuery } from 'react-query';
2
+
3
+ import { useFetchClient } from '@strapi/helper-plugin';
4
+
5
+ export type Platform = {
6
+ id: number;
7
+ title?: string;
8
+ };
9
+
10
+ const QUERY_KEY = 'platforms';
11
+
12
+ const fetchPlatforms = async ({ fetchClient }: Record<string, any>): Promise<Platform[]> => {
13
+ try {
14
+ const { get } = fetchClient;
15
+ const result = await get('/content-manager/collection-types/api::platform.platform?page=1&pageSize=999');
16
+
17
+ return result?.data?.results.map((entity: Record<string, any>) => ({
18
+ id: entity.id,
19
+ title: entity.title
20
+ }));
21
+ } catch {
22
+ return [];
23
+ }
24
+ };
25
+
26
+ export const useGetPlatforms = (params: Record<string, any>) => {
27
+ const fetchClient = useFetchClient();
28
+
29
+ return useQuery<Platform[], Error>([QUERY_KEY, params], () =>
30
+ fetchPlatforms({
31
+ ...params,
32
+ fetchClient
33
+ })
34
+ );
35
+ };