Skip to content

Commit

Permalink
fix(core): fix init logging and package.json updates
Browse files Browse the repository at this point in the history
  • Loading branch information
FrozenPandaz committed Apr 16, 2024
1 parent 71023c8 commit 13afdd7
Show file tree
Hide file tree
Showing 9 changed files with 40 additions and 75 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -5,13 +5,10 @@ import { join, relative } from 'path';
import { InitArgs } from '../init-v1';
import { readJsonFile } from '../../../utils/fileutils';
import { output } from '../../../utils/output';
import { getPackageManagerCommand } from '../../../utils/package-manager';
import {
addDepsToPackageJson,
createNxJsonFile,
initCloud,
markPackageJsonAsNxProject,
printFinalMessage,
runInstall,
updateGitIgnore,
} from './utils';
Expand Down Expand Up @@ -94,11 +91,6 @@ export async function addNxToMonorepo(options: Options) {
cacheableOperations,
scriptOutputs
);
if (!options.legacy) {
packageJsonFiles.forEach((packageJsonPath) => {
markPackageJsonAsNxProject(join(repoRoot, packageJsonPath));
});
}

updateGitIgnore(repoRoot);
addDepsToPackageJson(repoRoot);
Expand All @@ -110,16 +102,6 @@ export async function addNxToMonorepo(options: Options) {
output.log({ title: '🛠️ Setting up Nx Cloud' });
initCloud(repoRoot, 'nx-init-monorepo');
}

const pmc = getPackageManagerCommand();
printFinalMessage({
learnMoreLink: 'https://nx.dev/recipes/adopting-nx/adding-to-monorepo',
bodyLines: [
`- Run "${pmc.exec} nx run-many --target=build" to run the build script for every project in the monorepo.`,
'- Run it again to replay the cached computation.',
`- Run "${pmc.exec} nx graph" to see the structure of the monorepo.`,
],
});
}

// scanning package.json files
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,6 @@ import {
createNxJsonFile,
initCloud,
markRootPackageJsonAsNxProjectLegacy,
printFinalMessage,
runInstall,
updateGitIgnore,
} from './utils';
Expand Down Expand Up @@ -139,10 +138,6 @@ export async function addNxToNest(options: Options, packageJson: PackageJson) {
output.log({ title: '🛠️ Setting up Nx Cloud' });
initCloud(repoRoot, 'nx-init-nest');
}

printFinalMessage({
learnMoreLink: 'https://nx.dev/recipes/adopting-nx/adding-to-monorepo',
});
}

function addNestPluginToPackageJson(repoRoot: string) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,6 @@ import {
initCloud,
markPackageJsonAsNxProject,
markRootPackageJsonAsNxProjectLegacy,
printFinalMessage,
runInstall,
updateGitIgnore,
} from './utils';
Expand Down Expand Up @@ -96,9 +95,4 @@ export async function addNxToNpmRepo(options: Options) {
output.log({ title: '🛠️ Setting up Nx Cloud' });
initCloud(repoRoot, 'nx-init-npm-repo');
}

printFinalMessage({
learnMoreLink:
'https://nx.dev/recipes/adopting-nx/adding-to-existing-project',
});
}
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@ import type { PackageJson } from '../../../../utils/package-json';
import {
addDepsToPackageJson,
initCloud,
printFinalMessage,
runInstall,
updateGitIgnore,
} from '../utils';
Expand Down Expand Up @@ -65,13 +64,6 @@ export async function addNxToAngularCliRepo(options: Options) {
output.log({ title: '🛠️ Setting up Nx Cloud' });
initCloud(repoRoot, 'nx-init-angular');
}

printFinalMessage({
learnMoreLink: 'https://nx.dev/recipes/angular/migration/angular',
bodyLines: [
'- Execute "npx nx build" twice to see the computation caching in action.',
],
});
}

async function collectCacheableOperations(options: Options): Promise<string[]> {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ import {
resolvePackageVersionUsingInstallation,
resolvePackageVersionUsingRegistry,
} from '../../../../utils/package-manager';
import { initCloud, printFinalMessage } from '../utils';
import { initCloud } from '../utils';
import type { Options } from './types';
import { connectExistingRepoToNxCloudPrompt } from '../../../connect/connect-to-nx-cloud';

Expand Down Expand Up @@ -111,13 +111,6 @@ export async function getLegacyMigrationFunctionIfApplicable(
output.log({ title: '🛠️ Setting up Nx Cloud' });
initCloud(repoRoot, 'nx-init-angular');
}

printFinalMessage({
learnMoreLink: 'https://nx.dev/recipes/angular/migration/angular',
bodyLines: [
'- Execute "npx nx build" twice to see the computation caching in action.',
],
});
};
}

