@strapi/admin 5.22.0 → 5.23.1

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 (122) hide show
  1. package/dist/admin/admin/src/components/GuidedTour/Context.js +48 -8
  2. package/dist/admin/admin/src/components/GuidedTour/Context.js.map +1 -1
  3. package/dist/admin/admin/src/components/GuidedTour/Context.mjs +48 -9
  4. package/dist/admin/admin/src/components/GuidedTour/Context.mjs.map +1 -1
  5. package/dist/admin/admin/src/components/GuidedTour/Overview.js +35 -24
  6. package/dist/admin/admin/src/components/GuidedTour/Overview.js.map +1 -1
  7. package/dist/admin/admin/src/components/GuidedTour/Overview.mjs +36 -25
  8. package/dist/admin/admin/src/components/GuidedTour/Overview.mjs.map +1 -1
  9. package/dist/admin/admin/src/components/GuidedTour/Steps/ApiTokensSteps.js +156 -0
  10. package/dist/admin/admin/src/components/GuidedTour/Steps/ApiTokensSteps.js.map +1 -0
  11. package/dist/admin/admin/src/components/GuidedTour/Steps/ApiTokensSteps.mjs +154 -0
  12. package/dist/admin/admin/src/components/GuidedTour/Steps/ApiTokensSteps.mjs.map +1 -0
  13. package/dist/admin/admin/src/components/GuidedTour/Steps/ContentManagerSteps.js +221 -0
  14. package/dist/admin/admin/src/components/GuidedTour/Steps/ContentManagerSteps.js.map +1 -0
  15. package/dist/admin/admin/src/components/GuidedTour/Steps/ContentManagerSteps.mjs +219 -0
  16. package/dist/admin/admin/src/components/GuidedTour/Steps/ContentManagerSteps.mjs.map +1 -0
  17. package/dist/admin/admin/src/components/GuidedTour/Steps/ContentTypeBuilderSteps.js +219 -0
  18. package/dist/admin/admin/src/components/GuidedTour/Steps/ContentTypeBuilderSteps.js.map +1 -0
  19. package/dist/admin/admin/src/components/GuidedTour/Steps/ContentTypeBuilderSteps.mjs +217 -0
  20. package/dist/admin/admin/src/components/GuidedTour/Steps/ContentTypeBuilderSteps.mjs.map +1 -0
  21. package/dist/admin/admin/src/components/GuidedTour/{Step.js → Steps/Step.js} +116 -71
  22. package/dist/admin/admin/src/components/GuidedTour/Steps/Step.js.map +1 -0
  23. package/dist/admin/admin/src/components/GuidedTour/{Step.mjs → Steps/Step.mjs} +117 -74
  24. package/dist/admin/admin/src/components/GuidedTour/Steps/Step.mjs.map +1 -0
  25. package/dist/admin/admin/src/components/GuidedTour/Tours.js +47 -324
  26. package/dist/admin/admin/src/components/GuidedTour/Tours.js.map +1 -1
  27. package/dist/admin/admin/src/components/GuidedTour/Tours.mjs +48 -326
  28. package/dist/admin/admin/src/components/GuidedTour/Tours.mjs.map +1 -1
  29. package/dist/admin/admin/src/components/GuidedTour/utils/constants.js +19 -0
  30. package/dist/admin/admin/src/components/GuidedTour/utils/constants.js.map +1 -0
  31. package/dist/admin/admin/src/components/GuidedTour/utils/constants.mjs +17 -0
  32. package/dist/admin/admin/src/components/GuidedTour/utils/constants.mjs.map +1 -0
  33. package/dist/admin/admin/src/components/GuidedTour/utils/migrations.js +31 -0
  34. package/dist/admin/admin/src/components/GuidedTour/utils/migrations.js.map +1 -0
  35. package/dist/admin/admin/src/components/GuidedTour/utils/migrations.mjs +29 -0
  36. package/dist/admin/admin/src/components/GuidedTour/utils/migrations.mjs.map +1 -0
  37. package/dist/admin/admin/src/components/SubNav.js +3 -1
  38. package/dist/admin/admin/src/components/SubNav.js.map +1 -1
  39. package/dist/admin/admin/src/components/SubNav.mjs +3 -1
  40. package/dist/admin/admin/src/components/SubNav.mjs.map +1 -1
  41. package/dist/admin/admin/src/components/Widgets.js +4 -0
  42. package/dist/admin/admin/src/components/Widgets.js.map +1 -1
  43. package/dist/admin/admin/src/components/Widgets.mjs +5 -1
  44. package/dist/admin/admin/src/components/Widgets.mjs.map +1 -1
  45. package/dist/admin/admin/src/features/Tracking.js.map +1 -1
  46. package/dist/admin/admin/src/features/Tracking.mjs.map +1 -1
  47. package/dist/admin/admin/src/pages/Home/HomePage.js +10 -1
  48. package/dist/admin/admin/src/pages/Home/HomePage.js.map +1 -1
  49. package/dist/admin/admin/src/pages/Home/HomePage.mjs +10 -1
  50. package/dist/admin/admin/src/pages/Home/HomePage.mjs.map +1 -1
  51. package/dist/admin/admin/src/pages/Settings/components/Tokens/FormHead.js +17 -14
  52. package/dist/admin/admin/src/pages/Settings/components/Tokens/FormHead.js.map +1 -1
  53. package/dist/admin/admin/src/pages/Settings/components/Tokens/FormHead.mjs +17 -14
  54. package/dist/admin/admin/src/pages/Settings/components/Tokens/FormHead.mjs.map +1 -1
  55. package/dist/admin/admin/src/pages/Settings/components/Tokens/Table.js +31 -6
  56. package/dist/admin/admin/src/pages/Settings/components/Tokens/Table.js.map +1 -1
  57. package/dist/admin/admin/src/pages/Settings/components/Tokens/Table.mjs +12 -6
  58. package/dist/admin/admin/src/pages/Settings/components/Tokens/Table.mjs.map +1 -1
  59. package/dist/admin/admin/src/pages/Settings/components/Tokens/TokenBox.js +28 -24
  60. package/dist/admin/admin/src/pages/Settings/components/Tokens/TokenBox.js.map +1 -1
  61. package/dist/admin/admin/src/pages/Settings/components/Tokens/TokenBox.mjs +28 -24
  62. package/dist/admin/admin/src/pages/Settings/components/Tokens/TokenBox.mjs.map +1 -1
  63. package/dist/admin/admin/src/pages/Settings/pages/ApiTokens/EditView/EditViewPage.js.map +1 -1
  64. package/dist/admin/admin/src/pages/Settings/pages/ApiTokens/EditView/EditViewPage.mjs.map +1 -1
  65. package/dist/admin/admin/src/pages/Settings/pages/ApiTokens/ListView.js +56 -57
  66. package/dist/admin/admin/src/pages/Settings/pages/ApiTokens/ListView.js.map +1 -1
  67. package/dist/admin/admin/src/pages/Settings/pages/ApiTokens/ListView.mjs +57 -58
  68. package/dist/admin/admin/src/pages/Settings/pages/ApiTokens/ListView.mjs.map +1 -1
  69. package/dist/admin/admin/src/services/apiTokens.js +0 -1
  70. package/dist/admin/admin/src/services/apiTokens.js.map +1 -1
  71. package/dist/admin/admin/src/services/apiTokens.mjs +0 -1
  72. package/dist/admin/admin/src/services/apiTokens.mjs.map +1 -1
  73. package/dist/admin/admin/src/translations/en.json.js +33 -21
  74. package/dist/admin/admin/src/translations/en.json.js.map +1 -1
  75. package/dist/admin/admin/src/translations/en.json.mjs +33 -21
  76. package/dist/admin/admin/src/translations/en.json.mjs.map +1 -1
  77. package/dist/admin/ee/admin/src/components/AuditLogs/Widgets.js +2 -2
  78. package/dist/admin/ee/admin/src/components/AuditLogs/Widgets.js.map +1 -1
  79. package/dist/admin/ee/admin/src/components/AuditLogs/Widgets.mjs +2 -2
  80. package/dist/admin/ee/admin/src/components/AuditLogs/Widgets.mjs.map +1 -1
  81. package/dist/admin/index.js +6 -2
  82. package/dist/admin/index.js.map +1 -1
  83. package/dist/admin/index.mjs +2 -0
  84. package/dist/admin/index.mjs.map +1 -1
  85. package/dist/admin/src/components/GuidedTour/Context.d.ts +28 -10
  86. package/dist/admin/src/components/GuidedTour/Steps/ApiTokensSteps.d.ts +20 -0
  87. package/dist/admin/src/components/GuidedTour/Steps/ContentManagerSteps.d.ts +21 -0
  88. package/dist/admin/src/components/GuidedTour/Steps/ContentTypeBuilderSteps.d.ts +30 -0
  89. package/dist/admin/src/components/GuidedTour/{Step.d.ts → Steps/Step.d.ts} +25 -6
  90. package/dist/admin/src/components/GuidedTour/Tours.d.ts +53 -14
  91. package/dist/admin/src/components/GuidedTour/utils/constants.d.ts +15 -0
  92. package/dist/admin/src/components/GuidedTour/utils/migrations.d.ts +6 -0
  93. package/dist/admin/src/features/Tracking.d.ts +23 -4
  94. package/dist/admin/src/index.d.ts +5 -0
  95. package/dist/admin/src/pages/Home/HomePage.d.ts +2 -2
  96. package/dist/server/server/src/controllers/admin.js +2 -5
  97. package/dist/server/server/src/controllers/admin.js.map +1 -1
  98. package/dist/server/server/src/controllers/admin.mjs +2 -5
  99. package/dist/server/server/src/controllers/admin.mjs.map +1 -1
  100. package/dist/server/server/src/services/index.js +0 -2
  101. package/dist/server/server/src/services/index.js.map +1 -1
  102. package/dist/server/server/src/services/index.mjs +0 -2
  103. package/dist/server/server/src/services/index.mjs.map +1 -1
  104. package/dist/server/src/controllers/admin.d.ts +1 -1
  105. package/dist/server/src/controllers/admin.d.ts.map +1 -1
  106. package/dist/server/src/controllers/index.d.ts +1 -1
  107. package/dist/server/src/index.d.ts +1 -6
  108. package/dist/server/src/index.d.ts.map +1 -1
  109. package/dist/server/src/services/constants.d.ts +1 -0
  110. package/dist/server/src/services/guided-tour.d.ts +2 -3
  111. package/dist/server/src/services/guided-tour.d.ts.map +1 -1
  112. package/dist/server/src/services/index.d.ts +0 -5
  113. package/dist/server/src/services/index.d.ts.map +1 -1
  114. package/dist/shared/contracts/admin.d.ts +2 -2
  115. package/dist/shared/contracts/admin.d.ts.map +1 -1
  116. package/package.json +7 -7
  117. package/dist/admin/admin/src/components/GuidedTour/Step.js.map +0 -1
  118. package/dist/admin/admin/src/components/GuidedTour/Step.mjs.map +0 -1
  119. package/dist/server/server/src/services/guided-tour.js +0 -61
  120. package/dist/server/server/src/services/guided-tour.js.map +0 -1
  121. package/dist/server/server/src/services/guided-tour.mjs +0 -59
  122. package/dist/server/server/src/services/guided-tour.mjs.map +0 -1
