@strapi/strapi 5.42.1 → 5.44.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 (83) hide show
  1. package/dist/cli/commands/admin/active-user.d.ts +15 -0
  2. package/dist/cli/commands/admin/active-user.d.ts.map +1 -0
  3. package/dist/cli/commands/admin/block-user.d.ts +15 -0
  4. package/dist/cli/commands/admin/block-user.d.ts.map +1 -0
  5. package/dist/cli/commands/admin/delete-user.d.ts +14 -0
  6. package/dist/cli/commands/admin/delete-user.d.ts.map +1 -0
  7. package/dist/cli/commands/admin/list-users.d.ts +11 -0
  8. package/dist/cli/commands/admin/list-users.d.ts.map +1 -0
  9. package/dist/cli/commands/export/action.d.ts.map +1 -1
  10. package/dist/cli/commands/import/action.d.ts.map +1 -1
  11. package/dist/cli/commands/index.d.ts.map +1 -1
  12. package/dist/cli/commands/transfer/action.d.ts +1 -0
  13. package/dist/cli/commands/transfer/action.d.ts.map +1 -1
  14. package/dist/cli/commands/transfer/command.d.ts.map +1 -1
  15. package/dist/cli/utils/data-transfer.d.ts +6 -4
  16. package/dist/cli/utils/data-transfer.d.ts.map +1 -1
  17. package/dist/cli/utils/helpers.d.ts +15 -1
  18. package/dist/cli/utils/helpers.d.ts.map +1 -1
  19. package/dist/node/build.d.ts.map +1 -1
  20. package/dist/node/develop.d.ts.map +1 -1
  21. package/dist/package.json.js +1 -1
  22. package/dist/package.json.mjs +1 -1
  23. package/dist/src/cli/commands/admin/active-user.js +73 -0
  24. package/dist/src/cli/commands/admin/active-user.js.map +1 -0
  25. package/dist/src/cli/commands/admin/active-user.mjs +70 -0
  26. package/dist/src/cli/commands/admin/active-user.mjs.map +1 -0
  27. package/dist/src/cli/commands/admin/block-user.js +73 -0
  28. package/dist/src/cli/commands/admin/block-user.js.map +1 -0
  29. package/dist/src/cli/commands/admin/block-user.mjs +70 -0
  30. package/dist/src/cli/commands/admin/block-user.mjs.map +1 -0
  31. package/dist/src/cli/commands/admin/delete-user.js +88 -0
  32. package/dist/src/cli/commands/admin/delete-user.js.map +1 -0
  33. package/dist/src/cli/commands/admin/delete-user.mjs +85 -0
  34. package/dist/src/cli/commands/admin/delete-user.mjs.map +1 -0
  35. package/dist/src/cli/commands/admin/list-users.js +62 -0
  36. package/dist/src/cli/commands/admin/list-users.js.map +1 -0
  37. package/dist/src/cli/commands/admin/list-users.mjs +59 -0
  38. package/dist/src/cli/commands/admin/list-users.mjs.map +1 -0
  39. package/dist/src/cli/commands/export/action.js +2 -2
  40. package/dist/src/cli/commands/export/action.js.map +1 -1
  41. package/dist/src/cli/commands/export/action.mjs +3 -3
  42. package/dist/src/cli/commands/export/action.mjs.map +1 -1
  43. package/dist/src/cli/commands/import/action.js +3 -3
  44. package/dist/src/cli/commands/import/action.js.map +1 -1
  45. package/dist/src/cli/commands/import/action.mjs +4 -4
  46. package/dist/src/cli/commands/import/action.mjs.map +1 -1
  47. package/dist/src/cli/commands/index.js +8 -0
  48. package/dist/src/cli/commands/index.js.map +1 -1
  49. package/dist/src/cli/commands/index.mjs +34 -26
  50. package/dist/src/cli/commands/index.mjs.map +1 -1
  51. package/dist/src/cli/commands/transfer/action.js +105 -6
  52. package/dist/src/cli/commands/transfer/action.js.map +1 -1
  53. package/dist/src/cli/commands/transfer/action.mjs +107 -8
  54. package/dist/src/cli/commands/transfer/action.mjs.map +1 -1
  55. package/dist/src/cli/commands/transfer/command.js +1 -1
  56. package/dist/src/cli/commands/transfer/command.js.map +1 -1
  57. package/dist/src/cli/commands/transfer/command.mjs +1 -1
  58. package/dist/src/cli/commands/transfer/command.mjs.map +1 -1
  59. package/dist/src/cli/utils/data-transfer.js +69 -21
  60. package/dist/src/cli/utils/data-transfer.js.map +1 -1
  61. package/dist/src/cli/utils/data-transfer.mjs +70 -22
  62. package/dist/src/cli/utils/data-transfer.mjs.map +1 -1
  63. package/dist/src/cli/utils/helpers.js +36 -1
  64. package/dist/src/cli/utils/helpers.js.map +1 -1
  65. package/dist/src/cli/utils/helpers.mjs +34 -2
  66. package/dist/src/cli/utils/helpers.mjs.map +1 -1
  67. package/dist/src/node/build.js +10 -5
  68. package/dist/src/node/build.js.map +1 -1
  69. package/dist/src/node/build.mjs +10 -5
  70. package/dist/src/node/build.mjs.map +1 -1
  71. package/dist/src/node/develop.js +194 -148
  72. package/dist/src/node/develop.js.map +1 -1
  73. package/dist/src/node/develop.mjs +194 -148
  74. package/dist/src/node/develop.mjs.map +1 -1
  75. package/dist/src/node/vite/config.js +2 -1
  76. package/dist/src/node/vite/config.js.map +1 -1
  77. package/dist/src/node/vite/config.mjs +2 -1
  78. package/dist/src/node/vite/config.mjs.map +1 -1
  79. package/dist/src/node/webpack/config.js +2 -2
  80. package/dist/src/node/webpack/config.js.map +1 -1
  81. package/dist/src/node/webpack/config.mjs +2 -2
  82. package/dist/src/node/webpack/config.mjs.map +1 -1
  83. package/package.json +28 -28
@@ -60,11 +60,16 @@ const develop = async ({ cwd, polling, logger, tsconfig, watchAdmin, buildAdmin,
60
60
  logger,
61
61
  timer
62
62
  });
63
- await tsUtils.compile(cwd, {
64
- configOptions: {
65
- ignoreDiagnostics: true
66
- }
67
- });
63
+ try {
64
+ await tsUtils.compile(cwd, {
65
+ configOptions: {
66
+ ignoreDiagnostics: true
67
+ }
68
+ });
69
+ } catch (err) {
70
+ logger.error(`Error during initial TypeScript compilation: ${err.message}`);
71
+ // We don't return here because we want to attempt to start the server even if the initial compilation fails, as it can be fixed while the server is running
72
+ }
68
73
  }
69
74
  /**
70
75
  * IF we're not watching the admin we're going to build it, this makes
@@ -102,17 +107,23 @@ const develop = async ({ cwd, polling, logger, tsconfig, watchAdmin, buildAdmin,
102
107
  case 'reload':
103
108
  {
104
109
  if (tsconfig?.config) {
105
- // Build without diagnostics in case schemas have changed
106
- await cleanupDistDirectory({
107
- tsconfig,
108
- logger,
109
- timer
110
- });
111
- await tsUtils.compile(cwd, {
112
- configOptions: {
113
- ignoreDiagnostics: true
114
- }
115
- });
110
+ try {
111
+ // Build without diagnostics in case schemas have changed
112
+ await cleanupDistDirectory({
113
+ tsconfig,
114
+ logger,
115
+ timer
116
+ });
117
+ await tsUtils.compile(cwd, {
118
+ configOptions: {
119
+ ignoreDiagnostics: true
120
+ }
121
+ });
122
+ } catch (err) {
123
+ const message = err instanceof Error ? err.message : String(err);
124
+ logger.error(`Error during TypeScript compilation on reload: ${message}`);
125
+ process.exit(1);
126
+ }
116
127
  }
117
128
  logger.debug('cluster has the reload message, sending the worker kill message');
118
129
  worker.send('kill');
@@ -147,145 +158,180 @@ const develop = async ({ cwd, polling, logger, tsconfig, watchAdmin, buildAdmin,
147
158
  * as a strapi middleware.
148
159
  */ let bundleWatcher;