Expand Down
22 changes: 0 additions & 22 deletions packages/nx/src/command-line/init/implementation/react/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,6 @@ import {
PackageManagerCommands,
} from '../../../../utils/package-manager';
import { PackageJson } from '../../../../utils/package-json';
import { printFinalMessage } from '../utils';
import { checkForCustomWebpackSetup } from './check-for-custom-webpack-setup';
import { checkForUncommittedChanges } from './check-for-uncommitted-changes';
import { cleanUpFiles } from './clean-up-files';
Expand Down Expand Up @@ -141,27 +140,6 @@ async function reorgnizeWorkspaceStructure(options: NormalizedOptions) {
output.log({ title: '📦 Installing dependencies' });
installDependencies(options);

const buildCommand = options.integrated
? `npx nx build ${options.reactAppName}`
: 'npm run build';
printFinalMessage({
learnMoreLink:
'https://nx.dev/recipes/adopting-nx/adding-to-existing-project',
bodyLines: [
`- Execute "${buildCommand}" twice to see the computation caching in action.`,
],
});

output.note({
title: 'First time using Nx? Check out this interactive Nx tutorial.',
bodyLines: [
`https://nx.dev/react-tutorial/1-code-generation`,
` `,
`Prefer watching videos? Check out this free Nx course on Egghead.io.`,
`https://egghead.io/playlists/scale-react-development-with-nx-4038`,
],
});

if (options.isVite) {
const indexPath = options.isStandalone
? 'index.html'
Expand Down
6 changes: 5 additions & 1 deletion packages/nx/src/command-line/init/implementation/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -214,11 +214,15 @@ export function printFinalMessage({
const normalizedBodyLines = (bodyLines ?? []).map((l) =>
l.startsWith('- ') ? l : `- ${l}`
);
const pmc = getPackageManagerCommand();

output.success({
title: '🎉 Done!',
bodyLines: [
'- Enabled computation caching!',
`- Run "${pmc.exec} nx run-many --t build" to run the build target for every project in the workspace. Run it again to replay the cached computation.`,
` - https://nx.dev/features/cache-task-results`,
`- Run "${pmc.exec} nx graph" to see the graph of projects and tasks in your workspace.`,
` - https://nx.dev/core-features/explore-graph`,
...normalizedBodyLines,
learnMoreLink ? `- Learn more at ${learnMoreLink}.` : undefined,
].filter(Boolean),
Expand Down
25 changes: 24 additions & 1 deletion packages/nx/src/command-line/init/init-v1.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ import { runNxSync } from '../../utils/child-process';
import { directoryExists, readJsonFile } from '../../utils/fileutils';
import { PackageJson } from '../../utils/package-json';
import { nxVersion } from '../../utils/versions';
import { isMonorepo } from './implementation/utils';
import { isMonorepo, printFinalMessage } from './implementation/utils';

export interface InitArgs {
addE2e: boolean;
Expand Down Expand Up @@ -40,14 +40,37 @@ export async function initHandler(options: InitArgs) {
const packageJson: PackageJson = readJsonFile('package.json');
if (existsSync('angular.json')) {
await addNxToAngularCliRepo(options);

printFinalMessage({
learnMoreLink: 'https://nx.dev/recipes/angular/migration/angular',
});
return;
} else if (isCRA(packageJson)) {
await addNxToCraRepo(options);

printFinalMessage({
learnMoreLink: options.integrated
? 'https://nx.dev/getting-started/tutorials/react-monorepo-tutorial'
: 'https://nx.dev/getting-started/tutorials/react-standalone-tutorial',
});
return;
} else if (isNestCLI(packageJson)) {
await addNxToNest(options, packageJson);
printFinalMessage({
learnMoreLink: 'https://nx.dev/recipes/adopting-nx/adding-to-monorepo',
});
return;
} else if (isMonorepo(packageJson)) {
await addNxToMonorepo({ ...options, legacy: true });
printFinalMessage({
learnMoreLink: 'https://nx.dev/recipes/adopting-nx/adding-to-monorepo',
});
} else {
await addNxToNpmRepo({ ...options, legacy: true });
printFinalMessage({
learnMoreLink:
'https://nx.dev/recipes/adopting-nx/adding-to-existing-project',
});
}
} else {
const useDotNxFolder = await prompt<{ useDotNxFolder: string }>([
Expand Down
16 changes: 10 additions & 6 deletions packages/nx/src/command-line/init/init-v2.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ import {
addDepsToPackageJson,
createNxJsonFile,
isMonorepo,
printFinalMessage,
runInstall,
updateGitIgnore,
} from './implementation/utils';
Expand Down Expand Up @@ -67,6 +68,10 @@ export async function initHandler(options: InitArgs): Promise<void> {
...options,
integrated: !!options.integrated,
});

printFinalMessage({
learnMoreLink: 'https://nx.dev/recipes/angular/migration/angular',
});
return;
}

Expand All @@ -86,6 +91,9 @@ export async function initHandler(options: InitArgs): Promise<void> {
nxCloud: false,
});
}
const learnMoreLink = isMonorepo(packageJson)
? 'https://nx.dev/getting-started/tutorials/npm-workspaces-tutorial'
: 'https://nx.dev/recipes/adopting-nx/adding-to-existing-project';
const useNxCloud =
options.nxCloud ??
(options.interactive ? await connectExistingRepoToNxCloudPrompt() : false);
Expand Down Expand Up @@ -128,12 +136,8 @@ export async function initHandler(options: InitArgs): Promise<void> {
);
}

output.log({
title: '👀 Explore Your Workspace',
bodyLines: [
`Run "nx graph" to show the graph of the workspace. It will show tasks that you can run with Nx.`,
`Read this guide on exploring your workspace: https://nx.dev/core-features/explore-graph`,
],
printFinalMessage({
learnMoreLink,
});
}

Expand Down

0 comments on commit 13afdd7

Please sign in to comment.