@@ -1,329 +1,27 @@
1
1
  import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
2
2
  import * as React from 'react';
3
- import { Box, Portal, Popover, Button } from '@strapi/design-system';
4
- import { FormattedMessage } from 'react-intl';
3
+ import { Box, Portal, Popover } from '@strapi/design-system';
5
4
  import { styled } from 'styled-components';
6
5
  import { useGetGuidedTourMetaQuery } from '../../services/admin.mjs';
7
6
  import { useGuidedTour } from './Context.mjs';
8
- import { StepCount, createStepComponents } from './Step.mjs';
7
+ import { apiTokensSteps } from './Steps/ApiTokensSteps.mjs';
8
+ import { contentManagerSteps } from './Steps/ContentManagerSteps.mjs';
9
+ import { contentTypeBuilderSteps } from './Steps/ContentTypeBuilderSteps.mjs';
10
+ import { createStepComponents } from './Steps/Step.mjs';
11
+ import { GUIDED_TOUR_REQUIRED_ACTIONS } from './utils/constants.mjs';
9
12
 
10
13
  /* -------------------------------------------------------------------------------------------------
11
14
  * Tours
12
- * -----------------------------------------------------------------------------------------------*/ const GotItAction = ({ onClick })=>{
13
- return /*#__PURE__*/ jsx(Button, {
14
- onClick: onClick,
15
- children: /*#__PURE__*/ jsx(FormattedMessage, {
16
- id: "tours.gotIt",
17
- defaultMessage: "Got it"
18
- })
19
- });
20
- };
21
- const tours = {
22
- contentTypeBuilder: createTour('contentTypeBuilder', [
23
- {
24
- name: 'Introduction',
25
- content: (Step)=>/*#__PURE__*/ jsxs(Step.Root, {
26
- side: "bottom",
27
- sideOffset: 33,
28
- withArrow: false,
29
- children: [
30
- /*#__PURE__*/ jsx(Step.Title, {
31
- id: "tours.contentTypeBuilder.Introduction.title",
32
- defaultMessage: "Content-Type Builder"
33
- }),
34
- /*#__PURE__*/ jsx(Step.Content, {
35
- id: "tours.contentTypeBuilder.Introduction.content",
36
- defaultMessage: "Create and manage your content structure with collection types, single types and components."
37
- }),
38
- /*#__PURE__*/ jsx(Step.Actions, {
39
- showSkip: true
40
- })
41
- ]
42
- })
43
- },
44
- {
45
- name: 'CollectionTypes',
46
- content: (Step)=>/*#__PURE__*/ jsxs(Step.Root, {
47
- side: "right",
48
- sideOffset: 16,
49
- children: [
50
- /*#__PURE__*/ jsx(Step.Title, {
51
- id: "tours.contentTypeBuilder.CollectionTypes.title",
52
- defaultMessage: "Collection Types"
53
- }),
54
- /*#__PURE__*/ jsx(Step.Content, {
55
- id: "tours.contentTypeBuilder.CollectionTypes.content",
56
- defaultMessage: "A content structure that can manage multiple entries, such as articles or products."
57
- }),
58
- /*#__PURE__*/ jsx(Step.Actions, {})
59
- ]
60
- })
61
- },
62
- {
63
- name: 'SingleTypes',
64
- content: (Step)=>/*#__PURE__*/ jsxs(Step.Root, {
65
- side: "right",
66
- sideOffset: 16,
67
- children: [
68
- /*#__PURE__*/ jsx(Step.Title, {
69
- id: "tours.contentTypeBuilder.SingleTypes.title",
70
- defaultMessage: "Single Types"
71
- }),
72
- /*#__PURE__*/ jsx(Step.Content, {
73
- id: "tours.contentTypeBuilder.SingleTypes.content",
74
- defaultMessage: "A content structure that can manage a single entry, such as a homepage or a header."
75
- }),
76
- /*#__PURE__*/ jsx(Step.Actions, {})
77
- ]
78
- })
79
- },
80
- {
81
- name: 'Components',
82
- content: (Step, { dispatch })=>/*#__PURE__*/ jsxs(Step.Root, {
83
- side: "right",
84
- sideOffset: 16,
85
- children: [
86
- /*#__PURE__*/ jsx(Step.Title, {
87
- id: "tours.contentTypeBuilder.Components.title",
88
- defaultMessage: "Components"
89
- }),
90
- /*#__PURE__*/ jsx(Step.Content, {
91
- id: "tours.contentTypeBuilder.Components.content",
92
- defaultMessage: "A reusable content structure that can be used across multiple content types, such as buttons, sliders or cards."
93
- }),
94
- /*#__PURE__*/ jsxs(Step.Actions, {
95
- children: [
96
- /*#__PURE__*/ jsx(StepCount, {
97
- tourName: "contentTypeBuilder"
98
- }),
99
- /*#__PURE__*/ jsx(GotItAction, {
100
- onClick: ()=>dispatch({
101
- type: 'next_step',
102
- payload: 'contentTypeBuilder'
103
- })
104
- })
105
- ]
106
- })
107
- ]
108
- })
109
- },
110
- {
111
- name: 'Finish',
112
- content: (Step)=>/*#__PURE__*/ jsxs(Step.Root, {
113
- side: "right",
114
- children: [
115
- /*#__PURE__*/ jsx(Step.Title, {
116
- id: "tours.contentTypeBuilder.Finish.title",
117
- defaultMessage: "It's time to create content!"
118
- }),
119
- /*#__PURE__*/ jsx(Step.Content, {
120
- id: "tours.contentTypeBuilder.Finish.content",
121
- defaultMessage: "Now that you created content types, you'll be able to create content in the content manager."
122
- }),
123
- /*#__PURE__*/ jsx(Step.Actions, {
124
- showStepCount: false,
125
- to: "/content-manager"
126
- })
127
- ]
128
- }),
129
- when: (completedActions)=>completedActions.includes('didCreateContentTypeSchema')
130
- }
131
- ]),
132
- contentManager: createTour('contentManager', [
133
- {
134
- name: 'Introduction',
135
- when: (completedActions)=>completedActions.includes('didCreateContentTypeSchema'),
136
- content: (Step)=>/*#__PURE__*/ jsxs(Step.Root, {
137
- side: "top",
138
- sideOffset: 33,
139
- withArrow: false,
140
- children: [
141
- /*#__PURE__*/ jsx(Step.Title, {
142
- id: "tours.contentManager.Introduction.title",
143
- defaultMessage: "Content manager"
144
- }),
145
- /*#__PURE__*/ jsx(Step.Content, {
146
- id: "tours.contentManager.Introduction.content",
147
- defaultMessage: "Create and manage content from your collection types and single types."
148
- }),
149
- /*#__PURE__*/ jsx(Step.Actions, {
150
- showSkip: true
151
- })
152
- ]
153
- })
154
- },
155
- {
156
- name: 'Fields',
157
- content: (Step)=>/*#__PURE__*/ jsxs(Step.Root, {
158
- sideOffset: -12,
159
- children: [
160
- /*#__PURE__*/ jsx(Step.Title, {
161
- id: "tours.contentManager.Fields.title",
162
- defaultMessage: "Fields"
163
- }),
164
- /*#__PURE__*/ jsx(Step.Content, {
165
- id: "tours.contentManager.Fields.content",
166
- defaultMessage: "Add content to the fields created in the Content-Type Builder."
167
- }),
168
- /*#__PURE__*/ jsx(Step.Actions, {})
169
- ]
170
- })
171
- },
172
- {
173
- name: 'Publish',
174
- content: (Step, { dispatch })=>/*#__PURE__*/ jsxs(Step.Root, {
175
- side: "left",
176
- align: "center",
177
- children: [
178
- /*#__PURE__*/ jsx(Step.Title, {
179
- id: "tours.contentManager.Publish.title",
180
- defaultMessage: "Publish"
181
- }),
182
- /*#__PURE__*/ jsx(Step.Content, {
183
- id: "tours.contentManager.Publish.content",
184
- defaultMessage: "Publish entries to make their content available through the Document Service API."
185
- }),
186
- /*#__PURE__*/ jsxs(Step.Actions, {
187
- children: [
188
- /*#__PURE__*/ jsx(StepCount, {
189
- tourName: "contentManager"
190
- }),
191
- /*#__PURE__*/ jsx(GotItAction, {
192
- onClick: ()=>dispatch({
193
- type: 'next_step',
194
- payload: 'contentManager'
195
- })
196
- })
197
- ]
198
- })
199
- ]
200
- })
201
- },
202
- {
203
- name: 'Finish',
204
- content: (Step)=>/*#__PURE__*/ jsxs(Step.Root, {
205
- side: "right",
206
- children: [
207
- /*#__PURE__*/ jsx(Step.Title, {
208
- id: "tours.contentManager.FinalStep.title",
209
- defaultMessage: "It's time to create API Tokens!"
210
- }),
211
- /*#__PURE__*/ jsx(Step.Content, {
212
- id: "tours.contentManager.FinalStep.content",
213
- defaultMessage: "Now that you've created and published content, time to create API tokens and set up permissions."
214
- }),
215
- /*#__PURE__*/ jsx(Step.Actions, {
216
- showStepCount: false,
217
- to: "/settings/api-tokens"
218
- })
219
- ]
220
- }),
221
- when: (completedActions)=>completedActions.includes('didCreateContent')
222
- }
223
- ]),
224
- apiTokens: createTour('apiTokens', [
225
- {
226
- name: 'Introduction',
227
- content: (Step)=>/*#__PURE__*/ jsxs(Step.Root, {
228
- sideOffset: -36,
229
- withArrow: false,
230
- children: [
231
- /*#__PURE__*/ jsx(Step.Title, {
232
- id: "tours.apiTokens.Introduction.title",
233
- defaultMessage: "API tokens"
234
- }),
235
- /*#__PURE__*/ jsx(Step.Content, {
236
- id: "tours.apiTokens.Introduction.content",
237
- defaultMessage: "Create and manage API tokens with highly customizable permissions."
238
- }),
239
- /*#__PURE__*/ jsx(Step.Actions, {
240
- showSkip: true
241
- })
242
- ]
243
- })
244
- },
245
- {
246
- name: 'CreateAnAPIToken',
247
- content: (Step)=>/*#__PURE__*/ jsxs(Step.Root, {
248
- side: "bottom",
249
- align: "end",
250
- sideOffset: -10,
251
- children: [
252
- /*#__PURE__*/ jsx(Step.Title, {
253
- id: "tours.apiTokens.CreateAnAPIToken.title",
254
- defaultMessage: "Create an API token"
255
- }),
256
- /*#__PURE__*/ jsx(Step.Content, {
257
- id: "tours.apiTokens.CreateAnAPIToken.content",
258
- defaultMessage: "Create a new API token. Choose a name, duration and type."
259
- }),
260
- /*#__PURE__*/ jsx(Step.Actions, {})
261
- ]
262
- })
263
- },
264
- {
265
- name: 'CopyAPIToken',
266
- content: (Step, { dispatch })=>/*#__PURE__*/ jsxs(Step.Root, {
267
- side: "bottom",
268
- align: "start",
269
- sideOffset: -5,
270
- children: [
271
- /*#__PURE__*/ jsx(Step.Title, {
272
- id: "tours.apiTokens.CopyAPIToken.title",
273
- defaultMessage: "Copy your new API token"
274
- }),
275
- /*#__PURE__*/ jsx(Step.Content, {
276
- id: "tours.apiTokens.CopyAPIToken.content",
277
- defaultMessage: "Make sure to do it now, you won’t be able to see it again. You’ll need to generate a new one if you lose it."
278
- }),
279
- /*#__PURE__*/ jsxs(Step.Actions, {
280
- children: [
281
- /*#__PURE__*/ jsx(StepCount, {
282
- tourName: "apiTokens"
283
- }),
284
- /*#__PURE__*/ jsx(GotItAction, {
285
- onClick: ()=>dispatch({
286
- type: 'next_step',
287
- payload: 'apiTokens'
288
- })
289
- })
290
- ]
291
- })
292
- ]
293
- }),
294
- when: (completedActions)=>completedActions.includes('didCreateApiToken')
295
- },
296
- {
297
- name: 'Finish',
298
- content: (Step)=>/*#__PURE__*/ jsxs(Step.Root, {
299
- side: "right",
300
- align: "start",
301
- children: [
302
- /*#__PURE__*/ jsx(Step.Title, {
303
- id: "tours.apiTokens.FinalStep.title",
304
- defaultMessage: "It's time to deploy your application!"
305
- }),
306
- /*#__PURE__*/ jsx(Step.Content, {
307
- id: "tours.apiTokens.FinalStep.content",
308
- defaultMessage: "Your application is ready to be deployed and its content to be shared with the world!"
309
- }),
310
- /*#__PURE__*/ jsx(Step.Actions, {
311
- showStepCount: false,
312
- to: "/"
313
- })
314
- ]
315
- }),
316
- when: (completedActions)=>completedActions.includes('didCopyApiToken')
317
- }
318
- ]),
15
+ * -----------------------------------------------------------------------------------------------*/ const tours = {
16
+ contentTypeBuilder: createTour('contentTypeBuilder', contentTypeBuilderSteps),
17
+ contentManager: createTour('contentManager', contentManagerSteps),
18
+ apiTokens: createTour('apiTokens', apiTokensSteps),
319
19
  strapiCloud: createTour('strapiCloud', [])
320
20
  };
321
21
  const GuidedTourTooltip = ({ children, ...props })=>{
322
22
  const state = useGuidedTour('TooltipWrapper', (s)=>s.state);
323
23
  if (!state.enabled) {
324
- return /*#__PURE__*/ jsx(Fragment, {
325
- children: children
326
- });
24
+ return children;
327
25
  }
328
26
  return /*#__PURE__*/ jsx(GuidedTourTooltipImpl, {
329
27
  ...props,
@@ -357,17 +55,30 @@ const GuidedTourTooltipImpl = ({ children, content, tourName, step, when })=>{
357
55
  }, [
358
56
  isPopoverOpen
359
57
  ]);
360
- // TODO: This isn't great but the only solution for syncing the completed actions
58
+ const Step = React.useMemo(()=>createStepComponents(tourName), [
59
+ tourName
60
+ ]);
61
+ const hasApiSchema = Object.keys(guidedTourMeta?.data?.schemas ?? {}).filter((key)=>key.startsWith('api::')).length > 0;
361
62
  React.useEffect(()=>{
362
- dispatch({
363
- type: 'set_completed_actions',
364
- payload: guidedTourMeta?.data?.completedActions ?? []
365
- });
63
+ if (hasApiSchema) {
64
+ /**
65
+ * Fallback sync:
66
+ *
67
+ * When the user already has a schema (ie started project from template with seeded data),
68
+ * allow them to proceed to the content manager tour.
69
+ *
70
+ * When the CTB fails to restart after saving a schema (as it often does)
71
+ */ dispatch({
72
+ type: 'set_completed_actions',
73
+ payload: [
74
+ GUIDED_TOUR_REQUIRED_ACTIONS.contentTypeBuilder.createSchema
75
+ ]
76
+ });
77
+ }
366
78
  }, [
367
79
  dispatch,
368
- guidedTourMeta?.data?.completedActions
369
- ]);
370
- const Step = React.useMemo(()=>createStepComponents(tourName), [
80
+ hasApiSchema,
81
+ step,
371
82
  tourName
372
83
  ]);
373
84
  return /*#__PURE__*/ jsxs(Fragment, {
@@ -381,7 +92,8 @@ const GuidedTourTooltipImpl = ({ children, content, tourName, step, when })=>{
381
92
  /*#__PURE__*/ jsx(Popover.Anchor, {
382
93
  children: children
383
94
  }),
384
- content(Step, {
95
+ content({
96
+ Step,
385
97
  state,
386
98
  dispatch
387
99
  })
@@ -392,10 +104,11 @@ const GuidedTourTooltipImpl = ({ children, content, tourName, step, when })=>{
392
104
  };
393
105
  function createTour(tourName, steps) {
394
106
  const tour = steps.reduce((acc, step, index)=>{
395
- if (step.name in acc) {
107
+ const name = step.name;
108
+ if (name in acc) {
396
109
  throw Error(`The tour: ${tourName} with step: ${step.name} has already been registered`);
397
110
  }
398
- acc[step.name] = ({ children })=>{
111
+ acc[name] = ({ children })=>{
399
112
  return /*#__PURE__*/ jsx(GuidedTourTooltip, {
400
113
  tourName: tourName,
401
114
  step: index,
@@ -404,10 +117,19 @@ function createTour(tourName, steps) {
404
117
  children: children
405
118
  });
406
119
  };
120
+ if (step.excludeFromStepCount) {
121
+ // Subtract all steps registered to be excluded from the step count
122
+ acc._meta.displayedStepCount--;
123
+ }
407
124
  return acc;
408
- }, {});
125
+ }, {
126
+ _meta: {
127
+ totalStepCount: steps.length,
128
+ displayedStepCount: steps.length
129
+ }
130
+ });
409
131
  return tour;
410
132
  }
411
133
 
412
- export { tours };
134
+ export { createTour, tours };
413
135
  //# sourceMappingURL=Tours.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"Tours.mjs","sources":["../../../../../../admin/src/components/GuidedTour/Tours.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport { Box, Popover, Portal, Button } from '@strapi/design-system';\nimport { FormattedMessage } from 'react-intl';\nimport { styled } from 'styled-components';\n\nimport { useGetGuidedTourMetaQuery } from '../../services/admin';\n\nimport {\n type State,\n type Action,\n useGuidedTour,\n ValidTourName,\n ExtendedCompletedActions,\n} from './Context';\nimport { Step, StepCount, createStepComponents } from './Step';\n\n/* -------------------------------------------------------------------------------------------------\n * Tours\n * -----------------------------------------------------------------------------------------------*/\n\nconst GotItAction = ({ onClick }: { onClick: () => void }) => {\n return (\n <Button onClick={onClick}>\n <FormattedMessage id=\"tours.gotIt\" defaultMessage=\"Got it\" />\n </Button>\n );\n};\n\nconst tours = {\n contentTypeBuilder: createTour('contentTypeBuilder', [\n {\n name: 'Introduction',\n content: (Step) => (\n <Step.Root side=\"bottom\" sideOffset={33} withArrow={false}>\n <Step.Title\n id=\"tours.contentTypeBuilder.Introduction.title\"\n defaultMessage=\"Content-Type Builder\"\n />\n <Step.Content\n id=\"tours.contentTypeBuilder.Introduction.content\"\n defaultMessage=\"Create and manage your content structure with collection types, single types and components.\"\n />\n <Step.Actions showSkip />\n </Step.Root>\n ),\n },\n {\n name: 'CollectionTypes',\n content: (Step) => (\n <Step.Root side=\"right\" sideOffset={16}>\n <Step.Title\n id=\"tours.contentTypeBuilder.CollectionTypes.title\"\n defaultMessage=\"Collection Types\"\n />\n <Step.Content\n id=\"tours.contentTypeBuilder.CollectionTypes.content\"\n defaultMessage=\"A content structure that can manage multiple entries, such as articles or products.\"\n />\n <Step.Actions />\n </Step.Root>\n ),\n },\n {\n name: 'SingleTypes',\n content: (Step) => (\n <Step.Root side=\"right\" sideOffset={16}>\n <Step.Title\n id=\"tours.contentTypeBuilder.SingleTypes.title\"\n defaultMessage=\"Single Types\"\n />\n <Step.Content\n id=\"tours.contentTypeBuilder.SingleTypes.content\"\n defaultMessage=\"A content structure that can manage a single entry, such as a homepage or a header.\"\n />\n <Step.Actions />\n </Step.Root>\n ),\n },\n {\n name: 'Components',\n content: (Step, { dispatch }) => (\n <Step.Root side=\"right\" sideOffset={16}>\n <Step.Title id=\"tours.contentTypeBuilder.Components.title\" defaultMessage=\"Components\" />\n <Step.Content\n id=\"tours.contentTypeBuilder.Components.content\"\n defaultMessage=\"A reusable content structure that can be used across multiple content types, such as buttons, sliders or cards.\"\n />\n <Step.Actions>\n <StepCount tourName=\"contentTypeBuilder\" />\n <GotItAction\n onClick={() => dispatch({ type: 'next_step', payload: 'contentTypeBuilder' })}\n />\n </Step.Actions>\n </Step.Root>\n ),\n },\n {\n name: 'Finish',\n content: (Step) => (\n <Step.Root side=\"right\">\n <Step.Title\n id=\"tours.contentTypeBuilder.Finish.title\"\n defaultMessage=\"It's time to create content!\"\n />\n <Step.Content\n id=\"tours.contentTypeBuilder.Finish.content\"\n defaultMessage=\"Now that you created content types, you'll be able to create content in the content manager.\"\n />\n <Step.Actions showStepCount={false} to=\"/content-manager\" />\n </Step.Root>\n ),\n when: (completedActions) => completedActions.includes('didCreateContentTypeSchema'),\n },\n ]),\n contentManager: createTour('contentManager', [\n {\n name: 'Introduction',\n when: (completedActions) => completedActions.includes('didCreateContentTypeSchema'),\n content: (Step) => (\n <Step.Root side=\"top\" sideOffset={33} withArrow={false}>\n <Step.Title\n id=\"tours.contentManager.Introduction.title\"\n defaultMessage=\"Content manager\"\n />\n <Step.Content\n id=\"tours.contentManager.Introduction.content\"\n defaultMessage=\"Create and manage content from your collection types and single types.\"\n />\n <Step.Actions showSkip />\n </Step.Root>\n ),\n },\n {\n name: 'Fields',\n content: (Step) => (\n <Step.Root sideOffset={-12}>\n <Step.Title id=\"tours.contentManager.Fields.title\" defaultMessage=\"Fields\" />\n <Step.Content\n id=\"tours.contentManager.Fields.content\"\n defaultMessage=\"Add content to the fields created in the Content-Type Builder.\"\n />\n <Step.Actions />\n </Step.Root>\n ),\n },\n {\n name: 'Publish',\n content: (Step, { dispatch }) => (\n <Step.Root side=\"left\" align=\"center\">\n <Step.Title id=\"tours.contentManager.Publish.title\" defaultMessage=\"Publish\" />\n <Step.Content\n id=\"tours.contentManager.Publish.content\"\n defaultMessage=\"Publish entries to make their content available through the Document Service API.\"\n />\n <Step.Actions>\n <StepCount tourName=\"contentManager\" />\n <GotItAction\n onClick={() => dispatch({ type: 'next_step', payload: 'contentManager' })}\n />\n </Step.Actions>\n </Step.Root>\n ),\n },\n {\n name: 'Finish',\n content: (Step) => (\n <Step.Root side=\"right\">\n <Step.Title\n id=\"tours.contentManager.FinalStep.title\"\n defaultMessage=\"It's time to create API Tokens!\"\n />\n <Step.Content\n id=\"tours.contentManager.FinalStep.content\"\n defaultMessage=\"Now that you've created and published content, time to create API tokens and set up permissions.\"\n />\n <Step.Actions showStepCount={false} to=\"/settings/api-tokens\" />\n </Step.Root>\n ),\n when: (completedActions) => completedActions.includes('didCreateContent'),\n },\n ]),\n apiTokens: createTour('apiTokens', [\n {\n name: 'Introduction',\n content: (Step) => (\n <Step.Root sideOffset={-36} withArrow={false}>\n <Step.Title id=\"tours.apiTokens.Introduction.title\" defaultMessage=\"API tokens\" />\n <Step.Content\n id=\"tours.apiTokens.Introduction.content\"\n defaultMessage=\"Create and manage API tokens with highly customizable permissions.\"\n />\n <Step.Actions showSkip />\n </Step.Root>\n ),\n },\n {\n name: 'CreateAnAPIToken',\n content: (Step) => (\n <Step.Root side=\"bottom\" align=\"end\" sideOffset={-10}>\n <Step.Title\n id=\"tours.apiTokens.CreateAnAPIToken.title\"\n defaultMessage=\"Create an API token\"\n />\n <Step.Content\n id=\"tours.apiTokens.CreateAnAPIToken.content\"\n defaultMessage=\"Create a new API token. Choose a name, duration and type.\"\n />\n <Step.Actions />\n </Step.Root>\n ),\n },\n {\n name: 'CopyAPIToken',\n content: (Step, { dispatch }) => (\n <Step.Root side=\"bottom\" align=\"start\" sideOffset={-5}>\n <Step.Title\n id=\"tours.apiTokens.CopyAPIToken.title\"\n defaultMessage=\"Copy your new API token\"\n />\n <Step.Content\n id=\"tours.apiTokens.CopyAPIToken.content\"\n defaultMessage=\"Make sure to do it now, you won’t be able to see it again. You’ll need to generate a new one if you lose it.\"\n />\n <Step.Actions>\n <StepCount tourName=\"apiTokens\" />\n <GotItAction onClick={() => dispatch({ type: 'next_step', payload: 'apiTokens' })} />\n </Step.Actions>\n </Step.Root>\n ),\n when: (completedActions) => completedActions.includes('didCreateApiToken'),\n },\n {\n name: 'Finish',\n content: (Step) => (\n <Step.Root side=\"right\" align=\"start\">\n <Step.Title\n id=\"tours.apiTokens.FinalStep.title\"\n defaultMessage=\"It's time to deploy your application!\"\n />\n <Step.Content\n id=\"tours.apiTokens.FinalStep.content\"\n defaultMessage=\"Your application is ready to be deployed and its content to be shared with the world!\"\n />\n <Step.Actions showStepCount={false} to=\"/\" />\n </Step.Root>\n ),\n when: (completedActions) => completedActions.includes('didCopyApiToken'),\n },\n ]),\n strapiCloud: createTour('strapiCloud', []),\n} as const;\n\ntype Tours = typeof tours;\n\n/* -------------------------------------------------------------------------------------------------\n * GuidedTourTooltip\n * -----------------------------------------------------------------------------------------------*/\n\ntype Content = (\n Step: Step,\n {\n state,\n dispatch,\n }: {\n state: State;\n dispatch: React.Dispatch<Action>;\n }\n) => React.ReactNode;\n\ntype GuidedTourTooltipProps = {\n children: React.ReactNode;\n content: Content;\n tourName: ValidTourName;\n step: number;\n when?: (completedActions: ExtendedCompletedActions) => boolean;\n};\n\nconst GuidedTourTooltip = ({ children, ...props }: GuidedTourTooltipProps) => {\n const state = useGuidedTour('TooltipWrapper', (s) => s.state);\n\n if (!state.enabled) {\n return <>{children}</>;\n }\n\n return <GuidedTourTooltipImpl {...props}>{children}</GuidedTourTooltipImpl>;\n};\n\nconst GuidedTourOverlay = styled(Box)`\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background-color: rgba(50, 50, 77, 0.2);\n z-index: 10;\n`;\n\nconst GuidedTourTooltipImpl = ({\n children,\n content,\n tourName,\n step,\n when,\n}: GuidedTourTooltipProps) => {\n const { data: guidedTourMeta } = useGetGuidedTourMetaQuery();\n\n const state = useGuidedTour('GuidedTourTooltip', (s) => s.state);\n const dispatch = useGuidedTour('GuidedTourTooltip', (s) => s.dispatch);\n\n const isCurrentStep = state.tours[tourName].currentStep === step;\n const isStepConditionMet = when ? when(state.completedActions) : true;\n const isPopoverOpen =\n guidedTourMeta?.data?.isFirstSuperAdminUser &&\n !state.tours[tourName].isCompleted &&\n isCurrentStep &&\n isStepConditionMet;\n\n // Lock the scroll\n React.useEffect(() => {\n if (!isPopoverOpen) return;\n\n const originalStyle = window.getComputedStyle(document.body).overflow;\n document.body.style.overflow = 'hidden';\n\n return () => {\n document.body.style.overflow = originalStyle;\n };\n }, [isPopoverOpen]);\n\n // TODO: This isn't great but the only solution for syncing the completed actions\n React.useEffect(() => {\n dispatch({\n type: 'set_completed_actions',\n payload: guidedTourMeta?.data?.completedActions ?? [],\n });\n }, [dispatch, guidedTourMeta?.data?.completedActions]);\n\n const Step = React.useMemo(() => createStepComponents(tourName), [tourName]);\n\n return (\n <>\n {isPopoverOpen && (\n <Portal>\n <GuidedTourOverlay />\n </Portal>\n )}\n <Popover.Root open={isPopoverOpen}>\n <Popover.Anchor>{children}</Popover.Anchor>\n {content(Step, { state, dispatch })}\n </Popover.Root>\n </>\n );\n};\n\n/* -------------------------------------------------------------------------------------------------\n * Tour factory\n * -----------------------------------------------------------------------------------------------*/\n\ntype TourStep<P extends string> = {\n name: P;\n content: Content;\n when?: (completedActions: ExtendedCompletedActions) => boolean;\n};\n\nfunction createTour<const T extends ReadonlyArray<TourStep<string>>>(tourName: string, steps: T) {\n type Components = {\n [K in T[number]['name']]: React.ComponentType<{ children: React.ReactNode }>;\n };\n\n const tour = steps.reduce((acc, step, index) => {\n if (step.name in acc) {\n throw Error(`The tour: ${tourName} with step: ${step.name} has already been registered`);\n }\n\n acc[step.name as keyof Components] = ({ children }: { children: React.ReactNode }) => {\n return (\n <GuidedTourTooltip\n tourName={tourName as ValidTourName}\n step={index}\n content={step.content}\n when={step.when}\n >\n {children}\n </GuidedTourTooltip>\n );\n };\n\n return acc;\n }, {} as Components);\n\n return tour;\n}\n\nexport type { Content, Tours };\nexport { tours };\n"],"names":["GotItAction","onClick","_jsx","Button","FormattedMessage","id","defaultMessage","tours","contentTypeBuilder","createTour","name","content","Step","_jsxs","Root","side","sideOffset","withArrow","Title","Content","Actions","showSkip","dispatch","StepCount","tourName","type","payload","showStepCount","to","when","completedActions","includes","contentManager","align","apiTokens","strapiCloud","GuidedTourTooltip","children","props","state","useGuidedTour","s","enabled","_Fragment","GuidedTourTooltipImpl","GuidedTourOverlay","styled","Box","step","data","guidedTourMeta","useGetGuidedTourMetaQuery","isCurrentStep","currentStep","isStepConditionMet","isPopoverOpen","isFirstSuperAdminUser","isCompleted","React","useEffect","originalStyle","window","getComputedStyle","document","body","overflow","style","useMemo","createStepComponents","Portal","Popover","open","Anchor","steps","tour","reduce","acc","index","Error"],"mappings":"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"}
1
+ {"version":3,"file":"Tours.mjs","sources":["../../../../../../admin/src/components/GuidedTour/Tours.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport { Box, Popover, Portal } from '@strapi/design-system';\nimport { styled } from 'styled-components';\n\nimport { useGetGuidedTourMetaQuery } from '../../services/admin';\n\nimport { type State, type Action, useGuidedTour, ValidTourName, CompletedActions } from './Context';\nimport { apiTokensSteps } from './Steps/ApiTokensSteps';\nimport { contentManagerSteps } from './Steps/ContentManagerSteps';\nimport { contentTypeBuilderSteps } from './Steps/ContentTypeBuilderSteps';\nimport { type Step, createStepComponents } from './Steps/Step';\nimport { GUIDED_TOUR_REQUIRED_ACTIONS } from './utils/constants';\n\n/* -------------------------------------------------------------------------------------------------\n * Tours\n * -----------------------------------------------------------------------------------------------*/\n\nconst tours = {\n contentTypeBuilder: createTour('contentTypeBuilder', contentTypeBuilderSteps),\n contentManager: createTour('contentManager', contentManagerSteps),\n apiTokens: createTour('apiTokens', apiTokensSteps),\n strapiCloud: createTour('strapiCloud', []),\n} as const;\n\ntype Tours = typeof tours;\n\n/* -------------------------------------------------------------------------------------------------\n * GuidedTourTooltip\n * -----------------------------------------------------------------------------------------------*/\n\nexport type StepContentProps = {\n Step: Step;\n state: State;\n dispatch: React.Dispatch<Action>;\n};\ntype Content = (props: StepContentProps) => React.ReactNode;\n\ntype GuidedTourTooltipProps = {\n children: React.ReactNode;\n content: Content;\n tourName: ValidTourName;\n step: number;\n when?: (completedActions: CompletedActions) => boolean;\n};\n\nconst GuidedTourTooltip = ({ children, ...props }: GuidedTourTooltipProps) => {\n const state = useGuidedTour('TooltipWrapper', (s) => s.state);\n\n if (!state.enabled) {\n return children;\n }\n\n return <GuidedTourTooltipImpl {...props}>{children}</GuidedTourTooltipImpl>;\n};\n\nconst GuidedTourOverlay = styled(Box)`\n position: fixed;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background-color: rgba(50, 50, 77, 0.2);\n z-index: 10;\n`;\n\nconst GuidedTourTooltipImpl = ({\n children,\n content,\n tourName,\n step,\n when,\n}: GuidedTourTooltipProps) => {\n const { data: guidedTourMeta } = useGetGuidedTourMetaQuery();\n\n const state = useGuidedTour('GuidedTourTooltip', (s) => s.state);\n const dispatch = useGuidedTour('GuidedTourTooltip', (s) => s.dispatch);\n\n const isCurrentStep = state.tours[tourName].currentStep === step;\n const isStepConditionMet = when ? when(state.completedActions) : true;\n const isPopoverOpen =\n guidedTourMeta?.data?.isFirstSuperAdminUser &&\n !state.tours[tourName].isCompleted &&\n isCurrentStep &&\n isStepConditionMet;\n\n // Lock the scroll\n React.useEffect(() => {\n if (!isPopoverOpen) return;\n\n const originalStyle = window.getComputedStyle(document.body).overflow;\n document.body.style.overflow = 'hidden';\n\n return () => {\n document.body.style.overflow = originalStyle;\n };\n }, [isPopoverOpen]);\n\n const Step = React.useMemo(() => createStepComponents(tourName), [tourName]);\n\n const hasApiSchema =\n Object.keys(guidedTourMeta?.data?.schemas ?? {}).filter((key) => key.startsWith('api::'))\n .length > 0;\n\n React.useEffect(() => {\n if (hasApiSchema) {\n /**\n * Fallback sync:\n *\n * When the user already has a schema (ie started project from template with seeded data),\n * allow them to proceed to the content manager tour.\n *\n * When the CTB fails to restart after saving a schema (as it often does)\n */\n dispatch({\n type: 'set_completed_actions',\n payload: [GUIDED_TOUR_REQUIRED_ACTIONS.contentTypeBuilder.createSchema],\n });\n }\n }, [dispatch, hasApiSchema, step, tourName]);\n\n return (\n <>\n {isPopoverOpen && (\n <Portal>\n <GuidedTourOverlay />\n </Portal>\n )}\n <Popover.Root open={isPopoverOpen}>\n <Popover.Anchor>{children}</Popover.Anchor>\n {content({ Step, state, dispatch })}\n </Popover.Root>\n </>\n );\n};\n\n/* -------------------------------------------------------------------------------------------------\n * Tour factory\n * -----------------------------------------------------------------------------------------------*/\n\nexport type TourStep<P extends string> = {\n name: P;\n content: Content;\n when?: (completedActions: CompletedActions) => boolean;\n excludeFromStepCount?: boolean;\n};\n\nexport function createTour<const T extends ReadonlyArray<TourStep<string>>>(\n tourName: string,\n steps: T\n) {\n type Components = {\n [K in T[number]['name']]: React.ComponentType<{ children: React.ReactNode }>;\n };\n\n const tour = steps.reduce(\n (acc, step, index) => {\n const name = step.name as keyof Components;\n\n if (name in acc) {\n throw Error(`The tour: ${tourName} with step: ${step.name} has already been registered`);\n }\n\n (acc as Components)[name] = ({ children }: { children: React.ReactNode }) => {\n return (\n <GuidedTourTooltip\n tourName={tourName as ValidTourName}\n step={index}\n content={step.content}\n when={step.when}\n >\n {children}\n </GuidedTourTooltip>\n );\n };\n\n if (step.excludeFromStepCount) {\n // Subtract all steps registered to be excluded from the step count\n acc._meta.displayedStepCount--;\n }\n\n return acc;\n },\n { _meta: { totalStepCount: steps.length, displayedStepCount: steps.length } } as Components & {\n _meta: { totalStepCount: number; displayedStepCount: number };\n }\n );\n\n return tour;\n}\n\nexport type { Content, Tours };\nexport { tours };\n"],"names":["tours","contentTypeBuilder","createTour","contentTypeBuilderSteps","contentManager","contentManagerSteps","apiTokens","apiTokensSteps","strapiCloud","GuidedTourTooltip","children","props","state","useGuidedTour","s","enabled","_jsx","GuidedTourTooltipImpl","GuidedTourOverlay","styled","Box","content","tourName","step","when","data","guidedTourMeta","useGetGuidedTourMetaQuery","dispatch","isCurrentStep","currentStep","isStepConditionMet","completedActions","isPopoverOpen","isFirstSuperAdminUser","isCompleted","React","useEffect","originalStyle","window","getComputedStyle","document","body","overflow","style","Step","useMemo","createStepComponents","hasApiSchema","Object","keys","schemas","filter","key","startsWith","length","type","payload","GUIDED_TOUR_REQUIRED_ACTIONS","createSchema","_jsxs","_Fragment","Portal","Popover","Root","open","Anchor","steps","tour","reduce","acc","index","name","Error","excludeFromStepCount","_meta","displayedStepCount","totalStepCount"],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ 'use strict';
2
+
3
+ const GUIDED_TOUR_REQUIRED_ACTIONS = {
4
+ contentTypeBuilder: {
5
+ createSchema: 'didCreateContentTypeSchema',
6
+ addField: 'didAddFieldToSchema'
7
+ },
8
+ contentManager: {
9
+ createContent: 'didCreateContent'
10
+ },
11
+ apiTokens: {
12
+ createToken: 'didCreateApiToken',
13
+ copyToken: 'didCopyApiToken'
14
+ },
15
+ strapiCloud: {}
16
+ };
17
+
18
+ exports.GUIDED_TOUR_REQUIRED_ACTIONS = GUIDED_TOUR_REQUIRED_ACTIONS;
19
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sources":["../../../../../../../admin/src/components/GuidedTour/utils/constants.ts"],"sourcesContent":["const GUIDED_TOUR_REQUIRED_ACTIONS = {\n contentTypeBuilder: {\n createSchema: 'didCreateContentTypeSchema',\n addField: 'didAddFieldToSchema',\n },\n contentManager: {\n createContent: 'didCreateContent',\n },\n apiTokens: {\n createToken: 'didCreateApiToken',\n copyToken: 'didCopyApiToken',\n },\n strapiCloud: {},\n} as const;\n\nexport { GUIDED_TOUR_REQUIRED_ACTIONS };\n"],"names":["GUIDED_TOUR_REQUIRED_ACTIONS","contentTypeBuilder","createSchema","addField","contentManager","createContent","apiTokens","createToken","copyToken","strapiCloud"],"mappings":";;AAAA,MAAMA,4BAA+B,GAAA;IACnCC,kBAAoB,EAAA;QAClBC,YAAc,EAAA,4BAAA;QACdC,QAAU,EAAA;AACZ,KAAA;IACAC,cAAgB,EAAA;QACdC,aAAe,EAAA;AACjB,KAAA;IACAC,SAAW,EAAA;QACTC,WAAa,EAAA,mBAAA;QACbC,SAAW,EAAA;AACb,KAAA;AACAC,IAAAA,WAAAA,EAAa;AACf;;;;"}
@@ -0,0 +1,17 @@
1
+ const GUIDED_TOUR_REQUIRED_ACTIONS = {
2
+ contentTypeBuilder: {
3
+ createSchema: 'didCreateContentTypeSchema',
4
+ addField: 'didAddFieldToSchema'
5
+ },
6
+ contentManager: {
7
+ createContent: 'didCreateContent'
8
+ },
9
+ apiTokens: {
10
+ createToken: 'didCreateApiToken',
11
+ copyToken: 'didCopyApiToken'
12
+ },
13
+ strapiCloud: {}
14
+ };
15
+
16
+ export { GUIDED_TOUR_REQUIRED_ACTIONS };
17
+ //# sourceMappingURL=constants.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.mjs","sources":["../../../../../../../admin/src/components/GuidedTour/utils/constants.ts"],"sourcesContent":["const GUIDED_TOUR_REQUIRED_ACTIONS = {\n contentTypeBuilder: {\n createSchema: 'didCreateContentTypeSchema',\n addField: 'didAddFieldToSchema',\n },\n contentManager: {\n createContent: 'didCreateContent',\n },\n apiTokens: {\n createToken: 'didCreateApiToken',\n copyToken: 'didCopyApiToken',\n },\n strapiCloud: {},\n} as const;\n\nexport { GUIDED_TOUR_REQUIRED_ACTIONS };\n"],"names":["GUIDED_TOUR_REQUIRED_ACTIONS","contentTypeBuilder","createSchema","addField","contentManager","createContent","apiTokens","createToken","copyToken","strapiCloud"],"mappings":"AAAA,MAAMA,4BAA+B,GAAA;IACnCC,kBAAoB,EAAA;QAClBC,YAAc,EAAA,4BAAA;QACdC,QAAU,EAAA;AACZ,KAAA;IACAC,cAAgB,EAAA;QACdC,aAAe,EAAA;AACjB,KAAA;IACAC,SAAW,EAAA;QACTC,WAAa,EAAA,mBAAA;QACbC,SAAW,EAAA;AACb,KAAA;AACAC,IAAAA,WAAAA,EAAa;AACf;;;;"}
@@ -0,0 +1,31 @@
1
+ 'use strict';
2
+
3
+ var immer = require('immer');
4
+ var Tours = require('../Tours.js');
5
+
6
+ /**
7
+ * Migrates tours added or removed from the tours object
8
+ */ const migrateTours = (storedTourState)=>{
9
+ const storedTourNames = Object.keys(storedTourState.tours);
10
+ const currentTourNames = Object.keys(Tours.tours);
11
+ return immer.produce(storedTourState, (draft)=>{
12
+ // Add new tours that don't exist in stored state
13
+ currentTourNames.forEach((tourName)=>{
14
+ if (!storedTourNames.includes(tourName)) {
15
+ draft.tours[tourName] = {
16
+ currentStep: 0,
17
+ isCompleted: false
18
+ };
19
+ }
20
+ });
21
+ // Remove tours that no longer exist in current tours
22
+ storedTourNames.forEach((tourName)=>{
23
+ if (!currentTourNames.includes(tourName)) {
24
+ delete draft.tours[tourName];
25
+ }
26
+ });
27
+ });
28
+ };
29
+
30
+ exports.migrateTours = migrateTours;
31
+ //# sourceMappingURL=migrations.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"migrations.js","sources":["../../../../../../../admin/src/components/GuidedTour/utils/migrations.ts"],"sourcesContent":["import { produce } from 'immer';\n\nimport { tours } from '../Tours';\n\nimport type { State, ValidTourName } from '../Context';\n\n/**\n * Migrates tours added or removed from the tours object\n */\nconst migrateTours = (storedTourState: State) => {\n const storedTourNames = Object.keys(storedTourState.tours) as ValidTourName[];\n const currentTourNames = Object.keys(tours) as ValidTourName[];\n\n return produce(storedTourState, (draft) => {\n // Add new tours that don't exist in stored state\n currentTourNames.forEach((tourName) => {\n if (!storedTourNames.includes(tourName)) {\n draft.tours[tourName] = {\n currentStep: 0,\n isCompleted: false,\n };\n }\n });\n\n // Remove tours that no longer exist in current tours\n storedTourNames.forEach((tourName) => {\n if (!currentTourNames.includes(tourName)) {\n delete draft.tours[tourName];\n }\n });\n });\n};\n\nexport { migrateTours };\n"],"names":["migrateTours","storedTourState","storedTourNames","Object","keys","tours","currentTourNames","produce","draft","forEach","tourName","includes","currentStep","isCompleted"],"mappings":";;;;;AAMA;;IAGA,MAAMA,eAAe,CAACC,eAAAA,GAAAA;AACpB,IAAA,MAAMC,eAAkBC,GAAAA,MAAAA,CAAOC,IAAI,CAACH,gBAAgBI,KAAK,CAAA;IACzD,MAAMC,gBAAAA,GAAmBH,MAAOC,CAAAA,IAAI,CAACC,WAAAA,CAAAA;IAErC,OAAOE,aAAAA,CAAQN,iBAAiB,CAACO,KAAAA,GAAAA;;QAE/BF,gBAAiBG,CAAAA,OAAO,CAAC,CAACC,QAAAA,GAAAA;AACxB,YAAA,IAAI,CAACR,eAAAA,CAAgBS,QAAQ,CAACD,QAAW,CAAA,EAAA;gBACvCF,KAAMH,CAAAA,KAAK,CAACK,QAAAA,CAAS,GAAG;oBACtBE,WAAa,EAAA,CAAA;oBACbC,WAAa,EAAA;AACf,iBAAA;AACF;AACF,SAAA,CAAA;;QAGAX,eAAgBO,CAAAA,OAAO,CAAC,CAACC,QAAAA,GAAAA;AACvB,YAAA,IAAI,CAACJ,gBAAAA,CAAiBK,QAAQ,CAACD,QAAW,CAAA,EAAA;gBACxC,OAAOF,KAAAA,CAAMH,KAAK,CAACK,QAAS,CAAA;AAC9B;AACF,SAAA,CAAA;AACF,KAAA,CAAA;AACF;;;;"}
@@ -0,0 +1,29 @@
1
+ import { produce } from 'immer';
2
+ import { tours } from '../Tours.mjs';
3
+
4
+ /**
5
+ * Migrates tours added or removed from the tours object
6
+ */ const migrateTours = (storedTourState)=>{
7
+ const storedTourNames = Object.keys(storedTourState.tours);
8
+ const currentTourNames = Object.keys(tours);
9
+ return produce(storedTourState, (draft)=>{
10
+ // Add new tours that don't exist in stored state
11
+ currentTourNames.forEach((tourName)=>{
12
+ if (!storedTourNames.includes(tourName)) {
13
+ draft.tours[tourName] = {
14
+ currentStep: 0,
15
+ isCompleted: false
16
+ };
17
+ }
18
+ });
19
+ // Remove tours that no longer exist in current tours
20
+ storedTourNames.forEach((tourName)=>{
21
+ if (!currentTourNames.includes(tourName)) {
22
+ delete draft.tours[tourName];
23
+ }
24
+ });
25
+ });
26
+ };
27
+
28
+ export { migrateTours };
29
+ //# sourceMappingURL=migrations.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"migrations.mjs","sources":["../../../../../../../admin/src/components/GuidedTour/utils/migrations.ts"],"sourcesContent":["import { produce } from 'immer';\n\nimport { tours } from '../Tours';\n\nimport type { State, ValidTourName } from '../Context';\n\n/**\n * Migrates tours added or removed from the tours object\n */\nconst migrateTours = (storedTourState: State) => {\n const storedTourNames = Object.keys(storedTourState.tours) as ValidTourName[];\n const currentTourNames = Object.keys(tours) as ValidTourName[];\n\n return produce(storedTourState, (draft) => {\n // Add new tours that don't exist in stored state\n currentTourNames.forEach((tourName) => {\n if (!storedTourNames.includes(tourName)) {\n draft.tours[tourName] = {\n currentStep: 0,\n isCompleted: false,\n };\n }\n });\n\n // Remove tours that no longer exist in current tours\n storedTourNames.forEach((tourName) => {\n if (!currentTourNames.includes(tourName)) {\n delete draft.tours[tourName];\n }\n });\n });\n};\n\nexport { migrateTours };\n"],"names":["migrateTours","storedTourState","storedTourNames","Object","keys","tours","currentTourNames","produce","draft","forEach","tourName","includes","currentStep","isCompleted"],"mappings":";;;AAMA;;IAGA,MAAMA,eAAe,CAACC,eAAAA,GAAAA;AACpB,IAAA,MAAMC,eAAkBC,GAAAA,MAAAA,CAAOC,IAAI,CAACH,gBAAgBI,KAAK,CAAA;IACzD,MAAMC,gBAAAA,GAAmBH,MAAOC,CAAAA,IAAI,CAACC,KAAAA,CAAAA;IAErC,OAAOE,OAAAA,CAAQN,iBAAiB,CAACO,KAAAA,GAAAA;;QAE/BF,gBAAiBG,CAAAA,OAAO,CAAC,CAACC,QAAAA,GAAAA;AACxB,YAAA,IAAI,CAACR,eAAAA,CAAgBS,QAAQ,CAACD,QAAW,CAAA,EAAA;gBACvCF,KAAMH,CAAAA,KAAK,CAACK,QAAAA,CAAS,GAAG;oBACtBE,WAAa,EAAA,CAAA;oBACbC,WAAa,EAAA;AACf,iBAAA;AACF;AACF,SAAA,CAAA;;QAGAX,eAAgBO,CAAAA,OAAO,CAAC,CAACC,QAAAA,GAAAA;AACvB,YAAA,IAAI,CAACJ,gBAAAA,CAAiBK,QAAQ,CAACD,QAAW,CAAA,EAAA;gBACxC,OAAOF,KAAAA,CAAMH,KAAK,CAACK,QAAS,CAAA;AAC9B;AACF,SAAA,CAAA;AACF,KAAA,CAAA;AACF;;;;"}
@@ -132,7 +132,9 @@ const Sections = ({ children, ...props })=>{
132
132
  switch(sectionId){
133
133
  case 'models':
134
134
  return /*#__PURE__*/ jsxRuntime.jsx(Tours.tours.contentTypeBuilder.CollectionTypes, {
135
- children: children
135
+ children: /*#__PURE__*/ jsxRuntime.jsx(Tours.tours.contentTypeBuilder.YourTurn, {
136
+ children: children
137
+ })
136
138
  });
137
139
  case 'singleTypes':
138
140
  return /*#__PURE__*/ jsxRuntime.jsx(Tours.tours.contentTypeBuilder.SingleTypes, {