@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.
Files changed (93) hide show
  1. package/README.md +98 -98
  2. package/admin/src/api/collection-type.ts +110 -110
  3. package/admin/src/api/has-page-relation.ts +34 -34
  4. package/admin/src/api/page-type.ts +31 -31
  5. package/admin/src/api/template.ts +27 -27
  6. package/admin/src/components/Combobox/index.tsx +77 -77
  7. package/admin/src/components/Combobox/react-select-custom-styles.tsx +120 -111
  8. package/admin/src/components/Combobox/styles.ts +22 -22
  9. package/admin/src/components/ConfirmModal/index.tsx +90 -90
  10. package/admin/src/components/EditView/CollectionTypeSearch/index.tsx +124 -124
  11. package/admin/src/components/EditView/CollectionTypeSettings/CreatePageButton/index.tsx +104 -101
  12. package/admin/src/components/EditView/CollectionTypeSettings/CreatePageButton/styles.ts +19 -19
  13. package/admin/src/components/EditView/CollectionTypeSettings/index.tsx +74 -74
  14. package/admin/src/components/EditView/Details/index.tsx +47 -47
  15. package/admin/src/components/EditView/Details/styles.ts +51 -51
  16. package/admin/src/components/EditView/PageSettings/index.tsx +104 -104
  17. package/admin/src/components/EditView/Template/TemplateConfirmModal/index.tsx +36 -36
  18. package/admin/src/components/EditView/Template/TemplateSelect/index.tsx +69 -69
  19. package/admin/src/components/EditView/Template/TemplateSelect/use-template-modules.ts +38 -38
  20. package/admin/src/components/EditView/index.tsx +29 -29
  21. package/admin/src/components/EditView/page-type-select.tsx +32 -32
  22. package/admin/src/components/EditView/wrapper.tsx +35 -35
  23. package/admin/src/components/Initializer/index.tsx +24 -24
  24. package/admin/src/components/PageTypeFilter/index.tsx +17 -17
  25. package/admin/src/components/PageTypeFilter/page-type-filter.tsx +130 -130
  26. package/admin/src/components/PluginIcon/index.tsx +12 -12
  27. package/admin/src/constants.ts +3 -3
  28. package/admin/src/index.tsx +59 -59
  29. package/admin/src/middlewares/index.tsx +37 -37
  30. package/admin/src/pluginId.ts +5 -5
  31. package/admin/src/translations/en.json +6 -6
  32. package/admin/src/translations/nl.json +6 -6
  33. package/admin/src/utils/getRequestUrl.ts +11 -11
  34. package/admin/src/utils/getTrad.ts +5 -5
  35. package/admin/src/utils/hooks/useDebounce.ts +17 -17
  36. package/admin/src/utils/hooks/useGetLocaleFromUrl.ts +9 -9
  37. package/admin/src/utils/hooks/usePrevious.ts +12 -12
  38. package/admin/src/utils/sanitizeModules.ts +43 -10
  39. package/custom.d.ts +5 -5
  40. package/dist/package.json +9 -9
  41. package/dist/server/graphql/page-by-slug.js +9 -9
  42. package/dist/server/graphql/pages-by-uid.js +14 -14
  43. package/dist/server/services/builder.js +7 -4
  44. package/dist/server/services/template.js +1 -2
  45. package/dist/server/utils/graphql.js +18 -18
  46. package/dist/server/utils/strapi.js +1 -4
  47. package/dist/tsconfig.server.tsbuildinfo +1 -1
  48. package/package.json +71 -71
  49. package/server/bootstrap/collection-type-lifecycles.ts +47 -47
  50. package/server/bootstrap/permissions.ts +42 -42
  51. package/server/bootstrap.ts +198 -198
  52. package/server/config/index.ts +4 -4
  53. package/server/content-types/index.ts +1 -1
  54. package/server/controllers/collection-types.ts +27 -27
  55. package/server/controllers/index.ts +11 -11
  56. package/server/controllers/page-type.ts +13 -13
  57. package/server/controllers/page.ts +9 -9
  58. package/server/controllers/template.ts +16 -16
  59. package/server/destroy.ts +5 -5
  60. package/server/graphql/index.ts +9 -9
  61. package/server/graphql/page-by-slug.ts +98 -98
  62. package/server/graphql/page-type.ts +67 -67
  63. package/server/graphql/pages-by-uid.ts +127 -127
  64. package/server/index.ts +23 -23
  65. package/server/middlewares/index.ts +1 -1
  66. package/server/policies/index.ts +1 -1
  67. package/server/register.ts +15 -15
  68. package/server/routes/index.ts +58 -58
  69. package/server/schema/page-end.json +91 -91
  70. package/server/schema/page-start.json +87 -87
  71. package/server/schema/page-type-end.json +43 -43
  72. package/server/schema/page-type-start.json +38 -38
  73. package/server/schema/template-start.json +35 -35
  74. package/server/services/builder.ts +137 -134
  75. package/server/services/collection-types.ts +88 -88
  76. package/server/services/index.ts +13 -13
  77. package/server/services/page-type.ts +26 -26
  78. package/server/services/page.ts +24 -24
  79. package/server/services/template.ts +13 -14
  80. package/server/utils/filter-underscore-arguments.ts +12 -12
  81. package/server/utils/graphql.ts +113 -113
  82. package/server/utils/paginationValidation.ts +39 -39
  83. package/server/utils/reload-strapi-on-load.ts +13 -13
  84. package/server/utils/strapi.ts +45 -49
  85. package/shared/utils/constants.ts +4 -4
  86. package/shared/utils/sleep.ts +1 -1
  87. package/strapi-admin.js +3 -3
  88. package/strapi-server.js +3 -3
  89. package/tsconfig.json +20 -20
  90. package/tsconfig.server.json +25 -25
  91. package/dist/server/controllers/platform.js +0 -20
  92. package/dist/server/schema/platform-start.json +0 -31
  93. 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
+ };
@@ -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 };
@@ -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 === 'relation') {
18
- return populateAcc;
19
- }
20
-
21
- if (attribute.type === 'component') {
22
- populateAcc[attributeName] = {
23
- populate: getDeepPopulate(attribute.component, null, depth + 1)
24
- };
25
- }
26
-
27
- if (attribute.type === 'media') {
28
- populateAcc[attributeName] = true;
29
- }
30
-
31
- if (attribute.type === 'dynamiczone') {
32
- populateAcc[attributeName] = {
33
- populate: (attribute.components || []).reduce((acc, componentUID) => {
34
- return Object.assign(acc, getDeepPopulate(componentUID, null, depth + 1));
35
- }, {})
36
- };
37
- }
38
-
39
- return populateAcc;
40
- }, {});
41
- };
42
-
43
- export const getPopulatedEntity = async (uid, id) => {
44
- const populate = getDeepPopulate(uid);
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';
@@ -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
+ }
@@ -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
- };