@strapi/admin 4.5.4 → 4.6.0-beta.0
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/admin/src/components/AuthenticatedApp/index.js +2 -13
- package/admin/src/content-manager/components/ComponentInitializer/index.js +1 -7
- package/admin/src/content-manager/components/{RepeatableComponent/DragPreview.js → DragLayer/ComponentDragPreview.js} +25 -12
- package/admin/src/content-manager/components/DragLayer/RelationDragPreview.js +75 -0
- package/admin/src/content-manager/components/DragLayer/index.js +23 -7
- package/admin/src/content-manager/components/DynamicZone/components/DynamicComponent.js +130 -84
- package/admin/src/content-manager/components/DynamicZone/index.js +99 -24
- package/admin/src/content-manager/components/DynamicZone/utils/select.js +9 -5
- package/admin/src/content-manager/components/EditViewDataManagerProvider/index.js +37 -11
- package/admin/src/content-manager/components/EditViewDataManagerProvider/reducer.js +18 -22
- package/admin/src/content-manager/components/EditViewDataManagerProvider/utils/cleanData.js +24 -5
- package/admin/src/content-manager/components/RelationInput/RelationInput.js +209 -64
- package/admin/src/content-manager/components/RelationInput/components/RelationItem.js +134 -21
- package/admin/src/content-manager/components/RelationInput/components/RelationList.js +1 -2
- package/admin/src/content-manager/components/RelationInput/constants.js +1 -0
- package/admin/src/content-manager/components/RelationInputDataManager/RelationInputDataManager.js +131 -9
- package/admin/src/content-manager/components/RepeatableComponent/components/Accordion.js +77 -0
- package/admin/src/content-manager/components/RepeatableComponent/components/Component.js +262 -0
- package/admin/src/content-manager/components/RepeatableComponent/{DraggedItem → components}/Preview.js +0 -0
- package/admin/src/content-manager/components/RepeatableComponent/index.js +147 -87
- package/admin/src/content-manager/components/RepeatableComponent/utils/getComponentErrorKeys.js +1 -1
- package/admin/src/content-manager/hooks/index.js +2 -0
- package/admin/src/content-manager/hooks/useDragAndDrop.js +120 -0
- package/admin/src/content-manager/hooks/useKeyboardDragAndDrop.js +98 -0
- package/admin/src/content-manager/utils/ItemTypes.js +1 -1
- package/admin/src/content-manager/utils/composeRefs.js +28 -0
- package/admin/src/content-manager/utils/getMaxTempKey.js +1 -1
- package/admin/src/content-manager/utils/index.js +7 -0
- package/admin/src/pages/App/index.js +13 -20
- package/admin/src/pages/SettingsPage/pages/ApiTokens/EditView/index.js +3 -2
- package/admin/src/translations/en.json +6 -0
- package/admin/src/translations/tr.json +5 -485
- package/admin/src/utils/index.js +0 -1
- package/build/4318.80bdf035.chunk.js +30 -0
- package/build/{8176.e929d326.chunk.js → 8176.b19bc128.chunk.js} +32 -32
- package/build/{1233.802422fa.chunk.js → 8186.55910742.chunk.js} +96 -96
- package/build/{8633.43ec9042.chunk.js → 8633.59223842.chunk.js} +1 -1
- package/build/Admin-authenticatedApp.f9e74dc0.chunk.js +80 -0
- package/build/{Admin_profilePage.60ab80bb.chunk.js → Admin_profilePage.c07bdf08.chunk.js} +1 -1
- package/build/{Admin_settingsPage.6ef8acc9.chunk.js → Admin_settingsPage.50a8765b.chunk.js} +1 -1
- package/build/admin-app.2861b6d2.chunk.js +112 -0
- package/build/admin-edit-users.85231e4c.chunk.js +10 -0
- package/build/{admin-users.e64fb0f1.chunk.js → admin-users.a2707644.chunk.js} +2 -2
- package/build/api-tokens-create-page.dd4ddfcb.chunk.js +1 -0
- package/build/api-tokens-edit-page.821c5a6c.chunk.js +1 -0
- package/build/content-manager.ee948f75.chunk.js +1186 -0
- package/build/content-type-builder-translation-tr-json.2e52bc60.chunk.js +1 -0
- package/build/email-settings-page.db0d98d1.chunk.js +15 -0
- package/build/email-translation-tr-json.87f2feb3.chunk.js +1 -0
- package/build/{en-json.7dd57947.chunk.js → en-json.4a56dca7.chunk.js} +1 -1
- package/build/index.html +1 -1
- package/build/main.faac89ee.js +2025 -0
- package/build/runtime~main.75a15b8e.js +2 -0
- package/build/sso-settings-page.adb12ac3.chunk.js +1 -0
- package/build/tr-json.9c44ea0c.chunk.js +1 -0
- package/build/{upload.74540aab.chunk.js → upload.e2034370.chunk.js} +3 -3
- package/build/users-permissions-translation-tr-json.cdc49a3c.chunk.js +1 -0
- package/package.json +9 -9
- package/server/controllers/admin.js +0 -2
- package/server/routes/admin.js +1 -1
- package/server/services/metrics.js +2 -5
- package/admin/src/content-manager/components/RepeatableComponent/AccordionGroupCustom/index.js +0 -122
- package/admin/src/content-manager/components/RepeatableComponent/AddFieldButton.js +0 -58
- package/admin/src/content-manager/components/RepeatableComponent/DraggedItem/DraggingSibling.js +0 -72
- package/admin/src/content-manager/components/RepeatableComponent/DraggedItem/IconButtonCustoms.js +0 -32
- package/admin/src/content-manager/components/RepeatableComponent/DraggedItem/index.js +0 -326
- package/admin/src/content-manager/components/RepeatableComponent/DraggedItem/utils/connect.js +0 -11
- package/admin/src/content-manager/components/RepeatableComponent/DraggedItem/utils/index.js +0 -2
- package/admin/src/content-manager/components/RepeatableComponent/DraggedItem/utils/select.js +0 -30
- package/admin/src/content-manager/components/RepeatableComponent/utils/connect.js +0 -11
- package/admin/src/content-manager/components/RepeatableComponent/utils/select.js +0 -12
- package/admin/src/content-manager/hooks/__test__/usePrev.test.js +0 -26
- package/admin/src/utils/uniqueAdminHash.js +0 -22
- package/build/4318.9283c350.chunk.js +0 -30
- package/build/Admin-authenticatedApp.0da578b8.chunk.js +0 -80
- package/build/admin-app.a3277e72.chunk.js +0 -112
- package/build/admin-edit-users.5547b126.chunk.js +0 -10
- package/build/api-tokens-create-page.93dd0689.chunk.js +0 -1
- package/build/api-tokens-edit-page.b0adac81.chunk.js +0 -1
- package/build/content-manager.f9630c3b.chunk.js +0 -1197
- package/build/content-type-builder-translation-tr-json.949e22eb.chunk.js +0 -1
- package/build/email-settings-page.c6e62f6b.chunk.js +0 -15
- package/build/email-translation-tr-json.8aa034bb.chunk.js +0 -1
- package/build/i18n-translation-tr-json.34ca9d61.chunk.js +0 -1
- package/build/main.71f24343.js +0 -2034
- package/build/runtime~main.1115f82b.js +0 -2
- package/build/sso-settings-page.feed2f45.chunk.js +0 -1
- package/build/tr-json.eac8bd79.chunk.js +0 -1
- package/build/upload-translation-tr-json.b173223a.chunk.js +0 -1
- package/build/users-permissions-translation-tr-json.9bebc250.chunk.js +0 -1
|
@@ -1,326 +0,0 @@
|
|
|
1
|
-
/* eslint-disable import/no-cycle */
|
|
2
|
-
import React, { memo, useEffect, useRef, useState } from 'react';
|
|
3
|
-
import PropTypes from 'prop-types';
|
|
4
|
-
import { useDrag, useDrop } from 'react-dnd';
|
|
5
|
-
import { getEmptyImage } from 'react-dnd-html5-backend';
|
|
6
|
-
import styled from 'styled-components';
|
|
7
|
-
import { useIntl } from 'react-intl';
|
|
8
|
-
import toString from 'lodash/toString';
|
|
9
|
-
import { Accordion, AccordionToggle, AccordionContent } from '@strapi/design-system/Accordion';
|
|
10
|
-
import { Grid, GridItem } from '@strapi/design-system/Grid';
|
|
11
|
-
import { Stack } from '@strapi/design-system/Stack';
|
|
12
|
-
import { Box } from '@strapi/design-system/Box';
|
|
13
|
-
import { Tooltip } from '@strapi/design-system/Tooltip';
|
|
14
|
-
import Trash from '@strapi/icons/Trash';
|
|
15
|
-
import Drag from '@strapi/icons/Drag';
|
|
16
|
-
import ItemTypes from '../../../utils/ItemTypes';
|
|
17
|
-
import getTrad from '../../../utils/getTrad';
|
|
18
|
-
import Inputs from '../../Inputs';
|
|
19
|
-
import FieldComponent from '../../FieldComponent';
|
|
20
|
-
import Preview from './Preview';
|
|
21
|
-
import DraggingSibling from './DraggingSibling';
|
|
22
|
-
import { CustomIconButton } from './IconButtonCustoms';
|
|
23
|
-
import { connect, select } from './utils';
|
|
24
|
-
import useLazyComponents from '../../../hooks/useLazyComponents';
|
|
25
|
-
|
|
26
|
-
const DragButton = styled.span`
|
|
27
|
-
display: flex;
|
|
28
|
-
align-items: center;
|
|
29
|
-
height: ${({ theme }) => theme.spaces[7]};
|
|
30
|
-
|
|
31
|
-
padding: 0 ${({ theme }) => theme.spaces[3]};
|
|
32
|
-
cursor: all-scroll;
|
|
33
|
-
|
|
34
|
-
svg {
|
|
35
|
-
width: ${12 / 16}rem;
|
|
36
|
-
height: ${12 / 16}rem;
|
|
37
|
-
}
|
|
38
|
-
`;
|
|
39
|
-
|
|
40
|
-
/* eslint-disable react/no-array-index-key */
|
|
41
|
-
|
|
42
|
-
// Issues:
|
|
43
|
-
// https://github.com/react-dnd/react-dnd/issues/1368
|
|
44
|
-
// https://github.com/frontend-collective/react-sortable-tree/issues/490
|
|
45
|
-
|
|
46
|
-
const DraggedItem = ({
|
|
47
|
-
componentFieldName,
|
|
48
|
-
componentUid,
|
|
49
|
-
// Errors are retrieved from the AccordionGroupCustom cloneElement
|
|
50
|
-
hasErrorMessage,
|
|
51
|
-
hasErrors,
|
|
52
|
-
isDraggingSibling,
|
|
53
|
-
isOpen,
|
|
54
|
-
isReadOnly,
|
|
55
|
-
onClickToggle,
|
|
56
|
-
schema,
|
|
57
|
-
toggleCollapses,
|
|
58
|
-
// Retrieved from the select function
|
|
59
|
-
moveComponentField,
|
|
60
|
-
removeRepeatableField,
|
|
61
|
-
setIsDraggingSibling,
|
|
62
|
-
triggerFormValidation,
|
|
63
|
-
// checkFormErrors,
|
|
64
|
-
displayedValue,
|
|
65
|
-
}) => {
|
|
66
|
-
const dragRef = useRef(null);
|
|
67
|
-
const dropRef = useRef(null);
|
|
68
|
-
const [, forceRerenderAfterDnd] = useState(false);
|
|
69
|
-
const { formatMessage } = useIntl();
|
|
70
|
-
|
|
71
|
-
const fields = schema.layouts.edit;
|
|
72
|
-
|
|
73
|
-
const [, drop] = useDrop({
|
|
74
|
-
accept: ItemTypes.COMPONENT,
|
|
75
|
-
canDrop() {
|
|
76
|
-
return false;
|
|
77
|
-
},
|
|
78
|
-
hover(item, monitor) {
|
|
79
|
-
if (!dropRef.current) {
|
|
80
|
-
return;
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
const dragPath = item.originalPath;
|
|
84
|
-
const hoverPath = componentFieldName;
|
|
85
|
-
const fullPathToComponentArray = dragPath.split('.');
|
|
86
|
-
const dragIndexString = fullPathToComponentArray.slice().splice(-1).join('');
|
|
87
|
-
const hoverIndexString = hoverPath.split('.').splice(-1).join('');
|
|
88
|
-
const pathToComponentArray = fullPathToComponentArray.slice(
|
|
89
|
-
0,
|
|
90
|
-
fullPathToComponentArray.length - 1
|
|
91
|
-
);
|
|
92
|
-
const dragIndex = parseInt(dragIndexString, 10);
|
|
93
|
-
const hoverIndex = parseInt(hoverIndexString, 10);
|
|
94
|
-
|
|
95
|
-
// Don't replace items with themselves
|
|
96
|
-
if (dragIndex === hoverIndex) {
|
|
97
|
-
return;
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
// Determine rectangle on screen
|
|
101
|
-
const hoverBoundingRect = dropRef.current.getBoundingClientRect();
|
|
102
|
-
// Get vertical middle
|
|
103
|
-
const hoverMiddleY = (hoverBoundingRect.bottom - hoverBoundingRect.top) / 2;
|
|
104
|
-
// Determine mouse position
|
|
105
|
-
const clientOffset = monitor.getClientOffset();
|
|
106
|
-
// Get pixels to the top
|
|
107
|
-
const hoverClientY = clientOffset.y - hoverBoundingRect.top;
|
|
108
|
-
|
|
109
|
-
// Only perform the move when the mouse has crossed half of the items height
|
|
110
|
-
// When dragging downwards, only move when the cursor is below 50%
|
|
111
|
-
// When dragging upwards, only move when the cursor is above 50%
|
|
112
|
-
// Dragging downwards
|
|
113
|
-
if (dragIndex < hoverIndex && hoverClientY < hoverMiddleY) {
|
|
114
|
-
return;
|
|
115
|
-
}
|
|
116
|
-
// Dragging upwards
|
|
117
|
-
if (dragIndex > hoverIndex && hoverClientY > hoverMiddleY) {
|
|
118
|
-
return;
|
|
119
|
-
}
|
|
120
|
-
// If They are not in the same level, should not move
|
|
121
|
-
if (dragPath.split('.').length !== hoverPath.split('.').length) {
|
|
122
|
-
return;
|
|
123
|
-
}
|
|
124
|
-
// Time to actually perform the action in the data
|
|
125
|
-
moveComponentField(pathToComponentArray, dragIndex, hoverIndex);
|
|
126
|
-
|
|
127
|
-
item.originalPath = hoverPath;
|
|
128
|
-
},
|
|
129
|
-
});
|
|
130
|
-
const [{ isDragging }, drag, preview] = useDrag({
|
|
131
|
-
type: ItemTypes.COMPONENT,
|
|
132
|
-
item() {
|
|
133
|
-
// Close all collapses
|
|
134
|
-
toggleCollapses(-1);
|
|
135
|
-
|
|
136
|
-
return {
|
|
137
|
-
displayedValue,
|
|
138
|
-
originalPath: componentFieldName,
|
|
139
|
-
};
|
|
140
|
-
},
|
|
141
|
-
end() {
|
|
142
|
-
// Update the errors
|
|
143
|
-
triggerFormValidation();
|
|
144
|
-
setIsDraggingSibling(false);
|
|
145
|
-
},
|
|
146
|
-
collect: (monitor) => ({
|
|
147
|
-
isDragging: monitor.isDragging(),
|
|
148
|
-
}),
|
|
149
|
-
});
|
|
150
|
-
|
|
151
|
-
useEffect(() => {
|
|
152
|
-
preview(getEmptyImage(), { captureDraggingState: false });
|
|
153
|
-
}, [preview]);
|
|
154
|
-
|
|
155
|
-
useEffect(() => {
|
|
156
|
-
if (isDragging) {
|
|
157
|
-
setIsDraggingSibling(true);
|
|
158
|
-
}
|
|
159
|
-
}, [isDragging, setIsDraggingSibling]);
|
|
160
|
-
|
|
161
|
-
// Effect in order to force a rerender after reordering the components
|
|
162
|
-
// Since we are removing the Accordion when doing the DnD we are losing the dragRef, therefore the replaced element cannot be dragged
|
|
163
|
-
// anymore, this hack forces a rerender in order to apply the dragRef
|
|
164
|
-
useEffect(() => {
|
|
165
|
-
if (!isDraggingSibling) {
|
|
166
|
-
forceRerenderAfterDnd((prev) => !prev);
|
|
167
|
-
}
|
|
168
|
-
}, [isDraggingSibling]);
|
|
169
|
-
|
|
170
|
-
// Create the refs
|
|
171
|
-
// We need 1 for the drop target
|
|
172
|
-
// 1 for the drag target
|
|
173
|
-
const refs = {
|
|
174
|
-
dragRef: drag(dragRef),
|
|
175
|
-
dropRef: drop(dropRef),
|
|
176
|
-
};
|
|
177
|
-
|
|
178
|
-
const accordionTitle = toString(displayedValue);
|
|
179
|
-
const accordionHasError = hasErrors ? 'error' : undefined;
|
|
180
|
-
|
|
181
|
-
const { lazyComponentStore } = useLazyComponents();
|
|
182
|
-
|
|
183
|
-
return (
|
|
184
|
-
<Box ref={refs ? refs.dropRef : null}>
|
|
185
|
-
{isDragging && <Preview />}
|
|
186
|
-
{!isDragging && isDraggingSibling && (
|
|
187
|
-
<DraggingSibling displayedValue={accordionTitle} componentFieldName={componentFieldName} />
|
|
188
|
-
)}
|
|
189
|
-
|
|
190
|
-
{!isDragging && !isDraggingSibling && (
|
|
191
|
-
<Accordion
|
|
192
|
-
error={accordionHasError}
|
|
193
|
-
hasErrorMessage={hasErrorMessage}
|
|
194
|
-
expanded={isOpen}
|
|
195
|
-
onToggle={onClickToggle}
|
|
196
|
-
id={componentFieldName}
|
|
197
|
-
size="S"
|
|
198
|
-
>
|
|
199
|
-
<AccordionToggle
|
|
200
|
-
action={
|
|
201
|
-
isReadOnly ? null : (
|
|
202
|
-
<Stack horizontal spacing={0}>
|
|
203
|
-
<CustomIconButton
|
|
204
|
-
expanded={isOpen}
|
|
205
|
-
noBorder
|
|
206
|
-
onClick={() => {
|
|
207
|
-
removeRepeatableField(componentFieldName);
|
|
208
|
-
toggleCollapses();
|
|
209
|
-
}}
|
|
210
|
-
label={formatMessage({
|
|
211
|
-
id: getTrad('containers.Edit.delete'),
|
|
212
|
-
defaultMessage: 'Delete',
|
|
213
|
-
})}
|
|
214
|
-
icon={<Trash />}
|
|
215
|
-
/>
|
|
216
|
-
{/* react-dnd is broken in firefox with our IconButton, maybe a ref issue */}
|
|
217
|
-
<Tooltip
|
|
218
|
-
description={formatMessage({
|
|
219
|
-
id: getTrad('components.DragHandle-label'),
|
|
220
|
-
defaultMessage: 'Drag',
|
|
221
|
-
})}
|
|
222
|
-
>
|
|
223
|
-
<DragButton
|
|
224
|
-
role="button"
|
|
225
|
-
tabIndex={-1}
|
|
226
|
-
ref={refs.dragRef}
|
|
227
|
-
onClick={(e) => e.stopPropagation()}
|
|
228
|
-
>
|
|
229
|
-
<Drag />
|
|
230
|
-
</DragButton>
|
|
231
|
-
</Tooltip>
|
|
232
|
-
</Stack>
|
|
233
|
-
)
|
|
234
|
-
}
|
|
235
|
-
title={accordionTitle}
|
|
236
|
-
togglePosition="left"
|
|
237
|
-
/>
|
|
238
|
-
<AccordionContent>
|
|
239
|
-
<Stack background="neutral100" padding={6} spacing={6}>
|
|
240
|
-
{fields.map((fieldRow, key) => {
|
|
241
|
-
return (
|
|
242
|
-
<Grid gap={4} key={key}>
|
|
243
|
-
{fieldRow.map(({ name, fieldSchema, metadatas, queryInfos, size }) => {
|
|
244
|
-
const isComponent = fieldSchema.type === 'component';
|
|
245
|
-
const keys = `${componentFieldName}.${name}`;
|
|
246
|
-
|
|
247
|
-
if (isComponent) {
|
|
248
|
-
const componentUid = fieldSchema.component;
|
|
249
|
-
|
|
250
|
-
return (
|
|
251
|
-
<GridItem col={size} s={12} xs={12} key={name}>
|
|
252
|
-
<FieldComponent
|
|
253
|
-
componentUid={componentUid}
|
|
254
|
-
intlLabel={{
|
|
255
|
-
id: metadatas.label,
|
|
256
|
-
defaultMessage: metadatas.label,
|
|
257
|
-
}}
|
|
258
|
-
isRepeatable={fieldSchema.repeatable}
|
|
259
|
-
isNested
|
|
260
|
-
name={keys}
|
|
261
|
-
max={fieldSchema.max}
|
|
262
|
-
min={fieldSchema.min}
|
|
263
|
-
required={fieldSchema.required}
|
|
264
|
-
/>
|
|
265
|
-
</GridItem>
|
|
266
|
-
);
|
|
267
|
-
}
|
|
268
|
-
|
|
269
|
-
return (
|
|
270
|
-
<GridItem key={keys} col={size} s={12} xs={12}>
|
|
271
|
-
<Inputs
|
|
272
|
-
componentUid={componentUid}
|
|
273
|
-
fieldSchema={fieldSchema}
|
|
274
|
-
keys={keys}
|
|
275
|
-
metadatas={metadatas}
|
|
276
|
-
// onBlur={hasErrors ? checkFormErrors : null}
|
|
277
|
-
queryInfos={queryInfos}
|
|
278
|
-
size={size}
|
|
279
|
-
customFieldInputs={lazyComponentStore}
|
|
280
|
-
/>
|
|
281
|
-
</GridItem>
|
|
282
|
-
);
|
|
283
|
-
})}
|
|
284
|
-
</Grid>
|
|
285
|
-
);
|
|
286
|
-
})}
|
|
287
|
-
</Stack>
|
|
288
|
-
</AccordionContent>
|
|
289
|
-
</Accordion>
|
|
290
|
-
)}
|
|
291
|
-
</Box>
|
|
292
|
-
);
|
|
293
|
-
};
|
|
294
|
-
|
|
295
|
-
DraggedItem.defaultProps = {
|
|
296
|
-
componentUid: undefined,
|
|
297
|
-
isDraggingSibling: false,
|
|
298
|
-
isOpen: false,
|
|
299
|
-
setIsDraggingSibling() {},
|
|
300
|
-
toggleCollapses() {},
|
|
301
|
-
};
|
|
302
|
-
|
|
303
|
-
DraggedItem.propTypes = {
|
|
304
|
-
componentFieldName: PropTypes.string.isRequired,
|
|
305
|
-
componentUid: PropTypes.string,
|
|
306
|
-
hasErrorMessage: PropTypes.bool.isRequired,
|
|
307
|
-
hasErrors: PropTypes.bool.isRequired,
|
|
308
|
-
isDraggingSibling: PropTypes.bool,
|
|
309
|
-
isOpen: PropTypes.bool,
|
|
310
|
-
isReadOnly: PropTypes.bool.isRequired,
|
|
311
|
-
onClickToggle: PropTypes.func.isRequired,
|
|
312
|
-
schema: PropTypes.object.isRequired,
|
|
313
|
-
toggleCollapses: PropTypes.func,
|
|
314
|
-
moveComponentField: PropTypes.func.isRequired,
|
|
315
|
-
removeRepeatableField: PropTypes.func.isRequired,
|
|
316
|
-
setIsDraggingSibling: PropTypes.func,
|
|
317
|
-
triggerFormValidation: PropTypes.func.isRequired,
|
|
318
|
-
// checkFormErrors: PropTypes.func.isRequired,
|
|
319
|
-
displayedValue: PropTypes.string.isRequired,
|
|
320
|
-
};
|
|
321
|
-
|
|
322
|
-
const Memoized = memo(DraggedItem);
|
|
323
|
-
|
|
324
|
-
export default connect(Memoized, select);
|
|
325
|
-
|
|
326
|
-
export { DraggedItem };
|
package/admin/src/content-manager/components/RepeatableComponent/DraggedItem/utils/select.js
DELETED
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
import { useMemo } from 'react';
|
|
2
|
-
import { get, toString } from 'lodash';
|
|
3
|
-
import { useCMEditViewDataManager } from '@strapi/helper-plugin';
|
|
4
|
-
|
|
5
|
-
function useSelect({ schema, componentFieldName }) {
|
|
6
|
-
const {
|
|
7
|
-
checkFormErrors,
|
|
8
|
-
modifiedData,
|
|
9
|
-
moveComponentField,
|
|
10
|
-
removeRepeatableField,
|
|
11
|
-
triggerFormValidation,
|
|
12
|
-
} = useCMEditViewDataManager();
|
|
13
|
-
|
|
14
|
-
const mainField = useMemo(() => get(schema, ['settings', 'mainField'], 'id'), [schema]);
|
|
15
|
-
const displayedValue = toString(
|
|
16
|
-
get(modifiedData, [...componentFieldName.split('.'), mainField], '')
|
|
17
|
-
);
|
|
18
|
-
|
|
19
|
-
return {
|
|
20
|
-
displayedValue,
|
|
21
|
-
mainField,
|
|
22
|
-
checkFormErrors,
|
|
23
|
-
moveComponentField,
|
|
24
|
-
removeRepeatableField,
|
|
25
|
-
schema,
|
|
26
|
-
triggerFormValidation,
|
|
27
|
-
};
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
export default useSelect;
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import { useCMEditViewDataManager } from '@strapi/helper-plugin';
|
|
2
|
-
|
|
3
|
-
function useSelect() {
|
|
4
|
-
const { addRepeatableComponentToField, formErrors } = useCMEditViewDataManager();
|
|
5
|
-
|
|
6
|
-
return {
|
|
7
|
-
addRepeatableComponentToField,
|
|
8
|
-
formErrors,
|
|
9
|
-
};
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
export default useSelect;
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { renderHook } from '@testing-library/react-hooks';
|
|
2
|
-
|
|
3
|
-
import { usePrev } from '../usePrev';
|
|
4
|
-
|
|
5
|
-
describe('usePrev', () => {
|
|
6
|
-
const setup = () => renderHook(({ state }) => usePrev(state), { initialProps: { state: 0 } });
|
|
7
|
-
|
|
8
|
-
it('should return undefined on initial render', () => {
|
|
9
|
-
const { result } = setup();
|
|
10
|
-
|
|
11
|
-
expect(result.current).toBeUndefined();
|
|
12
|
-
});
|
|
13
|
-
|
|
14
|
-
it('should always return previous state after each update', () => {
|
|
15
|
-
const { result, rerender } = setup();
|
|
16
|
-
|
|
17
|
-
rerender({ state: 2 });
|
|
18
|
-
expect(result.current).toBe(0);
|
|
19
|
-
|
|
20
|
-
rerender({ state: 4 });
|
|
21
|
-
expect(result.current).toBe(2);
|
|
22
|
-
|
|
23
|
-
rerender({ state: 6 });
|
|
24
|
-
expect(result.current).toBe(4);
|
|
25
|
-
});
|
|
26
|
-
});
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
export const utils = {
|
|
2
|
-
bufferToHex(buffer) {
|
|
3
|
-
return [...new Uint8Array(buffer)].map((b) => b.toString(16).padStart(2, '0')).join('');
|
|
4
|
-
},
|
|
5
|
-
async digestMessage(message) {
|
|
6
|
-
const msgUint8 = new TextEncoder().encode(message);
|
|
7
|
-
const hashBuffer = await crypto.subtle.digest('SHA-256', msgUint8);
|
|
8
|
-
|
|
9
|
-
return this.bufferToHex(hashBuffer);
|
|
10
|
-
},
|
|
11
|
-
};
|
|
12
|
-
|
|
13
|
-
export default async function hashAdminUserEmail(payload) {
|
|
14
|
-
if (!payload) {
|
|
15
|
-
return null;
|
|
16
|
-
}
|
|
17
|
-
try {
|
|
18
|
-
return await utils.digestMessage(payload.email);
|
|
19
|
-
} catch (error) {
|
|
20
|
-
return null;
|
|
21
|
-
}
|
|
22
|
-
}
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
"use strict";(self.webpackChunk_strapi_admin=self.webpackChunk_strapi_admin||[]).push([[4318],{4318:(yn,Be,l)=>{l.d(Be,{Z:()=>on});var a=l(32735),T=l(5636),g=l(88425),ne=l(27649),je=l(83281),ae=l(5141),se=l(84968),Ve=l(64421),j=l(17247),re=l(64213),Ze=l(54049);const Ue=(e,t,n="en")=>{if(t&&typeof t=="number"){const r=t/24/60/60/1e3;return(0,re.format)((0,re.addDays)(new Date(e),r),"PPP",{locale:Ze[n]})}return"Unlimited"};var L=l(5173);const Ke=L.Ry().shape({name:L.Z_(g.translatedErrors.string).required(g.translatedErrors.required),type:L.Z_(g.translatedErrors.string).oneOf(["read-only","full-access","custom"]).required(g.translatedErrors.required),description:L.Z_().nullable(),lifespan:L.Rx().integer().min(0).nullable().defined(g.translatedErrors.required)});var w=l(92891);const oe=e=>{const t={allActionsIds:[],permissions:[]};return t.permissions=Object.keys(e).map(n=>({apiId:n,label:n.split("::")[1],controllers:(0,w.flatten)(Object.keys(e[n].controllers).map(r=>({controller:r,actions:(0,w.flatten)(e[n].controllers[r].map(o=>{const d=`${n}.${r}.${o}`;return n.includes("api::")&&t.allActionsIds.push(d),{action:o,actionId:d}}))})))})),t};var ie=l(28356),le=l(17e3),$=l(41415),de=l(66456),We=l(60216),s=l.n(We);const F=({apiTokenName:e})=>{const{formatMessage:t}=(0,T.useIntl)();return(0,g.useFocusWhenNavigate)(),a.createElement(ne.o,{"aria-busy":"true"},a.createElement(g.SettingsPageTitle,{name:"API Tokens"}),a.createElement(ie.T,{primaryAction:a.createElement($.z,{disabled:!0,startIcon:a.createElement(de.Z,null),type:"button",size:"L"},t({id:"global.save",defaultMessage:"Save"})),title:e||t({id:"Settings.apiTokens.createPage.title",defaultMessage:"Create API Token"})}),a.createElement(le.D,null,a.createElement(g.LoadingIndicatorPage,null)))};F.defaultProps={apiTokenName:null},F.propTypes={apiTokenName:s().string};const $e=F;var Fe=l(29439),O=l(27677),ce=l(44647),He=l(49737),Ge=(e,t,n)=>new Promise((r,o)=>{var d=m=>{try{u(n.next(m))}catch(y){o(y)}},i=m=>{try{u(n.throw(m))}catch(y){o(y)}},u=m=>m.done?r(m.value):Promise.resolve(m.value).then(d,i);u((n=n.apply(e,t)).next())});const H=({onRegenerate:e,idToRegenerate:t})=>{const{formatMessage:n}=(0,T.useIntl)(),[r,o]=(0,a.useState)(!1),{regenerateData:d,isLoadingConfirmation:i}=(0,He.rW)(t,e),u=()=>Ge(void 0,null,function*(){d(),o(!1)});return a.createElement(a.Fragment,null,a.createElement($.z,{startIcon:a.createElement(ce.Z,null),type:"button",size:"S",variant:"tertiary",onClick:()=>o(!0),name:"regenerate"},n({id:"Settings.apiTokens.regenerate",defaultMessage:"Regenerate"})),a.createElement(g.ConfirmDialog,{bodyText:{id:"Settings.apiTokens.popUpWarning.message",defaultMessage:"Are you sure you want to regenerate this token?"},iconRightButton:a.createElement(ce.Z,null),isConfirmButtonLoading:i,isOpen:r,onToggleDialog:()=>o(!1),onConfirm:u,leftButtonText:{id:"Settings.apiTokens.Button.cancel",defaultMessage:"Cancel"},rightButtonText:{id:"Settings.apiTokens.Button.regenerate",defaultMessage:"Regenerate"},title:{id:"Settings.apiTokens.RegenerateDialog.title",defaultMessage:"Regenerate token"}}))};H.defaultProps={onRegenerate(){}},H.propTypes={onRegenerate:s().func,idToRegenerate:s().oneOfType([s().number,s().string]).isRequired};const pe=H;var ze=Object.defineProperty,Ye=Object.defineProperties,Qe=Object.getOwnPropertyDescriptors,ue=Object.getOwnPropertySymbols,Xe=Object.prototype.hasOwnProperty,Je=Object.prototype.propertyIsEnumerable,me=(e,t,n)=>t in e?ze(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,qe=(e,t)=>{for(var n in t||(t={}))Xe.call(t,n)&&me(e,n,t[n]);if(ue)for(var n of ue(t))Je.call(t,n)&&me(e,n,t[n]);return e},_e=(e,t)=>Ye(e,Qe(t));const G=({apiToken:e,setApiToken:t,canEditInputs:n,canRegenerate:r,isSubmitting:o})=>{const{formatMessage:d}=(0,T.useIntl)(),i=u=>{t(_e(qe({},e),{accessKey:u}))};return a.createElement(ie.T,{title:(e==null?void 0:e.name)||d({id:"Settings.apiTokens.createPage.title",defaultMessage:"Create API Token"}),primaryAction:n?a.createElement(O.K,{horizontal:!0,spacing:2},r&&(e==null?void 0:e.id)&&a.createElement(pe,{onRegenerate:i,idToRegenerate:e==null?void 0:e.id}),a.createElement($.z,{disabled:o,loading:o,startIcon:a.createElement(de.Z,null),type:"submit",size:"S"},d({id:"global.save",defaultMessage:"Save"}))):r&&(e==null?void 0:e.id)&&a.createElement(pe,{onRegenerate:i,idToRegenerate:e==null?void 0:e.id}),navigationAction:a.createElement(g.Link,{startIcon:a.createElement(Fe.Z,null),to:"/settings/api-tokens"},d({id:"global.back",defaultMessage:"Back"}))})};G.propTypes={apiToken:s().shape({id:s().oneOfType([s().number,s().string]),type:s().string,lifespan:s().oneOfType([s().number,s().string]),name:s().string,accessKey:s().string,permissions:s().array,description:s().string,createdAt:s().string}),canEditInputs:s().bool.isRequired,canRegenerate:s().bool.isRequired,setApiToken:s().func.isRequired,isSubmitting:s().bool.isRequired},G.defaultProps={apiToken:void 0};const et=G;var tt=l(50563),nt=l(47765),at=l(59087),st=l(11631);const z=({apiToken:e})=>{const{formatMessage:t}=(0,T.useIntl)(),n=(0,g.useNotification)(),{trackUsage:r}=(0,g.useTracking)(),o=(0,a.useRef)(r);return a.createElement(g.ContentBox,{endAction:e&&a.createElement("span",{style:{alignSelf:"start"}},a.createElement(at.CopyToClipboard,{onCopy:()=>{o.current("didCopyTokenKey"),n({type:"success",message:{id:"Settings.apiTokens.notification.copied"}})},text:e},a.createElement(tt.h,{label:t({id:"app.component.CopyToClipboard.label",defaultMessage:"Copy to clipboard"}),noBorder:!0,icon:a.createElement(nt.Z,null),style:{padding:0,height:"1rem"}}))),title:e||t({id:"Settings.apiTokens.copy.editTitle",defaultMessage:"This token isn\u2019t accessible anymore."}),subtitle:t(e?{id:"Settings.apiTokens.copy.lastWarning",defaultMessage:"Make sure to copy this token, you won\u2019t be able to see it again!"}:{id:"Settings.apiTokens.copy.editMessage",defaultMessage:"For security reasons, you can only see your token once."}),icon:a.createElement(st.Z,null),iconBackground:"neutral100"})};z.defaultProps={apiToken:null},z.propTypes={apiToken:s().string};const rt=z;var C=l(62345),Y=l(15335),b=l(5803),ge=l(70218),R=l(84967),ot=l(10508),it=l(10369),h=l(88860);const Q=({errors:e,onChange:t,canEditInputs:n,isCreating:r,values:o,apiToken:d,onDispatch:i,setHasChangedPermissions:u})=>{var m,y,M,S;const{formatMessage:f}=(0,T.useIntl)(),[B]=(0,g.usePersistentState)("strapi-admin-language","en"),I=({target:{value:c}})=>{u(!1),c==="full-access"&&i({type:"SELECT_ALL_ACTIONS"}),c==="read-only"&&i({type:"ON_CHANGE_READ_ONLY"})};return a.createElement(C.x,{background:"neutral0",hasRadius:!0,shadow:"filterShadow",paddingTop:6,paddingBottom:6,paddingLeft:7,paddingRight:7},a.createElement(O.K,{spacing:4},a.createElement(h.Z,{variant:"delta",as:"h2"},f({id:"global.details",defaultMessage:"Details"})),a.createElement(Y.r,{gap:5},a.createElement(b.P,{key:"name",col:6,xs:12},a.createElement(it.o,{name:"name",error:e.name?f((m=e.name)!=null&&m.id?e.name:{id:e.name,defaultMessage:e.name}):null,label:f({id:"Settings.apiTokens.form.name",defaultMessage:"Name"}),onChange:t,value:o.name,disabled:!n,required:!0})),a.createElement(b.P,{key:"description",col:6,xs:12},a.createElement(ot.g,{label:f({id:"Settings.apiTokens.form.description",defaultMessage:"Description"}),name:"description",error:e.description?f((y=e.description)!=null&&y.id?e.description:{id:e.description,defaultMessage:e.description}):null,onChange:t,disabled:!n},o.description)),a.createElement(b.P,{key:"lifespan",col:6,xs:12},a.createElement(ge.P,{name:"lifespan",label:f({id:"Settings.apiTokens.form.duration",defaultMessage:"Token duration"}),value:o.lifespan!==null?o.lifespan:"0",error:e.lifespan?f((M=e.lifespan)!=null&&M.id?e.lifespan:{id:e.lifespan,defaultMessage:e.lifespan}):null,onChange:c=>{t({target:{name:"lifespan",value:c}})},required:!0,disabled:!r,placeholder:"Select"},a.createElement(R.W,{value:"604800000"},f({id:"Settings.apiTokens.duration.7-days",defaultMessage:"7 days"})),a.createElement(R.W,{value:"2592000000"},f({id:"Settings.apiTokens.duration.30-days",defaultMessage:"30 days"})),a.createElement(R.W,{value:"7776000000"},f({id:"Settings.apiTokens.duration.90-days",defaultMessage:"90 days"})),a.createElement(R.W,{value:"0"},f({id:"Settings.apiTokens.duration.unlimited",defaultMessage:"Unlimited"}))),a.createElement(h.Z,{variant:"pi",textColor:"neutral600"},!r&&`${f({id:"Settings.apiTokens.duration.expiration-date",defaultMessage:"Expiration date"})}: ${Ue(d==null?void 0:d.createdAt,parseInt(o.lifespan,10),B)}`)),a.createElement(b.P,{key:"type",col:6,xs:12},a.createElement(ge.P,{name:"type",label:f({id:"Settings.apiTokens.form.type",defaultMessage:"Token type"}),value:o==null?void 0:o.type,error:e.type?f((S=e.type)!=null&&S.id?e.type:{id:e.type,defaultMessage:e.type}):null,onChange:c=>{I({target:{value:c}}),t({target:{name:"type",value:c}})},placeholder:"Select",required:!0,disabled:!n},a.createElement(R.W,{value:"read-only"},f({id:"Settings.apiTokens.types.read-only",defaultMessage:"Read-only"})),a.createElement(R.W,{value:"full-access"},f({id:"Settings.apiTokens.types.full-access",defaultMessage:"Full access"})),a.createElement(R.W,{value:"custom"},f({id:"Settings.apiTokens.types.custom",defaultMessage:"Custom"})))))))};Q.propTypes={errors:s().shape({name:s().string,description:s().string,lifespan:s().string,type:s().string}),onChange:s().func.isRequired,canEditInputs:s().bool.isRequired,values:s().shape({name:s().string,description:s().string,lifespan:s().oneOfType([s().number,s().string]),type:s().string}).isRequired,isCreating:s().bool.isRequired,apiToken:s().shape({id:s().oneOfType([s().number,s().string]),type:s().string,lifespan:s().string,name:s().string,accessKey:s().string,permissions:s().array,description:s().string,createdAt:s().string}),onDispatch:s().func.isRequired,setHasChangedPermissions:s().func.isRequired},Q.defaultProps={errors:{},apiToken:{}};const lt=Q;var dt=l(83828),ct=l(61762),pt=l(89966),fe=l(8284),ut=l(36320),mt=l(45112),V=l(83292),ye=Object.getOwnPropertySymbols,gt=Object.prototype.hasOwnProperty,ft=Object.prototype.propertyIsEnumerable,yt=(e,t)=>{var n={};for(var r in e)gt.call(e,r)&&t.indexOf(r)<0&&(n[r]=e[r]);if(e!=null&&ye)for(var r of ye(e))t.indexOf(r)<0&&ft.call(e,r)&&(n[r]=e[r]);return n};const ve=(0,a.createContext)({}),Ee=e=>{var t=e,{children:n}=t,r=yt(t,["children"]);return a.createElement(ve.Provider,{value:r},n)},X=()=>(0,a.useContext)(ve);Ee.propTypes={children:s().node.isRequired};const he=V.css`
|
|
2
|
-
background: ${e=>e.theme.colors.primary100};
|
|
3
|
-
svg {
|
|
4
|
-
opacity: 1;
|
|
5
|
-
}
|
|
6
|
-
`,vt=(0,V.default)(C.x)`
|
|
7
|
-
display: flex;
|
|
8
|
-
justify-content: space-between;
|
|
9
|
-
align-items: center;
|
|
10
|
-
|
|
11
|
-
svg {
|
|
12
|
-
opacity: 0;
|
|
13
|
-
path {
|
|
14
|
-
fill: ${e=>e.theme.colors.primary600};
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
/* Show active style both on hover and when the action is selected */
|
|
19
|
-
${e=>e.isActive&&he}
|
|
20
|
-
&:hover {
|
|
21
|
-
${he}
|
|
22
|
-
}
|
|
23
|
-
`,Et=V.default.div`
|
|
24
|
-
flex: 1;
|
|
25
|
-
align-self: center;
|
|
26
|
-
border-top: 1px solid ${({theme:e})=>e.colors.neutral150};
|
|
27
|
-
`,J=({controllers:e,label:t,orderNumber:n,disabled:r,onExpanded:o,indexExpandendCollapsedContent:d})=>{const{value:{onChangeSelectAll:i,onChange:u,selectedActions:m,setSelectedAction:y,selectedAction:M}}=X(),[S,f]=(0,a.useState)(!1),B=()=>{f(c=>!c),o(n)};(0,a.useEffect)(()=>{d!==null&&d!==n&&S&&f(!1)},[d,n,S]);const I=c=>c===M;return a.createElement(dt.U,{expanded:S,onToggle:B,variant:n%2?"primary":"secondary"},a.createElement(ct.B,{title:(0,w.capitalize)(t)}),a.createElement(pt.v,null,e==null?void 0:e.map(c=>{const k=c.actions.every(E=>m.includes(E.actionId)),v=c.actions.some(E=>m.includes(E.actionId));return a.createElement(C.x,{key:`${t}.${c==null?void 0:c.controller}`},a.createElement(ut.k,{justifyContent:"space-between",alignItems:"center",padding:4},a.createElement(C.x,{paddingRight:4},a.createElement(h.Z,{variant:"sigma",textColor:"neutral600"},c==null?void 0:c.controller)),a.createElement(Et,null),a.createElement(C.x,{paddingLeft:4},a.createElement(fe.X,{value:k,indeterminate:!k&&v,onValueChange:()=>{i({target:{value:[...c.actions]}})},disabled:r},"Select all"))),a.createElement(Y.r,{gap:4,padding:4},(c==null?void 0:c.actions)&&(c==null?void 0:c.actions.map(E=>a.createElement(b.P,{col:6,key:E.actionId},a.createElement(vt,{isActive:I(E.actionId),padding:2,hasRadius:!0},a.createElement(fe.X,{value:m.includes(E.actionId),name:E.actionId,onValueChange:()=>{u({target:{value:E.actionId}})},disabled:r},E.action),a.createElement("button",{type:"button","data-testid":"action-cog",onClick:()=>y({target:{value:E.actionId}}),style:{display:"inline-flex",alignItems:"center"}},a.createElement(mt.Z,null))))))))})))};J.defaultProps={controllers:[],orderNumber:0,disabled:!1,onExpanded:()=>null,indexExpandendCollapsedContent:null},J.propTypes={controllers:s().array,orderNumber:s().number,label:s().string.isRequired,disabled:s().bool,onExpanded:s().func,indexExpandendCollapsedContent:s().number};const ht=J;var Pt=Object.defineProperty,Z=Object.getOwnPropertySymbols,Pe=Object.prototype.hasOwnProperty,Te=Object.prototype.propertyIsEnumerable,Oe=(e,t,n)=>t in e?Pt(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,Tt=(e,t)=>{for(var n in t||(t={}))Pe.call(t,n)&&Oe(e,n,t[n]);if(Z)for(var n of Z(t))Te.call(t,n)&&Oe(e,n,t[n]);return e},Ot=(e,t)=>{var n={};for(var r in e)Pe.call(e,r)&&t.indexOf(r)<0&&(n[r]=e[r]);if(e!=null&&Z)for(var r of Z(e))t.indexOf(r)<0&&Te.call(e,r)&&(n[r]=e[r]);return n};const q=e=>{var t=e,{section:n}=t,r=Ot(t,["section"]);const[o,d]=(0,a.useState)(null),i=u=>d(u);return a.createElement(C.x,{padding:4,background:"neutral0"},n&&n.map((u,m)=>a.createElement(ht,Tt({key:u.apiId,label:u.label,controllers:u.controllers,orderNumber:m,indexExpandendCollapsedContent:o,onExpanded:i,name:u.apiId},r))))};q.defaultProps={section:null},q.propTypes={section:s().arrayOf(s().object)};const Ct=q;var St=l(37213),At=l.n(St),bt=l(15738),Rt=l.n(bt);const It=e=>{switch(e){case"POST":return{text:"success600",border:"success200",background:"success100"};case"GET":return{text:"secondary600",border:"secondary200",background:"secondary100"};case"PUT":return{text:"warning600",border:"warning200",background:"warning100"};case"DELETE":return{text:"danger600",border:"danger200",background:"danger100"};default:return{text:"neutral600",border:"neutral200",background:"neutral100"}}},kt=(0,V.default)(C.x)`
|
|
28
|
-
margin: -1px;
|
|
29
|
-
border-radius: ${({theme:e})=>e.spaces[1]} 0 0 ${({theme:e})=>e.spaces[1]};
|
|
30
|
-
`;function _({route:e}){const{formatMessage:t}=(0,T.useIntl)(),{method:n,handler:r,path:o}=e,d=o?Rt()(o.split("/")):[],[i="",u=""]=r?r.split("."):[],m=It(e.method);return a.createElement(O.K,{spacing:2},a.createElement(h.Z,{variant:"delta",as:"h3"},t({id:"Settings.apiTokens.createPage.BoundRoute.title",defaultMessage:"Bound route to"}),"\xA0",a.createElement("span",null,i),a.createElement(h.Z,{variant:"delta",textColor:"primary600"},".",u)),a.createElement(O.K,{horizontal:!0,hasRadius:!0,background:"neutral0",borderColor:"neutral200",spacing:0},a.createElement(kt,{background:m.background,borderColor:m.border,padding:2},a.createElement(h.Z,{fontWeight:"bold",textColor:m.text},n)),a.createElement(C.x,{paddingLeft:2,paddingRight:2},At()(d,y=>a.createElement(h.Z,{key:y,textColor:y.includes(":")?"neutral600":"neutral900"},"/",y)))))}_.defaultProps={route:{handler:"Nocontroller.error",method:"GET",path:"/there-is-no-path"}},_.propTypes={route:s().shape({handler:s().string,method:s().string,path:s().string})};const xt=_,Mt=()=>{var e;const{value:{selectedAction:t,routes:n}}=X(),{formatMessage:r}=(0,T.useIntl)(),o=t==null?void 0:t.split(".")[0];return a.createElement(b.P,{col:5,background:"neutral150",paddingTop:6,paddingBottom:6,paddingLeft:7,paddingRight:7,style:{minHeight:"100%"}},t?a.createElement(O.K,{spacing:2},(e=n[o])==null?void 0:e.map(d=>{var i,u;return((u=(i=d.config.auth)==null?void 0:i.scope)==null?void 0:u.includes(t))||d.handler===t?a.createElement(xt,{key:d.handler,route:d}):null})):a.createElement(O.K,{spacing:2},a.createElement(h.Z,{variant:"delta",as:"h3"},r({id:"Settings.apiTokens.createPage.permissions.header.title",defaultMessage:"Advanced settings"})),a.createElement(h.Z,{as:"p",textColor:"neutral600"},r({id:"Settings.apiTokens.createPage.permissions.header.hint",defaultMessage:"Select the application's actions or the plugin's actions and click on the cog icon to display the bound route"}))))};var Nt=Object.defineProperty,U=Object.getOwnPropertySymbols,Ce=Object.prototype.hasOwnProperty,Se=Object.prototype.propertyIsEnumerable,Ae=(e,t,n)=>t in e?Nt(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,Lt=(e,t)=>{for(var n in t||(t={}))Ce.call(t,n)&&Ae(e,n,t[n]);if(U)for(var n of U(t))Se.call(t,n)&&Ae(e,n,t[n]);return e},wt=(e,t)=>{var n={};for(var r in e)Ce.call(e,r)&&t.indexOf(r)<0&&(n[r]=e[r]);if(e!=null&&U)for(var r of U(e))t.indexOf(r)<0&&Se.call(e,r)&&(n[r]=e[r]);return n};const Dt=e=>{var t=wt(e,[]);const{value:{data:n}}=X(),{formatMessage:r}=(0,T.useIntl)();return a.createElement(Y.r,{gap:0,shadow:"filterShadow",hasRadius:!0,background:"neutral0"},a.createElement(b.P,{col:7,paddingTop:6,paddingBottom:6,paddingLeft:7,paddingRight:7},a.createElement(O.K,{spacing:2},a.createElement(h.Z,{variant:"delta",as:"h2"},r({id:"Settings.apiTokens.createPage.permissions.title",defaultMessage:"Permissions"})),a.createElement(h.Z,{as:"p",textColor:"neutral600"},r({id:"Settings.apiTokens.createPage.permissions.description",defaultMessage:"Only actions bound by a route are listed below."}))),(n==null?void 0:n.permissions)&&a.createElement(Ct,Lt({section:n==null?void 0:n.permissions},t))),a.createElement(Mt,null))},Bt=(0,a.memo)(Dt),ee=({apiToken:e,errors:t,onChange:n,canEditInputs:r,isCreating:o,values:d,onDispatch:i,setHasChangedPermissions:u})=>a.createElement(le.D,null,a.createElement(O.K,{spacing:6},Boolean(e==null?void 0:e.name)&&a.createElement(rt,{apiToken:e==null?void 0:e.accessKey}),a.createElement(lt,{errors:t,onChange:n,canEditInputs:r,isCreating:o,values:d,apiToken:e,onDispatch:i,setHasChangedPermissions:u}),a.createElement(Bt,{disabled:!r||(d==null?void 0:d.type)==="read-only"||(d==null?void 0:d.type)==="full-access"})));ee.propTypes={errors:s().shape({name:s().string,description:s().string,lifespan:s().string,type:s().string}),apiToken:s().shape({id:s().oneOfType([s().number,s().string]),type:s().string,lifespan:s().oneOfType([s().number,s().string]),name:s().string,accessKey:s().string,permissions:s().array,description:s().string,createdAt:s().string}),onChange:s().func.isRequired,canEditInputs:s().bool.isRequired,isCreating:s().bool.isRequired,values:s().shape({name:s().string,description:s().string,lifespan:s().string,type:s().string}).isRequired,onDispatch:s().func.isRequired,setHasChangedPermissions:s().func.isRequired},ee.defaultProps={errors:{},apiToken:{}};const jt=ee;var Vt=l(83983),Zt=Object.defineProperty,Ut=Object.defineProperties,Kt=Object.getOwnPropertyDescriptors,be=Object.getOwnPropertySymbols,Wt=Object.prototype.hasOwnProperty,$t=Object.prototype.propertyIsEnumerable,Re=(e,t,n)=>t in e?Zt(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,Ft=(e,t)=>{for(var n in t||(t={}))Wt.call(t,n)&&Re(e,n,t[n]);if(be)for(var n of be(t))$t.call(t,n)&&Re(e,n,t[n]);return e},Ht=(e,t)=>Ut(e,Kt(t));const Gt=(e,t=[])=>Ht(Ft({},e),{selectedAction:null,routes:[],selectedActions:[],data:oe(t)});var zt=l(97889),Yt=Object.defineProperty,Ie=Object.getOwnPropertySymbols,Qt=Object.prototype.hasOwnProperty,Xt=Object.prototype.propertyIsEnumerable,ke=(e,t,n)=>t in e?Yt(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,Jt=(e,t)=>{for(var n in t||(t={}))Qt.call(t,n)&&ke(e,n,t[n]);if(Ie)for(var n of Ie(t))Xt.call(t,n)&&ke(e,n,t[n]);return e};const qt={data:{},selectedActions:[]},_t=(e,t)=>(0,zt.default)(e,n=>{switch(t.type){case"ON_CHANGE":{n.selectedActions.includes(t.value)?(0,w.pull)(n.selectedActions,t.value):n.selectedActions.push(t.value);break}case"SELECT_ALL_IN_PERMISSION":{t.value.every(o=>n.selectedActions.includes(o.actionId))?t.value.forEach(o=>{(0,w.pull)(n.selectedActions,o.actionId)}):t.value.forEach(o=>{n.selectedActions.push(o.actionId)});break}case"SELECT_ALL_ACTIONS":{n.selectedActions=[...n.data.allActionsIds];break}case"ON_CHANGE_READ_ONLY":{const r=n.data.allActionsIds.filter(o=>o.includes("find")||o.includes("findOne"));n.selectedActions=[...r];break}case"UPDATE_PERMISSIONS_LAYOUT":{n.data=oe(t.value);break}case"UPDATE_ROUTES":{n.routes=Jt({},t.value);break}case"UPDATE_PERMISSIONS":{n.selectedActions=[...t.value];break}case"SET_SELECTED_ACTION":{n.selectedAction=t.value;break}default:return n}});var en=Object.defineProperty,tn=Object.defineProperties,nn=Object.getOwnPropertyDescriptors,xe=Object.getOwnPropertySymbols,an=Object.prototype.hasOwnProperty,sn=Object.prototype.propertyIsEnumerable,Me=(e,t,n)=>t in e?en(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,D=(e,t)=>{for(var n in t||(t={}))an.call(t,n)&&Me(e,n,t[n]);if(xe)for(var n of xe(t))sn.call(t,n)&&Me(e,n,t[n]);return e},Ne=(e,t)=>tn(e,nn(t)),K=(e,t,n)=>new Promise((r,o)=>{var d=m=>{try{u(n.next(m))}catch(y){o(y)}},i=m=>{try{u(n.throw(m))}catch(y){o(y)}},u=m=>m.done?r(m.value):Promise.resolve(m.value).then(d,i);u((n=n.apply(e,t)).next())});const rn="Name already taken",on=()=>{var e;(0,g.useFocusWhenNavigate)();const{formatMessage:t}=(0,T.useIntl)(),{lockApp:n,unlockApp:r}=(0,g.useOverlayBlocker)(),o=(0,g.useNotification)(),d=(0,ae.useHistory)(),[i,u]=(0,a.useState)((e=d.location.state)!=null&&e.apiToken.accessKey?D({},d.location.state.apiToken):null),{trackUsage:m}=(0,g.useTracking)(),y=(0,a.useRef)(m),{setCurrentStep:M}=(0,g.useGuidedTour)(),{allowedActions:{canCreate:S,canUpdate:f,canRegenerate:B}}=(0,g.useRBAC)(Vt.Z.settings["api-tokens"]),[I,c]=(0,a.useReducer)(_t,qt,p=>Gt(p,{})),{params:{id:k}}=(0,ae.useRouteMatch)("/settings/api-tokens/:id"),v=k==="create";(0,se.useQuery)("content-api-permissions",()=>K(void 0,null,function*(){const[p,x]=yield Promise.all(["/admin/content-api/permissions","/admin/content-api/routes"].map(N=>K(void 0,null,function*(){const{data:A}=yield j.be.get(N);return A.data})));c({type:"UPDATE_PERMISSIONS_LAYOUT",value:p}),c({type:"UPDATE_ROUTES",value:x}),i&&((i==null?void 0:i.type)==="read-only"&&c({type:"ON_CHANGE_READ_ONLY"}),(i==null?void 0:i.type)==="full-access"&&c({type:"SELECT_ALL_ACTIONS"}),(i==null?void 0:i.type)==="custom"&&c({type:"UPDATE_PERMISSIONS",value:i==null?void 0:i.permissions}))}),{onError(){o({type:"warning",message:{id:"notification.error",defaultMessage:"An error occured"}})}}),(0,a.useEffect)(()=>{y.current(v?"didAddTokenFromList":"didEditTokenFromList")},[v]);const{status:E}=(0,se.useQuery)(["api-token",k],()=>K(void 0,null,function*(){const{data:{data:p}}=yield j.be.get(`/admin/api-tokens/${k}`);return u(D({},p)),(p==null?void 0:p.type)==="read-only"&&c({type:"ON_CHANGE_READ_ONLY"}),(p==null?void 0:p.type)==="full-access"&&c({type:"SELECT_ALL_ACTIONS"}),(p==null?void 0:p.type)==="custom"&&c({type:"UPDATE_PERMISSIONS",value:p==null?void 0:p.permissions}),p}),{enabled:!v&&!i,onError(){o({type:"warning",message:{id:"notification.error",defaultMessage:"An error occured"}})}}),ln=(p,x)=>K(void 0,null,function*(){var N,A,W,we,De;y.current(v?"willCreateToken":"willEditToken"),n();const gn=p.lifespan&&parseInt(p.lifespan,10)&&p.lifespan!=="0"?parseInt(p.lifespan,10):null;try{const{data:{data:P}}=v?yield j.be.post("/admin/api-tokens",Ne(D({},p),{lifespan:gn,permissions:p.type==="custom"?I.selectedActions:null})):yield j.be.put(`/admin/api-tokens/${k}`,{name:p.name,description:p.description,type:p.type,permissions:p.type==="custom"?I.selectedActions:null});v&&(d.replace(`/settings/api-tokens/${P.id}`,{apiToken:P}),M("apiTokens.success")),r(),u(D({},P)),o({type:"success",message:t(v?{id:"notification.success.tokencreated",defaultMessage:"API Token successfully created"}:{id:"notification.success.tokenedited",defaultMessage:"API Token successfully edited"})}),y.current(v?"didCreateToken":"didEditToken",{type:i.type})}catch(P){const fn=(0,Ve.Iz)(P.response.data);x.setErrors(fn),((W=(A=(N=P==null?void 0:P.response)==null?void 0:N.data)==null?void 0:A.error)==null?void 0:W.message)===rn?o({type:"warning",message:P.response.data.message||"notification.error.tokennamenotunique"}):o({type:"warning",message:((De=(we=P==null?void 0:P.response)==null?void 0:we.data)==null?void 0:De.message)||"notification.error"}),r()}}),[dn,te]=(0,a.useState)(!1),cn=({target:{value:p}})=>{te(!0),c({type:"ON_CHANGE",value:p})},pn=({target:{value:p}})=>{te(!0),c({type:"SELECT_ALL_IN_PERMISSION",value:p})},un=({target:{value:p}})=>{c({type:"SET_SELECTED_ACTION",value:p})},mn=Ne(D({},I),{onChange:cn,onChangeSelectAll:pn,setSelectedAction:un}),Le=f&&!v||S&&v;return!v&&!i&&E!=="success"?a.createElement($e,{apiTokenName:i==null?void 0:i.name}):a.createElement(Ee,{value:mn},a.createElement(ne.o,null,a.createElement(g.SettingsPageTitle,{name:"API Tokens"}),a.createElement(je.Formik,{validationSchema:Ke,validateOnChange:!1,initialValues:{name:(i==null?void 0:i.name)||"",description:(i==null?void 0:i.description)||"",type:i==null?void 0:i.type,lifespan:i!=null&&i.lifespan?i.lifespan.toString():i==null?void 0:i.lifespan},enableReinitialize:!0,onSubmit:(p,x)=>ln(p,x)},({errors:p,handleChange:x,isSubmitting:N,values:A,setFieldValue:W})=>(dn&&(A==null?void 0:A.type)!=="custom"&&W("type","custom"),a.createElement(g.Form,null,a.createElement(et,{apiToken:i,setApiToken:u,canEditInputs:Le,canRegenerate:B,isSubmitting:N}),a.createElement(jt,{apiToken:i,errors:p,onChange:x,canEditInputs:Le,isCreating:v,values:A,onDispatch:c,setHasChangedPermissions:te}))))))}}}]);
|