@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.
- package/README.md +166 -166
- package/admin/src/api/collection-type.ts +111 -111
- package/admin/src/api/entity-relation.ts +42 -42
- package/admin/src/api/has-page-relation.ts +37 -37
- package/admin/src/api/has-platform-relation.ts +40 -40
- package/admin/src/api/page-type-relation.ts +41 -41
- package/admin/src/api/platform-page-types.ts +45 -45
- package/admin/src/api/platform-relation.ts +42 -42
- package/admin/src/api/platform.ts +35 -35
- package/admin/src/api/search-filtered-entity.ts +114 -114
- package/admin/src/api/template.ts +39 -39
- package/admin/src/components/Combobox/index.tsx +83 -83
- package/admin/src/components/Combobox/react-select-custom-styles.tsx +121 -121
- package/admin/src/components/Combobox/styles.ts +46 -46
- package/admin/src/components/ConfirmModal/index.tsx +90 -90
- package/admin/src/components/EditView/CollectionTypeSearch/index.tsx +127 -127
- package/admin/src/components/EditView/CollectionTypeSettings/CreatePageButton/index.tsx +149 -149
- package/admin/src/components/EditView/CollectionTypeSettings/CreatePageButton/styles.ts +19 -19
- package/admin/src/components/EditView/CollectionTypeSettings/index.tsx +82 -82
- package/admin/src/components/EditView/Details/index.tsx +48 -48
- package/admin/src/components/EditView/Details/styles.ts +51 -51
- package/admin/src/components/EditView/PageSettings/index.tsx +124 -124
- package/admin/src/components/EditView/Platform/platform-select.tsx +30 -30
- package/admin/src/components/EditView/Template/TemplateConfirmModal/index.tsx +36 -36
- package/admin/src/components/EditView/Template/TemplateSelect/index.tsx +70 -70
- package/admin/src/components/EditView/Template/TemplateSelect/use-template-modules.ts +41 -41
- package/admin/src/components/EditView/index.tsx +35 -35
- package/admin/src/components/EditView/page-type-select.tsx +32 -32
- package/admin/src/components/EditView/wrapper.tsx +41 -41
- package/admin/src/components/GlobalPlatformSelect/index.tsx +40 -40
- package/admin/src/components/GlobalPlatformSelect/styles.ts +27 -27
- package/admin/src/components/Initializer/index.tsx +24 -24
- package/admin/src/components/PageFilters/PageTypeFilter/index.tsx +39 -39
- package/admin/src/components/PageFilters/PlatformFilter/index.tsx +32 -32
- package/admin/src/components/PageFilters/filters.tsx +189 -189
- package/admin/src/components/PageFilters/index.tsx +35 -35
- package/admin/src/components/PageTypeEditView/TemplatePlatformSelect/index.tsx +76 -76
- package/admin/src/components/PageTypeEditView/index.tsx +53 -53
- package/admin/src/components/PlatformFilteredSelectField/InputIcon/index.tsx +23 -23
- package/admin/src/components/PlatformFilteredSelectField/Multi/index.tsx +210 -210
- package/admin/src/components/PlatformFilteredSelectField/Single/index.tsx +197 -197
- package/admin/src/components/PlatformFilteredSelectField/hooks/useRelationLoad.tsx +128 -128
- package/admin/src/components/PlatformFilteredSelectField/index.tsx +85 -85
- package/admin/src/components/PlatformFilteredSelectField/styles.tsx +77 -77
- package/admin/src/components/PlatformFilteredSelectField/utils/get-translations.ts +3 -3
- package/admin/src/components/PlatformFilteredSelectField/utils/relation-helper.ts +147 -147
- package/admin/src/components/PluginIcon/index.tsx +94 -94
- package/admin/src/components/StrapiCore/admin/admin/src/content-manager/components/Relations/RelationInput.tsx +689 -689
- package/admin/src/components/StrapiCore/admin/admin/src/content-manager/components/Relations/RelationInputDataManager.tsx +6 -6
- package/admin/src/components/StrapiCore/admin/admin/src/content-manager/components/Relations/useRelation.ts +170 -170
- package/admin/src/components/StrapiCore/admin/admin/src/content-manager/components/Relations/utils/getRelationLink.ts +5 -5
- package/admin/src/components/StrapiCore/admin/admin/src/content-manager/components/Relations/utils/normalizeRelations.ts +52 -52
- package/admin/src/components/StrapiCore/admin/admin/src/content-manager/constants/attributes.ts +3 -3
- package/admin/src/components/StrapiCore/admin/admin/src/content-manager/hooks/useDragAndDrop.ts +253 -253
- package/admin/src/components/StrapiCore/admin/admin/src/content-manager/hooks/useKeyboardDragAndDrop.ts +96 -96
- package/admin/src/components/StrapiCore/admin/admin/src/content-manager/hooks/usePrev.ts +11 -11
- package/admin/src/components/StrapiCore/admin/admin/src/content-manager/utils/dragAndDrop.ts +8 -8
- package/admin/src/components/StrapiCore/admin/admin/src/content-manager/utils/paths.ts +29 -29
- package/admin/src/components/StrapiCore/admin/admin/src/content-manager/utils/refs.ts +19 -19
- package/admin/src/components/StrapiCore/admin/admin/src/content-manager/utils/translations.ts +3 -3
- package/admin/src/components/StrapiCore/content-manager/shared/contracts/collection-types.ts +300 -300
- package/admin/src/components/StrapiCore/content-manager/shared/contracts/components.ts +72 -72
- package/admin/src/components/StrapiCore/content-manager/shared/contracts/content-types.ts +116 -116
- package/admin/src/components/StrapiCore/content-manager/shared/contracts/index.ts +8 -8
- package/admin/src/components/StrapiCore/content-manager/shared/contracts/init.ts +22 -22
- package/admin/src/components/StrapiCore/content-manager/shared/contracts/relations.ts +80 -80
- package/admin/src/components/StrapiCore/content-manager/shared/contracts/review-workflows.ts +88 -88
- package/admin/src/components/StrapiCore/content-manager/shared/contracts/single-types.ts +112 -112
- package/admin/src/components/StrapiCore/content-manager/shared/contracts/uid.ts +48 -48
- package/admin/src/components/StrapiCore/content-manager/shared/index.ts +1 -1
- package/admin/src/constants.ts +3 -3
- package/admin/src/index.tsx +101 -101
- package/admin/src/middlewares/index.tsx +37 -37
- package/admin/src/pages/app/index.tsx +14 -14
- package/admin/src/pluginId.ts +5 -5
- package/admin/src/translations/en.json +9 -9
- package/admin/src/translations/nl.json +9 -9
- package/admin/src/utils/findDomElement.ts +6 -6
- package/admin/src/utils/findElementParent.ts +20 -20
- package/admin/src/utils/getObjectFromFormName.ts +42 -42
- 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/useDefaultPlatformFromLocalStorage.ts +61 -61
- package/admin/src/utils/hooks/useGetLocaleFromUrl.ts +9 -9
- package/admin/src/utils/hooks/useHideOverviewFilterTags.ts +34 -34
- package/admin/src/utils/hooks/usePlatformFormData.ts +64 -64
- package/admin/src/utils/hooks/usePrevious.ts +12 -12
- package/admin/src/utils/sanitizeModules.ts +93 -93
- package/custom.d.ts +6 -6
- package/dist/package.json +1 -1
- package/dist/server/bootstrap.js +1 -1
- package/dist/server/graphql/page-by-path.js +20 -17
- package/dist/server/graphql/pages-by-uid.js +5 -5
- package/dist/server/services/private-content/graphql/index.js +27 -27
- package/dist/server/services/private-content/graphql/types/index.js +74 -74
- package/dist/tsconfig.server.tsbuildinfo +1 -1
- package/package.json +78 -78
- package/server/bootstrap/collection-type-lifecycles.ts +47 -47
- package/server/bootstrap/permissions.ts +161 -161
- package/server/bootstrap.ts +261 -261
- package/server/config/index.ts +4 -4
- package/server/content-types/index.ts +7 -7
- package/server/content-types/user-category/schema.json +23 -23
- package/server/controllers/collection-types.ts +32 -32
- package/server/controllers/index.ts +19 -19
- package/server/controllers/page-type.ts +18 -18
- package/server/controllers/page.ts +9 -9
- package/server/controllers/platform.ts +21 -21
- package/server/controllers/private-content.ts +17 -17
- package/server/controllers/sitemap.ts +32 -32
- package/server/controllers/template.ts +16 -16
- package/server/controllers/user-category.ts +3 -3
- package/server/destroy.ts +5 -5
- package/server/graphql/index.ts +9 -9
- package/server/graphql/page-by-path.ts +135 -132
- package/server/graphql/page-type.ts +67 -67
- package/server/graphql/pages-by-uid.ts +89 -89
- package/server/index.ts +23 -23
- package/server/middlewares/index.ts +1 -1
- package/server/policies/index.ts +5 -5
- package/server/policies/isAuthorizedPage.ts +11 -11
- package/server/register.ts +22 -22
- package/server/routes/index.ts +115 -115
- package/server/routes/user-category.ts +3 -3
- package/server/schema/page-end.json +96 -96
- package/server/schema/page-start.json +87 -87
- package/server/schema/page-type-end.json +53 -53
- package/server/schema/page-type-start.json +38 -38
- package/server/schema/platform-start.json +21 -21
- package/server/schema/template-end.json +40 -40
- package/server/schema/template-start.json +35 -35
- package/server/services/builder.ts +232 -232
- package/server/services/collection-types.ts +95 -95
- package/server/services/email.ts +127 -127
- package/server/services/index.ts +23 -23
- package/server/services/page-type.ts +30 -30
- package/server/services/page.ts +24 -24
- package/server/services/platform.ts +30 -30
- package/server/services/private-content/components/admin-email.json +22 -22
- package/server/services/private-content/components/email.json +22 -22
- package/server/services/private-content/components/platform-email.json +30 -30
- package/server/services/private-content/constants/index.ts +13 -13
- package/server/services/private-content/graphql/index.ts +88 -88
- package/server/services/private-content/graphql/resolvers/findOnePage.ts +40 -40
- package/server/services/private-content/graphql/resolvers/findPage.ts +45 -45
- package/server/services/private-content/graphql/resolvers/forgot-password.ts +34 -34
- package/server/services/private-content/graphql/resolvers/login.ts +56 -56
- package/server/services/private-content/graphql/resolvers/register.ts +78 -78
- package/server/services/private-content/graphql/resolvers/reset-password.ts +44 -44
- package/server/services/private-content/graphql/types/index.ts +96 -96
- package/server/services/private-content/index.ts +95 -95
- package/server/services/private-content/mail-template/txtMail.email.template.text.ts +6 -6
- package/server/services/private-content/page.ts +20 -20
- package/server/services/private-content/platform.ts +19 -19
- package/server/services/private-content/schemas/index.ts +28 -28
- package/server/services/private-content/user.ts +197 -197
- package/server/services/sitemap.ts +83 -83
- package/server/services/template.ts +13 -13
- package/server/services/user-category.ts +3 -3
- package/server/utils/filter-underscore-arguments.ts +12 -12
- package/server/utils/reload-strapi-on-load.ts +13 -13
- package/server/utils/strapi.ts +50 -50
- package/shared/utils/constants.ts +8 -8
- 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/graphql/page-by-slug.js +0 -89
- package/dist/server/utils/graphql.js +0 -100
- package/dist/server/utils/paginationValidation.js +0 -31
package/package.json
CHANGED
|
@@ -1,78 +1,78 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "@webbio/strapi-plugin-page-builder",
|
|
3
|
-
"version": "0.12.
|
|
4
|
-
"description": "This is the description of the plugin.",
|
|
5
|
-
"scripts": {
|
|
6
|
-
"develop": "tsc -p tsconfig.server.json -w",
|
|
7
|
-
"build": "tsc -p tsconfig.server.json",
|
|
8
|
-
"prepublish": "tsc -p tsconfig.server.json",
|
|
9
|
-
"format": "prettier --write .",
|
|
10
|
-
"spu": "yarn upgrade-interactive --latest"
|
|
11
|
-
},
|
|
12
|
-
"strapi": {
|
|
13
|
-
"name": "page-builder",
|
|
14
|
-
"description": "Description of page-builder plugin",
|
|
15
|
-
"displayName": "Page Builder",
|
|
16
|
-
"kind": "plugin"
|
|
17
|
-
},
|
|
18
|
-
"repository": {
|
|
19
|
-
"type": "git",
|
|
20
|
-
"url": "https://github.com/webbio/strapi-plugin-page-builder.git"
|
|
21
|
-
},
|
|
22
|
-
"dependencies": {
|
|
23
|
-
"@aws-sdk/client-ses": "^3.485.0",
|
|
24
|
-
"@mantine/hooks": "^7.2.2",
|
|
25
|
-
"@strapi/design-system": "^1.11.0",
|
|
26
|
-
"@strapi/helper-plugin": "^4.15.0",
|
|
27
|
-
"@strapi/icons": "^1.11.0",
|
|
28
|
-
"@strapi/provider-email-amazon-ses": "^4.16.2",
|
|
29
|
-
"@strapi/typescript-utils": "^4.15.0",
|
|
30
|
-
"@strapi/utils": "^4.15.0",
|
|
31
|
-
"add": "^2.0.6",
|
|
32
|
-
"aws-sdk": "^2.1528.0",
|
|
33
|
-
"handlebars": "^4.7.8",
|
|
34
|
-
"react-select": "^5.7.4",
|
|
35
|
-
"sitemap": "^7.1.1",
|
|
36
|
-
"slugify": "^1.6.6"
|
|
37
|
-
},
|
|
38
|
-
"devDependencies": {
|
|
39
|
-
"@types/react": "^18.2.21",
|
|
40
|
-
"@types/react-dom": "^18.2.7",
|
|
41
|
-
"@types/react-router-dom": "^5.3.3",
|
|
42
|
-
"@types/styled-components": "^5.1.26",
|
|
43
|
-
"react": "^18.2.0",
|
|
44
|
-
"react-dom": "^18.2.0",
|
|
45
|
-
"react-router-dom": "^5.3.4",
|
|
46
|
-
"styled-components": "^5.3.6",
|
|
47
|
-
"typescript": "5.1.6"
|
|
48
|
-
},
|
|
49
|
-
"peerDependencies": {
|
|
50
|
-
"@strapi/strapi": "^4.15.0",
|
|
51
|
-
"@webbio/strapi-plugin-slug": "^3.3.1",
|
|
52
|
-
"react": "^17.0.0 || ^18.0.0",
|
|
53
|
-
"react-dom": "^17.0.0 || ^18.0.0",
|
|
54
|
-
"react-router-dom": "^5.3.4",
|
|
55
|
-
"styled-components": "^5.3.6"
|
|
56
|
-
},
|
|
57
|
-
"author": {
|
|
58
|
-
"name": "Webbio B.V.",
|
|
59
|
-
"email": "info@webbio.nl",
|
|
60
|
-
"url": "https://webbio.nl"
|
|
61
|
-
},
|
|
62
|
-
"maintainers": [
|
|
63
|
-
{
|
|
64
|
-
"name": "Webbio B.V.",
|
|
65
|
-
"email": "info@webbio.nl",
|
|
66
|
-
"url": "https://webbio.nl"
|
|
67
|
-
}
|
|
68
|
-
],
|
|
69
|
-
"engines": {
|
|
70
|
-
"node": ">=14.19.1 <=20.x.x",
|
|
71
|
-
"npm": ">=6.0.0"
|
|
72
|
-
},
|
|
73
|
-
"license": "MIT",
|
|
74
|
-
"publishConfig": {
|
|
75
|
-
"access": "public",
|
|
76
|
-
"registry": "https://registry.npmjs.org"
|
|
77
|
-
}
|
|
78
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"name": "@webbio/strapi-plugin-page-builder",
|
|
3
|
+
"version": "0.12.3-platform",
|
|
4
|
+
"description": "This is the description of the plugin.",
|
|
5
|
+
"scripts": {
|
|
6
|
+
"develop": "tsc -p tsconfig.server.json -w",
|
|
7
|
+
"build": "tsc -p tsconfig.server.json",
|
|
8
|
+
"prepublish": "tsc -p tsconfig.server.json",
|
|
9
|
+
"format": "prettier --write .",
|
|
10
|
+
"spu": "yarn upgrade-interactive --latest"
|
|
11
|
+
},
|
|
12
|
+
"strapi": {
|
|
13
|
+
"name": "page-builder",
|
|
14
|
+
"description": "Description of page-builder plugin",
|
|
15
|
+
"displayName": "Page Builder",
|
|
16
|
+
"kind": "plugin"
|
|
17
|
+
},
|
|
18
|
+
"repository": {
|
|
19
|
+
"type": "git",
|
|
20
|
+
"url": "https://github.com/webbio/strapi-plugin-page-builder.git"
|
|
21
|
+
},
|
|
22
|
+
"dependencies": {
|
|
23
|
+
"@aws-sdk/client-ses": "^3.485.0",
|
|
24
|
+
"@mantine/hooks": "^7.2.2",
|
|
25
|
+
"@strapi/design-system": "^1.11.0",
|
|
26
|
+
"@strapi/helper-plugin": "^4.15.0",
|
|
27
|
+
"@strapi/icons": "^1.11.0",
|
|
28
|
+
"@strapi/provider-email-amazon-ses": "^4.16.2",
|
|
29
|
+
"@strapi/typescript-utils": "^4.15.0",
|
|
30
|
+
"@strapi/utils": "^4.15.0",
|
|
31
|
+
"add": "^2.0.6",
|
|
32
|
+
"aws-sdk": "^2.1528.0",
|
|
33
|
+
"handlebars": "^4.7.8",
|
|
34
|
+
"react-select": "^5.7.4",
|
|
35
|
+
"sitemap": "^7.1.1",
|
|
36
|
+
"slugify": "^1.6.6"
|
|
37
|
+
},
|
|
38
|
+
"devDependencies": {
|
|
39
|
+
"@types/react": "^18.2.21",
|
|
40
|
+
"@types/react-dom": "^18.2.7",
|
|
41
|
+
"@types/react-router-dom": "^5.3.3",
|
|
42
|
+
"@types/styled-components": "^5.1.26",
|
|
43
|
+
"react": "^18.2.0",
|
|
44
|
+
"react-dom": "^18.2.0",
|
|
45
|
+
"react-router-dom": "^5.3.4",
|
|
46
|
+
"styled-components": "^5.3.6",
|
|
47
|
+
"typescript": "5.1.6"
|
|
48
|
+
},
|
|
49
|
+
"peerDependencies": {
|
|
50
|
+
"@strapi/strapi": "^4.15.0",
|
|
51
|
+
"@webbio/strapi-plugin-slug": "^3.3.1",
|
|
52
|
+
"react": "^17.0.0 || ^18.0.0",
|
|
53
|
+
"react-dom": "^17.0.0 || ^18.0.0",
|
|
54
|
+
"react-router-dom": "^5.3.4",
|
|
55
|
+
"styled-components": "^5.3.6"
|
|
56
|
+
},
|
|
57
|
+
"author": {
|
|
58
|
+
"name": "Webbio B.V.",
|
|
59
|
+
"email": "info@webbio.nl",
|
|
60
|
+
"url": "https://webbio.nl"
|
|
61
|
+
},
|
|
62
|
+
"maintainers": [
|
|
63
|
+
{
|
|
64
|
+
"name": "Webbio B.V.",
|
|
65
|
+
"email": "info@webbio.nl",
|
|
66
|
+
"url": "https://webbio.nl"
|
|
67
|
+
}
|
|
68
|
+
],
|
|
69
|
+
"engines": {
|
|
70
|
+
"node": ">=14.19.1 <=20.x.x",
|
|
71
|
+
"npm": ">=6.0.0"
|
|
72
|
+
},
|
|
73
|
+
"license": "MIT",
|
|
74
|
+
"publishConfig": {
|
|
75
|
+
"access": "public",
|
|
76
|
+
"registry": "https://registry.npmjs.org"
|
|
77
|
+
}
|
|
78
|
+
}
|
|
@@ -1,47 +1,47 @@
|
|
|
1
|
-
import { Common, Strapi } from '@strapi/strapi';
|
|
2
|
-
|
|
3
|
-
import { ICollectionTypeGL } from '../services/collection-types';
|
|
4
|
-
import { PAGE_UID } from '../../shared/utils/constants';
|
|
5
|
-
|
|
6
|
-
export default async ({ strapi }: { strapi: Strapi }) => {
|
|
7
|
-
const collectionTypesWithPageMorph: ICollectionTypeGL[] = strapi
|
|
8
|
-
.service('plugin::page-builder.collection-types')
|
|
9
|
-
.withPageMorph();
|
|
10
|
-
|
|
11
|
-
const models = collectionTypesWithPageMorph.map((ct) => ct.uid);
|
|
12
|
-
|
|
13
|
-
strapi.db?.lifecycles.subscribe({
|
|
14
|
-
models,
|
|
15
|
-
async beforeUpdate(event) {
|
|
16
|
-
try {
|
|
17
|
-
let { data, where } = event?.params;
|
|
18
|
-
|
|
19
|
-
if (data?.lifecycleState?.exit) {
|
|
20
|
-
return;
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
let connectedPageId: number = data.page?.[0];
|
|
24
|
-
|
|
25
|
-
if (!connectedPageId) {
|
|
26
|
-
const originalEntity = await strapi.entityService?.findOne(
|
|
27
|
-
event.model.uid as Common.UID.ContentType,
|
|
28
|
-
data.id || where.id,
|
|
29
|
-
{ populate: { page: true } } as Record<string, any>
|
|
30
|
-
);
|
|
31
|
-
|
|
32
|
-
connectedPageId = originalEntity?.page?.[0]?.id;
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
if (connectedPageId && data.updatedAt) {
|
|
36
|
-
await strapi.entityService?.update(PAGE_UID, connectedPageId, {
|
|
37
|
-
data: {
|
|
38
|
-
updatedAt: data.updatedAt
|
|
39
|
-
}
|
|
40
|
-
} as Record<string, any>);
|
|
41
|
-
}
|
|
42
|
-
} catch (error) {
|
|
43
|
-
console.log('[PAGEBUILDER PLUGIN] collection type lifecycle error: ', error);
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
|
-
});
|
|
47
|
-
};
|
|
1
|
+
import { Common, Strapi } from '@strapi/strapi';
|
|
2
|
+
|
|
3
|
+
import { ICollectionTypeGL } from '../services/collection-types';
|
|
4
|
+
import { PAGE_UID } from '../../shared/utils/constants';
|
|
5
|
+
|
|
6
|
+
export default async ({ strapi }: { strapi: Strapi }) => {
|
|
7
|
+
const collectionTypesWithPageMorph: ICollectionTypeGL[] = strapi
|
|
8
|
+
.service('plugin::page-builder.collection-types')
|
|
9
|
+
.withPageMorph();
|
|
10
|
+
|
|
11
|
+
const models = collectionTypesWithPageMorph.map((ct) => ct.uid);
|
|
12
|
+
|
|
13
|
+
strapi.db?.lifecycles.subscribe({
|
|
14
|
+
models,
|
|
15
|
+
async beforeUpdate(event) {
|
|
16
|
+
try {
|
|
17
|
+
let { data, where } = event?.params;
|
|
18
|
+
|
|
19
|
+
if (data?.lifecycleState?.exit) {
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
let connectedPageId: number = data.page?.[0];
|
|
24
|
+
|
|
25
|
+
if (!connectedPageId) {
|
|
26
|
+
const originalEntity = await strapi.entityService?.findOne(
|
|
27
|
+
event.model.uid as Common.UID.ContentType,
|
|
28
|
+
data.id || where.id,
|
|
29
|
+
{ populate: { page: true } } as Record<string, any>
|
|
30
|
+
);
|
|
31
|
+
|
|
32
|
+
connectedPageId = originalEntity?.page?.[0]?.id;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
if (connectedPageId && data.updatedAt) {
|
|
36
|
+
await strapi.entityService?.update(PAGE_UID, connectedPageId, {
|
|
37
|
+
data: {
|
|
38
|
+
updatedAt: data.updatedAt
|
|
39
|
+
}
|
|
40
|
+
} as Record<string, any>);
|
|
41
|
+
}
|
|
42
|
+
} catch (error) {
|
|
43
|
+
console.log('[PAGEBUILDER PLUGIN] collection type lifecycle error: ', error);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
};
|
|
@@ -1,161 +1,161 @@
|
|
|
1
|
-
import uniq from 'lodash/uniq';
|
|
2
|
-
import { Strapi } from '@strapi/strapi';
|
|
3
|
-
import { PLATFORM_UID } from '../../shared/utils/constants';
|
|
4
|
-
|
|
5
|
-
export default async ({ strapi }: { strapi: Strapi }) => {
|
|
6
|
-
try {
|
|
7
|
-
const platforms = (await strapi.entityService?.findMany(PLATFORM_UID, {
|
|
8
|
-
limit: -1
|
|
9
|
-
})) as Record<string, any>[];
|
|
10
|
-
|
|
11
|
-
const platformPagePermissions = platforms.map((platform) => {
|
|
12
|
-
const name = `platform-is-${platform.title}`;
|
|
13
|
-
const displayName = platform.title;
|
|
14
|
-
|
|
15
|
-
return {
|
|
16
|
-
plugin: 'page-builder',
|
|
17
|
-
name,
|
|
18
|
-
displayName,
|
|
19
|
-
category: 'Platform',
|
|
20
|
-
handler: async (x) => {
|
|
21
|
-
if (x?.permission?.subject === 'api::platform.platform') {
|
|
22
|
-
return {
|
|
23
|
-
id: {
|
|
24
|
-
$eq: platform.id
|
|
25
|
-
}
|
|
26
|
-
};
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
if (x?.permission?.subject === 'api::page.page') {
|
|
30
|
-
try {
|
|
31
|
-
const roles = (await strapi.entityService?.findMany('admin::role', {
|
|
32
|
-
limit: -1,
|
|
33
|
-
populate: '*'
|
|
34
|
-
})) as Record<string, any>[];
|
|
35
|
-
|
|
36
|
-
// checks which role the user has
|
|
37
|
-
const foundRole = roles.filter((role) => {
|
|
38
|
-
return x.roles.find((userRole) => userRole.name === role.name);
|
|
39
|
-
});
|
|
40
|
-
|
|
41
|
-
// get the right platform permissions, and filters out the platform
|
|
42
|
-
// this is neccesary because of multiple platforms. if you can see Vacancy from platform 1 and collegue from platform 2
|
|
43
|
-
// it will show both at page level, so this filters out the wrong page
|
|
44
|
-
const platformPermission = foundRole?.[0]?.permissions.map((permission) => {
|
|
45
|
-
return {
|
|
46
|
-
permission: permission.subject,
|
|
47
|
-
condition: permission.conditions.filter((condition) => condition.includes(platform.title))
|
|
48
|
-
};
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
// get the right permission for platform
|
|
52
|
-
const permissions = platformPermission.map((permission) => {
|
|
53
|
-
if (permission.condition.length > 0) {
|
|
54
|
-
return permission.permission;
|
|
55
|
-
}
|
|
56
|
-
});
|
|
57
|
-
|
|
58
|
-
const uniquePermissions = uniq(permissions);
|
|
59
|
-
|
|
60
|
-
return {
|
|
61
|
-
$and: [
|
|
62
|
-
{
|
|
63
|
-
$or: [
|
|
64
|
-
{
|
|
65
|
-
'platform.id': {
|
|
66
|
-
$eq: platform.id
|
|
67
|
-
}
|
|
68
|
-
},
|
|
69
|
-
{
|
|
70
|
-
// This is a fix for not showing data after saving. After an update, no platform is returned for the page, so the permission system thinks the user has no access.
|
|
71
|
-
// All pages have a platform, so this fix won't break anything 🙏
|
|
72
|
-
'platform.id': {
|
|
73
|
-
$eq: null
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
]
|
|
77
|
-
},
|
|
78
|
-
{
|
|
79
|
-
$or: [
|
|
80
|
-
{
|
|
81
|
-
'pageType.uid': {
|
|
82
|
-
$in: uniquePermissions
|
|
83
|
-
}
|
|
84
|
-
},
|
|
85
|
-
{
|
|
86
|
-
'pageType.uid': {
|
|
87
|
-
// This means there is no pageType (which is the case for any other page)
|
|
88
|
-
$eq: null
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
]
|
|
92
|
-
}
|
|
93
|
-
]
|
|
94
|
-
};
|
|
95
|
-
} catch (error) {
|
|
96
|
-
console.log(error);
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
return {
|
|
101
|
-
$and: [
|
|
102
|
-
{
|
|
103
|
-
'platform.id': {
|
|
104
|
-
$eq: platform.id
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
]
|
|
108
|
-
};
|
|
109
|
-
}
|
|
110
|
-
};
|
|
111
|
-
});
|
|
112
|
-
|
|
113
|
-
const allPermissions = [...platformPagePermissions.flat()];
|
|
114
|
-
|
|
115
|
-
// @ts-ignore shitty types
|
|
116
|
-
await strapi.admin.services.permission.conditionProvider.registerMany(allPermissions);
|
|
117
|
-
} catch (error) {
|
|
118
|
-
console.log('Cannot set page permissions');
|
|
119
|
-
}
|
|
120
|
-
};
|
|
121
|
-
|
|
122
|
-
// Leave this commented code here, This might be used in the future to change up the permissions IF needed
|
|
123
|
-
|
|
124
|
-
// const platformPagePermissions = platforms.map((platform) => {
|
|
125
|
-
// const platformPageTypes = pageTypes.filter((pageType) => pageType.platform.id === platform.id);
|
|
126
|
-
// return platformPageTypes.map((pageType) => {
|
|
127
|
-
// const name = `platform-is-${platform.title}-${pageType.uid}`;
|
|
128
|
-
// const displayName = pageType.title;
|
|
129
|
-
|
|
130
|
-
// return {
|
|
131
|
-
// plugin: 'page-builder',
|
|
132
|
-
// name,
|
|
133
|
-
// displayName,
|
|
134
|
-
// category: `${platform.title} pageTypes`,
|
|
135
|
-
// handler: async (x) => {
|
|
136
|
-
// if (x?.permission?.subject === 'api::platform.platform') {
|
|
137
|
-
// return {
|
|
138
|
-
// id: {
|
|
139
|
-
// $eq: platform.id
|
|
140
|
-
// }
|
|
141
|
-
// };
|
|
142
|
-
// }
|
|
143
|
-
|
|
144
|
-
// return {
|
|
145
|
-
// $and: [
|
|
146
|
-
// {
|
|
147
|
-
// 'platform.id': {
|
|
148
|
-
// $eq: platform.id
|
|
149
|
-
// }
|
|
150
|
-
// },
|
|
151
|
-
// {
|
|
152
|
-
// 'pageType.uid': {
|
|
153
|
-
// $eq: pageType.uid
|
|
154
|
-
// }
|
|
155
|
-
// }
|
|
156
|
-
// ]
|
|
157
|
-
// };
|
|
158
|
-
// }
|
|
159
|
-
// };
|
|
160
|
-
// });
|
|
161
|
-
// });
|
|
1
|
+
import uniq from 'lodash/uniq';
|
|
2
|
+
import { Strapi } from '@strapi/strapi';
|
|
3
|
+
import { PLATFORM_UID } from '../../shared/utils/constants';
|
|
4
|
+
|
|
5
|
+
export default async ({ strapi }: { strapi: Strapi }) => {
|
|
6
|
+
try {
|
|
7
|
+
const platforms = (await strapi.entityService?.findMany(PLATFORM_UID, {
|
|
8
|
+
limit: -1
|
|
9
|
+
})) as Record<string, any>[];
|
|
10
|
+
|
|
11
|
+
const platformPagePermissions = platforms.map((platform) => {
|
|
12
|
+
const name = `platform-is-${platform.title}`;
|
|
13
|
+
const displayName = platform.title;
|
|
14
|
+
|
|
15
|
+
return {
|
|
16
|
+
plugin: 'page-builder',
|
|
17
|
+
name,
|
|
18
|
+
displayName,
|
|
19
|
+
category: 'Platform',
|
|
20
|
+
handler: async (x) => {
|
|
21
|
+
if (x?.permission?.subject === 'api::platform.platform') {
|
|
22
|
+
return {
|
|
23
|
+
id: {
|
|
24
|
+
$eq: platform.id
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
if (x?.permission?.subject === 'api::page.page') {
|
|
30
|
+
try {
|
|
31
|
+
const roles = (await strapi.entityService?.findMany('admin::role', {
|
|
32
|
+
limit: -1,
|
|
33
|
+
populate: '*'
|
|
34
|
+
})) as Record<string, any>[];
|
|
35
|
+
|
|
36
|
+
// checks which role the user has
|
|
37
|
+
const foundRole = roles.filter((role) => {
|
|
38
|
+
return x.roles.find((userRole) => userRole.name === role.name);
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
// get the right platform permissions, and filters out the platform
|
|
42
|
+
// this is neccesary because of multiple platforms. if you can see Vacancy from platform 1 and collegue from platform 2
|
|
43
|
+
// it will show both at page level, so this filters out the wrong page
|
|
44
|
+
const platformPermission = foundRole?.[0]?.permissions.map((permission) => {
|
|
45
|
+
return {
|
|
46
|
+
permission: permission.subject,
|
|
47
|
+
condition: permission.conditions.filter((condition) => condition.includes(platform.title))
|
|
48
|
+
};
|
|
49
|
+
});
|
|
50
|
+
|
|
51
|
+
// get the right permission for platform
|
|
52
|
+
const permissions = platformPermission.map((permission) => {
|
|
53
|
+
if (permission.condition.length > 0) {
|
|
54
|
+
return permission.permission;
|
|
55
|
+
}
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
const uniquePermissions = uniq(permissions);
|
|
59
|
+
|
|
60
|
+
return {
|
|
61
|
+
$and: [
|
|
62
|
+
{
|
|
63
|
+
$or: [
|
|
64
|
+
{
|
|
65
|
+
'platform.id': {
|
|
66
|
+
$eq: platform.id
|
|
67
|
+
}
|
|
68
|
+
},
|
|
69
|
+
{
|
|
70
|
+
// This is a fix for not showing data after saving. After an update, no platform is returned for the page, so the permission system thinks the user has no access.
|
|
71
|
+
// All pages have a platform, so this fix won't break anything 🙏
|
|
72
|
+
'platform.id': {
|
|
73
|
+
$eq: null
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
]
|
|
77
|
+
},
|
|
78
|
+
{
|
|
79
|
+
$or: [
|
|
80
|
+
{
|
|
81
|
+
'pageType.uid': {
|
|
82
|
+
$in: uniquePermissions
|
|
83
|
+
}
|
|
84
|
+
},
|
|
85
|
+
{
|
|
86
|
+
'pageType.uid': {
|
|
87
|
+
// This means there is no pageType (which is the case for any other page)
|
|
88
|
+
$eq: null
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
]
|
|
92
|
+
}
|
|
93
|
+
]
|
|
94
|
+
};
|
|
95
|
+
} catch (error) {
|
|
96
|
+
console.log(error);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
return {
|
|
101
|
+
$and: [
|
|
102
|
+
{
|
|
103
|
+
'platform.id': {
|
|
104
|
+
$eq: platform.id
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
]
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
};
|
|
111
|
+
});
|
|
112
|
+
|
|
113
|
+
const allPermissions = [...platformPagePermissions.flat()];
|
|
114
|
+
|
|
115
|
+
// @ts-ignore shitty types
|
|
116
|
+
await strapi.admin.services.permission.conditionProvider.registerMany(allPermissions);
|
|
117
|
+
} catch (error) {
|
|
118
|
+
console.log('Cannot set page permissions');
|
|
119
|
+
}
|
|
120
|
+
};
|
|
121
|
+
|
|
122
|
+
// Leave this commented code here, This might be used in the future to change up the permissions IF needed
|
|
123
|
+
|
|
124
|
+
// const platformPagePermissions = platforms.map((platform) => {
|
|
125
|
+
// const platformPageTypes = pageTypes.filter((pageType) => pageType.platform.id === platform.id);
|
|
126
|
+
// return platformPageTypes.map((pageType) => {
|
|
127
|
+
// const name = `platform-is-${platform.title}-${pageType.uid}`;
|
|
128
|
+
// const displayName = pageType.title;
|
|
129
|
+
|
|
130
|
+
// return {
|
|
131
|
+
// plugin: 'page-builder',
|
|
132
|
+
// name,
|
|
133
|
+
// displayName,
|
|
134
|
+
// category: `${platform.title} pageTypes`,
|
|
135
|
+
// handler: async (x) => {
|
|
136
|
+
// if (x?.permission?.subject === 'api::platform.platform') {
|
|
137
|
+
// return {
|
|
138
|
+
// id: {
|
|
139
|
+
// $eq: platform.id
|
|
140
|
+
// }
|
|
141
|
+
// };
|
|
142
|
+
// }
|
|
143
|
+
|
|
144
|
+
// return {
|
|
145
|
+
// $and: [
|
|
146
|
+
// {
|
|
147
|
+
// 'platform.id': {
|
|
148
|
+
// $eq: platform.id
|
|
149
|
+
// }
|
|
150
|
+
// },
|
|
151
|
+
// {
|
|
152
|
+
// 'pageType.uid': {
|
|
153
|
+
// $eq: pageType.uid
|
|
154
|
+
// }
|
|
155
|
+
// }
|
|
156
|
+
// ]
|
|
157
|
+
// };
|
|
158
|
+
// }
|
|
159
|
+
// };
|
|
160
|
+
// });
|
|
161
|
+
// });
|