@tramvai/cli 2.64.0 → 2.65.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +46 -38
- package/lib/api/analyze/providers/shared.js +1 -1
- package/lib/api/analyze/providers/shared.js.map +1 -1
- package/lib/api/benchmark/index.d.ts +1 -1
- package/lib/api/build/child-app.js +3 -2
- package/lib/api/build/child-app.js.map +1 -1
- package/lib/api/build/module.js +1 -2
- package/lib/api/build/module.js.map +1 -1
- package/lib/api/build/providers/shared.js +1 -1
- package/lib/api/build/providers/shared.js.map +1 -1
- package/lib/api/index.d.ts +6 -2
- package/lib/api/index.js +3 -3
- package/lib/api/index.js.map +1 -1
- package/lib/api/shared/types/withConfig.d.ts +3 -2
- package/lib/api/start/providers/application/shared.js +1 -1
- package/lib/api/start/providers/application/shared.js.map +1 -1
- package/lib/api/start/providers/child-app/shared.js +8 -7
- package/lib/api/start/providers/child-app/shared.js.map +1 -1
- package/lib/api/start/providers/module/shared.js +14 -13
- package/lib/api/start/providers/module/shared.js.map +1 -1
- package/lib/api/start/utils/banner.js +3 -2
- package/lib/api/start/utils/banner.js.map +1 -1
- package/lib/api/start/utils/tips/tips.js +10 -8
- package/lib/api/start/utils/tips/tips.js.map +1 -1
- package/lib/api/start-prod/providers/application.js +5 -5
- package/lib/api/start-prod/providers/application.js.map +1 -1
- package/lib/api/start-prod/providers/child-app.js +2 -2
- package/lib/api/start-prod/providers/child-app.js.map +1 -1
- package/lib/api/start-prod/providers/shared.js +3 -3
- package/lib/api/start-prod/providers/shared.js.map +1 -1
- package/lib/builder/webpack/devServer/client.js +18 -15
- package/lib/builder/webpack/devServer/client.js.map +1 -1
- package/lib/builder/webpack/devServer/notifier.d.ts +2 -2
- package/lib/builder/webpack/devServer/notifier.js +3 -3
- package/lib/builder/webpack/devServer/notifier.js.map +1 -1
- package/lib/builder/webpack/devServer/pool/process/pool.js +3 -2
- package/lib/builder/webpack/devServer/pool/process/pool.js.map +1 -1
- package/lib/builder/webpack/devServer/pool/thread/pool.js +7 -0
- package/lib/builder/webpack/devServer/pool/thread/pool.js.map +1 -1
- package/lib/builder/webpack/devServer/server.js +7 -2
- package/lib/builder/webpack/devServer/server.js.map +1 -1
- package/lib/builder/webpack/providers/analyze/shared.js +3 -3
- package/lib/builder/webpack/providers/analyze/shared.js.map +1 -1
- package/lib/builder/webpack/providers/build/application/server.js.map +1 -1
- package/lib/builder/webpack/providers/build/client.js +3 -3
- package/lib/builder/webpack/providers/build/client.js.map +1 -1
- package/lib/builder/webpack/providers/build/server.js +1 -1
- package/lib/builder/webpack/providers/build/server.js.map +1 -1
- package/lib/builder/webpack/tokens.d.ts +313 -3
- package/lib/builder/webpack/tokens.js.map +1 -1
- package/lib/builder/webpack/utils/copyBuildFile.d.ts +2 -1
- package/lib/builder/webpack/utils/copyBuildFile.js +2 -3
- package/lib/builder/webpack/utils/copyBuildFile.js.map +1 -1
- package/lib/builder/webpack/utils/copyStatsJsonFile.d.ts +2 -1
- package/lib/builder/webpack/utils/copyStatsJsonFile.js +1 -1
- package/lib/builder/webpack/utils/copyStatsJsonFile.js.map +1 -1
- package/lib/cli/CLI.d.ts +2 -2
- package/lib/cli/CLI.js +2 -2
- package/lib/cli/CLI.js.map +1 -1
- package/lib/cli/index.js.map +1 -1
- package/lib/commands/analyze/command.d.ts +1 -1
- package/lib/commands/analyze/command.js.map +1 -1
- package/lib/commands/benchmark/command.d.ts +1 -1
- package/lib/commands/benchmark/command.js.map +1 -1
- package/lib/commands/build/command.d.ts +1 -1
- package/lib/commands/build/command.js.map +1 -1
- package/lib/commands/new/new.js +0 -1
- package/lib/commands/new/new.js.map +1 -1
- package/lib/commands/new/questions/packageManager.d.ts +1 -1
- package/lib/commands/new/questions/packageManager.js.map +1 -1
- package/lib/commands/new/questions/template.d.ts +1 -1
- package/lib/commands/new/questions/template.js.map +1 -1
- package/lib/commands/new/questions/testingFramework.d.ts +1 -1
- package/lib/commands/new/questions/testingFramework.js.map +1 -1
- package/lib/commands/new/questions/type.d.ts +1 -1
- package/lib/commands/new/questions/type.js.map +1 -1
- package/lib/commands/new/steps/initializationGit.d.ts +1 -1
- package/lib/commands/new/steps/initializationGit.js.map +1 -1
- package/lib/commands/start/command.d.ts +1 -1
- package/lib/commands/start/command.js.map +1 -1
- package/lib/commands/start-prod/command.d.ts +1 -1
- package/lib/commands/start-prod/command.js.map +1 -1
- package/lib/commands/static/application.js +4 -4
- package/lib/commands/static/application.js.map +1 -1
- package/lib/commands/static/command.d.ts +1 -1
- package/lib/commands/static/command.js.map +1 -1
- package/lib/commands/static/generate.js +2 -2
- package/lib/commands/static/generate.js.map +1 -1
- package/lib/commands/static/server.d.ts +2 -1
- package/lib/commands/static/server.js +1 -1
- package/lib/commands/static/server.js.map +1 -1
- package/lib/commands/static/staticServer.d.ts +2 -1
- package/lib/commands/static/staticServer.js +1 -1
- package/lib/commands/static/staticServer.js.map +1 -1
- package/lib/commands/update/updatePackageJson.js +3 -0
- package/lib/commands/update/updatePackageJson.js.map +1 -1
- package/lib/config/configManager.d.ts +12 -73
- package/lib/config/configManager.js +61 -92
- package/lib/config/configManager.js.map +1 -1
- package/lib/config/showConfig.d.ts +1 -1
- package/lib/config/showConfig.js +1 -1
- package/lib/config/showConfig.js.map +1 -1
- package/lib/config/validate.d.ts +5 -4
- package/lib/config/validate.js +2 -9
- package/lib/config/validate.js.map +1 -1
- package/lib/di/tokens/config.d.ts +106 -1
- package/lib/di/tokens/config.js.map +1 -1
- package/lib/external/config.d.ts +2 -2
- package/lib/library/babel/index.js +1 -0
- package/lib/library/babel/index.js.map +1 -1
- package/lib/library/swc/index.js +1 -1
- package/lib/library/swc/index.js.map +1 -1
- package/lib/library/webpack/application/client/common.js +6 -4
- package/lib/library/webpack/application/client/common.js.map +1 -1
- package/lib/library/webpack/application/client/dev.js +9 -8
- package/lib/library/webpack/application/client/dev.js.map +1 -1
- package/lib/library/webpack/application/client/prod/optimization/splitChunks.js +40 -39
- package/lib/library/webpack/application/client/prod/optimization/splitChunks.js.map +1 -1
- package/lib/library/webpack/application/client/prod.js +3 -4
- package/lib/library/webpack/application/client/prod.js.map +1 -1
- package/lib/library/webpack/application/server/common.js +5 -5
- package/lib/library/webpack/application/server/common.js.map +1 -1
- package/lib/library/webpack/application/server/dev.js +3 -6
- package/lib/library/webpack/application/server/dev.js.map +1 -1
- package/lib/library/webpack/application/server/prod.js +3 -4
- package/lib/library/webpack/application/server/prod.js.map +1 -1
- package/lib/library/webpack/blocks/apiResolve.js +1 -1
- package/lib/library/webpack/blocks/apiResolve.js.map +1 -1
- package/lib/library/webpack/blocks/configResolve.js +2 -2
- package/lib/library/webpack/blocks/configResolve.js.map +1 -1
- package/lib/library/webpack/blocks/configToEnv.js +5 -2
- package/lib/library/webpack/blocks/configToEnv.js.map +1 -1
- package/lib/library/webpack/blocks/css.d.ts +3 -1
- package/lib/library/webpack/blocks/css.js +17 -6
- package/lib/library/webpack/blocks/css.js.map +1 -1
- package/lib/library/webpack/blocks/extractCssPlugin.d.ts +4 -3
- package/lib/library/webpack/blocks/extractCssPlugin.js +4 -6
- package/lib/library/webpack/blocks/extractCssPlugin.js.map +1 -1
- package/lib/library/webpack/blocks/filesClient.d.ts +3 -2
- package/lib/library/webpack/blocks/filesClient.js +7 -7
- package/lib/library/webpack/blocks/filesClient.js.map +1 -1
- package/lib/library/webpack/blocks/filesServer.d.ts +2 -1
- package/lib/library/webpack/blocks/filesServer.js +3 -3
- package/lib/library/webpack/blocks/filesServer.js.map +1 -1
- package/lib/library/webpack/blocks/js.d.ts +2 -1
- package/lib/library/webpack/blocks/js.js +1 -1
- package/lib/library/webpack/blocks/js.js.map +1 -1
- package/lib/library/webpack/blocks/nodeClient.d.ts +2 -1
- package/lib/library/webpack/blocks/nodeClient.js +2 -2
- package/lib/library/webpack/blocks/nodeClient.js.map +1 -1
- package/lib/library/webpack/blocks/optimize.d.ts +2 -1
- package/lib/library/webpack/blocks/optimize.js +3 -3
- package/lib/library/webpack/blocks/optimize.js.map +1 -1
- package/lib/library/webpack/blocks/pagesResolve.js +1 -1
- package/lib/library/webpack/blocks/pagesResolve.js.map +1 -1
- package/lib/library/webpack/blocks/postcssAssets.d.ts +2 -1
- package/lib/library/webpack/blocks/postcssAssets.js +2 -2
- package/lib/library/webpack/blocks/postcssAssets.js.map +1 -1
- package/lib/library/webpack/blocks/serverInline.d.ts +2 -1
- package/lib/library/webpack/blocks/serverInline.js.map +1 -1
- package/lib/library/webpack/blocks/ts.d.ts +2 -1
- package/lib/library/webpack/blocks/ts.js.map +1 -1
- package/lib/library/webpack/child-app/client/common.d.ts +2 -2
- package/lib/library/webpack/child-app/client/common.js +1 -1
- package/lib/library/webpack/child-app/client/common.js.map +1 -1
- package/lib/library/webpack/child-app/client/dev.d.ts +2 -2
- package/lib/library/webpack/child-app/client/dev.js +6 -5
- package/lib/library/webpack/child-app/client/dev.js.map +1 -1
- package/lib/library/webpack/child-app/client/prod.d.ts +2 -2
- package/lib/library/webpack/child-app/client/prod.js.map +1 -1
- package/lib/library/webpack/child-app/common.d.ts +2 -2
- package/lib/library/webpack/child-app/common.js.map +1 -1
- package/lib/library/webpack/child-app/server/common.d.ts +2 -2
- package/lib/library/webpack/child-app/server/common.js +1 -1
- package/lib/library/webpack/child-app/server/common.js.map +1 -1
- package/lib/library/webpack/child-app/server/dev.d.ts +2 -2
- package/lib/library/webpack/child-app/server/dev.js.map +1 -1
- package/lib/library/webpack/child-app/server/prod.d.ts +2 -2
- package/lib/library/webpack/child-app/server/prod.js.map +1 -1
- package/lib/library/webpack/common/client/prod.d.ts +2 -1
- package/lib/library/webpack/common/client/prod.js +4 -5
- package/lib/library/webpack/common/client/prod.js.map +1 -1
- package/lib/library/webpack/common/main.d.ts +2 -1
- package/lib/library/webpack/common/main.js +3 -3
- package/lib/library/webpack/common/main.js.map +1 -1
- package/lib/library/webpack/common/server/prod.d.ts +2 -1
- package/lib/library/webpack/common/server/prod.js +4 -5
- package/lib/library/webpack/common/server/prod.js.map +1 -1
- package/lib/library/webpack/index.js +1 -2
- package/lib/library/webpack/index.js.map +1 -1
- package/lib/library/webpack/loaders/image-loader/index.d.ts +2 -1
- package/lib/library/webpack/loaders/image-loader/index.js.map +1 -1
- package/lib/library/webpack/loaders/pagesResolve.d.ts +10 -1
- package/lib/library/webpack/loaders/pagesResolve.js +4 -3
- package/lib/library/webpack/loaders/pagesResolve.js.map +1 -1
- package/lib/library/webpack/loaders/replaceContent.d.ts +6 -1
- package/lib/library/webpack/loaders/replaceContent.js +4 -3
- package/lib/library/webpack/loaders/replaceContent.js.map +1 -1
- package/lib/library/webpack/module/client/common.js +1 -1
- package/lib/library/webpack/module/client/common.js.map +1 -1
- package/lib/library/webpack/module/externals.d.ts +1 -1
- package/lib/library/webpack/module/externals.js.map +1 -1
- package/lib/library/webpack/module/resolveExternal.d.ts +1 -1
- package/lib/library/webpack/module/resolveExternal.js.map +1 -1
- package/lib/library/webpack/module/server/common.js +1 -1
- package/lib/library/webpack/module/server/common.js.map +1 -1
- package/lib/library/webpack/plugins/LazyModuleInitialization.d.ts +2 -2
- package/lib/library/webpack/plugins/LazyModuleInitialization.js +1 -0
- package/lib/library/webpack/plugins/LazyModuleInitialization.js.map +1 -1
- package/lib/library/webpack/plugins/WebpackBar/utils/index.d.ts +7 -7
- package/lib/library/webpack/plugins/WebpackBar/utils/index.js.map +1 -1
- package/lib/library/webpack/plugins/WebpackBar/utils/webpack.d.ts +2 -2
- package/lib/library/webpack/plugins/WebpackBar/utils/webpack.js.map +1 -1
- package/lib/library/webpack/types/webpack.d.ts +2 -2
- package/lib/library/webpack/utils/files.d.ts +4 -3
- package/lib/library/webpack/utils/files.js +2 -2
- package/lib/library/webpack/utils/files.js.map +1 -1
- package/lib/library/webpack/utils/transpiler.d.ts +3 -2
- package/lib/library/webpack/utils/transpiler.js +2 -2
- package/lib/library/webpack/utils/transpiler.js.map +1 -1
- package/lib/library/webpack/utils/workersPool.d.ts +3 -6
- package/lib/library/webpack/utils/workersPool.js +1 -1
- package/lib/library/webpack/utils/workersPool.js.map +1 -1
- package/lib/models/config.d.ts +2 -3
- package/lib/models/config.js +32 -3
- package/lib/models/config.js.map +1 -1
- package/lib/schema/ConfigSchema.d.ts +13 -4
- package/lib/schema/autogeneratedSchema.json +1808 -2074
- package/lib/typings/configEntry/application.d.ts +81 -86
- package/lib/typings/configEntry/child-app.d.ts +10 -29
- package/lib/typings/configEntry/cli.d.ts +254 -0
- package/lib/typings/configEntry/{CheckAsyncTsConfig.js → cli.js} +1 -1
- package/lib/typings/configEntry/cli.js.map +1 -0
- package/lib/typings/configEntry/common.d.ts +16 -276
- package/lib/typings/configEntry/common.js +15 -0
- package/lib/typings/configEntry/common.js.map +1 -1
- package/lib/typings/configEntry/module.d.ts +10 -29
- package/lib/typings/configEntry/package.d.ts +2 -1
- package/lib/ui/commander.js +1 -1
- package/lib/ui/commander.js.map +1 -1
- package/lib/utils/applyTemplate.js.map +1 -1
- package/lib/utils/safeRequire.js +5 -1
- package/lib/utils/safeRequire.js.map +1 -1
- package/lib/utils/webpackBuild.d.ts +2 -1
- package/lib/utils/webpackBuild.js +3 -3
- package/lib/utils/webpackBuild.js.map +1 -1
- package/package.json +13 -9
- package/schema.json +1802 -2068
- package/src/api/analyze/providers/shared.ts +3 -2
- package/src/api/benchmark/__integration__/__fixtures__/tramvai.json +1 -8
- package/src/api/benchmark/index.ts +1 -1
- package/src/api/build/__integration__/__fixtures__/app/App.tsx +0 -1
- package/src/api/build/__integration__/__fixtures__/app/index.tsx +14 -8
- package/src/api/build/__integration__/__fixtures__/app/server.tsx +0 -1
- package/src/api/build/__integration__/__fixtures__/tramvai.json +1 -10
- package/src/api/build/__integration__/build.test.ts +4 -13
- package/src/api/build/child-app.ts +4 -4
- package/src/api/build/module.ts +2 -4
- package/src/api/build/providers/shared.ts +2 -2
- package/src/api/index.ts +6 -2
- package/src/api/shared/types/withConfig.ts +5 -6
- package/src/api/start/__integration__/__fixtures__/app/index.tsx +11 -7
- package/src/api/start/__integration__/__fixtures__/tramvai.json +6 -17
- package/src/api/start/__integration__/start.test.ts +1 -12
- package/src/api/start/providers/application/shared.ts +2 -2
- package/src/api/start/providers/child-app/shared.ts +9 -14
- package/src/api/start/providers/module/shared.ts +19 -30
- package/src/api/start/utils/banner.ts +3 -2
- package/src/api/start/utils/tips/tips.ts +11 -8
- package/src/api/start-prod/providers/application.ts +10 -14
- package/src/api/start-prod/providers/child-app.ts +4 -5
- package/src/api/start-prod/providers/shared.ts +4 -8
- package/src/builder/webpack/devServer/client.ts +22 -15
- package/src/builder/webpack/devServer/notifier.ts +6 -6
- package/src/builder/webpack/devServer/pool/process/pool.ts +3 -3
- package/src/builder/webpack/devServer/pool/thread/pool.ts +7 -0
- package/src/builder/webpack/devServer/server.ts +13 -6
- package/src/builder/webpack/providers/analyze/shared.ts +3 -2
- package/src/builder/webpack/providers/build/application/server.ts +5 -1
- package/src/builder/webpack/providers/build/client.ts +3 -2
- package/src/builder/webpack/providers/build/server.ts +1 -1
- package/src/builder/webpack/tokens.ts +4 -3
- package/src/builder/webpack/utils/copyBuildFile.ts +4 -5
- package/src/builder/webpack/utils/copyStatsJsonFile.ts +5 -2
- package/src/cli/CLI.ts +6 -6
- package/src/cli/index.ts +1 -1
- package/src/commands/analyze/command.ts +1 -1
- package/src/commands/benchmark/command.ts +1 -1
- package/src/commands/build/command.ts +2 -2
- package/src/commands/new/new.ts +0 -1
- package/src/commands/new/questions/packageManager.ts +1 -1
- package/src/commands/new/questions/template.ts +1 -1
- package/src/commands/new/questions/testingFramework.ts +1 -1
- package/src/commands/new/questions/type.ts +1 -1
- package/src/commands/new/steps/initializationGit.ts +1 -1
- package/src/commands/new/templates/app/monorepo/tramvai.json.hbs +6 -32
- package/src/commands/new/templates/app/multirepo/tramvai.json.hbs +6 -23
- package/src/commands/new/templates/child-app/monorepo/tramvai.json.hbs +3 -18
- package/src/commands/new/templates/child-app/multirepo/tramvai.json.hbs +3 -9
- package/src/commands/start/command.ts +2 -2
- package/src/commands/start-prod/command.ts +2 -2
- package/src/commands/static/application.ts +5 -14
- package/src/commands/static/command.ts +1 -1
- package/src/commands/static/generate.ts +2 -2
- package/src/commands/static/server.ts +5 -2
- package/src/commands/static/staticServer.ts +6 -3
- package/src/commands/update/updatePackageJson.ts +6 -2
- package/src/config/configManager.spec.ts +49 -0
- package/src/config/configManager.ts +123 -197
- package/src/config/showConfig.ts +2 -2
- package/src/config/validate.ts +14 -25
- package/src/di/tokens/config.ts +2 -1
- package/src/library/babel/index.ts +1 -0
- package/src/library/swc/__integration__/swc.build.test.ts +3 -21
- package/src/library/swc/__integration__/swc.start.test.ts +3 -21
- package/src/library/swc/index.ts +1 -1
- package/src/library/webpack/application/client/common.ts +7 -7
- package/src/library/webpack/application/client/dev.ts +9 -9
- package/src/library/webpack/application/client/prod/optimization/splitChunks.ts +43 -44
- package/src/library/webpack/application/client/prod.ts +3 -5
- package/src/library/webpack/application/server/common.ts +5 -8
- package/src/library/webpack/application/server/dev.ts +5 -6
- package/src/library/webpack/application/server/prod.ts +3 -9
- package/src/library/webpack/blocks/apiResolve.ts +1 -1
- package/src/library/webpack/blocks/configResolve.ts +2 -2
- package/src/library/webpack/blocks/configToEnv.ts +5 -2
- package/src/library/webpack/blocks/css.ts +26 -17
- package/src/library/webpack/blocks/extractCssPlugin.ts +11 -10
- package/src/library/webpack/blocks/filesClient.ts +52 -50
- package/src/library/webpack/blocks/filesServer.ts +4 -3
- package/src/library/webpack/blocks/js.ts +3 -2
- package/src/library/webpack/blocks/nodeClient.ts +4 -3
- package/src/library/webpack/blocks/optimize.ts +5 -6
- package/src/library/webpack/blocks/pagesResolve.ts +1 -1
- package/src/library/webpack/blocks/postcssAssets.ts +6 -7
- package/src/library/webpack/blocks/serverInline.ts +2 -1
- package/src/library/webpack/blocks/ts.ts +2 -1
- package/src/library/webpack/child-app/client/common.ts +3 -3
- package/src/library/webpack/child-app/client/dev.ts +8 -8
- package/src/library/webpack/child-app/client/prod.ts +2 -2
- package/src/library/webpack/child-app/common.ts +2 -2
- package/src/library/webpack/child-app/server/common.ts +3 -3
- package/src/library/webpack/child-app/server/dev.ts +2 -2
- package/src/library/webpack/child-app/server/prod.ts +2 -2
- package/src/library/webpack/common/client/prod.ts +10 -6
- package/src/library/webpack/common/main.ts +9 -4
- package/src/library/webpack/common/server/prod.ts +10 -6
- package/src/library/webpack/index.ts +2 -3
- package/src/library/webpack/loaders/image-loader/index.ts +2 -1
- package/src/library/webpack/loaders/pagesResolve.ts +17 -5
- package/src/library/webpack/loaders/replaceContent.ts +11 -2
- package/src/library/webpack/module/client/common.ts +1 -1
- package/src/library/webpack/module/externals.ts +1 -1
- package/src/library/webpack/module/resolveExternal.ts +1 -1
- package/src/library/webpack/module/server/common.ts +1 -1
- package/src/library/webpack/plugins/LazyModuleInitialization.ts +6 -1
- package/src/library/webpack/plugins/WebpackBar/utils/index.ts +8 -8
- package/src/library/webpack/plugins/WebpackBar/utils/webpack.ts +1 -1
- package/src/library/webpack/types/webpack.ts +2 -2
- package/src/library/webpack/utils/files.ts +4 -3
- package/src/library/webpack/utils/transpiler.ts +6 -11
- package/src/library/webpack/utils/workersPool.ts +6 -9
- package/src/models/config.spec.ts +352 -0
- package/src/models/config.ts +41 -9
- package/src/schema/ConfigSchema.ts +15 -4
- package/src/schema/autogeneratedSchema.json +1808 -2074
- package/src/schema/tramvai.spec.ts +89 -184
- package/src/typings/configEntry/application.ts +85 -87
- package/src/typings/configEntry/child-app.ts +10 -30
- package/src/typings/configEntry/cli.ts +271 -0
- package/src/typings/configEntry/common.ts +26 -278
- package/src/typings/configEntry/module.ts +11 -30
- package/src/typings/configEntry/package.ts +3 -1
- package/src/ui/commander.ts +1 -1
- package/src/utils/applyTemplate.ts +2 -2
- package/src/utils/safeRequire.ts +6 -1
- package/src/utils/webpackBuild.ts +4 -3
- package/lib/library/webpack/plugins/DedupePlugin/DedupePlugin.d.ts +0 -37
- package/lib/library/webpack/plugins/DedupePlugin/DedupePlugin.js +0 -241
- package/lib/library/webpack/plugins/DedupePlugin/DedupePlugin.js.map +0 -1
- package/lib/library/webpack/plugins/DedupePlugin/index.d.ts +0 -1
- package/lib/library/webpack/plugins/DedupePlugin/index.js +0 -6
- package/lib/library/webpack/plugins/DedupePlugin/index.js.map +0 -1
- package/lib/typings/configEntry/CheckAsyncTsConfig.d.ts +0 -13
- package/lib/typings/configEntry/CheckAsyncTsConfig.js.map +0 -1
- package/src/library/webpack/plugins/DedupePlugin/DedupePlugin.spec.ts +0 -95
- package/src/library/webpack/plugins/DedupePlugin/DedupePlugin.ts +0 -307
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-1/index.js +0 -3
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-1/node_modules/package-dep/index.js +0 -1
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-1/node_modules/package-dep/package.json +0 -7
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-1/package.json +0 -7
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-2/index.js +0 -3
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-2/node_modules/package-dep/index.js +0 -1
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-2/node_modules/package-dep/package.json +0 -7
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-2/package.json +0 -7
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-3/index.js +0 -3
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-3/node_modules/package-dep/index.js +0 -1
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-3/node_modules/package-dep/package.json +0 -7
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-3/package.json +0 -7
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-dep/index.js +0 -1
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-dep/package.json +0 -7
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-esm-1/index.js +0 -3
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-esm-1/node_modules/package-esm-dep/index.js +0 -1
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-esm-1/node_modules/package-esm-dep/package.json +0 -8
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-esm-1/package.json +0 -8
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-esm-2/index.js +0 -3
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-esm-2/node_modules/package-esm-dep/index.js +0 -1
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-esm-2/node_modules/package-esm-dep/package.json +0 -8
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/node_modules/package-esm-2/package.json +0 -8
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/package-lock.json +0 -0
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/package.json +0 -14
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/src/index.js +0 -9
- package/src/library/webpack/plugins/DedupePlugin/__fixtures__/dedupe/tramvai.json +0 -67
- package/src/library/webpack/plugins/DedupePlugin/__integration__/DedupePlugin.test.ts +0 -90
- package/src/library/webpack/plugins/DedupePlugin/index.ts +0 -1
- package/src/typings/configEntry/CheckAsyncTsConfig.ts +0 -15
|
@@ -5,13 +5,14 @@ import {
|
|
|
5
5
|
COMMAND_PARAMETERS_TOKEN,
|
|
6
6
|
CONFIG_ENTRY_TOKEN,
|
|
7
7
|
} from '../../../di/tokens';
|
|
8
|
-
import {
|
|
8
|
+
import { createConfigManager } from '../../../config/configManager';
|
|
9
|
+
import type { CliConfigEntry } from '../../../typings/configEntry/cli';
|
|
9
10
|
|
|
10
11
|
export const sharedProviders: readonly Provider[] = [
|
|
11
12
|
provide({
|
|
12
13
|
provide: CONFIG_MANAGER_TOKEN,
|
|
13
14
|
useFactory: ({ configEntry, parameters }) => {
|
|
14
|
-
return
|
|
15
|
+
return createConfigManager(configEntry as CliConfigEntry, {
|
|
15
16
|
...parameters,
|
|
16
17
|
env: 'production',
|
|
17
18
|
buildType: 'client',
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import React from 'react';
|
|
2
1
|
import ReactDOM from 'react-dom';
|
|
3
2
|
import App from './App';
|
|
4
3
|
|
|
@@ -9,12 +8,19 @@ const bundlesMap = {
|
|
|
9
8
|
third: () => import('./bundles/third'),
|
|
10
9
|
};
|
|
11
10
|
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
if (url.searchParams.has('bundle')) {
|
|
15
|
-
bundlesMap[url.searchParams.get('bundle')]().then(({ default: name }) =>
|
|
16
|
-
console.log(`loaded bundle ${name}`)
|
|
17
|
-
);
|
|
11
|
+
if (typeof window === 'undefined') {
|
|
12
|
+
require('./server.tsx')
|
|
18
13
|
}
|
|
19
14
|
|
|
20
|
-
|
|
15
|
+
if (typeof window !== 'undefined') {
|
|
16
|
+
const url = new URL(window.location.href);
|
|
17
|
+
|
|
18
|
+
if (url.searchParams.has('bundle')) {
|
|
19
|
+
bundlesMap[url.searchParams.get('bundle')]().then(({ default: name }) =>
|
|
20
|
+
console.log(`loaded bundle ${name}`)
|
|
21
|
+
);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
ReactDOM.hydrate(<App />, document.getElementById('root'));
|
|
25
|
+
|
|
26
|
+
}
|
|
@@ -5,16 +5,7 @@
|
|
|
5
5
|
"name": "app",
|
|
6
6
|
"root": "app",
|
|
7
7
|
"type": "application",
|
|
8
|
-
"
|
|
9
|
-
"build": {
|
|
10
|
-
"options": {
|
|
11
|
-
"server": "app/server.tsx"
|
|
12
|
-
},
|
|
13
|
-
"configurations": {
|
|
14
|
-
"modern": false
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
}
|
|
8
|
+
"modern": false
|
|
18
9
|
},
|
|
19
10
|
"module": {
|
|
20
11
|
"name": "module",
|
|
@@ -55,19 +55,10 @@ describe('@tramvai/cli build command', () => {
|
|
|
55
55
|
name: 'app',
|
|
56
56
|
type: 'application',
|
|
57
57
|
root: resolve(FIXTURES_DIR, 'app'),
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
},
|
|
63
|
-
configurations: {
|
|
64
|
-
modern: false,
|
|
65
|
-
definePlugin: {
|
|
66
|
-
dev: {
|
|
67
|
-
IS_REACT_APP: true,
|
|
68
|
-
},
|
|
69
|
-
},
|
|
70
|
-
},
|
|
58
|
+
modern: false,
|
|
59
|
+
define: {
|
|
60
|
+
development: {
|
|
61
|
+
IS_REACT_APP: 'true',
|
|
71
62
|
},
|
|
72
63
|
},
|
|
73
64
|
},
|
|
@@ -2,13 +2,11 @@ import type { Container } from '@tinkoff/dippy';
|
|
|
2
2
|
import type { Result } from './index';
|
|
3
3
|
import { sharedProviders } from './providers/shared';
|
|
4
4
|
import { registerProviders } from '../../utils/di';
|
|
5
|
-
import { ABSTRACT_BUILDER_FACTORY_TOKEN
|
|
5
|
+
import { ABSTRACT_BUILDER_FACTORY_TOKEN } from '../../di/tokens';
|
|
6
6
|
|
|
7
7
|
export const buildChildApp = async (di: Container): Result => {
|
|
8
8
|
registerProviders(di, sharedProviders);
|
|
9
9
|
|
|
10
|
-
const configManager = di.get(CONFIG_MANAGER_TOKEN);
|
|
11
|
-
|
|
12
10
|
const builderFactory = di.get(ABSTRACT_BUILDER_FACTORY_TOKEN);
|
|
13
11
|
const builder = await builderFactory.createBuilder('webpack', {
|
|
14
12
|
options: {
|
|
@@ -18,7 +16,9 @@ export const buildChildApp = async (di: Container): Result => {
|
|
|
18
16
|
});
|
|
19
17
|
|
|
20
18
|
const builderBuild = await builder.build({
|
|
21
|
-
|
|
19
|
+
// child-app either should be built for legacy code always
|
|
20
|
+
// or should be smart loaded depending on browser capabilities
|
|
21
|
+
modern: false,
|
|
22
22
|
});
|
|
23
23
|
|
|
24
24
|
return {
|
package/src/api/build/module.ts
CHANGED
|
@@ -2,13 +2,11 @@ import type { Container } from '@tinkoff/dippy';
|
|
|
2
2
|
import type { Result } from './index';
|
|
3
3
|
import { sharedProviders } from './providers/shared';
|
|
4
4
|
import { registerProviders } from '../../utils/di';
|
|
5
|
-
import { ABSTRACT_BUILDER_FACTORY_TOKEN
|
|
5
|
+
import { ABSTRACT_BUILDER_FACTORY_TOKEN } from '../../di/tokens';
|
|
6
6
|
|
|
7
7
|
export const buildModule = async (di: Container): Result => {
|
|
8
8
|
registerProviders(di, [...sharedProviders]);
|
|
9
9
|
|
|
10
|
-
const configManager = di.get(CONFIG_MANAGER_TOKEN);
|
|
11
|
-
|
|
12
10
|
const builderFactory = di.get(ABSTRACT_BUILDER_FACTORY_TOKEN);
|
|
13
11
|
const builder = await builderFactory.createBuilder('webpack', {
|
|
14
12
|
options: {
|
|
@@ -18,7 +16,7 @@ export const buildModule = async (di: Container): Result => {
|
|
|
18
16
|
});
|
|
19
17
|
|
|
20
18
|
const builderBuild = await builder.build({
|
|
21
|
-
modern:
|
|
19
|
+
modern: false,
|
|
22
20
|
});
|
|
23
21
|
|
|
24
22
|
return {
|
|
@@ -4,7 +4,7 @@ import {
|
|
|
4
4
|
COMMAND_PARAMETERS_TOKEN,
|
|
5
5
|
CONFIG_ENTRY_TOKEN,
|
|
6
6
|
} from '../../../di/tokens';
|
|
7
|
-
import {
|
|
7
|
+
import { createConfigManager } from '../../../config/configManager';
|
|
8
8
|
import type { ApplicationConfigEntry } from '../../../typings/configEntry/application';
|
|
9
9
|
import type { Params } from '../index';
|
|
10
10
|
|
|
@@ -18,7 +18,7 @@ export const sharedProviders: readonly Provider[] = [
|
|
|
18
18
|
configEntry: ApplicationConfigEntry;
|
|
19
19
|
parameters: Params;
|
|
20
20
|
}) => {
|
|
21
|
-
return
|
|
21
|
+
return createConfigManager(configEntry, {
|
|
22
22
|
...parameters,
|
|
23
23
|
env: 'production',
|
|
24
24
|
buildType: 'client',
|
package/src/api/index.ts
CHANGED
|
@@ -14,12 +14,16 @@ import type { AnalyzeCommand } from './analyze';
|
|
|
14
14
|
import type { StartProdCommand } from './start-prod';
|
|
15
15
|
|
|
16
16
|
export * from '../di/tokens';
|
|
17
|
-
export { ConfigManager } from '../config/configManager';
|
|
17
|
+
export { ConfigManager, createConfigManager } from '../config/configManager';
|
|
18
|
+
export { CliConfigEntry } from '../typings/configEntry/cli';
|
|
19
|
+
export { ApplicationConfigEntry } from '../typings/configEntry/application';
|
|
20
|
+
export { ChildAppConfigEntry } from '../typings/configEntry/child-app';
|
|
21
|
+
export { ConvertToSchema } from '../schema/ConfigSchema';
|
|
18
22
|
export { ConfigManager as ConfigManagerValidator } from '../models/config';
|
|
19
23
|
export { getTramvaiConfig } from '../utils/getTramvaiConfig';
|
|
20
24
|
export { syncJsonFile } from '../utils/syncJsonFile';
|
|
21
25
|
export { babelConfigFactory } from '../library/babel';
|
|
22
|
-
export {
|
|
26
|
+
export { filesClientWebpackRulesFactory } from '../library/webpack/blocks/filesClient';
|
|
23
27
|
export { cssWebpackRulesFactory } from '../library/webpack/blocks/css';
|
|
24
28
|
export { lessWebpackRulesFactory } from '../library/webpack/blocks/less';
|
|
25
29
|
export { postcssAssetsWebpackRulesFactory } from '../library/webpack/blocks/postcssAssets';
|
|
@@ -1,17 +1,16 @@
|
|
|
1
|
+
import type { WithRootDir } from './withRootDir';
|
|
1
2
|
import type { ApplicationConfigEntry } from '../../../typings/configEntry/application';
|
|
2
3
|
import type { ModuleConfigEntry } from '../../../typings/configEntry/module';
|
|
3
|
-
import type { WithRootDir } from './withRootDir';
|
|
4
4
|
import type { PackageConfigEntry } from '../../../typings/configEntry/package';
|
|
5
5
|
import type { ChildAppConfigEntry } from '../../../typings/configEntry/child-app';
|
|
6
|
+
import type { ConvertToSchema } from '../../../schema/ConfigSchema';
|
|
6
7
|
|
|
7
8
|
export type WithConfig<T> = WithRootDir<T> &
|
|
8
9
|
(
|
|
9
10
|
| { target: string }
|
|
10
11
|
| {
|
|
11
|
-
config:
|
|
12
|
-
|
|
|
13
|
-
|
|
14
|
-
| PackageConfigEntry
|
|
15
|
-
| ChildAppConfigEntry;
|
|
12
|
+
config: ConvertToSchema<
|
|
13
|
+
ApplicationConfigEntry | ModuleConfigEntry | PackageConfigEntry | ChildAppConfigEntry
|
|
14
|
+
>;
|
|
16
15
|
}
|
|
17
16
|
);
|
|
@@ -8,12 +8,16 @@ const bundlesMap = {
|
|
|
8
8
|
third: () => import('./bundles/third'),
|
|
9
9
|
};
|
|
10
10
|
|
|
11
|
-
|
|
11
|
+
if (typeof window === 'undefined') {
|
|
12
|
+
require('./server')
|
|
13
|
+
} else {
|
|
14
|
+
const url = new URL(window.location.href);
|
|
12
15
|
|
|
13
|
-
if (url.searchParams.has('bundle')) {
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
}
|
|
16
|
+
if (url.searchParams.has('bundle')) {
|
|
17
|
+
bundlesMap[
|
|
18
|
+
url.searchParams.get('bundle') as keyof typeof bundlesMap
|
|
19
|
+
]().then(({ default: name }: { default: string }) => console.log(`loaded bundle ${name}`));
|
|
20
|
+
}
|
|
18
21
|
|
|
19
|
-
ReactDOM.hydrate(<App />, document.getElementById('root'));
|
|
22
|
+
ReactDOM.hydrate(<App />, document.getElementById('root'));
|
|
23
|
+
}
|
|
@@ -5,23 +5,12 @@
|
|
|
5
5
|
"name": "app",
|
|
6
6
|
"root": "app",
|
|
7
7
|
"type": "application",
|
|
8
|
-
"
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
"configurations": {
|
|
15
|
-
"fileSystemPages": {
|
|
16
|
-
"enable": true
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
},
|
|
20
|
-
"serve": {
|
|
21
|
-
"configurations": {
|
|
22
|
-
"hotRefresh": true
|
|
23
|
-
}
|
|
24
|
-
}
|
|
8
|
+
"serverApiDir": "app/api",
|
|
9
|
+
"fileSystemPages": {
|
|
10
|
+
"enabled": true
|
|
11
|
+
},
|
|
12
|
+
"hotRefresh": {
|
|
13
|
+
"enabled": true
|
|
25
14
|
}
|
|
26
15
|
},
|
|
27
16
|
"module": {
|
|
@@ -93,9 +93,7 @@ describe('@tramvai/cli start command', () => {
|
|
|
93
93
|
port: serverPort,
|
|
94
94
|
staticPort: staticServerPort,
|
|
95
95
|
type: 'application',
|
|
96
|
-
|
|
97
|
-
name: 'app',
|
|
98
|
-
}),
|
|
96
|
+
name: 'app',
|
|
99
97
|
});
|
|
100
98
|
|
|
101
99
|
const { body: browserslistConfig } = await request
|
|
@@ -136,8 +134,6 @@ describe('@tramvai/cli start command', () => {
|
|
|
136
134
|
|
|
137
135
|
await page.goto(serverUrl);
|
|
138
136
|
|
|
139
|
-
console.log(await page.$eval('body', (node) => node.innerHTML));
|
|
140
|
-
|
|
141
137
|
expect(
|
|
142
138
|
await page.$eval('#cmp', (node) => (node as HTMLElement).innerText)
|
|
143
139
|
).toMatchInlineSnapshot(`"Cmp test: start"`);
|
|
@@ -173,13 +169,6 @@ describe('@tramvai/cli start command', () => {
|
|
|
173
169
|
name: 'app',
|
|
174
170
|
type: 'application',
|
|
175
171
|
root,
|
|
176
|
-
commands: {
|
|
177
|
-
build: {
|
|
178
|
-
options: {
|
|
179
|
-
server: resolve(root, 'server.tsx'),
|
|
180
|
-
},
|
|
181
|
-
},
|
|
182
|
-
},
|
|
183
172
|
},
|
|
184
173
|
});
|
|
185
174
|
|
|
@@ -10,7 +10,7 @@ import {
|
|
|
10
10
|
import { stopServer } from '../../utils/stopServer';
|
|
11
11
|
import type { ApplicationConfigEntry } from '../../../../typings/configEntry/application';
|
|
12
12
|
import type { Params } from '../../index';
|
|
13
|
-
import {
|
|
13
|
+
import { createConfigManager } from '../../../../config/configManager';
|
|
14
14
|
import { createServer } from '../../utils/createServer';
|
|
15
15
|
import { listenServer } from '../../utils/listenServer';
|
|
16
16
|
import { getListeningPort } from '../../utils/getListeningPort';
|
|
@@ -29,7 +29,7 @@ export const sharedProviders: readonly Provider[] = [
|
|
|
29
29
|
server: typeof SERVER_TOKEN;
|
|
30
30
|
staticServer: typeof STATIC_SERVER_TOKEN;
|
|
31
31
|
}) => {
|
|
32
|
-
return
|
|
32
|
+
return createConfigManager(configEntry, {
|
|
33
33
|
...parameters,
|
|
34
34
|
env: 'development',
|
|
35
35
|
buildType: 'client',
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { Provider } from '@tinkoff/dippy';
|
|
2
|
+
import { provide } from '@tinkoff/dippy';
|
|
2
3
|
import { CLOSE_HANDLER_TOKEN, INIT_HANDLER_TOKEN } from '../../tokens';
|
|
3
4
|
import {
|
|
4
5
|
CONFIG_MANAGER_TOKEN,
|
|
@@ -8,23 +9,17 @@ import {
|
|
|
8
9
|
} from '../../../../di/tokens';
|
|
9
10
|
import type { ChildAppConfigEntry } from '../../../../typings/configEntry/child-app';
|
|
10
11
|
import type { Params } from '../../index';
|
|
11
|
-
import { ConfigManager } from '../../../../config/configManager';
|
|
12
12
|
import { closeWorkerPoolTranspiler } from '../../../../library/webpack/utils/workersPool';
|
|
13
13
|
import { stopServer } from '../../utils/stopServer';
|
|
14
14
|
import { createServer } from '../../utils/createServer';
|
|
15
15
|
import { listenServer } from '../../utils/listenServer';
|
|
16
|
+
import { createConfigManager } from '../../../../config/configManager';
|
|
16
17
|
|
|
17
18
|
export const sharedProviders: readonly Provider[] = [
|
|
18
|
-
{
|
|
19
|
+
provide({
|
|
19
20
|
provide: CONFIG_MANAGER_TOKEN,
|
|
20
|
-
useFactory: ({
|
|
21
|
-
configEntry,
|
|
22
|
-
parameters,
|
|
23
|
-
}: {
|
|
24
|
-
configEntry: ChildAppConfigEntry;
|
|
25
|
-
parameters: Params;
|
|
26
|
-
}) => {
|
|
27
|
-
return new ConfigManager(configEntry, {
|
|
21
|
+
useFactory: ({ configEntry, parameters }) => {
|
|
22
|
+
return createConfigManager(configEntry as ChildAppConfigEntry, {
|
|
28
23
|
...parameters,
|
|
29
24
|
env: 'development',
|
|
30
25
|
port: parameters.port ?? 4040,
|
|
@@ -35,7 +30,7 @@ export const sharedProviders: readonly Provider[] = [
|
|
|
35
30
|
configEntry: CONFIG_ENTRY_TOKEN,
|
|
36
31
|
parameters: COMMAND_PARAMETERS_TOKEN,
|
|
37
32
|
},
|
|
38
|
-
},
|
|
33
|
+
}),
|
|
39
34
|
{
|
|
40
35
|
provide: STATIC_SERVER_TOKEN,
|
|
41
36
|
useFactory: createServer,
|
|
@@ -83,10 +78,10 @@ export const sharedProviders: readonly Provider[] = [
|
|
|
83
78
|
staticServer: STATIC_SERVER_TOKEN,
|
|
84
79
|
},
|
|
85
80
|
},
|
|
86
|
-
{
|
|
81
|
+
provide({
|
|
87
82
|
provide: CLOSE_HANDLER_TOKEN,
|
|
88
83
|
multi: true,
|
|
89
|
-
useFactory: ({ configManager }
|
|
84
|
+
useFactory: ({ configManager }) => {
|
|
90
85
|
return async () => {
|
|
91
86
|
await closeWorkerPoolTranspiler(configManager);
|
|
92
87
|
};
|
|
@@ -94,5 +89,5 @@ export const sharedProviders: readonly Provider[] = [
|
|
|
94
89
|
deps: {
|
|
95
90
|
configManager: CONFIG_MANAGER_TOKEN,
|
|
96
91
|
},
|
|
97
|
-
},
|
|
92
|
+
}),
|
|
98
93
|
] as const;
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import type { Provider } from '@tinkoff/dippy';
|
|
2
|
+
import { provide } from '@tinkoff/dippy';
|
|
2
3
|
import { CLOSE_HANDLER_TOKEN, INIT_HANDLER_TOKEN } from '../../tokens';
|
|
3
4
|
import {
|
|
4
5
|
CONFIG_MANAGER_TOKEN,
|
|
@@ -6,25 +7,19 @@ import {
|
|
|
6
7
|
COMMAND_PARAMETERS_TOKEN,
|
|
7
8
|
STATIC_SERVER_TOKEN,
|
|
8
9
|
} from '../../../../di/tokens';
|
|
9
|
-
import type {
|
|
10
|
-
import
|
|
11
|
-
import { ConfigManager } from '../../../../config/configManager';
|
|
10
|
+
import type { ConfigManager } from '../../../../config/configManager';
|
|
11
|
+
import { createConfigManager } from '../../../../config/configManager';
|
|
12
12
|
import { closeWorkerPoolTranspiler } from '../../../../library/webpack/utils/workersPool';
|
|
13
13
|
import { stopServer } from '../../utils/stopServer';
|
|
14
14
|
import { createServer } from '../../utils/createServer';
|
|
15
15
|
import { listenServer } from '../../utils/listenServer';
|
|
16
|
+
import type { ModuleConfigEntry } from '../../../../typings/configEntry/module';
|
|
16
17
|
|
|
17
18
|
export const sharedProviders: readonly Provider[] = [
|
|
18
|
-
{
|
|
19
|
+
provide({
|
|
19
20
|
provide: CONFIG_MANAGER_TOKEN,
|
|
20
|
-
useFactory: ({
|
|
21
|
-
configEntry,
|
|
22
|
-
parameters,
|
|
23
|
-
}: {
|
|
24
|
-
configEntry: ModuleConfigEntry;
|
|
25
|
-
parameters: Params;
|
|
26
|
-
}) => {
|
|
27
|
-
return new ConfigManager(configEntry, {
|
|
21
|
+
useFactory: ({ configEntry, parameters }) => {
|
|
22
|
+
return createConfigManager(configEntry as ModuleConfigEntry, {
|
|
28
23
|
...parameters,
|
|
29
24
|
env: 'development',
|
|
30
25
|
port: parameters.port ?? 4040,
|
|
@@ -35,21 +30,15 @@ export const sharedProviders: readonly Provider[] = [
|
|
|
35
30
|
configEntry: CONFIG_ENTRY_TOKEN,
|
|
36
31
|
parameters: COMMAND_PARAMETERS_TOKEN,
|
|
37
32
|
},
|
|
38
|
-
},
|
|
39
|
-
{
|
|
33
|
+
}),
|
|
34
|
+
provide({
|
|
40
35
|
provide: STATIC_SERVER_TOKEN,
|
|
41
36
|
useFactory: createServer,
|
|
42
|
-
},
|
|
43
|
-
{
|
|
37
|
+
}),
|
|
38
|
+
provide({
|
|
44
39
|
provide: INIT_HANDLER_TOKEN,
|
|
45
40
|
multi: true,
|
|
46
|
-
useFactory: ({
|
|
47
|
-
staticServer,
|
|
48
|
-
parameters,
|
|
49
|
-
}: {
|
|
50
|
-
staticServer: typeof STATIC_SERVER_TOKEN;
|
|
51
|
-
parameters: Params;
|
|
52
|
-
}) => {
|
|
41
|
+
useFactory: ({ staticServer, parameters }) => {
|
|
53
42
|
return async function staticServerListen() {
|
|
54
43
|
const { host = 'localhost', port = 4040 } = parameters;
|
|
55
44
|
|
|
@@ -70,11 +59,11 @@ export const sharedProviders: readonly Provider[] = [
|
|
|
70
59
|
staticServer: STATIC_SERVER_TOKEN,
|
|
71
60
|
parameters: COMMAND_PARAMETERS_TOKEN,
|
|
72
61
|
},
|
|
73
|
-
},
|
|
74
|
-
{
|
|
62
|
+
}),
|
|
63
|
+
provide({
|
|
75
64
|
provide: CLOSE_HANDLER_TOKEN,
|
|
76
65
|
multi: true,
|
|
77
|
-
useFactory: ({ staticServer }
|
|
66
|
+
useFactory: ({ staticServer }) => {
|
|
78
67
|
return () => {
|
|
79
68
|
return stopServer(staticServer);
|
|
80
69
|
};
|
|
@@ -82,11 +71,11 @@ export const sharedProviders: readonly Provider[] = [
|
|
|
82
71
|
deps: {
|
|
83
72
|
staticServer: STATIC_SERVER_TOKEN,
|
|
84
73
|
},
|
|
85
|
-
},
|
|
86
|
-
{
|
|
74
|
+
}),
|
|
75
|
+
provide({
|
|
87
76
|
provide: CLOSE_HANDLER_TOKEN,
|
|
88
77
|
multi: true,
|
|
89
|
-
useFactory: ({ configManager }
|
|
78
|
+
useFactory: ({ configManager }) => {
|
|
90
79
|
return async () => {
|
|
91
80
|
closeWorkerPoolTranspiler(configManager);
|
|
92
81
|
};
|
|
@@ -94,5 +83,5 @@ export const sharedProviders: readonly Provider[] = [
|
|
|
94
83
|
deps: {
|
|
95
84
|
configManager: CONFIG_MANAGER_TOKEN,
|
|
96
85
|
},
|
|
97
|
-
},
|
|
86
|
+
}),
|
|
98
87
|
] as const;
|
|
@@ -3,6 +3,7 @@ import type { Container } from '@tinkoff/dippy';
|
|
|
3
3
|
import { successBox } from '../../../utils/formatting';
|
|
4
4
|
import { UI_SHOW_BANNER_TOKEN, CONFIG_MANAGER_TOKEN, STDOUT_TOKEN } from '../../../di/tokens';
|
|
5
5
|
import { getDocUrl, getTip } from './tips';
|
|
6
|
+
import { isApplication } from '../../../config/validate';
|
|
6
7
|
|
|
7
8
|
const label = (name) => chalk.bold.cyan(`▸ ${name}:`);
|
|
8
9
|
const link = (url) => chalk.underline.blue(url);
|
|
@@ -24,9 +25,9 @@ export function showBanner(di: Container) {
|
|
|
24
25
|
titleLines.push(`${label('Type')} ${config.type}`);
|
|
25
26
|
}
|
|
26
27
|
titleLines.push(`${label('Modern')} ${config.modern}`);
|
|
27
|
-
titleLines.push(`${label('ReactRefresh')} ${config.hotRefresh}`);
|
|
28
|
+
titleLines.push(`${label('ReactRefresh')} ${config.hotRefresh.enabled}`);
|
|
28
29
|
|
|
29
|
-
if (config.
|
|
30
|
+
if (isApplication(config) && config.fileSystemPages.enabled) {
|
|
30
31
|
titleLines.push(`${label('FileSystemPages')} true`);
|
|
31
32
|
}
|
|
32
33
|
|
|
@@ -3,6 +3,7 @@ import { existsSync } from 'fs-extra';
|
|
|
3
3
|
import { sync as resolveSync } from 'resolve';
|
|
4
4
|
import { CONFIG_MANAGER_TOKEN } from '../../../../di/tokens';
|
|
5
5
|
import type { TramvaiTip } from './types';
|
|
6
|
+
import { isApplication } from '../../../../config/validate';
|
|
6
7
|
|
|
7
8
|
const DEFAULT_ROOT_DIR = process.cwd();
|
|
8
9
|
|
|
@@ -22,10 +23,7 @@ Consider to test out swc support.`,
|
|
|
22
23
|
isApplicable(di) {
|
|
23
24
|
const configManager = di.get(CONFIG_MANAGER_TOKEN);
|
|
24
25
|
|
|
25
|
-
return
|
|
26
|
-
configManager.serve.configurations?.experiments?.transpilation?.loader !== 'swc' &&
|
|
27
|
-
configManager.build.configurations?.experiments?.transpilation?.loader !== 'swc'
|
|
28
|
-
);
|
|
26
|
+
return configManager.experiments?.transpilation?.loader !== 'swc';
|
|
29
27
|
},
|
|
30
28
|
},
|
|
31
29
|
{
|
|
@@ -43,7 +41,7 @@ Consider to test out swc support.`,
|
|
|
43
41
|
isApplicable(di) {
|
|
44
42
|
const configManager = di.get(CONFIG_MANAGER_TOKEN);
|
|
45
43
|
|
|
46
|
-
return configManager.hotRefresh !== true;
|
|
44
|
+
return configManager.hotRefresh.enabled !== true;
|
|
47
45
|
},
|
|
48
46
|
},
|
|
49
47
|
{
|
|
@@ -53,9 +51,14 @@ It may reduce the boilerplate code required with bundles`,
|
|
|
53
51
|
isApplicable(di) {
|
|
54
52
|
const configManager = di.get(CONFIG_MANAGER_TOKEN);
|
|
55
53
|
const { rootDir, root } = configManager;
|
|
56
|
-
const { fileSystemPages } = configManager.build.configurations;
|
|
57
54
|
|
|
58
|
-
if (!
|
|
55
|
+
if (!isApplication(configManager)) {
|
|
56
|
+
return false;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
const { fileSystemPages } = configManager;
|
|
60
|
+
|
|
61
|
+
if (!fileSystemPages.enabled) {
|
|
59
62
|
return true;
|
|
60
63
|
}
|
|
61
64
|
|
|
@@ -107,7 +110,7 @@ So you can remove alias config from tramvai.json`,
|
|
|
107
110
|
isApplicable(di) {
|
|
108
111
|
const configManager = di.get(CONFIG_MANAGER_TOKEN);
|
|
109
112
|
|
|
110
|
-
return !!configManager.
|
|
113
|
+
return !!configManager.alias;
|
|
111
114
|
},
|
|
112
115
|
},
|
|
113
116
|
{
|
|
@@ -8,17 +8,19 @@ import {
|
|
|
8
8
|
CONFIG_MANAGER_TOKEN,
|
|
9
9
|
} from '../../../di/tokens';
|
|
10
10
|
import type { Params } from '../index';
|
|
11
|
-
import { ConfigManager } from '../../index';
|
|
12
11
|
import type { ConfigEntry } from '../../../typings/configEntry/common';
|
|
13
12
|
import { CLOSE_HANDLER_TOKEN, SERVER_PROCESS_TOKEN } from '../tokens';
|
|
14
13
|
import { DEBUG_ARGV } from '../../../config/constants';
|
|
15
14
|
import { safeRequire } from '../../../utils/safeRequire';
|
|
15
|
+
import type { ConfigManager } from '../../../config/configManager';
|
|
16
|
+
import { createConfigManager } from '../../../config/configManager';
|
|
17
|
+
import type { ApplicationConfigEntry } from '../../../typings/configEntry/application';
|
|
16
18
|
|
|
17
19
|
export const applicationsProviders: readonly Provider[] = [
|
|
18
20
|
provide({
|
|
19
21
|
provide: CONFIG_MANAGER_TOKEN,
|
|
20
22
|
useFactory: ({ configEntry, parameters }: { configEntry: ConfigEntry; parameters: Params }) => {
|
|
21
|
-
return
|
|
23
|
+
return createConfigManager(configEntry, {
|
|
22
24
|
...parameters,
|
|
23
25
|
env: 'production',
|
|
24
26
|
port: parameters.port ?? 3000,
|
|
@@ -35,19 +37,13 @@ export const applicationsProviders: readonly Provider[] = [
|
|
|
35
37
|
provide: SERVER_PROCESS_TOKEN,
|
|
36
38
|
useFactory: ({ configManager, parameters }) => {
|
|
37
39
|
const { env } = parameters;
|
|
38
|
-
const serverConfigManager =
|
|
40
|
+
const serverConfigManager = (
|
|
41
|
+
configManager as ConfigManager<ApplicationConfigEntry>
|
|
42
|
+
).withSettings({
|
|
39
43
|
buildType: 'server',
|
|
40
44
|
});
|
|
41
|
-
const {
|
|
42
|
-
|
|
43
|
-
port,
|
|
44
|
-
staticPort,
|
|
45
|
-
staticHost,
|
|
46
|
-
build: {
|
|
47
|
-
options: { outputClient },
|
|
48
|
-
},
|
|
49
|
-
} = serverConfigManager;
|
|
50
|
-
const root = serverConfigManager.getBuildPath();
|
|
45
|
+
const { debug, port, staticPort, staticHost, output } = serverConfigManager;
|
|
46
|
+
const root = serverConfigManager.buildPath;
|
|
51
47
|
|
|
52
48
|
return fork(path.resolve(root, 'server.js'), [], {
|
|
53
49
|
execArgv: debug ? DEBUG_ARGV : [],
|
|
@@ -62,7 +58,7 @@ export const applicationsProviders: readonly Provider[] = [
|
|
|
62
58
|
PORT_SERVER: `${port}`,
|
|
63
59
|
ASSETS_PREFIX:
|
|
64
60
|
process.env.ASSETS_PREFIX ??
|
|
65
|
-
`http://${staticHost}:${staticPort}/${
|
|
61
|
+
`http://${staticHost}:${staticPort}/${output.client.replace(/\/$/, '')}/`,
|
|
66
62
|
},
|
|
67
63
|
});
|
|
68
64
|
},
|