@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
|
@@ -1,96 +1,96 @@
|
|
|
1
|
-
import * as React from 'react';
|
|
2
|
-
|
|
3
|
-
export type UseKeyboardDragAndDropCallbacks<TIndex extends number | Array<number> = number> = {
|
|
4
|
-
onCancel?: (index: TIndex) => void;
|
|
5
|
-
onDropItem?: (currentIndex: TIndex, newIndex?: TIndex) => void;
|
|
6
|
-
onGrabItem?: (index: TIndex) => void;
|
|
7
|
-
onMoveItem?: (newIndex: TIndex, currentIndex: TIndex) => void;
|
|
8
|
-
};
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* Utility hook designed to implement keyboard accessibile drag and drop by
|
|
12
|
-
* returning an onKeyDown handler to be passed to the drag icon button.
|
|
13
|
-
*
|
|
14
|
-
* @internal - You should use `useDragAndDrop` instead.
|
|
15
|
-
*/
|
|
16
|
-
export const useKeyboardDragAndDrop = <TIndex extends number | Array<number> = number>(
|
|
17
|
-
active: boolean,
|
|
18
|
-
index: TIndex,
|
|
19
|
-
{ onCancel, onDropItem, onGrabItem, onMoveItem }: UseKeyboardDragAndDropCallbacks<TIndex>
|
|
20
|
-
) => {
|
|
21
|
-
const [isSelected, setIsSelected] = React.useState(false);
|
|
22
|
-
|
|
23
|
-
const handleMove = (movement: 'UP' | 'DOWN') => {
|
|
24
|
-
if (!isSelected) {
|
|
25
|
-
return;
|
|
26
|
-
}
|
|
27
|
-
if (typeof index === 'number' && onMoveItem) {
|
|
28
|
-
if (movement === 'UP') {
|
|
29
|
-
onMoveItem((index - 1) as TIndex, index);
|
|
30
|
-
} else if (movement === 'DOWN') {
|
|
31
|
-
onMoveItem((index + 1) as TIndex, index);
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
};
|
|
35
|
-
|
|
36
|
-
const handleDragClick = () => {
|
|
37
|
-
if (isSelected) {
|
|
38
|
-
if (onDropItem) {
|
|
39
|
-
onDropItem(index);
|
|
40
|
-
}
|
|
41
|
-
setIsSelected(false);
|
|
42
|
-
} else {
|
|
43
|
-
if (onGrabItem) {
|
|
44
|
-
onGrabItem(index);
|
|
45
|
-
}
|
|
46
|
-
setIsSelected(true);
|
|
47
|
-
}
|
|
48
|
-
};
|
|
49
|
-
|
|
50
|
-
const handleCancel = () => {
|
|
51
|
-
if (isSelected) {
|
|
52
|
-
setIsSelected(false);
|
|
53
|
-
|
|
54
|
-
if (onCancel) {
|
|
55
|
-
onCancel(index);
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
};
|
|
59
|
-
|
|
60
|
-
const handleKeyDown: React.KeyboardEventHandler<HTMLButtonElement> = (e) => {
|
|
61
|
-
if (!active) {
|
|
62
|
-
return;
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
if (e.key === 'Tab' && !isSelected) {
|
|
66
|
-
return;
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
e.preventDefault();
|
|
70
|
-
|
|
71
|
-
switch (e.key) {
|
|
72
|
-
case ' ':
|
|
73
|
-
case 'Enter':
|
|
74
|
-
handleDragClick();
|
|
75
|
-
break;
|
|
76
|
-
|
|
77
|
-
case 'Escape':
|
|
78
|
-
handleCancel();
|
|
79
|
-
break;
|
|
80
|
-
|
|
81
|
-
case 'ArrowDown':
|
|
82
|
-
case 'ArrowRight':
|
|
83
|
-
handleMove('DOWN');
|
|
84
|
-
break;
|
|
85
|
-
|
|
86
|
-
case 'ArrowUp':
|
|
87
|
-
case 'ArrowLeft':
|
|
88
|
-
handleMove('UP');
|
|
89
|
-
break;
|
|
90
|
-
|
|
91
|
-
default:
|
|
92
|
-
}
|
|
93
|
-
};
|
|
94
|
-
|
|
95
|
-
return handleKeyDown;
|
|
96
|
-
};
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
|
|
3
|
+
export type UseKeyboardDragAndDropCallbacks<TIndex extends number | Array<number> = number> = {
|
|
4
|
+
onCancel?: (index: TIndex) => void;
|
|
5
|
+
onDropItem?: (currentIndex: TIndex, newIndex?: TIndex) => void;
|
|
6
|
+
onGrabItem?: (index: TIndex) => void;
|
|
7
|
+
onMoveItem?: (newIndex: TIndex, currentIndex: TIndex) => void;
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* Utility hook designed to implement keyboard accessibile drag and drop by
|
|
12
|
+
* returning an onKeyDown handler to be passed to the drag icon button.
|
|
13
|
+
*
|
|
14
|
+
* @internal - You should use `useDragAndDrop` instead.
|
|
15
|
+
*/
|
|
16
|
+
export const useKeyboardDragAndDrop = <TIndex extends number | Array<number> = number>(
|
|
17
|
+
active: boolean,
|
|
18
|
+
index: TIndex,
|
|
19
|
+
{ onCancel, onDropItem, onGrabItem, onMoveItem }: UseKeyboardDragAndDropCallbacks<TIndex>
|
|
20
|
+
) => {
|
|
21
|
+
const [isSelected, setIsSelected] = React.useState(false);
|
|
22
|
+
|
|
23
|
+
const handleMove = (movement: 'UP' | 'DOWN') => {
|
|
24
|
+
if (!isSelected) {
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
if (typeof index === 'number' && onMoveItem) {
|
|
28
|
+
if (movement === 'UP') {
|
|
29
|
+
onMoveItem((index - 1) as TIndex, index);
|
|
30
|
+
} else if (movement === 'DOWN') {
|
|
31
|
+
onMoveItem((index + 1) as TIndex, index);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
const handleDragClick = () => {
|
|
37
|
+
if (isSelected) {
|
|
38
|
+
if (onDropItem) {
|
|
39
|
+
onDropItem(index);
|
|
40
|
+
}
|
|
41
|
+
setIsSelected(false);
|
|
42
|
+
} else {
|
|
43
|
+
if (onGrabItem) {
|
|
44
|
+
onGrabItem(index);
|
|
45
|
+
}
|
|
46
|
+
setIsSelected(true);
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
const handleCancel = () => {
|
|
51
|
+
if (isSelected) {
|
|
52
|
+
setIsSelected(false);
|
|
53
|
+
|
|
54
|
+
if (onCancel) {
|
|
55
|
+
onCancel(index);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
const handleKeyDown: React.KeyboardEventHandler<HTMLButtonElement> = (e) => {
|
|
61
|
+
if (!active) {
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
if (e.key === 'Tab' && !isSelected) {
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
e.preventDefault();
|
|
70
|
+
|
|
71
|
+
switch (e.key) {
|
|
72
|
+
case ' ':
|
|
73
|
+
case 'Enter':
|
|
74
|
+
handleDragClick();
|
|
75
|
+
break;
|
|
76
|
+
|
|
77
|
+
case 'Escape':
|
|
78
|
+
handleCancel();
|
|
79
|
+
break;
|
|
80
|
+
|
|
81
|
+
case 'ArrowDown':
|
|
82
|
+
case 'ArrowRight':
|
|
83
|
+
handleMove('DOWN');
|
|
84
|
+
break;
|
|
85
|
+
|
|
86
|
+
case 'ArrowUp':
|
|
87
|
+
case 'ArrowLeft':
|
|
88
|
+
handleMove('UP');
|
|
89
|
+
break;
|
|
90
|
+
|
|
91
|
+
default:
|
|
92
|
+
}
|
|
93
|
+
};
|
|
94
|
+
|
|
95
|
+
return handleKeyDown;
|
|
96
|
+
};
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import { useEffect, useRef } from 'react';
|
|
2
|
-
|
|
3
|
-
export const usePrev = <T>(value: T): T | undefined => {
|
|
4
|
-
const ref = useRef<T>();
|
|
5
|
-
|
|
6
|
-
useEffect(() => {
|
|
7
|
-
ref.current = value;
|
|
8
|
-
}, [value]);
|
|
9
|
-
|
|
10
|
-
return ref.current;
|
|
11
|
-
};
|
|
1
|
+
import { useEffect, useRef } from 'react';
|
|
2
|
+
|
|
3
|
+
export const usePrev = <T>(value: T): T | undefined => {
|
|
4
|
+
const ref = useRef<T>();
|
|
5
|
+
|
|
6
|
+
useEffect(() => {
|
|
7
|
+
ref.current = value;
|
|
8
|
+
}, [value]);
|
|
9
|
+
|
|
10
|
+
return ref.current;
|
|
11
|
+
};
|
package/admin/src/components/StrapiCore/admin/admin/src/content-manager/utils/dragAndDrop.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
export const ItemTypes = {
|
|
2
|
-
COMPONENT: 'component',
|
|
3
|
-
EDIT_FIELD: 'editField',
|
|
4
|
-
FIELD: 'field',
|
|
5
|
-
DYNAMIC_ZONE: 'dynamicZone',
|
|
6
|
-
RELATION: 'relation',
|
|
7
|
-
BLOCKS: 'blocks'
|
|
8
|
-
} as const;
|
|
1
|
+
export const ItemTypes = {
|
|
2
|
+
COMPONENT: 'component',
|
|
3
|
+
EDIT_FIELD: 'editField',
|
|
4
|
+
FIELD: 'field',
|
|
5
|
+
DYNAMIC_ZONE: 'dynamicZone',
|
|
6
|
+
RELATION: 'relation',
|
|
7
|
+
BLOCKS: 'blocks'
|
|
8
|
+
} as const;
|
|
@@ -1,29 +1,29 @@
|
|
|
1
|
-
import get from 'lodash/get';
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* This is typically used in circumstances where there are re-orderable pieces e.g. Dynamic Zones
|
|
5
|
-
* or Repeatable fields. It finds the _original_ location of the initial data using `__temp_key__` values
|
|
6
|
-
* which are added to the fields in the `INIT_FORM` reducer to give array data a stable (when you add
|
|
7
|
-
* a new item they wont have a server ID).
|
|
8
|
-
*/
|
|
9
|
-
export const getInitialDataPathUsingTempKeys =
|
|
10
|
-
(initialData?: Record<string, any>, modifiedData?: Record<string, any>) => (currentPath: string) => {
|
|
11
|
-
const splitPath = currentPath.split('.');
|
|
12
|
-
|
|
13
|
-
return splitPath.reduce<string[]>((acc, currentValue, index) => {
|
|
14
|
-
const initialDataParent = get(initialData, acc);
|
|
15
|
-
const modifiedDataTempKey = get(modifiedData, [...splitPath.slice(0, index), currentValue, '__temp_key__']);
|
|
16
|
-
|
|
17
|
-
if (Array.isArray(initialDataParent) && typeof modifiedDataTempKey === 'number') {
|
|
18
|
-
const initialDataIndex = initialDataParent.findIndex((entry) => entry.__temp_key__ === modifiedDataTempKey);
|
|
19
|
-
|
|
20
|
-
acc.push(initialDataIndex.toString());
|
|
21
|
-
|
|
22
|
-
return acc;
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
acc.push(currentValue);
|
|
26
|
-
|
|
27
|
-
return acc;
|
|
28
|
-
}, []);
|
|
29
|
-
};
|
|
1
|
+
import get from 'lodash/get';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* This is typically used in circumstances where there are re-orderable pieces e.g. Dynamic Zones
|
|
5
|
+
* or Repeatable fields. It finds the _original_ location of the initial data using `__temp_key__` values
|
|
6
|
+
* which are added to the fields in the `INIT_FORM` reducer to give array data a stable (when you add
|
|
7
|
+
* a new item they wont have a server ID).
|
|
8
|
+
*/
|
|
9
|
+
export const getInitialDataPathUsingTempKeys =
|
|
10
|
+
(initialData?: Record<string, any>, modifiedData?: Record<string, any>) => (currentPath: string) => {
|
|
11
|
+
const splitPath = currentPath.split('.');
|
|
12
|
+
|
|
13
|
+
return splitPath.reduce<string[]>((acc, currentValue, index) => {
|
|
14
|
+
const initialDataParent = get(initialData, acc);
|
|
15
|
+
const modifiedDataTempKey = get(modifiedData, [...splitPath.slice(0, index), currentValue, '__temp_key__']);
|
|
16
|
+
|
|
17
|
+
if (Array.isArray(initialDataParent) && typeof modifiedDataTempKey === 'number') {
|
|
18
|
+
const initialDataIndex = initialDataParent.findIndex((entry) => entry.__temp_key__ === modifiedDataTempKey);
|
|
19
|
+
|
|
20
|
+
acc.push(initialDataIndex.toString());
|
|
21
|
+
|
|
22
|
+
return acc;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
acc.push(currentValue);
|
|
26
|
+
|
|
27
|
+
return acc;
|
|
28
|
+
}, []);
|
|
29
|
+
};
|
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
import { MutableRefObject, Ref } from 'react';
|
|
2
|
-
|
|
3
|
-
type PossibleRef<T> = Ref<T> | undefined;
|
|
4
|
-
|
|
5
|
-
const setRef = <T>(ref: PossibleRef<T>, value: T) => {
|
|
6
|
-
if (typeof ref === 'function') {
|
|
7
|
-
ref(value);
|
|
8
|
-
} else if (ref !== null && ref !== undefined) {
|
|
9
|
-
(ref as MutableRefObject<T>).current = value;
|
|
10
|
-
}
|
|
11
|
-
};
|
|
12
|
-
|
|
13
|
-
/**
|
|
14
|
-
* A utility to compose multiple refs together
|
|
15
|
-
* Accepts callback refs and RefObject(s)
|
|
16
|
-
*/
|
|
17
|
-
export const composeRefs = <T>(...refs: PossibleRef<T>[]) => {
|
|
18
|
-
return (node: T) => refs.forEach((ref) => setRef(ref, node));
|
|
19
|
-
};
|
|
1
|
+
import { MutableRefObject, Ref } from 'react';
|
|
2
|
+
|
|
3
|
+
type PossibleRef<T> = Ref<T> | undefined;
|
|
4
|
+
|
|
5
|
+
const setRef = <T>(ref: PossibleRef<T>, value: T) => {
|
|
6
|
+
if (typeof ref === 'function') {
|
|
7
|
+
ref(value);
|
|
8
|
+
} else if (ref !== null && ref !== undefined) {
|
|
9
|
+
(ref as MutableRefObject<T>).current = value;
|
|
10
|
+
}
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* A utility to compose multiple refs together
|
|
15
|
+
* Accepts callback refs and RefObject(s)
|
|
16
|
+
*/
|
|
17
|
+
export const composeRefs = <T>(...refs: PossibleRef<T>[]) => {
|
|
18
|
+
return (node: T) => refs.forEach((ref) => setRef(ref, node));
|
|
19
|
+
};
|
package/admin/src/components/StrapiCore/admin/admin/src/content-manager/utils/translations.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
const getTranslation = (id: string) => `content-manager.${id}`;
|
|
2
|
-
|
|
3
|
-
export { getTranslation };
|
|
1
|
+
const getTranslation = (id: string) => `content-manager.${id}`;
|
|
2
|
+
|
|
3
|
+
export { getTranslation };
|