From 750f485b93e7c97ea15b66085a1713e18104b4b7 Mon Sep 17 00:00:00 2001 From: Jack Hsu Date: Tue, 22 Aug 2023 07:05:30 -0400 Subject: [PATCH] fix(web): generate .swcrc file with modern defaults when creating new webapps (#18749) --- e2e/web/src/web.test.ts | 2 +- .../application/application.spec.ts | 11 ++++ .../lib/create-application-files.ts | 61 +++++++++---------- .../application/application.spec.ts | 6 ++ .../src/generators/application/application.ts | 13 ++++ .../files/app-webpack/.babelrc__tmpl__ | 5 -- 6 files changed, 59 insertions(+), 39 deletions(-) delete mode 100644 packages/web/src/generators/application/files/app-webpack/.babelrc__tmpl__ diff --git a/e2e/web/src/web.test.ts b/e2e/web/src/web.test.ts index 5d3f79642e362..4aaa1266a8883 100644 --- a/e2e/web/src/web.test.ts +++ b/e2e/web/src/web.test.ts @@ -77,7 +77,7 @@ describe('Web Components Applications', () => { customElements.define('app-root', AppElement); ` ); - runCLI(`build ${appName} --outputHashing none --compiler babel`); + runCLI(`build ${appName} --outputHashing none`); checkFilesExist( `dist/apps/${appName}/index.html`, `dist/apps/${appName}/runtime.js`, diff --git a/packages/react/src/generators/application/application.spec.ts b/packages/react/src/generators/application/application.spec.ts index 178dea62abd34..8b89127ad9c9a 100644 --- a/packages/react/src/generators/application/application.spec.ts +++ b/packages/react/src/generators/application/application.spec.ts @@ -967,6 +967,17 @@ describe('app', () => { 'swc-loader': expect.any(String), }); }); + + it('should add .swcrc when --compiler=swc', async () => { + await applicationGenerator(appTree, { + ...schema, + compiler: 'swc', + }); + + expect(readJson(appTree, '/apps/my-app/.swcrc')).toEqual({ + jsc: { target: 'es2016' }, + }); + }); }); describe('--root-project', () => { diff --git a/packages/react/src/generators/application/lib/create-application-files.ts b/packages/react/src/generators/application/lib/create-application-files.ts index 5c1743be78b3b..1190f06a26ae1 100644 --- a/packages/react/src/generators/application/lib/create-application-files.ts +++ b/packages/react/src/generators/application/lib/create-application-files.ts @@ -79,39 +79,34 @@ export function createApplicationFiles(host: Tree, options: NormalizedSchema) { : undefined, ].filter(Boolean), }); - } else if ( - options.style === 'styled-components' || - options.style === '@emotion/styled' || - options.style === 'styled-jsx' - ) { - writeJson( - host, - `${options.appProjectRoot}/.swcrc`, - - { - jsc: { - experimental: { - plugins: [ - options.style === 'styled-components' - ? [ - '@swc/plugin-styled-components', - { - displayName: true, - ssr: true, - }, - ] - : undefined, - options.style === 'styled-jsx' - ? ['@swc/plugin-styled-jsx', {}] - : undefined, - options.style === '@emotion/styled' - ? ['@swc/plugin-emotion', {}] - : undefined, - ].filter(Boolean), - }, - }, - } - ); + } else if (options.compiler === 'swc') { + const swcrc: any = { + jsc: { + target: 'es2016', + }, + }; + if (options.style === 'styled-components') { + swcrc.jsc.experimental = { + plugins: [ + [ + '@swc/plugin-styled-components', + { + displayName: true, + ssr: true, + }, + ], + ], + }; + } else if (options.style === '@emotion/styled') { + swcrc.jsc.experimental = { + plugins: [['@swc/plugin-emotion', {}]], + }; + } else if (options.style === 'styled-jsx') { + swcrc.jsc.experimental = { + plugins: [['@swc/plugin-styled-jsx', {}]], + }; + } + writeJson(host, `${options.appProjectRoot}/.swcrc`, swcrc); } } else if (options.bundler === 'rspack') { generateFiles( diff --git a/packages/web/src/generators/application/application.spec.ts b/packages/web/src/generators/application/application.spec.ts index 14f4d82428e42..fcf7ca9554b69 100644 --- a/packages/web/src/generators/application/application.spec.ts +++ b/packages/web/src/generators/application/application.spec.ts @@ -586,6 +586,9 @@ describe('app', () => { }; " `); + + expect(tree.exists('apps/my-app/.babelrc')).toBeTruthy(); + expect(tree.exists('apps/my-app/.swcrc')).toBeFalsy(); }); it('should support swc compiler', async () => { @@ -609,6 +612,9 @@ describe('app', () => { }; " `); + + expect(tree.exists('apps/my-app/.babelrc')).toBeFalsy(); + expect(tree.exists('apps/my-app/.swcrc')).toBeTruthy(); }); }); diff --git a/packages/web/src/generators/application/application.ts b/packages/web/src/generators/application/application.ts index a1e8051ad3fce..ed785a7a37389 100644 --- a/packages/web/src/generators/application/application.ts +++ b/packages/web/src/generators/application/application.ts @@ -20,6 +20,7 @@ import { Tree, updateNxJson, updateProjectConfiguration, + writeJson, } from '@nx/devkit'; import { swcCoreVersion } from '@nx/js/src/utils/versions'; import type { Linter } from '@nx/linter'; @@ -312,12 +313,24 @@ export async function applicationGenerator(host: Tree, schema: Schema) { } if (options.compiler === 'swc') { + writeJson(host, joinPathFragments(options.appProjectRoot, '.swcrc'), { + jsc: { + parser: { + syntax: 'typescript', + }, + target: 'es2016', + }, + }); const installTask = addDependenciesToPackageJson( host, {}, { '@swc/core': swcCoreVersion, 'swc-loader': swcLoaderVersion } ); tasks.push(installTask); + } else { + writeJson(host, joinPathFragments(options.appProjectRoot, '.babelrc'), { + presets: ['@nx/js/babel'], + }); } setDefaults(host, options); diff --git a/packages/web/src/generators/application/files/app-webpack/.babelrc__tmpl__ b/packages/web/src/generators/application/files/app-webpack/.babelrc__tmpl__ deleted file mode 100644 index 19ebd10e1179b..0000000000000 --- a/packages/web/src/generators/application/files/app-webpack/.babelrc__tmpl__ +++ /dev/null @@ -1,5 +0,0 @@ -{ - "presets": [ - "@nx/js/babel" - ] -}