You can always add another app to a standalone repository the same way you would in a monorepo. But at some point, you may want to move the primary app out of the root of your repo because the repo is no longer primarily focused on that one app. There are other apps that are equally important and you want the folder structure to align with the new reality.
Run the Generator
Section titled “Run the Generator”The convert-to-monorepo generator will attempt to convert a standalone repo to a monorepo.
nx g convert-to-monorepoIf you need to do the conversion manually, you can follow the steps below.
Manual Conversion Strategy
Section titled “Manual Conversion Strategy”For this recipe, we'll assume that the root-level app is named my-app. The high-level process we'll go through to move the app involves four stages:
- Create a new app named
tempunderapps/temp. - Move source and config files from
my-appintoapps/temp. - Delete the files for
my-app. - Rename
apps/temptoapps/my-app
If there is a
tsconfig.jsonfile in the root, rename it totsconfig.old.jsonThis step is to make sure that a
tsconfig.base.jsonfile is generated by the app generator in the next step.Create a new app using the appropriate plugin under
apps/tempnx g app apps/tempMove the
/src(and/public, if present) folders toapps/temp/, overwriting the folders already there.For each config file in
apps/temp, copy over the corresponding file from the root of the repo.It can be difficult to know which files are root-level config files and which files are project-specific config files. Here is a non-exhaustive list of config files to help distinguish between the two.
Type of Config Files Root-level .eslintignore,.eslintrc.base.json,.gitignore,.prettierignore,jest.config.ts,jest.preset.js,.prettierrc,nx.json,package.json,tsconfig.base.jsonProject-level .eslintrc.json,index.html,project.json,jest.config.app.ts,tsconfig.app.json,tsconfig.json,tsconfig.spec.json,vite.config.ts,webpack.config.jsUpdate the paths of the project-specific config files that were copied into
apps/temp.Here is a non-exhaustive list of properties that will need to be updated to have the correct path:
Config File(s) Properties to Check project.json$schema,sourceRoot,root,outputPath,reportsDirectory,cypressConfig,lintFilePatterns,index,main,tsConfig,assets,styles,jestConfigtsconfig.json,tsconfig.app.json,tsconfig.spec.jsonextends,outDir,files.eslintrc.jsonextendsjest.config.tspreset,coverageDirectoryvite.config.tscacheDir,root,dirDoublecheck that all the tasks defined in the
apps/temp/project.jsonfile still work.nx build tempnx test tempnx lint tempMove the
/e2e/srcfolder to/apps/temp-e2e, overwriting the folder already thereFor each config file in
apps/temp-e2e, copy over the corresponding file from the root of the repo. Update the paths for these files in the same way you did for themy-appconfig files.Update the
/apps/temp-e2e/project.jsonimplicitDependenciesto betempinstead ofmy-appDoublecheck that all the tasks defined in the
apps/temp-e2e/project.jsonfile still work.nx lint temp-e2enx e2e temp-e2eDelete all the project specific config files in the root and under
e2eOnce the
project.jsonfile has been deleted in the root, renametemp-e2etomy-app-e2eand renametemptomy-appnx g move --projectName=temp-e2e --destination=my-app-e2enx g move --projectName=temp --destination=my-appUpdate the
defaultProjectinnx.jsonif neededCheck again that all the tasks still work and that the
nx graphdisplays what you expect.