@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.
Files changed (90) hide show
  1. package/admin/src/components/AuthenticatedApp/index.js +2 -13
  2. package/admin/src/content-manager/components/ComponentInitializer/index.js +1 -7
  3. package/admin/src/content-manager/components/{RepeatableComponent/DragPreview.js → DragLayer/ComponentDragPreview.js} +25 -12
  4. package/admin/src/content-manager/components/DragLayer/RelationDragPreview.js +75 -0
  5. package/admin/src/content-manager/components/DragLayer/index.js +23 -7
  6. package/admin/src/content-manager/components/DynamicZone/components/DynamicComponent.js +130 -84
  7. package/admin/src/content-manager/components/DynamicZone/index.js +99 -24
  8. package/admin/src/content-manager/components/DynamicZone/utils/select.js +9 -5
  9. package/admin/src/content-manager/components/EditViewDataManagerProvider/index.js +37 -11
  10. package/admin/src/content-manager/components/EditViewDataManagerProvider/reducer.js +18 -22
  11. package/admin/src/content-manager/components/EditViewDataManagerProvider/utils/cleanData.js +24 -5
  12. package/admin/src/content-manager/components/RelationInput/RelationInput.js +209 -64
  13. package/admin/src/content-manager/components/RelationInput/components/RelationItem.js +134 -21
  14. package/admin/src/content-manager/components/RelationInput/components/RelationList.js +1 -2
  15. package/admin/src/content-manager/components/RelationInput/constants.js +1 -0
  16. package/admin/src/content-manager/components/RelationInputDataManager/RelationInputDataManager.js +131 -9
  17. package/admin/src/content-manager/components/RepeatableComponent/components/Accordion.js +77 -0
  18. package/admin/src/content-manager/components/RepeatableComponent/components/Component.js +262 -0
  19. package/admin/src/content-manager/components/RepeatableComponent/{DraggedItem → components}/Preview.js +0 -0
  20. package/admin/src/content-manager/components/RepeatableComponent/index.js +147 -87
  21. package/admin/src/content-manager/components/RepeatableComponent/utils/getComponentErrorKeys.js +1 -1
  22. package/admin/src/content-manager/hooks/index.js +2 -0
  23. package/admin/src/content-manager/hooks/useDragAndDrop.js +120 -0
  24. package/admin/src/content-manager/hooks/useKeyboardDragAndDrop.js +98 -0
  25. package/admin/src/content-manager/utils/ItemTypes.js +1 -1
  26. package/admin/src/content-manager/utils/composeRefs.js +28 -0
  27. package/admin/src/content-manager/utils/getMaxTempKey.js +1 -1
  28. package/admin/src/content-manager/utils/index.js +7 -0
  29. package/admin/src/pages/App/index.js +13 -20
  30. package/admin/src/pages/SettingsPage/pages/ApiTokens/EditView/index.js +3 -2
  31. package/admin/src/translations/en.json +6 -0
  32. package/admin/src/translations/tr.json +5 -485
  33. package/admin/src/utils/index.js +0 -1
  34. package/build/4318.80bdf035.chunk.js +30 -0
  35. package/build/{8176.e929d326.chunk.js → 8176.b19bc128.chunk.js} +32 -32
  36. package/build/{1233.802422fa.chunk.js → 8186.55910742.chunk.js} +96 -96
  37. package/build/{8633.43ec9042.chunk.js → 8633.59223842.chunk.js} +1 -1
  38. package/build/Admin-authenticatedApp.f9e74dc0.chunk.js +80 -0
  39. package/build/{Admin_profilePage.60ab80bb.chunk.js → Admin_profilePage.c07bdf08.chunk.js} +1 -1
  40. package/build/{Admin_settingsPage.6ef8acc9.chunk.js → Admin_settingsPage.50a8765b.chunk.js} +1 -1
  41. package/build/admin-app.2861b6d2.chunk.js +112 -0
  42. package/build/admin-edit-users.85231e4c.chunk.js +10 -0
  43. package/build/{admin-users.e64fb0f1.chunk.js → admin-users.a2707644.chunk.js} +2 -2
  44. package/build/api-tokens-create-page.dd4ddfcb.chunk.js +1 -0
  45. package/build/api-tokens-edit-page.821c5a6c.chunk.js +1 -0
  46. package/build/content-manager.ee948f75.chunk.js +1186 -0
  47. package/build/content-type-builder-translation-tr-json.2e52bc60.chunk.js +1 -0
  48. package/build/email-settings-page.db0d98d1.chunk.js +15 -0
  49. package/build/email-translation-tr-json.87f2feb3.chunk.js +1 -0
  50. package/build/{en-json.7dd57947.chunk.js → en-json.4a56dca7.chunk.js} +1 -1
  51. package/build/index.html +1 -1
  52. package/build/main.faac89ee.js +2025 -0
  53. package/build/runtime~main.75a15b8e.js +2 -0
  54. package/build/sso-settings-page.adb12ac3.chunk.js +1 -0
  55. package/build/tr-json.9c44ea0c.chunk.js +1 -0
  56. package/build/{upload.74540aab.chunk.js → upload.e2034370.chunk.js} +3 -3
  57. package/build/users-permissions-translation-tr-json.cdc49a3c.chunk.js +1 -0
  58. package/package.json +9 -9
  59. package/server/controllers/admin.js +0 -2
  60. package/server/routes/admin.js +1 -1
  61. package/server/services/metrics.js +2 -5
  62. package/admin/src/content-manager/components/RepeatableComponent/AccordionGroupCustom/index.js +0 -122
  63. package/admin/src/content-manager/components/RepeatableComponent/AddFieldButton.js +0 -58
  64. package/admin/src/content-manager/components/RepeatableComponent/DraggedItem/DraggingSibling.js +0 -72
  65. package/admin/src/content-manager/components/RepeatableComponent/DraggedItem/IconButtonCustoms.js +0 -32
  66. package/admin/src/content-manager/components/RepeatableComponent/DraggedItem/index.js +0 -326
  67. package/admin/src/content-manager/components/RepeatableComponent/DraggedItem/utils/connect.js +0 -11
  68. package/admin/src/content-manager/components/RepeatableComponent/DraggedItem/utils/index.js +0 -2
  69. package/admin/src/content-manager/components/RepeatableComponent/DraggedItem/utils/select.js +0 -30
  70. package/admin/src/content-manager/components/RepeatableComponent/utils/connect.js +0 -11
  71. package/admin/src/content-manager/components/RepeatableComponent/utils/select.js +0 -12
  72. package/admin/src/content-manager/hooks/__test__/usePrev.test.js +0 -26
  73. package/admin/src/utils/uniqueAdminHash.js +0 -22
  74. package/build/4318.9283c350.chunk.js +0 -30
  75. package/build/Admin-authenticatedApp.0da578b8.chunk.js +0 -80
  76. package/build/admin-app.a3277e72.chunk.js +0 -112
  77. package/build/admin-edit-users.5547b126.chunk.js +0 -10
  78. package/build/api-tokens-create-page.93dd0689.chunk.js +0 -1
  79. package/build/api-tokens-edit-page.b0adac81.chunk.js +0 -1
  80. package/build/content-manager.f9630c3b.chunk.js +0 -1197
  81. package/build/content-type-builder-translation-tr-json.949e22eb.chunk.js +0 -1
  82. package/build/email-settings-page.c6e62f6b.chunk.js +0 -15
  83. package/build/email-translation-tr-json.8aa034bb.chunk.js +0 -1
  84. package/build/i18n-translation-tr-json.34ca9d61.chunk.js +0 -1
  85. package/build/main.71f24343.js +0 -2034
  86. package/build/runtime~main.1115f82b.js +0 -2
  87. package/build/sso-settings-page.feed2f45.chunk.js +0 -1
  88. package/build/tr-json.eac8bd79.chunk.js +0 -1
  89. package/build/upload-translation-tr-json.b173223a.chunk.js +0 -1
  90. 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 };
@@ -1,11 +0,0 @@
1
- import React from 'react';
2
-
3
- function connect(WrappedComponent, select) {
4
- return (props) => {
5
- const selectors = select(props);
6
-
7
- return <WrappedComponent {...props} {...selectors} />;
8
- };
9
- }
10
-
11
- export default connect;
@@ -1,2 +0,0 @@
1
- export { default as connect } from './connect';
2
- export { default as select } from './select';
@@ -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,11 +0,0 @@
1
- import React from 'react';
2
-
3
- function connect(WrappedComponent, select) {
4
- return (props) => {
5
- const selectors = select(props);
6
-
7
- return <WrappedComponent {...props} {...selectors} />;
8
- };
9
- }
10
-
11
- export default connect;
@@ -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}))))))}}}]);