149
160
  const strapiInstance = await strapi.load();
150
- if (watchAdmin) {
151
- timer.start('createBuildContext');
152
- const contextSpinner = logger.spinner(`Building build context`).start();
153
- console.log('');
154
- const ctx = await createBuildContext({
155
- cwd,
156
- logger,
157
- strapi,
158
- tsconfig,
159
- options
160
- });
161
- const contextDuration = timer.end('createBuildContext');
162
- contextSpinner.text = `Building build context (${prettyTime(contextDuration)})`;
163
- contextSpinner.succeed();
164
- timer.start('creatingAdmin');
165
- const adminSpinner = logger.spinner(`Creating admin`).start();
166
- await writeStaticClientFiles(ctx);
167
- if (ctx.bundler === 'webpack') {
168
- const { watch: watchWebpack } = await import('./webpack/watch.mjs');
169
- bundleWatcher = await watchWebpack(ctx);
170
- } else if (ctx.bundler === 'vite') {
171
- const { watch: watchVite } = await import('./vite/watch.mjs');
172
- bundleWatcher = await watchVite(ctx);
161
+ const contextSpinner = logger.spinner(`Building build context`);
162
+ const adminSpinner = logger.spinner(`Creating admin`);
163
+ const generatingTsSpinner = logger.spinner(`Generating types`);
164
+ const compilingTsSpinner = logger.spinner(`Compiling TS`);
165
+ let watcherStarted = false;
166
+ const ensureWatcher = ()=>{
167
+ if (!watcherStarted) {
168
+ watcherStarted = true;
169
+ startWatcher(strapiInstance, cwd, polling ?? false, logger, bundleWatcher);
173
170
  }
174
- const adminDuration = timer.end('creatingAdmin');
175
- adminSpinner.text = `Creating admin (${prettyTime(adminDuration)})`;
176
- adminSpinner.succeed();
177
- }
178
- const loadStrapiDuration = timer.end('loadStrapi');
179
- loadStrapiSpinner.text = `Loading Strapi (${prettyTime(loadStrapiDuration)})`;
180
- loadStrapiSpinner.succeed();
181
- // For TS projects, type generation is a requirement for the develop command so that the server can restart
182
- // For JS projects, we respect the experimental autogenerate setting
183
- if (tsconfig?.config || strapi.config.get('typescript.autogenerate') !== false) {
184
- timer.start('generatingTS');
185
- const generatingTsSpinner = logger.spinner(`Generating types`).start();
186
- await tsUtils.generators.generate({
187
- strapi: strapiInstance,
188
- pwd: cwd,
189
- rootDir: undefined,
190
- logger: {
191
- silent: true,
192
- debug: false
193
- },
194
- artifacts: {
195
- contentTypes: true,
196
- components: true
197
- }
198
- });
199
- const generatingDuration = timer.end('generatingTS');
200
- generatingTsSpinner.text = `Generating types (${prettyTime(generatingDuration)})`;
201
- generatingTsSpinner.succeed();
202
- }
203
- if (tsconfig?.config) {
204
- timer.start('compilingTS');
205
- const compilingTsSpinner = logger.spinner(`Compiling TS`).start();
206
- await cleanupDistDirectory({
207
- tsconfig,
208
- logger,
209
- timer
210
- });
211
- await tsUtils.compile(cwd, {
212
- configOptions: {
213
- ignoreDiagnostics: false
171
+ };
172
+ try {
173
+ if (watchAdmin) {
174
+ timer.start('createBuildContext');
175
+ contextSpinner.start();
176
+ const ctx = await createBuildContext({
177
+ cwd,
178
+ logger,
179
+ strapi,
180
+ tsconfig,
181
+ options
182
+ });
183
+ const contextDuration = timer.end('createBuildContext');
184
+ contextSpinner.text = `Building build context (${prettyTime(contextDuration)})`;
185
+ contextSpinner.succeed();
186
+ timer.start('creatingAdmin');
187
+ adminSpinner.start();
188
+ await writeStaticClientFiles(ctx);
189
+ if (ctx.bundler === 'webpack') {
190
+ const { watch: watchWebpack } = await import('./webpack/watch.mjs');
191
+ bundleWatcher = await watchWebpack(ctx);
192
+ } else if (ctx.bundler === 'vite') {
193
+ const { watch: watchVite } = await import('./vite/watch.mjs');
194
+ bundleWatcher = await watchVite(ctx);
214
195
  }
215
- });
216
- const compilingDuration = timer.end('compilingTS');
217
- compilingTsSpinner.text = `Compiling TS (${prettyTime(compilingDuration)})`;
218
- compilingTsSpinner.succeed();
219
- }
220
- const restart = async ()=>{
221
- if (strapiInstance.reload.isWatching && !strapiInstance.reload.isReloading) {
222
- strapiInstance.reload.isReloading = true;
223
- strapiInstance.reload();
196
+ const adminDuration = timer.end('creatingAdmin');
197
+ adminSpinner.text = `Creating admin (${prettyTime(adminDuration)})`;
198
+ adminSpinner.succeed();
224
199
  }
225
- };
226
- const watcher = chokidar.watch(cwd, {
227
- ignoreInitial: true,
228
- usePolling: polling,
229
- ignored: [
230
- /(^|[/\\])\../,
231
- /tmp/,
232
- '**/src/admin/**',
233
- '**/src/plugins/**/admin/**',
234
- '**/dist/src/plugins/test/admin/**',
235
- '**/documentation',
236
- '**/documentation/**',
237
- '**/node_modules',
238
- '**/node_modules/**',
239
- '**/plugins.json',
240
- '**/build',
241
- '**/build/**',
242
- '**/log',
243
- '**/log/**',
244
- '**/logs',
245
- '**/logs/**',
246
- '**/*.log',
247
- '**/index.html',
248
- '**/public',
249
- '**/public/**',
250
- strapiInstance.dirs.static.public,
251
- strings.joinBy('/', strapiInstance.dirs.static.public, '**'),
252
- '**/*.db*',
253
- '**/exports/**',
254
- '**/dist/**',
255
- '**/*.d.ts',
256
- '**/.yalc/**',
257
- '**/yalc.lock',
258
- // TODO v6: watch only src folder by default, and flip this to watchIncludeFiles
259
- ...strapiInstance.config.get('admin.watchIgnoreFiles', [])
260
- ]
261
- }).on('add', (path)=>{
262
- strapiInstance.log.info(`File created: ${path}`);
263
- restart();
264
- }).on('change', (path)=>{
265
- strapiInstance.log.info(`File changed: ${path}`);
266
- restart();
267
- }).on('unlink', (path)=>{
268
- strapiInstance.log.info(`File deleted: ${path}`);
269
- restart();
270
- });
271
- process.on('message', async (message)=>{
272
- switch(message){
273
- case 'kill':
274
- {
275
- logger.debug('child process has the kill message, destroying the strapi instance and sending the killed process message');
276
- await watcher.close();
277
- await strapiInstance.destroy();
278
- if (bundleWatcher) {
279
- bundleWatcher.close();
280
- }
281
- process.send?.('killed');
282
- break;
200
+ const loadStrapiDuration = timer.end('loadStrapi');
201
+ loadStrapiSpinner.text = `Loading Strapi (${prettyTime(loadStrapiDuration)})`;
202
+ loadStrapiSpinner.succeed();
203
+ // For TS projects, type generation is a requirement for the develop command so that the server can restart
204
+ // For JS projects, we respect the experimental autogenerate setting
205
+ if (tsconfig?.config || strapi.config.get('typescript.autogenerate') !== false) {
206
+ timer.start('generatingTS');
207
+ generatingTsSpinner.start();
208
+ await tsUtils.generators.generate({
209
+ strapi: strapiInstance,
210
+ pwd: cwd,
211
+ rootDir: undefined,
212
+ logger: {
213
+ silent: true,
214
+ debug: false
215
+ },
216
+ artifacts: {
217
+ contentTypes: true,
218
+ components: true
283
219
  }
220
+ });
221
+ const generatingDuration = timer.end('generatingTS');
222
+ generatingTsSpinner.text = `Generating types (${prettyTime(generatingDuration)})`;
223
+ generatingTsSpinner.succeed();
284
224
  }
285
- });
286
- strapiInstance.start();
225
+ if (tsconfig?.config) {
226
+ timer.start('compilingTS');
227
+ compilingTsSpinner.start();
228
+ await cleanupDistDirectory({
229
+ tsconfig,
230
+ logger,
231
+ timer
232
+ });
233
+ await tsUtils.compile(cwd, {
234
+ configOptions: {
235
+ ignoreDiagnostics: false
236
+ }
237
+ });
238
+ const compilingDuration = timer.end('compilingTS');
239
+ compilingTsSpinner.text = `Compiling TS (${prettyTime(compilingDuration)})`;
240
+ compilingTsSpinner.succeed();
241
+ }
242
+ ensureWatcher();
243
+ strapiInstance.start();
244
+ } catch (err) {
245
+ const message = err instanceof Error ? err.message : String(err);
246
+ logger.error(`Error during development: ${message}`);
247
+ if (loadStrapiSpinner.isSpinning) {
248
+ loadStrapiSpinner.fail();
249
+ }
250
+ // Fail any spinners that were left running.
251
+ if (contextSpinner.isSpinning) {
252
+ contextSpinner.fail();
253
+ }
254
+ if (compilingTsSpinner.isSpinning) {
255
+ compilingTsSpinner.fail();
256
+ }
257
+ if (adminSpinner.isSpinning) {
258
+ adminSpinner.fail();
259
+ }
260
+ if (generatingTsSpinner.isSpinning) {
261
+ generatingTsSpinner.fail();
262
+ }
263
+ ensureWatcher();
264
+ }
287
265
  }
288
266
  };
267
+ function startWatcher(strapiInstance, cwd, polling, logger, bundleWatcher) {
268
+ const restart = async ()=>{
269
+ if (strapiInstance.reload.isWatching && !strapiInstance.reload.isReloading) {
270
+ strapiInstance.reload.isReloading = true;
271
+ strapiInstance.reload();
272
+ }
273
+ };
274
+ const watcher = chokidar.watch(cwd, {
275
+ ignoreInitial: true,
276
+ usePolling: polling,
277
+ ignored: [
278
+ /(^|[/\\])\../,
279
+ /tmp/,
280
+ '**/src/admin/**',
281
+ '**/src/plugins/**/admin/**',
282
+ '**/dist/src/plugins/test/admin/**',
283
+ '**/documentation',
284
+ '**/documentation/**',
285
+ '**/node_modules',
286
+ '**/node_modules/**',
287
+ '**/plugins.json',
288
+ '**/build',
289
+ '**/build/**',
290
+ '**/log',
291
+ '**/log/**',
292
+ '**/logs',
293
+ '**/logs/**',
294
+ '**/*.log',
295
+ '**/index.html',
296
+ '**/public',
297
+ '**/public/**',
298
+ strapiInstance.dirs.static.public,
299
+ strings.joinBy('/', strapiInstance.dirs.static.public, '**'),
300
+ '**/*.db*',
301
+ '**/exports/**',
302
+ '**/dist/**',
303
+ '**/*.d.ts',
304
+ '**/.yalc/**',
305
+ '**/yalc.lock',
306
+ // TODO v6: watch only src folder by default, and flip this to watchIncludeFiles
307
+ ...strapiInstance.config.get('admin.watchIgnoreFiles', [])
308
+ ]
309
+ }).on('add', (path)=>{
310
+ strapiInstance.log.info(`File created: ${path}`);
311
+ restart();
312
+ }).on('change', (path)=>{
313
+ strapiInstance.log.info(`File changed: ${path}`);
314
+ restart();
315
+ }).on('unlink', (path)=>{
316
+ strapiInstance.log.info(`File deleted: ${path}`);
317
+ restart();
318
+ });
319
+ process.on('message', async (message)=>{
320
+ switch(message){
321
+ case 'kill':
322
+ {
323
+ logger.debug('child process has the kill message, destroying the strapi instance and sending the killed process message');
324
+ await watcher.close();
325
+ await strapiInstance.destroy();
326
+ if (bundleWatcher) {
327
+ bundleWatcher.close();
328
+ }
329
+ process.send?.('killed');
330
+ break;
331
+ }
332
+ }
333
+ });
334
+ }
289
335
 
290
336
  export { develop };
291
337
  //# sourceMappingURL=develop.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"develop.mjs","sources":["../../../src/node/develop.ts"],"sourcesContent":["import * as tsUtils from '@strapi/typescript-utils';\nimport { strings } from '@strapi/utils';\nimport chokidar from 'chokidar';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport cluster from 'node:cluster';\nimport { createStrapi } from '@strapi/core';\n\nimport type { CLIContext } from '../cli/types';\nimport { checkRequiredDependencies } from './core/dependencies';\nimport { getTimer, prettyTime, type TimeMeasurer } from './core/timer';\nimport { createBuildContext } from './create-build-context';\nimport type { WebpackWatcher } from './webpack/watch';\nimport type { ViteWatcher } from './vite/watch';\n\nimport { writeStaticClientFiles } from './staticFiles';\n\ninterface DevelopOptions extends CLIContext {\n /**\n * Which bundler to use for building.\n *\n * @default webpack\n */\n bundler?: 'webpack' | 'vite';\n polling?: boolean;\n open?: boolean;\n watchAdmin?: boolean;\n buildAdmin?: boolean;\n}\n\n// This method removes all non-admin build files from the dist directory\nconst cleanupDistDirectory = async ({\n tsconfig,\n logger,\n timer,\n}: Pick<DevelopOptions, 'tsconfig' | 'logger'> & { timer: TimeMeasurer }) => {\n const distDir = tsconfig?.config?.options?.outDir;\n\n if (\n !distDir || // we don't have a dist dir\n (await fs\n .access(distDir)\n .then(() => false)\n .catch(() => true)) // it doesn't exist -- if it does but no access, that will be caught later\n ) {\n return;\n }\n\n const timerName = `cleaningDist${Date.now()}`;\n timer.start(timerName);\n const cleaningSpinner = logger.spinner(`Cleaning dist dir ${distDir}`).start();\n\n try {\n const dirContent = await fs.readdir(distDir);\n const validFilenames = dirContent\n // Ignore the admin build folder\n .filter((filename) => filename !== 'build');\n for (const filename of validFilenames) {\n await fs.rm(path.resolve(distDir, filename), { recursive: true });\n }\n } catch (err: unknown) {\n const generatingDuration = timer.end(timerName);\n cleaningSpinner.text = `Error cleaning dist dir: ${err} (${prettyTime(generatingDuration)})`;\n cleaningSpinner?.fail();\n return;\n }\n\n const generatingDuration = timer.end(timerName);\n cleaningSpinner.text = `Cleaning dist dir (${prettyTime(generatingDuration)})`;\n cleaningSpinner?.succeed();\n};\n\nconst develop = async ({\n cwd,\n polling,\n logger,\n tsconfig,\n watchAdmin,\n buildAdmin,\n ...options\n}: DevelopOptions) => {\n const timer = getTimer();\n\n if (cluster.isPrimary) {\n const { didInstall } = await checkRequiredDependencies({ cwd, logger }).catch((err) => {\n logger.error(err.message);\n process.exit(1);\n });\n\n if (didInstall) {\n return;\n }\n\n if (tsconfig?.config) {\n // Build without diagnostics in case schemas have changed\n await cleanupDistDirectory({ tsconfig, logger, timer });\n await tsUtils.compile(cwd, { configOptions: { ignoreDiagnostics: true } });\n }\n\n /**\n * IF we're not watching the admin we're going to build it, this makes\n * sure that at least the admin is built for users & they can interact\n * with the application.\n */\n if (!watchAdmin && buildAdmin) {\n timer.start('createBuildContext');\n const contextSpinner = logger.spinner(`Building build context`).start();\n console.log('');\n\n const ctx = await createBuildContext({\n cwd,\n logger,\n tsconfig,\n options,\n });\n const contextDuration = timer.end('createBuildContext');\n contextSpinner.text = `Building build context (${prettyTime(contextDuration)})`;\n contextSpinner.succeed();\n\n timer.start('creatingAdmin');\n const adminSpinner = logger.spinner(`Creating admin`).start();\n\n await writeStaticClientFiles(ctx);\n\n if (ctx.bundler === 'webpack') {\n const { build: buildWebpack } = await import('./webpack/build');\n await buildWebpack(ctx);\n } else if (ctx.bundler === 'vite') {\n const { build: buildVite } = await import('./vite/build');\n await buildVite(ctx);\n }\n\n const adminDuration = timer.end('creatingAdmin');\n adminSpinner.text = `Creating admin (${prettyTime(adminDuration)})`;\n adminSpinner.succeed();\n }\n\n cluster.on('message', async (worker, message) => {\n switch (message) {\n case 'reload': {\n if (tsconfig?.config) {\n // Build without diagnostics in case schemas have changed\n await cleanupDistDirectory({ tsconfig, logger, timer });\n await tsUtils.compile(cwd, { configOptions: { ignoreDiagnostics: true } });\n }\n logger.debug('cluster has the reload message, sending the worker kill message');\n worker.send('kill');\n break;\n }\n case 'killed': {\n logger.debug('cluster has the killed message, forking the cluster');\n cluster.fork();\n break;\n }\n case 'stop': {\n process.exit(1);\n break;\n }\n default:\n break;\n }\n });\n\n cluster.fork();\n }\n\n if (cluster.isWorker) {\n timer.start('loadStrapi');\n const loadStrapiSpinner = logger.spinner(`Loading Strapi`).start();\n\n const strapi = createStrapi({\n appDir: cwd,\n distDir: tsconfig?.config.options.outDir ?? '',\n autoReload: true,\n serveAdminPanel: !watchAdmin,\n });\n\n /**\n * If we're watching the admin panel then we're going to attach the watcher\n * as a strapi middleware.\n */\n let bundleWatcher: WebpackWatcher | ViteWatcher | undefined;\n\n const strapiInstance = await strapi.load();\n\n if (watchAdmin) {\n timer.start('createBuildContext');\n const contextSpinner = logger.spinner(`Building build context`).start();\n console.log('');\n\n const ctx = await createBuildContext({\n cwd,\n logger,\n strapi,\n tsconfig,\n options,\n });\n const contextDuration = timer.end('createBuildContext');\n contextSpinner.text = `Building build context (${prettyTime(contextDuration)})`;\n contextSpinner.succeed();\n\n timer.start('creatingAdmin');\n const adminSpinner = logger.spinner(`Creating admin`).start();\n\n await writeStaticClientFiles(ctx);\n\n if (ctx.bundler === 'webpack') {\n const { watch: watchWebpack } = await import('./webpack/watch');\n bundleWatcher = await watchWebpack(ctx);\n } else if (ctx.bundler === 'vite') {\n const { watch: watchVite } = await import('./vite/watch');\n bundleWatcher = await watchVite(ctx);\n }\n\n const adminDuration = timer.end('creatingAdmin');\n adminSpinner.text = `Creating admin (${prettyTime(adminDuration)})`;\n adminSpinner.succeed();\n }\n\n const loadStrapiDuration = timer.end('loadStrapi');\n loadStrapiSpinner.text = `Loading Strapi (${prettyTime(loadStrapiDuration)})`;\n loadStrapiSpinner.succeed();\n\n // For TS projects, type generation is a requirement for the develop command so that the server can restart\n // For JS projects, we respect the experimental autogenerate setting\n if (tsconfig?.config || strapi.config.get('typescript.autogenerate') !== false) {\n timer.start('generatingTS');\n const generatingTsSpinner = logger.spinner(`Generating types`).start();\n\n await tsUtils.generators.generate({\n strapi: strapiInstance,\n pwd: cwd,\n rootDir: undefined,\n logger: { silent: true, debug: false },\n artifacts: { contentTypes: true, components: true },\n });\n\n const generatingDuration = timer.end('generatingTS');\n generatingTsSpinner.text = `Generating types (${prettyTime(generatingDuration)})`;\n generatingTsSpinner.succeed();\n }\n\n if (tsconfig?.config) {\n timer.start('compilingTS');\n const compilingTsSpinner = logger.spinner(`Compiling TS`).start();\n\n await cleanupDistDirectory({ tsconfig, logger, timer });\n await tsUtils.compile(cwd, { configOptions: { ignoreDiagnostics: false } });\n\n const compilingDuration = timer.end('compilingTS');\n compilingTsSpinner.text = `Compiling TS (${prettyTime(compilingDuration)})`;\n compilingTsSpinner.succeed();\n }\n\n const restart = async () => {\n if (strapiInstance.reload.isWatching && !strapiInstance.reload.isReloading) {\n strapiInstance.reload.isReloading = true;\n strapiInstance.reload();\n }\n };\n\n const watcher = chokidar\n .watch(cwd, {\n ignoreInitial: true,\n usePolling: polling,\n ignored: [\n /(^|[/\\\\])\\../, // dot files\n /tmp/,\n '**/src/admin/**',\n '**/src/plugins/**/admin/**',\n '**/dist/src/plugins/test/admin/**',\n '**/documentation',\n '**/documentation/**',\n '**/node_modules',\n '**/node_modules/**',\n '**/plugins.json',\n '**/build',\n '**/build/**',\n '**/log',\n '**/log/**',\n '**/logs',\n '**/logs/**',\n '**/*.log',\n '**/index.html',\n '**/public',\n '**/public/**',\n strapiInstance.dirs.static.public,\n strings.joinBy('/', strapiInstance.dirs.static.public, '**'),\n '**/*.db*',\n '**/exports/**',\n '**/dist/**',\n '**/*.d.ts',\n '**/.yalc/**',\n '**/yalc.lock',\n // TODO v6: watch only src folder by default, and flip this to watchIncludeFiles\n ...strapiInstance.config.get('admin.watchIgnoreFiles', []),\n ],\n })\n .on('add', (path) => {\n strapiInstance.log.info(`File created: ${path}`);\n restart();\n })\n .on('change', (path) => {\n strapiInstance.log.info(`File changed: ${path}`);\n restart();\n })\n .on('unlink', (path) => {\n strapiInstance.log.info(`File deleted: ${path}`);\n restart();\n });\n\n process.on('message', async (message) => {\n switch (message) {\n case 'kill': {\n logger.debug(\n 'child process has the kill message, destroying the strapi instance and sending the killed process message'\n );\n await watcher.close();\n\n await strapiInstance.destroy();\n\n if (bundleWatcher) {\n bundleWatcher.close();\n }\n process.send?.('killed');\n break;\n }\n default:\n break;\n }\n });\n\n strapiInstance.start();\n }\n};\n\nexport { develop };\nexport type { DevelopOptions };\n"],"names":["cleanupDistDirectory","tsconfig","logger","timer","distDir","config","options","outDir","fs","access","then","catch","timerName","Date","now","start","cleaningSpinner","spinner","dirContent","readdir","validFilenames","filter","filename","rm","path","resolve","recursive","err","generatingDuration","end","text","prettyTime","fail","succeed","develop","cwd","polling","watchAdmin","buildAdmin","getTimer","cluster","isPrimary","didInstall","checkRequiredDependencies","error","message","process","exit","tsUtils","compile","configOptions","ignoreDiagnostics","contextSpinner","console","log","ctx","createBuildContext","contextDuration","adminSpinner","writeStaticClientFiles","bundler","build","buildWebpack","buildVite","adminDuration","on","worker","debug","send","fork","isWorker","loadStrapiSpinner","strapi","createStrapi","appDir","autoReload","serveAdminPanel","bundleWatcher","strapiInstance","load","watch","watchWebpack","watchVite","loadStrapiDuration","get","generatingTsSpinner","generators","generate","pwd","rootDir","undefined","silent","artifacts","contentTypes","components","compilingTsSpinner","compilingDuration","restart","reload","isWatching","isReloading","watcher","chokidar","ignoreInitial","usePolling","ignored","dirs","static","public","strings","joinBy","info","close","destroy"],"mappings":"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"}
1
+ {"version":3,"file":"develop.mjs","sources":["../../../src/node/develop.ts"],"sourcesContent":["import * as tsUtils from '@strapi/typescript-utils';\nimport { strings } from '@strapi/utils';\nimport chokidar from 'chokidar';\nimport fs from 'node:fs/promises';\nimport path from 'node:path';\nimport cluster from 'node:cluster';\nimport { createStrapi } from '@strapi/core';\n\nimport type { CLIContext } from '../cli/types';\nimport { checkRequiredDependencies } from './core/dependencies';\nimport { getTimer, prettyTime, type TimeMeasurer } from './core/timer';\nimport { createBuildContext } from './create-build-context';\nimport type { WebpackWatcher } from './webpack/watch';\nimport type { ViteWatcher } from './vite/watch';\n\nimport { writeStaticClientFiles } from './staticFiles';\nimport { Logger } from '../cli/utils/logger';\n\ninterface DevelopOptions extends CLIContext {\n /**\n * Which bundler to use for building.\n *\n * @default webpack\n */\n bundler?: 'webpack' | 'vite';\n polling?: boolean;\n open?: boolean;\n watchAdmin?: boolean;\n buildAdmin?: boolean;\n}\n\n// This method removes all non-admin build files from the dist directory\nconst cleanupDistDirectory = async ({\n tsconfig,\n logger,\n timer,\n}: Pick<DevelopOptions, 'tsconfig' | 'logger'> & { timer: TimeMeasurer }) => {\n const distDir = tsconfig?.config?.options?.outDir;\n\n if (\n !distDir || // we don't have a dist dir\n (await fs\n .access(distDir)\n .then(() => false)\n .catch(() => true)) // it doesn't exist -- if it does but no access, that will be caught later\n ) {\n return;\n }\n\n const timerName = `cleaningDist${Date.now()}`;\n timer.start(timerName);\n const cleaningSpinner = logger.spinner(`Cleaning dist dir ${distDir}`).start();\n\n try {\n const dirContent = await fs.readdir(distDir);\n const validFilenames = dirContent\n // Ignore the admin build folder\n .filter((filename) => filename !== 'build');\n for (const filename of validFilenames) {\n await fs.rm(path.resolve(distDir, filename), { recursive: true });\n }\n } catch (err: unknown) {\n const generatingDuration = timer.end(timerName);\n cleaningSpinner.text = `Error cleaning dist dir: ${err} (${prettyTime(generatingDuration)})`;\n cleaningSpinner?.fail();\n return;\n }\n\n const generatingDuration = timer.end(timerName);\n cleaningSpinner.text = `Cleaning dist dir (${prettyTime(generatingDuration)})`;\n cleaningSpinner?.succeed();\n};\n\nconst develop = async ({\n cwd,\n polling,\n logger,\n tsconfig,\n watchAdmin,\n buildAdmin,\n ...options\n}: DevelopOptions) => {\n const timer = getTimer();\n\n if (cluster.isPrimary) {\n const { didInstall } = await checkRequiredDependencies({ cwd, logger }).catch((err) => {\n logger.error(err.message);\n process.exit(1);\n });\n\n if (didInstall) {\n return;\n }\n\n if (tsconfig?.config) {\n // Build without diagnostics in case schemas have changed\n await cleanupDistDirectory({ tsconfig, logger, timer });\n try {\n await tsUtils.compile(cwd, { configOptions: { ignoreDiagnostics: true } });\n } catch (err: unknown) {\n logger.error(`Error during initial TypeScript compilation: ${(err as Error).message}`);\n // We don't return here because we want to attempt to start the server even if the initial compilation fails, as it can be fixed while the server is running\n }\n }\n\n /**\n * IF we're not watching the admin we're going to build it, this makes\n * sure that at least the admin is built for users & they can interact\n * with the application.\n */\n if (!watchAdmin && buildAdmin) {\n timer.start('createBuildContext');\n const contextSpinner = logger.spinner(`Building build context`).start();\n console.log('');\n\n const ctx = await createBuildContext({\n cwd,\n logger,\n tsconfig,\n options,\n });\n const contextDuration = timer.end('createBuildContext');\n contextSpinner.text = `Building build context (${prettyTime(contextDuration)})`;\n contextSpinner.succeed();\n\n timer.start('creatingAdmin');\n const adminSpinner = logger.spinner(`Creating admin`).start();\n\n await writeStaticClientFiles(ctx);\n\n if (ctx.bundler === 'webpack') {\n const { build: buildWebpack } = await import('./webpack/build');\n await buildWebpack(ctx);\n } else if (ctx.bundler === 'vite') {\n const { build: buildVite } = await import('./vite/build');\n await buildVite(ctx);\n }\n\n const adminDuration = timer.end('creatingAdmin');\n adminSpinner.text = `Creating admin (${prettyTime(adminDuration)})`;\n adminSpinner.succeed();\n }\n\n cluster.on('message', async (worker, message) => {\n switch (message) {\n case 'reload': {\n if (tsconfig?.config) {\n try {\n // Build without diagnostics in case schemas have changed\n await cleanupDistDirectory({ tsconfig, logger, timer });\n await tsUtils.compile(cwd, { configOptions: { ignoreDiagnostics: true } });\n } catch (err: unknown) {\n const message = err instanceof Error ? err.message : String(err);\n logger.error(`Error during TypeScript compilation on reload: ${message}`);\n process.exit(1);\n }\n }\n logger.debug('cluster has the reload message, sending the worker kill message');\n worker.send('kill');\n break;\n }\n case 'killed': {\n logger.debug('cluster has the killed message, forking the cluster');\n cluster.fork();\n break;\n }\n case 'stop': {\n process.exit(1);\n break;\n }\n default:\n break;\n }\n });\n\n cluster.fork();\n }\n\n if (cluster.isWorker) {\n timer.start('loadStrapi');\n const loadStrapiSpinner = logger.spinner(`Loading Strapi`).start();\n\n const strapi = createStrapi({\n appDir: cwd,\n distDir: tsconfig?.config.options.outDir ?? '',\n autoReload: true,\n serveAdminPanel: !watchAdmin,\n });\n\n /**\n * If we're watching the admin panel then we're going to attach the watcher\n * as a strapi middleware.\n */\n let bundleWatcher: WebpackWatcher | ViteWatcher | undefined;\n\n const strapiInstance = await strapi.load();\n\n const contextSpinner = logger.spinner(`Building build context`);\n const adminSpinner = logger.spinner(`Creating admin`);\n const generatingTsSpinner = logger.spinner(`Generating types`);\n const compilingTsSpinner = logger.spinner(`Compiling TS`);\n\n let watcherStarted = false;\n const ensureWatcher = () => {\n if (!watcherStarted) {\n watcherStarted = true;\n startWatcher(strapiInstance, cwd, polling ?? false, logger, bundleWatcher);\n }\n };\n\n try {\n if (watchAdmin) {\n timer.start('createBuildContext');\n contextSpinner.start();\n\n const ctx = await createBuildContext({\n cwd,\n logger,\n strapi,\n tsconfig,\n options,\n });\n const contextDuration = timer.end('createBuildContext');\n contextSpinner.text = `Building build context (${prettyTime(contextDuration)})`;\n contextSpinner.succeed();\n\n timer.start('creatingAdmin');\n adminSpinner.start();\n\n await writeStaticClientFiles(ctx);\n\n if (ctx.bundler === 'webpack') {\n const { watch: watchWebpack } = await import('./webpack/watch');\n bundleWatcher = await watchWebpack(ctx);\n } else if (ctx.bundler === 'vite') {\n const { watch: watchVite } = await import('./vite/watch');\n bundleWatcher = await watchVite(ctx);\n }\n\n const adminDuration = timer.end('creatingAdmin');\n adminSpinner.text = `Creating admin (${prettyTime(adminDuration)})`;\n adminSpinner.succeed();\n }\n\n const loadStrapiDuration = timer.end('loadStrapi');\n loadStrapiSpinner.text = `Loading Strapi (${prettyTime(loadStrapiDuration)})`;\n loadStrapiSpinner.succeed();\n\n // For TS projects, type generation is a requirement for the develop command so that the server can restart\n // For JS projects, we respect the experimental autogenerate setting\n if (tsconfig?.config || strapi.config.get('typescript.autogenerate') !== false) {\n timer.start('generatingTS');\n generatingTsSpinner.start();\n\n await tsUtils.generators.generate({\n strapi: strapiInstance,\n pwd: cwd,\n rootDir: undefined,\n logger: { silent: true, debug: false },\n artifacts: { contentTypes: true, components: true },\n });\n\n const generatingDuration = timer.end('generatingTS');\n generatingTsSpinner.text = `Generating types (${prettyTime(generatingDuration)})`;\n generatingTsSpinner.succeed();\n }\n\n if (tsconfig?.config) {\n timer.start('compilingTS');\n compilingTsSpinner.start();\n\n await cleanupDistDirectory({ tsconfig, logger, timer });\n await tsUtils.compile(cwd, { configOptions: { ignoreDiagnostics: false } });\n\n const compilingDuration = timer.end('compilingTS');\n compilingTsSpinner.text = `Compiling TS (${prettyTime(compilingDuration)})`;\n compilingTsSpinner.succeed();\n }\n\n ensureWatcher();\n\n strapiInstance.start();\n } catch (err: unknown) {\n const message = err instanceof Error ? err.message : String(err);\n logger.error(`Error during development: ${message}`);\n\n if (loadStrapiSpinner.isSpinning) {\n loadStrapiSpinner.fail();\n }\n // Fail any spinners that were left running.\n if (contextSpinner.isSpinning) {\n contextSpinner.fail();\n }\n if (compilingTsSpinner.isSpinning) {\n compilingTsSpinner.fail();\n }\n if (adminSpinner.isSpinning) {\n adminSpinner.fail();\n }\n if (generatingTsSpinner.isSpinning) {\n generatingTsSpinner.fail();\n }\n\n ensureWatcher();\n }\n }\n};\n\nfunction startWatcher(\n strapiInstance: Awaited<ReturnType<typeof createStrapi>>,\n cwd: string,\n polling: boolean,\n logger: Logger,\n bundleWatcher?: WebpackWatcher | ViteWatcher\n) {\n const restart = async () => {\n if (strapiInstance.reload.isWatching && !strapiInstance.reload.isReloading) {\n strapiInstance.reload.isReloading = true;\n strapiInstance.reload();\n }\n };\n\n const watcher = chokidar\n .watch(cwd, {\n ignoreInitial: true,\n usePolling: polling,\n ignored: [\n /(^|[/\\\\])\\../, // dot files\n /tmp/,\n '**/src/admin/**',\n '**/src/plugins/**/admin/**',\n '**/dist/src/plugins/test/admin/**',\n '**/documentation',\n '**/documentation/**',\n '**/node_modules',\n '**/node_modules/**',\n '**/plugins.json',\n '**/build',\n '**/build/**',\n '**/log',\n '**/log/**',\n '**/logs',\n '**/logs/**',\n '**/*.log',\n '**/index.html',\n '**/public',\n '**/public/**',\n strapiInstance.dirs.static.public,\n strings.joinBy('/', strapiInstance.dirs.static.public, '**'),\n '**/*.db*',\n '**/exports/**',\n '**/dist/**',\n '**/*.d.ts',\n '**/.yalc/**',\n '**/yalc.lock',\n // TODO v6: watch only src folder by default, and flip this to watchIncludeFiles\n ...strapiInstance.config.get('admin.watchIgnoreFiles', []),\n ],\n })\n .on('add', (path) => {\n strapiInstance.log.info(`File created: ${path}`);\n restart();\n })\n .on('change', (path) => {\n strapiInstance.log.info(`File changed: ${path}`);\n restart();\n })\n .on('unlink', (path) => {\n strapiInstance.log.info(`File deleted: ${path}`);\n restart();\n });\n\n process.on('message', async (message) => {\n switch (message) {\n case 'kill': {\n logger.debug(\n 'child process has the kill message, destroying the strapi instance and sending the killed process message'\n );\n await watcher.close();\n\n await strapiInstance.destroy();\n\n if (bundleWatcher) {\n bundleWatcher.close();\n }\n process.send?.('killed');\n break;\n }\n default:\n break;\n }\n });\n}\n\nexport { develop };\nexport type { DevelopOptions };\n"],"names":["cleanupDistDirectory","tsconfig","logger","timer","distDir","config","options","outDir","fs","access","then","catch","timerName","Date","now","start","cleaningSpinner","spinner","dirContent","readdir","validFilenames","filter","filename","rm","path","resolve","recursive","err","generatingDuration","end","text","prettyTime","fail","succeed","develop","cwd","polling","watchAdmin","buildAdmin","getTimer","cluster","isPrimary","didInstall","checkRequiredDependencies","error","message","process","exit","tsUtils","compile","configOptions","ignoreDiagnostics","contextSpinner","console","log","ctx","createBuildContext","contextDuration","adminSpinner","writeStaticClientFiles","bundler","build","buildWebpack","buildVite","adminDuration","on","worker","Error","String","debug","send","fork","isWorker","loadStrapiSpinner","strapi","createStrapi","appDir","autoReload","serveAdminPanel","bundleWatcher","strapiInstance","load","generatingTsSpinner","compilingTsSpinner","watcherStarted","ensureWatcher","startWatcher","watch","watchWebpack","watchVite","loadStrapiDuration","get","generators","generate","pwd","rootDir","undefined","silent","artifacts","contentTypes","components","compilingDuration","isSpinning","restart","reload","isWatching","isReloading","watcher","chokidar","ignoreInitial","usePolling","ignored","dirs","static","public","strings","joinBy","info","close","destroy"],"mappings":"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"}
@@ -197,7 +197,8 @@ const resolveDevelopmentConfig = async (ctx)=>{
197
197
  const USER_CONFIGS = [
198
198
  'vite.config.js',
199
199
  'vite.config.mjs',
200
- 'vite.config.ts'
200
+ 'vite.config.ts',
201
+ 'vite.config.mts'
201
202
  ];
202
203
  const mergeConfigWithUserConfig = async (config$1, ctx)=>{
203
204
  const userConfig = await config.getUserConfig(USER_CONFIGS, ctx);
@@ -1 +1 @@
1
- {"version":3,"file":"config.js","sources":["../../../../src/node/vite/config.ts"],"sourcesContent":["import type { InlineConfig, UserConfig } from 'vite';\nimport browserslistToEsbuild from 'browserslist-to-esbuild';\nimport react from '@vitejs/plugin-react-swc';\n\nimport { getUserConfig } from '../core/config';\nimport { getModulePath } from '../core/resolve-module';\nimport { isDesignSystemLinked } from '../core/linked-packages';\nimport { loadStrapiMonorepo } from '../core/monorepo';\nimport { getMonorepoAliases } from '../core/aliases';\nimport type { BuildContext } from '../create-build-context';\nimport { buildFilesPlugin } from './plugins';\n\nconst resolveBaseConfig = async (ctx: BuildContext): Promise<InlineConfig> => {\n const target = browserslistToEsbuild(ctx.target);\n const isMonorepoExampleApp = (ctx.strapi as any).internal_config?.uuid === 'getstarted';\n const designSystemLinked = isDesignSystemLinked();\n\n return {\n root: ctx.cwd,\n base: ctx.basePath,\n build: {\n emptyOutDir: false, // Rely on CLI to do this\n outDir: ctx.distDir,\n target,\n },\n cacheDir: 'node_modules/.strapi/vite',\n configFile: false,\n define: {\n process: {},\n 'process.env': JSON.stringify(ctx.env),\n },\n envPrefix: 'STRAPI_ADMIN_',\n optimizeDeps: {\n // When design-system is linked (portal:, file:, yarn link), exclude from pre-bundling\n // so changes are reflected without clearing node_modules/.strapi/vite cache\n ...(designSystemLinked && { exclude: ['@strapi/design-system'] }),\n include: [\n // pre-bundle React dependencies to avoid React duplicates,\n // even if React dependencies are not direct dependencies\n // https://react.dev/warnings/invalid-hook-call-warning#duplicate-react\n 'react',\n `react/jsx-runtime`,\n 'react-dom/client',\n 'styled-components',\n 'react-router-dom',\n // Pre-bundle design-system so plugin custom field chunks (dynamic imports) resolve\n // to the same instance as the main app. Otherwise TooltipProvider/DesignSystemProvider\n // context from the root is not seen by components in plugin chunks.\n // Omit when linked so local changes are picked up (see exclude above)\n ...(!designSystemLinked ? ['@strapi/design-system'] : []),\n '@radix-ui/react-tooltip',\n // Pre-bundle lodash: design-system uses named imports (e.g. assignWith) but lodash\n // is CommonJS-only; pre-bundling converts it to ESM for the browser\n 'lodash',\n /**\n * Pre-bundle other dependencies that would otherwise cause a page reload when imported.\n * See \"performance\" section: https://vite.dev/guide/dep-pre-bundling.html#the-why\n * Only include dependencies for our internal example apps, otherwise it will break\n * real user apps that may not have those dependencies.\n */\n ...(isMonorepoExampleApp\n ? [\n '@dnd-kit/core',\n '@dnd-kit/sortable',\n '@dnd-kit/utilities',\n '@dnd-kit/modifiers',\n '@radix-ui/react-toolbar',\n 'codemirror5',\n 'codemirror5/addon/display/placeholder',\n 'date-fns-tz',\n 'date-fns/format',\n 'date-fns/formatISO',\n 'highlight.js',\n 'lodash/capitalize',\n 'lodash/fp',\n 'lodash/groupBy',\n 'lodash/has',\n 'lodash/isNil',\n 'lodash/locale',\n 'lodash/map',\n 'lodash/mapValues',\n 'lodash/pull',\n 'lodash/size',\n 'lodash/sortBy',\n 'lodash/tail',\n 'lodash/toLower',\n 'lodash/toNumber',\n 'lodash/toString',\n 'lodash/truncate',\n 'lodash/uniq',\n 'lodash/upperFirst',\n 'markdown-it',\n 'markdown-it-abbr',\n 'markdown-it-container',\n 'markdown-it-deflist',\n 'markdown-it-emoji',\n 'markdown-it-footnote',\n 'markdown-it-ins',\n 'markdown-it-mark',\n 'markdown-it-sub',\n 'markdown-it-sup',\n 'prismjs/components/*.js',\n 'react-colorful',\n 'react-dnd-html5-backend',\n 'react-window',\n 'sanitize-html',\n 'semver',\n 'semver/functions/lt',\n 'semver/functions/valid',\n 'slate',\n 'slate-history',\n 'slate-react',\n 'motion',\n ]\n : []),\n ],\n },\n resolve: {\n // https://react.dev/warnings/invalid-hook-call-warning#duplicate-react\n // Include design-system so plugin chunks use the same instance and inherit root context\n dedupe: [\n 'react',\n 'react-dom',\n 'react-router-dom',\n 'styled-components',\n '@strapi/design-system',\n '@radix-ui/react-tooltip',\n 'lodash',\n ],\n // Explicit aliases ensure resolution under pnpm's strict dependency isolation,\n // where packages imported by plugins may not be resolvable from plugin chunks\n alias: {\n react: getModulePath('react'),\n 'react-dom': getModulePath('react-dom'),\n 'react-router-dom': getModulePath('react-router-dom'),\n 'styled-components': getModulePath('styled-components'),\n '@strapi/design-system': getModulePath('@strapi/design-system'),\n '@radix-ui/react-tooltip': getModulePath('@radix-ui/react-tooltip'),\n lodash: getModulePath('lodash'),\n },\n },\n plugins: [react(), buildFilesPlugin(ctx)],\n };\n};\n\nconst resolveProductionConfig = async (ctx: BuildContext): Promise<InlineConfig> => {\n const {\n options: { minify, sourcemaps },\n } = ctx;\n\n const baseConfig = await resolveBaseConfig(ctx);\n\n return {\n ...baseConfig,\n logLevel: 'silent',\n mode: 'production',\n build: {\n ...baseConfig.build,\n assetsDir: '',\n minify,\n sourcemap: sourcemaps,\n rollupOptions: {\n input: {\n strapi: ctx.entry,\n },\n },\n },\n };\n};\n\nconst resolveDevelopmentConfig = async (ctx: BuildContext): Promise<InlineConfig> => {\n const monorepo = await loadStrapiMonorepo(ctx.cwd);\n const baseConfig = await resolveBaseConfig(ctx);\n\n return {\n ...baseConfig,\n mode: 'development',\n resolve: {\n ...baseConfig.resolve,\n alias: {\n ...baseConfig.resolve?.alias,\n ...getMonorepoAliases({ monorepo }),\n },\n },\n server: {\n cors: false,\n middlewareMode: true,\n open: ctx.options.open,\n hmr: {\n overlay: false,\n server: ctx.options.hmrServer,\n clientPort: ctx.options.hmrClientPort,\n },\n },\n appType: 'custom',\n };\n};\n\nconst USER_CONFIGS = ['vite.config.js', 'vite.config.mjs', 'vite.config.ts'];\n\ntype UserViteConfig = (config: UserConfig) => UserConfig;\n\nconst mergeConfigWithUserConfig = async (config: InlineConfig, ctx: BuildContext) => {\n const userConfig = await getUserConfig<UserViteConfig>(USER_CONFIGS, ctx);\n\n if (userConfig) {\n return userConfig(config);\n }\n\n return config;\n};\n\nexport { mergeConfigWithUserConfig, resolveProductionConfig, resolveDevelopmentConfig };\n"],"names":["resolveBaseConfig","ctx","target","browserslistToEsbuild","isMonorepoExampleApp","strapi","internal_config","uuid","designSystemLinked","isDesignSystemLinked","root","cwd","base","basePath","build","emptyOutDir","outDir","distDir","cacheDir","configFile","define","process","JSON","stringify","env","envPrefix","optimizeDeps","exclude","include","resolve","dedupe","alias","react","getModulePath","lodash","plugins","buildFilesPlugin","resolveProductionConfig","options","minify","sourcemaps","baseConfig","logLevel","mode","assetsDir","sourcemap","rollupOptions","input","entry","resolveDevelopmentConfig","monorepo","loadStrapiMonorepo","getMonorepoAliases","server","cors","middlewareMode","open","hmr","overlay","hmrServer","clientPort","hmrClientPort","appType","USER_CONFIGS","mergeConfigWithUserConfig","config","userConfig","getUserConfig"],"mappings":"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"}
1
+ {"version":3,"file":"config.js","sources":["../../../../src/node/vite/config.ts"],"sourcesContent":["import type { InlineConfig, UserConfig } from 'vite';\nimport browserslistToEsbuild from 'browserslist-to-esbuild';\nimport react from '@vitejs/plugin-react-swc';\n\nimport { getUserConfig } from '../core/config';\nimport { getModulePath } from '../core/resolve-module';\nimport { isDesignSystemLinked } from '../core/linked-packages';\nimport { loadStrapiMonorepo } from '../core/monorepo';\nimport { getMonorepoAliases } from '../core/aliases';\nimport type { BuildContext } from '../create-build-context';\nimport { buildFilesPlugin } from './plugins';\n\nconst resolveBaseConfig = async (ctx: BuildContext): Promise<InlineConfig> => {\n const target = browserslistToEsbuild(ctx.target);\n const isMonorepoExampleApp = (ctx.strapi as any).internal_config?.uuid === 'getstarted';\n const designSystemLinked = isDesignSystemLinked();\n\n return {\n root: ctx.cwd,\n base: ctx.basePath,\n build: {\n emptyOutDir: false, // Rely on CLI to do this\n outDir: ctx.distDir,\n target,\n },\n cacheDir: 'node_modules/.strapi/vite',\n configFile: false,\n define: {\n process: {},\n 'process.env': JSON.stringify(ctx.env),\n },\n envPrefix: 'STRAPI_ADMIN_',\n optimizeDeps: {\n // When design-system is linked (portal:, file:, yarn link), exclude from pre-bundling\n // so changes are reflected without clearing node_modules/.strapi/vite cache\n ...(designSystemLinked && { exclude: ['@strapi/design-system'] }),\n include: [\n // pre-bundle React dependencies to avoid React duplicates,\n // even if React dependencies are not direct dependencies\n // https://react.dev/warnings/invalid-hook-call-warning#duplicate-react\n 'react',\n `react/jsx-runtime`,\n 'react-dom/client',\n 'styled-components',\n 'react-router-dom',\n // Pre-bundle design-system so plugin custom field chunks (dynamic imports) resolve\n // to the same instance as the main app. Otherwise TooltipProvider/DesignSystemProvider\n // context from the root is not seen by components in plugin chunks.\n // Omit when linked so local changes are picked up (see exclude above)\n ...(!designSystemLinked ? ['@strapi/design-system'] : []),\n '@radix-ui/react-tooltip',\n // Pre-bundle lodash: design-system uses named imports (e.g. assignWith) but lodash\n // is CommonJS-only; pre-bundling converts it to ESM for the browser\n 'lodash',\n /**\n * Pre-bundle other dependencies that would otherwise cause a page reload when imported.\n * See \"performance\" section: https://vite.dev/guide/dep-pre-bundling.html#the-why\n * Only include dependencies for our internal example apps, otherwise it will break\n * real user apps that may not have those dependencies.\n */\n ...(isMonorepoExampleApp\n ? [\n '@dnd-kit/core',\n '@dnd-kit/sortable',\n '@dnd-kit/utilities',\n '@dnd-kit/modifiers',\n '@radix-ui/react-toolbar',\n 'codemirror5',\n 'codemirror5/addon/display/placeholder',\n 'date-fns-tz',\n 'date-fns/format',\n 'date-fns/formatISO',\n 'highlight.js',\n 'lodash/capitalize',\n 'lodash/fp',\n 'lodash/groupBy',\n 'lodash/has',\n 'lodash/isNil',\n 'lodash/locale',\n 'lodash/map',\n 'lodash/mapValues',\n 'lodash/pull',\n 'lodash/size',\n 'lodash/sortBy',\n 'lodash/tail',\n 'lodash/toLower',\n 'lodash/toNumber',\n 'lodash/toString',\n 'lodash/truncate',\n 'lodash/uniq',\n 'lodash/upperFirst',\n 'markdown-it',\n 'markdown-it-abbr',\n 'markdown-it-container',\n 'markdown-it-deflist',\n 'markdown-it-emoji',\n 'markdown-it-footnote',\n 'markdown-it-ins',\n 'markdown-it-mark',\n 'markdown-it-sub',\n 'markdown-it-sup',\n 'prismjs/components/*.js',\n 'react-colorful',\n 'react-dnd-html5-backend',\n 'react-window',\n 'sanitize-html',\n 'semver',\n 'semver/functions/lt',\n 'semver/functions/valid',\n 'slate',\n 'slate-history',\n 'slate-react',\n 'motion',\n ]\n : []),\n ],\n },\n resolve: {\n // https://react.dev/warnings/invalid-hook-call-warning#duplicate-react\n // Include design-system so plugin chunks use the same instance and inherit root context\n dedupe: [\n 'react',\n 'react-dom',\n 'react-router-dom',\n 'styled-components',\n '@strapi/design-system',\n '@radix-ui/react-tooltip',\n 'lodash',\n ],\n // Explicit aliases ensure resolution under pnpm's strict dependency isolation,\n // where packages imported by plugins may not be resolvable from plugin chunks\n alias: {\n react: getModulePath('react'),\n 'react-dom': getModulePath('react-dom'),\n 'react-router-dom': getModulePath('react-router-dom'),\n 'styled-components': getModulePath('styled-components'),\n '@strapi/design-system': getModulePath('@strapi/design-system'),\n '@radix-ui/react-tooltip': getModulePath('@radix-ui/react-tooltip'),\n lodash: getModulePath('lodash'),\n },\n },\n plugins: [react(), buildFilesPlugin(ctx)],\n };\n};\n\nconst resolveProductionConfig = async (ctx: BuildContext): Promise<InlineConfig> => {\n const {\n options: { minify, sourcemaps },\n } = ctx;\n\n const baseConfig = await resolveBaseConfig(ctx);\n\n return {\n ...baseConfig,\n logLevel: 'silent',\n mode: 'production',\n build: {\n ...baseConfig.build,\n assetsDir: '',\n minify,\n sourcemap: sourcemaps,\n rollupOptions: {\n input: {\n strapi: ctx.entry,\n },\n },\n },\n };\n};\n\nconst resolveDevelopmentConfig = async (ctx: BuildContext): Promise<InlineConfig> => {\n const monorepo = await loadStrapiMonorepo(ctx.cwd);\n const baseConfig = await resolveBaseConfig(ctx);\n\n return {\n ...baseConfig,\n mode: 'development',\n resolve: {\n ...baseConfig.resolve,\n alias: {\n ...baseConfig.resolve?.alias,\n ...getMonorepoAliases({ monorepo }),\n },\n },\n server: {\n cors: false,\n middlewareMode: true,\n open: ctx.options.open,\n hmr: {\n overlay: false,\n server: ctx.options.hmrServer,\n clientPort: ctx.options.hmrClientPort,\n },\n },\n appType: 'custom',\n };\n};\n\nconst USER_CONFIGS = ['vite.config.js', 'vite.config.mjs', 'vite.config.ts', 'vite.config.mts'];\n\ntype UserViteConfig = (config: UserConfig) => UserConfig;\n\nconst mergeConfigWithUserConfig = async (config: InlineConfig, ctx: BuildContext) => {\n const userConfig = await getUserConfig<UserViteConfig>(USER_CONFIGS, ctx);\n\n if (userConfig) {\n return userConfig(config);\n }\n\n return config;\n};\n\nexport { mergeConfigWithUserConfig, resolveProductionConfig, resolveDevelopmentConfig };\n"],"names":["resolveBaseConfig","ctx","target","browserslistToEsbuild","isMonorepoExampleApp","strapi","internal_config","uuid","designSystemLinked","isDesignSystemLinked","root","cwd","base","basePath","build","emptyOutDir","outDir","distDir","cacheDir","configFile","define","process","JSON","stringify","env","envPrefix","optimizeDeps","exclude","include","resolve","dedupe","alias","react","getModulePath","lodash","plugins","buildFilesPlugin","resolveProductionConfig","options","minify","sourcemaps","baseConfig","logLevel","mode","assetsDir","sourcemap","rollupOptions","input","entry","resolveDevelopmentConfig","monorepo","loadStrapiMonorepo","getMonorepoAliases","server","cors","middlewareMode","open","hmr","overlay","hmrServer","clientPort","hmrClientPort","appType","USER_CONFIGS","mergeConfigWithUserConfig","config","userConfig","getUserConfig"],"mappings":"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"}
@@ -195,7 +195,8 @@ const resolveDevelopmentConfig = async (ctx)=>{
195
195
  const USER_CONFIGS = [
196
196
  'vite.config.js',
197
197
  'vite.config.mjs',
198
- 'vite.config.ts'
198
+ 'vite.config.ts',
199
+ 'vite.config.mts'
199
200
  ];
200
201
  const mergeConfigWithUserConfig = async (config, ctx)=>{
201
202
  const userConfig = await getUserConfig(USER_CONFIGS, ctx);