@webbio/strapi-plugin-page-builder 0.2.2 → 0.2.4
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.
- package/README.md +98 -98
- package/admin/src/api/collection-type.ts +110 -110
- package/admin/src/api/has-page-relation.ts +34 -34
- package/admin/src/api/page-type.ts +31 -31
- package/admin/src/api/template.ts +27 -27
- package/admin/src/components/Combobox/index.tsx +77 -77
- package/admin/src/components/Combobox/react-select-custom-styles.tsx +120 -111
- package/admin/src/components/Combobox/styles.ts +22 -22
- package/admin/src/components/ConfirmModal/index.tsx +90 -90
- package/admin/src/components/EditView/CollectionTypeSearch/index.tsx +124 -124
- package/admin/src/components/EditView/CollectionTypeSettings/CreatePageButton/index.tsx +104 -101
- package/admin/src/components/EditView/CollectionTypeSettings/CreatePageButton/styles.ts +19 -19
- package/admin/src/components/EditView/CollectionTypeSettings/index.tsx +74 -74
- package/admin/src/components/EditView/Details/index.tsx +47 -47
- package/admin/src/components/EditView/Details/styles.ts +51 -51
- package/admin/src/components/EditView/PageSettings/index.tsx +104 -104
- package/admin/src/components/EditView/Template/TemplateConfirmModal/index.tsx +36 -36
- package/admin/src/components/EditView/Template/TemplateSelect/index.tsx +69 -69
- package/admin/src/components/EditView/Template/TemplateSelect/use-template-modules.ts +38 -38
- package/admin/src/components/EditView/index.tsx +29 -29
- package/admin/src/components/EditView/page-type-select.tsx +32 -32
- package/admin/src/components/EditView/wrapper.tsx +35 -35
- package/admin/src/components/Initializer/index.tsx +24 -24
- package/admin/src/components/PageTypeFilter/index.tsx +17 -17
- package/admin/src/components/PageTypeFilter/page-type-filter.tsx +130 -130
- package/admin/src/components/PluginIcon/index.tsx +12 -12
- package/admin/src/constants.ts +3 -3
- package/admin/src/index.tsx +59 -59
- package/admin/src/middlewares/index.tsx +37 -37
- package/admin/src/pluginId.ts +5 -5
- package/admin/src/translations/en.json +6 -6
- package/admin/src/translations/nl.json +6 -6
- package/admin/src/utils/getRequestUrl.ts +11 -11
- package/admin/src/utils/getTrad.ts +5 -5
- package/admin/src/utils/hooks/useDebounce.ts +17 -17
- package/admin/src/utils/hooks/useGetLocaleFromUrl.ts +9 -9
- package/admin/src/utils/hooks/usePrevious.ts +12 -12
- package/admin/src/utils/sanitizeModules.ts +43 -10
- package/custom.d.ts +5 -5
- package/dist/package.json +9 -9
- package/dist/server/graphql/page-by-slug.js +9 -9
- package/dist/server/graphql/pages-by-uid.js +14 -14
- package/dist/server/services/builder.js +7 -4
- package/dist/server/services/template.js +1 -2
- package/dist/server/utils/graphql.js +18 -18
- package/dist/server/utils/strapi.js +1 -4
- package/dist/tsconfig.server.tsbuildinfo +1 -1
- package/package.json +71 -71
- package/server/bootstrap/collection-type-lifecycles.ts +47 -47
- package/server/bootstrap/permissions.ts +42 -42
- package/server/bootstrap.ts +198 -198
- package/server/config/index.ts +4 -4
- package/server/content-types/index.ts +1 -1
- package/server/controllers/collection-types.ts +27 -27
- package/server/controllers/index.ts +11 -11
- package/server/controllers/page-type.ts +13 -13
- package/server/controllers/page.ts +9 -9
- package/server/controllers/template.ts +16 -16
- package/server/destroy.ts +5 -5
- package/server/graphql/index.ts +9 -9
- package/server/graphql/page-by-slug.ts +98 -98
- package/server/graphql/page-type.ts +67 -67
- package/server/graphql/pages-by-uid.ts +127 -127
- package/server/index.ts +23 -23
- package/server/middlewares/index.ts +1 -1
- package/server/policies/index.ts +1 -1
- package/server/register.ts +15 -15
- package/server/routes/index.ts +58 -58
- package/server/schema/page-end.json +91 -91
- package/server/schema/page-start.json +87 -87
- package/server/schema/page-type-end.json +43 -43
- package/server/schema/page-type-start.json +38 -38
- package/server/schema/template-start.json +35 -35
- package/server/services/builder.ts +137 -134
- package/server/services/collection-types.ts +88 -88
- package/server/services/index.ts +13 -13
- package/server/services/page-type.ts +26 -26
- package/server/services/page.ts +24 -24
- package/server/services/template.ts +13 -14
- package/server/utils/filter-underscore-arguments.ts +12 -12
- package/server/utils/graphql.ts +113 -113
- package/server/utils/paginationValidation.ts +39 -39
- package/server/utils/reload-strapi-on-load.ts +13 -13
- package/server/utils/strapi.ts +45 -49
- package/shared/utils/constants.ts +4 -4
- package/shared/utils/sleep.ts +1 -1
- package/strapi-admin.js +3 -3
- package/strapi-server.js +3 -3
- package/tsconfig.json +20 -20
- package/tsconfig.server.json +25 -25
- package/dist/server/controllers/platform.js +0 -20
- package/dist/server/schema/platform-start.json +0 -31
- package/dist/server/services/platform.js +0 -36
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
export const filterUnderscoreArguments = (args: Record<string, any>) => {
|
|
2
|
-
const newArgs = {};
|
|
3
|
-
const objectArray = Object.keys(args);
|
|
4
|
-
|
|
5
|
-
objectArray.forEach((key) => {
|
|
6
|
-
if (!key.startsWith('_')) {
|
|
7
|
-
newArgs[key] = args[key];
|
|
8
|
-
}
|
|
9
|
-
});
|
|
10
|
-
|
|
11
|
-
return newArgs;
|
|
12
|
-
};
|
|
1
|
+
export const filterUnderscoreArguments = (args: Record<string, any>) => {
|
|
2
|
+
const newArgs = {};
|
|
3
|
+
const objectArray = Object.keys(args);
|
|
4
|
+
|
|
5
|
+
objectArray.forEach((key) => {
|
|
6
|
+
if (!key.startsWith('_')) {
|
|
7
|
+
newArgs[key] = args[key];
|
|
8
|
+
}
|
|
9
|
+
});
|
|
10
|
+
|
|
11
|
+
return newArgs;
|
|
12
|
+
};
|
package/server/utils/graphql.ts
CHANGED
|
@@ -1,113 +1,113 @@
|
|
|
1
|
-
import { Strapi } from '@strapi/strapi';
|
|
2
|
-
import { PAGE_UID } from '../../shared/utils/constants';
|
|
3
|
-
|
|
4
|
-
const findPageByPath = (strapi: Strapi) => {
|
|
5
|
-
const typeDefs = `
|
|
6
|
-
type Query {
|
|
7
|
-
findPageByPath(path: String, locale: I18NLocaleCode): PageEntityResponse
|
|
8
|
-
}
|
|
9
|
-
`;
|
|
10
|
-
|
|
11
|
-
const resolvers = (strapi: Strapi) => {
|
|
12
|
-
const { transformArgs } = strapi.plugin('graphql').service('builders').utils;
|
|
13
|
-
const { toEntityResponse, toEntityResponseCollection } = strapi.plugin('graphql').service('format').returnTypes;
|
|
14
|
-
|
|
15
|
-
return {
|
|
16
|
-
Query: {
|
|
17
|
-
findPageByPath: {
|
|
18
|
-
resolve: async (parent: any, args: Record<string, any>, ctx: any) => {
|
|
19
|
-
const contentType = strapi.getModel(PAGE_UID);
|
|
20
|
-
const transformedArgs = transformArgs(args, { contentType });
|
|
21
|
-
|
|
22
|
-
const queryResult = await strapi.entityService.findMany(contentType.uid, {
|
|
23
|
-
filters: {
|
|
24
|
-
path: {
|
|
25
|
-
$eq: transformedArgs.path
|
|
26
|
-
}
|
|
27
|
-
},
|
|
28
|
-
locale: transformedArgs.locale
|
|
29
|
-
});
|
|
30
|
-
|
|
31
|
-
const result = queryResult?.[0];
|
|
32
|
-
return toEntityResponse(result, {
|
|
33
|
-
args: transformedArgs,
|
|
34
|
-
resourceUID: contentType.uid
|
|
35
|
-
});
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
};
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
const resolversConfig = {
|
|
43
|
-
'Query.findPageByPath': {
|
|
44
|
-
auth: false
|
|
45
|
-
}
|
|
46
|
-
};
|
|
47
|
-
|
|
48
|
-
return {
|
|
49
|
-
typeDefs,
|
|
50
|
-
resolvers: resolvers(strapi),
|
|
51
|
-
resolversConfig
|
|
52
|
-
};
|
|
53
|
-
};
|
|
54
|
-
|
|
55
|
-
const findPagePaths = (strapi: Strapi) => {
|
|
56
|
-
const typeDefs = `
|
|
57
|
-
type PageByPath {
|
|
58
|
-
id: Int!
|
|
59
|
-
path: String!
|
|
60
|
-
title: String!
|
|
61
|
-
locale: String!
|
|
62
|
-
pageType: ENUM_PAGE_PAGETYPE
|
|
63
|
-
updatedAt: DateTime!
|
|
64
|
-
publishedAt: DateTime!
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
type Query {
|
|
68
|
-
findPagePaths(locale: String, pageType: String = "all"): [PageByPath]
|
|
69
|
-
}
|
|
70
|
-
`;
|
|
71
|
-
|
|
72
|
-
const resolvers = (strapi: Strapi) => {
|
|
73
|
-
const { transformArgs } = strapi.plugin('graphql').service('builders').utils;
|
|
74
|
-
|
|
75
|
-
return {
|
|
76
|
-
Query: {
|
|
77
|
-
findPagePaths: {
|
|
78
|
-
resolve: async (parent: any, args: Record<string, any>, ctx: any) => {
|
|
79
|
-
const contentType = strapi.getModel(PAGE_UID);
|
|
80
|
-
const transformedArgs = transformArgs(args, { contentType });
|
|
81
|
-
|
|
82
|
-
const queryResult = await strapi.entityService.findMany(contentType.uid, {
|
|
83
|
-
populate: '*',
|
|
84
|
-
locale: transformedArgs.locale
|
|
85
|
-
});
|
|
86
|
-
|
|
87
|
-
const result = queryResult.filter((page) => page?.path);
|
|
88
|
-
|
|
89
|
-
return result;
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
};
|
|
94
|
-
};
|
|
95
|
-
|
|
96
|
-
const resolversConfig = {
|
|
97
|
-
'Query.findPagePaths': {
|
|
98
|
-
auth: false
|
|
99
|
-
}
|
|
100
|
-
};
|
|
101
|
-
|
|
102
|
-
return {
|
|
103
|
-
typeDefs,
|
|
104
|
-
resolvers: resolvers(strapi),
|
|
105
|
-
resolversConfig
|
|
106
|
-
};
|
|
107
|
-
};
|
|
108
|
-
|
|
109
|
-
export const registerGraphQLResolvers = (strapi: Strapi) => {
|
|
110
|
-
const extensionService = strapi.plugin('graphql').service('extension');
|
|
111
|
-
extensionService.use(findPageByPath(strapi));
|
|
112
|
-
extensionService.use(findPagePaths(strapi));
|
|
113
|
-
};
|
|
1
|
+
import { Strapi } from '@strapi/strapi';
|
|
2
|
+
import { PAGE_UID } from '../../shared/utils/constants';
|
|
3
|
+
|
|
4
|
+
const findPageByPath = (strapi: Strapi) => {
|
|
5
|
+
const typeDefs = `
|
|
6
|
+
type Query {
|
|
7
|
+
findPageByPath(path: String, locale: I18NLocaleCode): PageEntityResponse
|
|
8
|
+
}
|
|
9
|
+
`;
|
|
10
|
+
|
|
11
|
+
const resolvers = (strapi: Strapi) => {
|
|
12
|
+
const { transformArgs } = strapi.plugin('graphql').service('builders').utils;
|
|
13
|
+
const { toEntityResponse, toEntityResponseCollection } = strapi.plugin('graphql').service('format').returnTypes;
|
|
14
|
+
|
|
15
|
+
return {
|
|
16
|
+
Query: {
|
|
17
|
+
findPageByPath: {
|
|
18
|
+
resolve: async (parent: any, args: Record<string, any>, ctx: any) => {
|
|
19
|
+
const contentType = strapi.getModel(PAGE_UID);
|
|
20
|
+
const transformedArgs = transformArgs(args, { contentType });
|
|
21
|
+
|
|
22
|
+
const queryResult = await strapi.entityService.findMany(contentType.uid, {
|
|
23
|
+
filters: {
|
|
24
|
+
path: {
|
|
25
|
+
$eq: transformedArgs.path
|
|
26
|
+
}
|
|
27
|
+
},
|
|
28
|
+
locale: transformedArgs.locale
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
const result = queryResult?.[0];
|
|
32
|
+
return toEntityResponse(result, {
|
|
33
|
+
args: transformedArgs,
|
|
34
|
+
resourceUID: contentType.uid
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
};
|
|
41
|
+
|
|
42
|
+
const resolversConfig = {
|
|
43
|
+
'Query.findPageByPath': {
|
|
44
|
+
auth: false
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
return {
|
|
49
|
+
typeDefs,
|
|
50
|
+
resolvers: resolvers(strapi),
|
|
51
|
+
resolversConfig
|
|
52
|
+
};
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
const findPagePaths = (strapi: Strapi) => {
|
|
56
|
+
const typeDefs = `
|
|
57
|
+
type PageByPath {
|
|
58
|
+
id: Int!
|
|
59
|
+
path: String!
|
|
60
|
+
title: String!
|
|
61
|
+
locale: String!
|
|
62
|
+
pageType: ENUM_PAGE_PAGETYPE
|
|
63
|
+
updatedAt: DateTime!
|
|
64
|
+
publishedAt: DateTime!
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
type Query {
|
|
68
|
+
findPagePaths(locale: String, pageType: String = "all"): [PageByPath]
|
|
69
|
+
}
|
|
70
|
+
`;
|
|
71
|
+
|
|
72
|
+
const resolvers = (strapi: Strapi) => {
|
|
73
|
+
const { transformArgs } = strapi.plugin('graphql').service('builders').utils;
|
|
74
|
+
|
|
75
|
+
return {
|
|
76
|
+
Query: {
|
|
77
|
+
findPagePaths: {
|
|
78
|
+
resolve: async (parent: any, args: Record<string, any>, ctx: any) => {
|
|
79
|
+
const contentType = strapi.getModel(PAGE_UID);
|
|
80
|
+
const transformedArgs = transformArgs(args, { contentType });
|
|
81
|
+
|
|
82
|
+
const queryResult = await strapi.entityService.findMany(contentType.uid, {
|
|
83
|
+
populate: '*',
|
|
84
|
+
locale: transformedArgs.locale
|
|
85
|
+
});
|
|
86
|
+
|
|
87
|
+
const result = queryResult.filter((page) => page?.path);
|
|
88
|
+
|
|
89
|
+
return result;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
};
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
const resolversConfig = {
|
|
97
|
+
'Query.findPagePaths': {
|
|
98
|
+
auth: false
|
|
99
|
+
}
|
|
100
|
+
};
|
|
101
|
+
|
|
102
|
+
return {
|
|
103
|
+
typeDefs,
|
|
104
|
+
resolvers: resolvers(strapi),
|
|
105
|
+
resolversConfig
|
|
106
|
+
};
|
|
107
|
+
};
|
|
108
|
+
|
|
109
|
+
export const registerGraphQLResolvers = (strapi: Strapi) => {
|
|
110
|
+
const extensionService = strapi.plugin('graphql').service('extension');
|
|
111
|
+
extensionService.use(findPageByPath(strapi));
|
|
112
|
+
extensionService.use(findPagePaths(strapi));
|
|
113
|
+
};
|
|
@@ -1,39 +1,39 @@
|
|
|
1
|
-
import { Common } from '@strapi/strapi';
|
|
2
|
-
|
|
3
|
-
export class Pagination {
|
|
4
|
-
public static checkPagination(page: number, pageSize: number) {
|
|
5
|
-
const startPage = page === 1 ? 0 : page - 1;
|
|
6
|
-
|
|
7
|
-
const start = startPage * pageSize;
|
|
8
|
-
const limit = (startPage + 1) * pageSize;
|
|
9
|
-
|
|
10
|
-
return { start, limit };
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
public static async getPaginationInfo(
|
|
14
|
-
transformedpageArgs: any,
|
|
15
|
-
transformArgs: any,
|
|
16
|
-
start: number,
|
|
17
|
-
pageSize: number,
|
|
18
|
-
entityResponse: any,
|
|
19
|
-
uid: string
|
|
20
|
-
) {
|
|
21
|
-
const total = await strapi?.entityService?.count(uid as Common.UID.ContentType, {
|
|
22
|
-
filters: {
|
|
23
|
-
...transformArgs.filters,
|
|
24
|
-
hasPage: { $eq: true },
|
|
25
|
-
page: { ...transformedpageArgs.filters }
|
|
26
|
-
}
|
|
27
|
-
});
|
|
28
|
-
const pageCount = Math.ceil(total / pageSize);
|
|
29
|
-
const page = Math.floor(start / pageSize) + 1;
|
|
30
|
-
|
|
31
|
-
entityResponse.metaInfo = {
|
|
32
|
-
total,
|
|
33
|
-
pageCount,
|
|
34
|
-
page,
|
|
35
|
-
pageSize
|
|
36
|
-
};
|
|
37
|
-
return entityResponse;
|
|
38
|
-
}
|
|
39
|
-
}
|
|
1
|
+
import { Common } from '@strapi/strapi';
|
|
2
|
+
|
|
3
|
+
export class Pagination {
|
|
4
|
+
public static checkPagination(page: number, pageSize: number) {
|
|
5
|
+
const startPage = page === 1 ? 0 : page - 1;
|
|
6
|
+
|
|
7
|
+
const start = startPage * pageSize;
|
|
8
|
+
const limit = (startPage + 1) * pageSize;
|
|
9
|
+
|
|
10
|
+
return { start, limit };
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
public static async getPaginationInfo(
|
|
14
|
+
transformedpageArgs: any,
|
|
15
|
+
transformArgs: any,
|
|
16
|
+
start: number,
|
|
17
|
+
pageSize: number,
|
|
18
|
+
entityResponse: any,
|
|
19
|
+
uid: string
|
|
20
|
+
) {
|
|
21
|
+
const total = await strapi?.entityService?.count(uid as Common.UID.ContentType, {
|
|
22
|
+
filters: {
|
|
23
|
+
...transformArgs.filters,
|
|
24
|
+
hasPage: { $eq: true },
|
|
25
|
+
page: { ...transformedpageArgs.filters }
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
const pageCount = Math.ceil(total / pageSize);
|
|
29
|
+
const page = Math.floor(start / pageSize) + 1;
|
|
30
|
+
|
|
31
|
+
entityResponse.metaInfo = {
|
|
32
|
+
total,
|
|
33
|
+
pageCount,
|
|
34
|
+
page,
|
|
35
|
+
pageSize
|
|
36
|
+
};
|
|
37
|
+
return entityResponse;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
const reloadStrapiOnLoad = () => {
|
|
2
|
-
console.log('[Plugin Page Builder]: Checking if strapi is loaded', strapi.isLoaded);
|
|
3
|
-
|
|
4
|
-
if (strapi.isLoaded) {
|
|
5
|
-
strapi.reload();
|
|
6
|
-
|
|
7
|
-
return;
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
setTimeout(reloadStrapiOnLoad, 1000);
|
|
11
|
-
};
|
|
12
|
-
|
|
13
|
-
export { reloadStrapiOnLoad };
|
|
1
|
+
const reloadStrapiOnLoad = () => {
|
|
2
|
+
console.log('[Plugin Page Builder]: Checking if strapi is loaded', strapi.isLoaded);
|
|
3
|
+
|
|
4
|
+
if (strapi.isLoaded) {
|
|
5
|
+
strapi.reload();
|
|
6
|
+
|
|
7
|
+
return;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
setTimeout(reloadStrapiOnLoad, 1000);
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export { reloadStrapiOnLoad };
|
package/server/utils/strapi.ts
CHANGED
|
@@ -1,49 +1,45 @@
|
|
|
1
|
-
import { Common } from '@strapi/strapi';
|
|
2
|
-
|
|
3
|
-
export const getDeepPopulate = (uid: Common.UID.Component, populate?: any, depth: number = 0) => {
|
|
4
|
-
if (populate) {
|
|
5
|
-
return populate;
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
if (depth > 2) {
|
|
9
|
-
return {};
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
const { attributes } = strapi.getModel(uid);
|
|
13
|
-
|
|
14
|
-
return Object.keys(attributes).reduce((populateAcc, attributeName) => {
|
|
15
|
-
const attribute = attributes[attributeName];
|
|
16
|
-
|
|
17
|
-
if (attribute.type === '
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
if (attribute.type === '
|
|
28
|
-
populateAcc[attributeName] =
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
return strapi.entityService.findOne(uid, id, {
|
|
47
|
-
populate
|
|
48
|
-
});
|
|
49
|
-
};
|
|
1
|
+
import { Common } from '@strapi/strapi';
|
|
2
|
+
|
|
3
|
+
export const getDeepPopulate = (uid: Common.UID.Component, populate?: any, depth: number = 0) => {
|
|
4
|
+
if (populate) {
|
|
5
|
+
return populate;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
if (depth > 2) {
|
|
9
|
+
return {};
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
const { attributes } = strapi.getModel(uid);
|
|
13
|
+
|
|
14
|
+
return Object.keys(attributes).reduce((populateAcc, attributeName) => {
|
|
15
|
+
const attribute = attributes[attributeName];
|
|
16
|
+
|
|
17
|
+
if (attribute.type === 'component') {
|
|
18
|
+
populateAcc[attributeName] = {
|
|
19
|
+
populate: getDeepPopulate(attribute.component, null, depth + 1)
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
if (attribute.type === 'relation' || attribute.type === 'media') {
|
|
24
|
+
populateAcc[attributeName] = true;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
if (attribute.type === 'dynamiczone') {
|
|
28
|
+
populateAcc[attributeName] = {
|
|
29
|
+
populate: (attribute.components || []).reduce((acc, componentUID) => {
|
|
30
|
+
return Object.assign(acc, getDeepPopulate(componentUID, null, depth + 1));
|
|
31
|
+
}, {})
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
return populateAcc;
|
|
36
|
+
}, {});
|
|
37
|
+
};
|
|
38
|
+
|
|
39
|
+
export const getPopulatedEntity = async (uid, id) => {
|
|
40
|
+
const populate = getDeepPopulate(uid);
|
|
41
|
+
|
|
42
|
+
return strapi.entityService.findOne(uid, id, {
|
|
43
|
+
populate
|
|
44
|
+
});
|
|
45
|
+
};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export const PAGE_UID = 'api::page.page';
|
|
2
|
-
export const TEMPLATE_UID = 'api::template.template';
|
|
3
|
-
export const PAGE_TYPE_UID = 'api::page-type.page-type';
|
|
4
|
-
export const PAGE_TYPE_PAGE = 'page';
|
|
1
|
+
export const PAGE_UID = 'api::page.page';
|
|
2
|
+
export const TEMPLATE_UID = 'api::template.template';
|
|
3
|
+
export const PAGE_TYPE_UID = 'api::page-type.page-type';
|
|
4
|
+
export const PAGE_TYPE_PAGE = 'page';
|
package/shared/utils/sleep.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export const sleep = (ms: number) => new Promise((r) => setTimeout(r, ms));
|
|
1
|
+
export const sleep = (ms: number) => new Promise((r) => setTimeout(r, ms));
|
package/strapi-admin.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
module.exports = require('./admin/src').default;
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
module.exports = require('./admin/src').default;
|
package/strapi-server.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
'use strict';
|
|
2
|
-
|
|
3
|
-
module.exports = require('./dist/server');
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
module.exports = require('./dist/server');
|
package/tsconfig.json
CHANGED
|
@@ -1,20 +1,20 @@
|
|
|
1
|
-
{
|
|
2
|
-
"extends": "@strapi/typescript-utils/tsconfigs/admin",
|
|
3
|
-
|
|
4
|
-
"compilerOptions": {
|
|
5
|
-
"target": "ESNext",
|
|
6
|
-
"strict": true
|
|
7
|
-
},
|
|
8
|
-
|
|
9
|
-
"include": ["admin", "custom.d.ts"],
|
|
10
|
-
|
|
11
|
-
"exclude": [
|
|
12
|
-
"node_modules/",
|
|
13
|
-
"dist/",
|
|
14
|
-
|
|
15
|
-
// Do not include server files in the server compilation
|
|
16
|
-
"server/",
|
|
17
|
-
// Do not include test files
|
|
18
|
-
"**/*.test.ts"
|
|
19
|
-
]
|
|
20
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"extends": "@strapi/typescript-utils/tsconfigs/admin",
|
|
3
|
+
|
|
4
|
+
"compilerOptions": {
|
|
5
|
+
"target": "ESNext",
|
|
6
|
+
"strict": true
|
|
7
|
+
},
|
|
8
|
+
|
|
9
|
+
"include": ["admin", "custom.d.ts"],
|
|
10
|
+
|
|
11
|
+
"exclude": [
|
|
12
|
+
"node_modules/",
|
|
13
|
+
"dist/",
|
|
14
|
+
|
|
15
|
+
// Do not include server files in the server compilation
|
|
16
|
+
"server/",
|
|
17
|
+
// Do not include test files
|
|
18
|
+
"**/*.test.ts"
|
|
19
|
+
]
|
|
20
|
+
}
|
package/tsconfig.server.json
CHANGED
|
@@ -1,25 +1,25 @@
|
|
|
1
|
-
{
|
|
2
|
-
"extends": "@strapi/typescript-utils/tsconfigs/server",
|
|
3
|
-
|
|
4
|
-
"compilerOptions": {
|
|
5
|
-
"outDir": "dist",
|
|
6
|
-
"rootDir": "."
|
|
7
|
-
},
|
|
8
|
-
|
|
9
|
-
"include": [
|
|
10
|
-
// Include the root directory
|
|
11
|
-
"server",
|
|
12
|
-
// Force the JSON files in the src folder to be included
|
|
13
|
-
"server/**/*.json"
|
|
14
|
-
],
|
|
15
|
-
|
|
16
|
-
"exclude": [
|
|
17
|
-
"node_modules/",
|
|
18
|
-
"dist/",
|
|
19
|
-
|
|
20
|
-
// Do not include admin files in the server compilation
|
|
21
|
-
"admin/",
|
|
22
|
-
// Do not include test files
|
|
23
|
-
"**/*.test.ts"
|
|
24
|
-
]
|
|
25
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"extends": "@strapi/typescript-utils/tsconfigs/server",
|
|
3
|
+
|
|
4
|
+
"compilerOptions": {
|
|
5
|
+
"outDir": "dist",
|
|
6
|
+
"rootDir": "."
|
|
7
|
+
},
|
|
8
|
+
|
|
9
|
+
"include": [
|
|
10
|
+
// Include the root directory
|
|
11
|
+
"server",
|
|
12
|
+
// Force the JSON files in the src folder to be included
|
|
13
|
+
"server/**/*.json"
|
|
14
|
+
],
|
|
15
|
+
|
|
16
|
+
"exclude": [
|
|
17
|
+
"node_modules/",
|
|
18
|
+
"dist/",
|
|
19
|
+
|
|
20
|
+
// Do not include admin files in the server compilation
|
|
21
|
+
"admin/",
|
|
22
|
+
// Do not include test files
|
|
23
|
+
"**/*.test.ts"
|
|
24
|
+
]
|
|
25
|
+
}
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.default = {
|
|
4
|
-
async findAll() {
|
|
5
|
-
return await strapi.service('plugin::page-builder.platform').findAll();
|
|
6
|
-
},
|
|
7
|
-
async findOneByUid(ctx) {
|
|
8
|
-
var _a;
|
|
9
|
-
const uid = (_a = ctx === null || ctx === void 0 ? void 0 : ctx.params) === null || _a === void 0 ? void 0 : _a.uid;
|
|
10
|
-
if (!uid) {
|
|
11
|
-
return ctx.badRequest('uid is missing.');
|
|
12
|
-
}
|
|
13
|
-
return await strapi.service('plugin::page-builder.platform').findOneByUid(uid);
|
|
14
|
-
},
|
|
15
|
-
async findPageTypesByPlatform(ctx) {
|
|
16
|
-
var _a;
|
|
17
|
-
const platform = (_a = ctx === null || ctx === void 0 ? void 0 : ctx.params) === null || _a === void 0 ? void 0 : _a.platform;
|
|
18
|
-
return await strapi.services['plugin::page-builder.platform'].findPageTypesByPlatform(platform);
|
|
19
|
-
}
|
|
20
|
-
};
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"draftAndPublish": false,
|
|
3
|
-
"displayName": "Platforms",
|
|
4
|
-
"singularName": "platform",
|
|
5
|
-
"pluralName": "platforms",
|
|
6
|
-
"description": "",
|
|
7
|
-
"plugin": "page-builder",
|
|
8
|
-
"pluginOptions": {},
|
|
9
|
-
"kind": "collectionType",
|
|
10
|
-
"collectionName": "platforms",
|
|
11
|
-
"attributes": {
|
|
12
|
-
"title": {
|
|
13
|
-
"type": "string",
|
|
14
|
-
"required": true,
|
|
15
|
-
"unique": true
|
|
16
|
-
},
|
|
17
|
-
"domain": {
|
|
18
|
-
"type": "string"
|
|
19
|
-
},
|
|
20
|
-
"template": {
|
|
21
|
-
"type": "relation",
|
|
22
|
-
"relation": "oneToMany",
|
|
23
|
-
"target": "api::template.template"
|
|
24
|
-
},
|
|
25
|
-
"pageTypes": {
|
|
26
|
-
"type": "relation",
|
|
27
|
-
"relation": "oneToMany",
|
|
28
|
-
"target": "api::page-type.page-type"
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
}
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const constants_1 = require("../../shared/utils/constants");
|
|
4
|
-
exports.default = {
|
|
5
|
-
async findAll() {
|
|
6
|
-
return await strapi.entityService.findMany(constants_1.PLATFORM_UID, { populate: '*' });
|
|
7
|
-
},
|
|
8
|
-
async findOneByUid(uid) {
|
|
9
|
-
return await strapi.entityService.findMany(constants_1.PLATFORM_UID, {
|
|
10
|
-
populate: '*',
|
|
11
|
-
filters: {
|
|
12
|
-
pagetype: {
|
|
13
|
-
uid
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
});
|
|
17
|
-
},
|
|
18
|
-
async findPageTypesByPlatform(platform) {
|
|
19
|
-
const results = await strapi.entityService.findMany(constants_1.PLATFORM_UID, {
|
|
20
|
-
populate: {
|
|
21
|
-
pagetype: true
|
|
22
|
-
},
|
|
23
|
-
filters: {
|
|
24
|
-
title: {
|
|
25
|
-
$eq: platform
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
});
|
|
29
|
-
if (results.length > 0) {
|
|
30
|
-
return results;
|
|
31
|
-
}
|
|
32
|
-
else {
|
|
33
|
-
return null;
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
};
|