From 11a9da61a7457eb12a8dc76d7226bbf348201a17 Mon Sep 17 00:00:00 2001 From: Nicholas Cunningham Date: Mon, 29 May 2023 12:04:00 -0600 Subject: [PATCH] feat(bundling): Add support to rollup for babelUpwardRootMode --- .../packages/rollup/executors/rollup.json | 5 ++ packages/expo/migrations.json | 6 ++ .../expo/src/executors/build/build.impl.ts | 2 +- .../library/files/lib/tsconfig.json.template | 2 +- .../update-16-3-1-rename-babel.ts | 18 ++++++ .../update-16-3-1-rename.babel.spec.ts | 28 +++++++++ packages/react-native/migrations.json | 6 ++ .../library/files/lib/tsconfig.json__tmpl__ | 2 +- .../update-16-3-1-rename-babel.spec.ts | 28 +++++++++ .../update-16-3-1-rename-babel.ts | 18 ++++++ packages/rollup/migrations.json | 6 ++ .../src/executors/rollup/rollup.impl.ts | 2 +- .../rollup/src/executors/rollup/schema.d.ts | 1 + .../rollup/src/executors/rollup/schema.json | 5 ++ ...-1-add-babel-upward-root-mode-flag.spec.ts | 58 +++++++++++++++++++ ...-16-3-1-add-babel-upward-root-mode-flag.ts | 32 ++++++++++ 16 files changed, 215 insertions(+), 4 deletions(-) create mode 100644 packages/expo/src/migrations/update-16-3-1-rename-babel/update-16-3-1-rename-babel.ts create mode 100644 packages/expo/src/migrations/update-16-3-1-rename-babel/update-16-3-1-rename.babel.spec.ts create mode 100644 packages/react-native/src/migrations/update-16-3-1-rename-babel/update-16-3-1-rename-babel.spec.ts create mode 100644 packages/react-native/src/migrations/update-16-3-1-rename-babel/update-16-3-1-rename-babel.ts create mode 100644 packages/rollup/src/migrations/update-16-3-1-add-babel-upward-root-mode-flag/update-16-3-1-add-babel-upward-root-mode-flag.spec.ts create mode 100644 packages/rollup/src/migrations/update-16-3-1-add-babel-upward-root-mode-flag/update-16-3-1-add-babel-upward-root-mode-flag.ts diff --git a/docs/generated/packages/rollup/executors/rollup.json b/docs/generated/packages/rollup/executors/rollup.json index 01e282a9118098..09eb46124dbfe6 100644 --- a/docs/generated/packages/rollup/executors/rollup.json +++ b/docs/generated/packages/rollup/executors/rollup.json @@ -150,6 +150,11 @@ "default": "babel", "description": "Which compiler to use." }, + "babelUpwardRootMode": { + "type": "boolean", + "description": "Whether to set rootmode to upward. See https://babeljs.io/docs/en/options#rootmode", + "default": false + }, "javascriptEnabled": { "type": "boolean", "description": "Sets `javascriptEnabled` option for less loader", diff --git a/packages/expo/migrations.json b/packages/expo/migrations.json index 2a042e7a3e3d05..c5129ec01d148e 100644 --- a/packages/expo/migrations.json +++ b/packages/expo/migrations.json @@ -65,6 +65,12 @@ "cli": "nx", "description": "Add app.json for detox", "factory": "./src/migrations/update-16-1-4/add-detox-app-json" + }, + "update-16-3-1-rename-babel": { + "cli": "nx", + "version": "16.3.1-beta.0", + "description": "Rename babel.config.json to .babelrc for rollup libs", + "implementation": "./src/migrations/update-16-3-1-rename-babel/update-16-3-1-rename-babel" } }, "packageJsonUpdates": { diff --git a/packages/expo/src/executors/build/build.impl.ts b/packages/expo/src/executors/build/build.impl.ts index 5fbfd16de62aa6..97d42fc12d5548 100644 --- a/packages/expo/src/executors/build/build.impl.ts +++ b/packages/expo/src/executors/build/build.impl.ts @@ -3,7 +3,7 @@ import { join, normalize, sep } from 'path'; import { ChildProcess, fork } from 'child_process'; import { ensureNodeModulesSymlink } from '../../utils/ensure-node-modules-symlink'; -import { copyBuildFile, unzipBuild } from '../download/download.impl'; +import { unzipBuild } from '../download/download.impl'; import { ExpoEasBuildOptions } from './schema'; import { removeSync } from 'fs-extra'; diff --git a/packages/expo/src/generators/library/files/lib/tsconfig.json.template b/packages/expo/src/generators/library/files/lib/tsconfig.json.template index dacf3c7f5e0ac6..d9affba903da06 100644 --- a/packages/expo/src/generators/library/files/lib/tsconfig.json.template +++ b/packages/expo/src/generators/library/files/lib/tsconfig.json.template @@ -1,7 +1,7 @@ { "extends": "<%= rootTsConfigPath %>", "compilerOptions": { - "jsx": "react-native", + "jsx": "react-jsx", "allowJs": true, "esModuleInterop": true, "allowSyntheticDefaultImports": true diff --git a/packages/expo/src/migrations/update-16-3-1-rename-babel/update-16-3-1-rename-babel.ts b/packages/expo/src/migrations/update-16-3-1-rename-babel/update-16-3-1-rename-babel.ts new file mode 100644 index 00000000000000..96ac5982ff6559 --- /dev/null +++ b/packages/expo/src/migrations/update-16-3-1-rename-babel/update-16-3-1-rename-babel.ts @@ -0,0 +1,18 @@ +import { Tree, formatFiles, readProjectConfiguration } from '@nx/devkit'; +import { forEachExecutorOptions } from '@nx/devkit/src/generators/executor-options-utils'; +import { RollupExecutorOptions } from '@nx/rollup'; + +export default async function update(tree: Tree) { + forEachExecutorOptions( + tree, + '@nx/rollup:rollup', + (_, projectName) => { + const root = readProjectConfiguration(tree, projectName).sourceRoot; + const oldBabelPath = `${root}/babel.config.json`; + if (tree.exists(oldBabelPath)) { + tree.rename(oldBabelPath, `${root}/.babelrc`); + } + } + ); + await formatFiles(tree); +} diff --git a/packages/expo/src/migrations/update-16-3-1-rename-babel/update-16-3-1-rename.babel.spec.ts b/packages/expo/src/migrations/update-16-3-1-rename-babel/update-16-3-1-rename.babel.spec.ts new file mode 100644 index 00000000000000..573b1343d0cec6 --- /dev/null +++ b/packages/expo/src/migrations/update-16-3-1-rename-babel/update-16-3-1-rename.babel.spec.ts @@ -0,0 +1,28 @@ +import { Tree, addProjectConfiguration } from '@nx/devkit'; +import { createTreeWithEmptyWorkspace } from 'nx/src/devkit-testing-exports'; +import update from './update-16-3-1-rename-babel'; +describe('rename babelConfig', () => { + let tree: Tree; + beforeEach(async () => { + tree = createTreeWithEmptyWorkspace({ layout: 'apps-libs' }); + addProjectConfiguration(tree, 'products', { + root: 'libs/products', + sourceRoot: 'libs/products/src', + targets: { + start: { + executor: '@nx/rollup:rollup', + options: {}, + }, + }, + }); + }); + + it('should rename babel.config.json to .babelrc', async () => { + tree.write('libs/products/src/babel.config.json', `{}`); + + await update(tree); + + expect(tree.exists('libs/products/src/.babelrc')).toBeTruthy(); + expect(tree.exists('libs/products/src/.babel.config.json')).toBeFalsy(); + }); +}); diff --git a/packages/react-native/migrations.json b/packages/react-native/migrations.json index 651b8db797e529..41ffe2f7a33e78 100644 --- a/packages/react-native/migrations.json +++ b/packages/react-native/migrations.json @@ -89,6 +89,12 @@ "version": "16.1.0-beta.0", "description": "Upgrade @storybook/react-native to 6.5", "implementation": "./src/migrations/update-16-1-0/upgrade-storybook-6-5" + }, + "update-16-3-1-rename-babel": { + "cli": "nx", + "version": "16.3.1-beta.0", + "description": "Rename babel.config.json to .babelrc for rollup libs", + "implementation": "./src/migrations/update-16-3-1-rename-babel/update-16-3-1-rename-babel" } }, "packageJsonUpdates": { diff --git a/packages/react-native/src/generators/library/files/lib/tsconfig.json__tmpl__ b/packages/react-native/src/generators/library/files/lib/tsconfig.json__tmpl__ index dacf3c7f5e0ac6..d9affba903da06 100644 --- a/packages/react-native/src/generators/library/files/lib/tsconfig.json__tmpl__ +++ b/packages/react-native/src/generators/library/files/lib/tsconfig.json__tmpl__ @@ -1,7 +1,7 @@ { "extends": "<%= rootTsConfigPath %>", "compilerOptions": { - "jsx": "react-native", + "jsx": "react-jsx", "allowJs": true, "esModuleInterop": true, "allowSyntheticDefaultImports": true diff --git a/packages/react-native/src/migrations/update-16-3-1-rename-babel/update-16-3-1-rename-babel.spec.ts b/packages/react-native/src/migrations/update-16-3-1-rename-babel/update-16-3-1-rename-babel.spec.ts new file mode 100644 index 00000000000000..573b1343d0cec6 --- /dev/null +++ b/packages/react-native/src/migrations/update-16-3-1-rename-babel/update-16-3-1-rename-babel.spec.ts @@ -0,0 +1,28 @@ +import { Tree, addProjectConfiguration } from '@nx/devkit'; +import { createTreeWithEmptyWorkspace } from 'nx/src/devkit-testing-exports'; +import update from './update-16-3-1-rename-babel'; +describe('rename babelConfig', () => { + let tree: Tree; + beforeEach(async () => { + tree = createTreeWithEmptyWorkspace({ layout: 'apps-libs' }); + addProjectConfiguration(tree, 'products', { + root: 'libs/products', + sourceRoot: 'libs/products/src', + targets: { + start: { + executor: '@nx/rollup:rollup', + options: {}, + }, + }, + }); + }); + + it('should rename babel.config.json to .babelrc', async () => { + tree.write('libs/products/src/babel.config.json', `{}`); + + await update(tree); + + expect(tree.exists('libs/products/src/.babelrc')).toBeTruthy(); + expect(tree.exists('libs/products/src/.babel.config.json')).toBeFalsy(); + }); +}); diff --git a/packages/react-native/src/migrations/update-16-3-1-rename-babel/update-16-3-1-rename-babel.ts b/packages/react-native/src/migrations/update-16-3-1-rename-babel/update-16-3-1-rename-babel.ts new file mode 100644 index 00000000000000..96ac5982ff6559 --- /dev/null +++ b/packages/react-native/src/migrations/update-16-3-1-rename-babel/update-16-3-1-rename-babel.ts @@ -0,0 +1,18 @@ +import { Tree, formatFiles, readProjectConfiguration } from '@nx/devkit'; +import { forEachExecutorOptions } from '@nx/devkit/src/generators/executor-options-utils'; +import { RollupExecutorOptions } from '@nx/rollup'; + +export default async function update(tree: Tree) { + forEachExecutorOptions( + tree, + '@nx/rollup:rollup', + (_, projectName) => { + const root = readProjectConfiguration(tree, projectName).sourceRoot; + const oldBabelPath = `${root}/babel.config.json`; + if (tree.exists(oldBabelPath)) { + tree.rename(oldBabelPath, `${root}/.babelrc`); + } + } + ); + await formatFiles(tree); +} diff --git a/packages/rollup/migrations.json b/packages/rollup/migrations.json index ad135dd94f011d..35c19e83e6e8be 100644 --- a/packages/rollup/migrations.json +++ b/packages/rollup/migrations.json @@ -11,6 +11,12 @@ "version": "16.0.0-beta.1", "description": "Replace @nrwl/rollup with @nx/rollup", "implementation": "./src/migrations/update-16-0-0-add-nx-packages/update-16-0-0-add-nx-packages" + }, + "update-16-3-1-add-babel-upward-root-mode-flag": { + "cli": "nx", + "version": "16-3-1-beta.0", + "description": "Add babelUpwardRootMode if not already defined", + "implementation": "./src/migrations/update-16-3-1-add-babel-upward-root-mode-flag/update-16-3-1-add-babel-upward-root-mode-flag" } }, "packageJsonUpdates": {} diff --git a/packages/rollup/src/executors/rollup/rollup.impl.ts b/packages/rollup/src/executors/rollup/rollup.impl.ts index 423115122e35a5..881dbcd593e3a3 100644 --- a/packages/rollup/src/executors/rollup/rollup.impl.ts +++ b/packages/rollup/src/executors/rollup/rollup.impl.ts @@ -255,7 +255,7 @@ export function createRollupOptions( isModern: true, }, cwd: join(context.root, sourceRoot), - rootMode: 'upward', + rootMode: options.babelUpwardRootMode ? 'upward' : undefined, babelrc: true, extensions: fileExtensions, babelHelpers: 'bundled', diff --git a/packages/rollup/src/executors/rollup/schema.d.ts b/packages/rollup/src/executors/rollup/schema.d.ts index bcc5d69a6ad6c6..ffef9aa4be9a3c 100644 --- a/packages/rollup/src/executors/rollup/schema.d.ts +++ b/packages/rollup/src/executors/rollup/schema.d.ts @@ -32,4 +32,5 @@ export interface RollupExecutorOptions { javascriptEnabled?: boolean; generateExportsField?: boolean; skipTypeCheck?: boolean; + babelUpwardRootMode?: boolean; } diff --git a/packages/rollup/src/executors/rollup/schema.json b/packages/rollup/src/executors/rollup/schema.json index 3a1ceef59b38f1..6510c4c224152e 100644 --- a/packages/rollup/src/executors/rollup/schema.json +++ b/packages/rollup/src/executors/rollup/schema.json @@ -137,6 +137,11 @@ "default": "babel", "description": "Which compiler to use." }, + "babelUpwardRootMode": { + "type": "boolean", + "description": "Whether to set rootmode to upward. See https://babeljs.io/docs/en/options#rootmode", + "default": false + }, "javascriptEnabled": { "type": "boolean", "description": "Sets `javascriptEnabled` option for less loader", diff --git a/packages/rollup/src/migrations/update-16-3-1-add-babel-upward-root-mode-flag/update-16-3-1-add-babel-upward-root-mode-flag.spec.ts b/packages/rollup/src/migrations/update-16-3-1-add-babel-upward-root-mode-flag/update-16-3-1-add-babel-upward-root-mode-flag.spec.ts new file mode 100644 index 00000000000000..758106b3351c84 --- /dev/null +++ b/packages/rollup/src/migrations/update-16-3-1-add-babel-upward-root-mode-flag/update-16-3-1-add-babel-upward-root-mode-flag.spec.ts @@ -0,0 +1,58 @@ +import { createTreeWithEmptyWorkspace } from '@nx/devkit/testing'; +import { + addProjectConfiguration, + readProjectConfiguration, + Tree, +} from '@nx/devkit'; +import addBabelUpwardRootModeFlag from './update-16-3-1-add-babel-upward-root-mode-flag'; + +describe('16.3.0 migration (add babelUpwardRootMode flag)', () => { + let tree: Tree; + + beforeEach(async () => { + tree = createTreeWithEmptyWorkspace({ layout: 'apps-libs' }); + }); + + it('should add the babelUpwardRootMode flag to rollup projects', async () => { + addProjectConfiguration(tree, 'app1', { + root: 'apps/app1', + targets: { + build: { + executor: '@nx/rollup:rollup', + options: {}, + }, + }, + }); + addProjectConfiguration(tree, 'app2', { + root: 'apps/app2', + targets: { + build: { + executor: '@nx/rollup:rollup', + options: { + babelUpwardRootMode: false, + }, + }, + }, + }); + + addProjectConfiguration(tree, 'app3', { + root: 'apps/app3', + targets: { + build: { + executor: '@nx/esbuild:esbuild', + options: {}, + }, + }, + }); + + await addBabelUpwardRootModeFlag(tree); + + const app1 = readProjectConfiguration(tree, 'app1'); + const app2 = readProjectConfiguration(tree, 'app2'); + const app3 = readProjectConfiguration(tree, 'app3'); + + expect(app1.targets['build'].options.babelUpwardRootMode).toBeTruthy(); + expect(app2.targets['build'].options.babelUpwardRootMode).toBeFalsy(); + expect(app3.targets['build'].options.babelUpwardRootMode).toBeUndefined(); + }); +}); diff --git a/packages/rollup/src/migrations/update-16-3-1-add-babel-upward-root-mode-flag/update-16-3-1-add-babel-upward-root-mode-flag.ts b/packages/rollup/src/migrations/update-16-3-1-add-babel-upward-root-mode-flag/update-16-3-1-add-babel-upward-root-mode-flag.ts new file mode 100644 index 00000000000000..35e02941539e5e --- /dev/null +++ b/packages/rollup/src/migrations/update-16-3-1-add-babel-upward-root-mode-flag/update-16-3-1-add-babel-upward-root-mode-flag.ts @@ -0,0 +1,32 @@ +import { + formatFiles, + readProjectConfiguration, + Tree, + updateProjectConfiguration, +} from '@nx/devkit'; +import { forEachExecutorOptions } from '@nx/devkit/src/generators/executor-options-utils'; +import { RollupExecutorOptions } from '../../executors/rollup/schema'; + +export default async function (tree: Tree) { + forEachExecutorOptions( + tree, + '@nx/rollup:rollup', + ( + options: RollupExecutorOptions, + projectName, + targetName, + _configurationName + ) => { + if (options.babelUpwardRootMode !== undefined) { + return; + } + + const projectConfiguration = readProjectConfiguration(tree, projectName); + projectConfiguration.targets[targetName].options.babelUpwardRootMode = + true; + updateProjectConfiguration(tree, projectName, projectConfiguration); + } + ); + + await formatFiles(tree); +}